1 |
|
2 |
import os |
3 |
import sys |
4 |
import ConfigParser |
5 |
|
6 |
|
7 |
_platdir = 'platform' |
8 |
|
9 |
|
10 |
def read_plat(env, args, fn): |
11 |
cfig = ConfigParser.ConfigParser(env.Dictionary()) |
12 |
cfig.read(fn) |
13 |
buildvars = [['CC', |
14 |
'TIFFINCLUDE', # where to find preinstalled tifflib headers |
15 |
'TIFFLIB', # where to find a preinstalled tifflib library |
16 |
], # replace |
17 |
['CPPPATH', 'CPPDEFINES', 'CPPFLAGS', 'CCFLAGS', |
18 |
'LIBPATH', 'LINKFLAGS', |
19 |
'EZXML_CPPDEFINES', # build flags specific to ezxml.c |
20 |
]] # append |
21 |
vars = [ |
22 |
['install', |
23 |
['RAD_BASEDIR', 'RAD_BINDIR', 'RAD_RLIBDIR', 'RAD_MANDIR'], |
24 |
[]], |
25 |
['code', |
26 |
[ # replace |
27 |
], |
28 |
[ # append |
29 |
'RAD_COMPAT', # theoretically obsolete (src/common/strcmp.c) |
30 |
'RAD_MATHCOMPAT', # erf.c floating point error function |
31 |
'RAD_ARGSCOMPAT', # fixargv0.c for Windows |
32 |
'RAD_NETCOMPAT', # [win_]netproc.c for ranimate |
33 |
'RAD_MLIB', # usually 'm', or any fastlib available |
34 |
'RAD_SOCKETLIB', # ws_2_32 on Windows (VC links it automatically) |
35 |
'RAD_PROCESS', # our process abstraction and win_popen() |
36 |
'RAD_PCALLS', # more custom process abstraction |
37 |
]], |
38 |
] |
39 |
if args.get('RAD_DEBUG',0): |
40 |
vars.insert(0, ['debug'] + buildvars) |
41 |
else: vars.insert(0, ['build'] + buildvars) |
42 |
for section in vars: |
43 |
if cfig.has_section(section[0]): |
44 |
for p in section[1]: # single items to replace |
45 |
try: v = cfig.get(section[0], p) |
46 |
except ConfigParser.NoOptionError: continue |
47 |
env[p] = v |
48 |
#print '%s: %s' % (p, env[p]) |
49 |
for p in section[2]: # multiple items to append |
50 |
try: v = cfig.get(section[0], p) |
51 |
except ConfigParser.NoOptionError: continue |
52 |
apply(env.Append,[],{p:env.Split(v)}) |
53 |
# XXX Check that basedir exists. |
54 |
for k in ['RAD_BINDIR', 'RAD_RLIBDIR', 'RAD_MANDIR']: |
55 |
if (env.has_key('RAD_BASEDIR') and env.has_key(k) |
56 |
and not os.path.isabs(env[k])): |
57 |
env[k] = os.path.join(env['RAD_BASEDIR'],env[k]) |
58 |
|
59 |
|
60 |
def load_plat(env, args, platform=None): |
61 |
if platform == None: # override |
62 |
p = sys.platform |
63 |
else: p = platform |
64 |
if p == 'win32' and 'gcc' in env['TOOLS']: |
65 |
# we don't really want to know this here... |
66 |
p = 'mingw' |
67 |
pl = [] |
68 |
print 'Detected platform "%s" (%s).' % (sys.platform, os.name) |
69 |
for i in [len(p), -1, -2]: |
70 |
pfn = os.path.join(_platdir, p[:i] + '_custom.cfg') |
71 |
if os.path.isfile(pfn): |
72 |
print 'Reading configuration "%s"' % pfn |
73 |
read_plat(env, args, pfn) |
74 |
return 1 |
75 |
pfn = os.path.join(_platdir, p[:i] + '.cfg') |
76 |
if os.path.isfile(pfn): |
77 |
print 'Reading configuration "%s"' % pfn |
78 |
read_plat(env, args, pfn) |
79 |
return 1 |
80 |
|
81 |
if os.name == 'posix': |
82 |
pfn = os.path.join(_platdir, 'posix.cfg') |
83 |
if os.path.isfile(pfn): |
84 |
print 'Reading generic configuration "%s".' % pfn |
85 |
read_plat(env, args, pfn) |
86 |
return 1 |
87 |
|
88 |
print 'Platform "%s/%s" not supported yet' % (os.name, sys.platform) |
89 |
sys.exit(2) |
90 |
|
91 |
|
92 |
|