| 1 |
schorsch |
1.1 |
import os |
| 2 |
|
|
|
| 3 |
|
|
Import ('env') |
| 4 |
|
|
|
| 5 |
|
|
# compose paths |
| 6 |
schorsch |
1.2 |
def radbin(name): return os.path.join(env['RAD_BUILDBIN'], name) |
| 7 |
|
|
def radlib(name): return os.path.join(env['RAD_BUILDLIB'], name) |
| 8 |
schorsch |
1.1 |
|
| 9 |
schorsch |
1.2 |
# extra flag |
| 10 |
|
|
MDIRFLAGS = env.get('CPPFLAGS', []) + [ |
| 11 |
|
|
'-DMDIR=\\"%s\\"' % os.path.join(env['RAD_RLIBDIR'], 'meta')] |
| 12 |
|
|
bgraph = env.Object(source='bgraph.c', CPPFLAGS=MDIRFLAGS) |
| 13 |
|
|
igraph = env.Object(source='igraph.c', CPPFLAGS=MDIRFLAGS) |
| 14 |
|
|
dgraph = env.Object(source='dgraph.c', CPPFLAGS=MDIRFLAGS) |
| 15 |
|
|
gcomp = env.Object(source='gcomp.c', CPPFLAGS=MDIRFLAGS) |
| 16 |
|
|
syscalls = env.Object(source='syscalls.c', CPPFLAGS=MDIRFLAGS) |
| 17 |
|
|
# used by several targets |
| 18 |
|
|
mfio = env.Object(source='mfio.c') |
| 19 |
|
|
misc = env.Object(source='misc.c') |
| 20 |
|
|
primout = env.Object(source='primout.c') |
| 21 |
|
|
plot = env.Object(source='plot.c') |
| 22 |
|
|
palloc = env.Object(source='palloc.c') |
| 23 |
|
|
mplot = env.Object(source='mplot.c') |
| 24 |
|
|
plotin = env.Object(source='plotin.c') |
| 25 |
|
|
tgraph = env.Object(source='tgraph.c') |
| 26 |
|
|
mgvars = env.Object(source='mgvars.c') |
| 27 |
|
|
mgraph = env.Object(source='mgraph.c') |
| 28 |
|
|
cgraph = env.Object(source='cgraph.c') |
| 29 |
|
|
gcalc = env.Object(source='gcalc.c') |
| 30 |
|
|
# multiple output from same source |
| 31 |
|
|
plotout = env.Object(source='plotout.c') |
| 32 |
|
|
t4014 = env.Object(target="t4014", source='plotout.c', |
| 33 |
|
|
CPPFLAGS=env.get('CPPFLAGS',[]) + ['-DFORTEK']) |
| 34 |
schorsch |
1.1 |
|
| 35 |
schorsch |
1.2 |
common = [mfio, misc, syscalls] |
| 36 |
schorsch |
1.1 |
|
| 37 |
schorsch |
1.2 |
libmeta = env.StaticLibrary(radlib('meta'), |
| 38 |
|
|
Split ('metacalls.c progname.c') +[primout] + common) |
| 39 |
schorsch |
1.1 |
|
| 40 |
|
|
# standard targets |
| 41 |
|
|
PROGS = ( |
| 42 |
schorsch |
1.2 |
('meta2tga', Split('meta2tga.c rplot.c') +[palloc, plot] + common, |
| 43 |
|
|
['rtproc','rtpath','rtio', # proc/path/rtio for win_popen() |
| 44 |
|
|
'rtcont','rtmem','rterror']), |
| 45 |
|
|
('pexpand', Split('pexpand.c expand.c segment.c') +[palloc]+ common, |
| 46 |
|
|
['rtcont','rtmem','rterror']), |
| 47 |
|
|
('psort', Split('psort.c sort.c') +[palloc]+ common, |
| 48 |
|
|
['rtpath','rtcont','rtmem','rterror']), |
| 49 |
|
|
('cv', Split('cv.c cvhfio.c') + common, |
| 50 |
|
|
['rtcont','rtmem','rterror']), |
| 51 |
|
|
('psmeta', Split('psmeta.c psplot.c') + common, |
| 52 |
|
|
['rtcont','rtmem','rterror']), |
| 53 |
|
|
('plotin', [plotin, primout] + common, |
| 54 |
|
|
['rtcont','rtmem','rterror']), |
| 55 |
|
|
('bgraph', [bgraph, mgraph, mgvars], |
| 56 |
|
|
['rtproc','rtpath','rtio', # proc/path/rtio for win_popen() |
| 57 |
|
|
'rtfunc','rtcont','rtmem','rterror','meta']), |
| 58 |
|
|
('igraph', [igraph, gcalc, cgraph, mgraph, mgvars], |
| 59 |
|
|
['rtproc','rtpath','rtio', # proc/path/rtio for win_popen() |
| 60 |
|
|
'rtfunc','rtcont','rtmem','rterror','meta']), |
| 61 |
|
|
('dgraph', [dgraph, cgraph, mgvars], |
| 62 |
|
|
['rtproc','rtpath','rtio', # proc/path/rtio for win_popen() |
| 63 |
|
|
'rtfunc','rtcont','rtmem','rterror']), |
| 64 |
|
|
('gcomp', [gcomp, gcalc, mgvars], |
| 65 |
|
|
['rtproc','rtpath','rtio', # proc/path/rtio for win_popen() |
| 66 |
|
|
'rtfunc','rtcont','rtmem','rterror']), |
| 67 |
|
|
('plot4', Split('plot4.c') +[primout]+ common, |
| 68 |
|
|
['rtproc','rtpath','rtio', # proc/path/rtio for win_popen() |
| 69 |
|
|
'rtcont','rtmem','rterror']), |
| 70 |
schorsch |
1.1 |
) |
| 71 |
|
|
for p in PROGS: |
| 72 |
schorsch |
1.2 |
prog = env.Program(target=radbin(p[0]), source=p[1], |
| 73 |
|
|
LIBS=p[2]+env['RAD_MLIB']) |
| 74 |
schorsch |
1.1 |
Default(prog) |
| 75 |
schorsch |
1.2 |
env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], prog)]) |
| 76 |
schorsch |
1.1 |
|
| 77 |
|
|
|
| 78 |
|
|
lib4014srcs = Split('''arc.c box.c circle.c close.c dot.c erase.c label.c |
| 79 |
|
|
line.c linemod.c move.c open.c point.c space.c subr.c''') |
| 80 |
|
|
lib4014 = env.Library(os.path.join(env['RAD_BUILDLIB'], '4014'), |
| 81 |
|
|
source=map(lambda s:os.path.join('lib4014', s), lib4014srcs)) |
| 82 |
|
|
|
| 83 |
schorsch |
1.2 |
plotsrc = [mplot, palloc, plot] |
| 84 |
schorsch |
1.1 |
|
| 85 |
|
|
SPECIAL = ( |
| 86 |
schorsch |
1.2 |
('mt160l', Split('mt160l.c') + plotsrc + common, |
| 87 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 88 |
|
|
('mt160', Split('mt160.c') + plotsrc + common, |
| 89 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 90 |
|
|
('mtext', Split('mtext.c') +[primout]+ common, |
| 91 |
|
|
['rtcont','rtmem','rterror']), |
| 92 |
|
|
('okimate', Split('okimate.c') + plotsrc + common, |
| 93 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 94 |
|
|
('mx80', Split('mx80.c') + plotsrc + common, |
| 95 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 96 |
|
|
('imagew', Split('imagew.c') + plotsrc + common, |
| 97 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 98 |
|
|
('impress', Split('impress.c implot.c imPfuncs.c') +[plot]+ common, |
| 99 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 100 |
|
|
('aed5', Split('aed5.c') + common, |
| 101 |
|
|
['rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 102 |
|
|
('tcurve', Split('tcurve.c') +[tgraph, primout]+ common, |
| 103 |
|
|
['rtcont','rtmem','rterror']), |
| 104 |
|
|
('tscat', Split('tscat.c') +[tgraph, primout]+ common, |
| 105 |
|
|
['rtpath','rtcont','rtmem','rterror']), |
| 106 |
|
|
('tbar', Split('tbar.c') +[tgraph, primout]+ common, |
| 107 |
|
|
['rtcont','rtmem','rterror']), |
| 108 |
|
|
('plotout', [plotout] + common, |
| 109 |
|
|
['4014', 'rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 110 |
|
|
('t4014', [t4014] + common, |
| 111 |
|
|
['4014', 'rtproc','rtpath','rtio','rtcont','rtmem','rterror']), |
| 112 |
schorsch |
1.1 |
) |
| 113 |
|
|
sbin = [] |
| 114 |
|
|
sinst = [] |
| 115 |
|
|
for p in SPECIAL: |
| 116 |
schorsch |
1.2 |
prog = env.Program(target=radbin(p[0]), source=p[1], |
| 117 |
|
|
LIBS=p[2]+env['RAD_MLIB']) |
| 118 |
schorsch |
1.1 |
sbin.append(prog) |
| 119 |
schorsch |
1.2 |
sinst.append(env.Install(env['RAD_BINDIR'], prog)) |
| 120 |
|
|
env.Alias('meta_special', sbin) |
| 121 |
|
|
env.Alias('meta_special_install', sinst) |
| 122 |
schorsch |
1.1 |
|
| 123 |
|
|
# X11 targets |
| 124 |
schorsch |
1.2 |
if env.has_key('X11LIB'): |
| 125 |
|
|
x11meta = env.Program(radbin('x11meta'), [plotin, primout]+ common, |
| 126 |
|
|
CPPPATH=env.get('CPPPATH',[])+[env['X11INCLUDE']], |
| 127 |
|
|
LIBPATH=env.get('LIBPATH',[])+[env['X11LIB']], |
| 128 |
|
|
LIBS=['rtcont','rtmem','rterror', 'X11'] + env['RAD_MLIB']) |
| 129 |
schorsch |
1.1 |
Default(x11meta) |
| 130 |
schorsch |
1.2 |
env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], x11meta)]) |
| 131 |
schorsch |
1.1 |
|
| 132 |
|
|
|