| 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 |  |  |  |