--- ray/src/hd/SConscript 2003/10/21 19:27:29 1.1 +++ ray/src/hd/SConscript 2004/11/08 19:24:46 1.4 @@ -2,28 +2,34 @@ import os Import('env') - # math libs mlib = env['RAD_MLIB'] # common objects viewbeams = env.Object(source='viewbeams.c') holo = env.Object(source='holo.c') +holofile = env.Object(source='holofile.c') +Version = env.Object(source='../rt/Version.c') # XXX ../rt/not_nice + # standard targets PROGS = ( -('rholo', Split('''rholo.c rholo2.c rholo2l.c rholo3.c rholo4.c - holofile.c Version.c''') + [holo, viewbeams]), -('rhpict', Split('rhpict.c rhpict2.c holofile.c Version.c')+[holo, viewbeams]), -('rhcopy', Split('rhcopy.c clumpbeams.c holofile.c') + [holo]), -('rhinfo', Split('rhinfo.c holofile.c') + [holo]), -#('genrhenv', Split('genrhenv.c holofile.c') + [holo]), # XXX broken -('genrhgrid', Split('genrhgrid.c') + [holo]), +('rholo', Split('''rholo.c rholo2.c rholo2l.c rholo3.c rholo4.c''') + + [Version, holofile, holo, viewbeams], + ['rtpic','rtio','rtproc','rtpath','rtargs','rtmath','rtmem','rterror']), +('rhpict', Split('rhpict.c rhpict2.c')+[Version, holofile, holo, viewbeams], + ['rtpic','rtio','rtproc','rtargs','rtmath','rtmem','rterror']), +('rhcopy', Split('rhcopy.c clumpbeams.c') + [holofile, holo], + ['rtpic','rtio','rtproc','rtargs','rtmath','rtmem','rterror']), +('rhinfo', Split('rhinfo.c') + [holofile, holo], + ['rtio','rtproc', 'rtmath','rterror']), +('genrhgrid', Split('genrhgrid.c') + [holofile, holo], + ['rtio','rtmath','rtproc','rterror']), ) if os.name != 'nt': # pending some major work... for p in PROGS: prog = env.Program(target=os.path.join(env['RAD_BUILDBIN'], p[0]), - source=p[1], LIBS=['rt'] + mlib) + source=p[1], LIBS=p[2] + mlib) Default(prog) env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], prog)]) @@ -44,6 +50,7 @@ if env.has_key('X11INCLUDE'): # XXX the .hdi extension will cause problems on Windows xenv['PROGSUFFIX'] = '.hdi' + dlibs = ['rtpic','rtio','rtmath','rtcont','rtmem','rtargs','rterror'] def make_hdi(p): # build them obj = xenv.Object(target=p[3], source=p[4], CPPFLAGS=ocppflags + p[5]) prog = xenv.Program(target=os.path.join(devdir, p[0]), @@ -57,40 +64,32 @@ if env.has_key('X11INCLUDE'): # (name, sources, libs, obj, objsrc, objflags) XHDI = (('x11', Split('rhd_ctab.c rhd_qtree2r.c') + [rhd_qtree], - ['rt','X11'] + mlib, + dlibs + ['X11'] + mlib, 'rhd_x11', 'rhd_x11.c', []), ) for p in XHDI: make_hdi(p) if env.has_key('OGL'): - # XXX There's a BITS(x) macro missing in sm_geom.h - #sm_common_s = Split('''sm_samp.c sm_qtree.c sm_stree.c sm_geom.c - # sm_list.c sm_del.c sm_ogl.c sm_usets.c sm.c''') - #sm_common = map(lambda s:xenv.Object(source=s), sm_common_s) + rgllibs = ['rgl','rtscene','rtpath'] ogl_common_s = Split('rhd_odraw.c rhd_geom.c') ogl_common = map(lambda s:xenv.Object(source=s), ogl_common_s) rhdobj = xenv.Object(source='rhdobj.c') GLHDI = ( + # glx1h ('glx1', ['rhd_qtree2c.c', rhd_qtree], - ['rt','GLU','GL','X11'] + mlib, + dlibs + ['GLU','GL','X11'] + mlib, 'rhd_glx1', 'rhd_glx1.c', ['-DNOSTEREO']), - #('glx', sm_common, - # ['rt','GLU','GL','X11'] + mlib, - # 'rhd_glx0', 'rhd_glx.c', ['-DNOSTEREO']), - - #('glxo', [rhdobj] + sm_common, - # ['rgl','rt','GLU','GL','X11'] + mlib, - # 'rhd_glxo', 'rhd_glx.c', ['-DDOBJ', '-DNOSTEREO']), - + # oglh ('ogl', ogl_common, - ['rgl','rt','GLU','GL','X11'] + mlib, + rgllibs+dlibs+['GLU','GL','X11'] + mlib, 'rhd_ogl0', 'rhd_ogl.c', ['-DNOSTEREO']), + # ogloh ('oglo', [rhdobj] + ogl_common, - ['rgl','rt','GLU','GL','X11'] + mlib, + rgllibs+['rtproc']+dlibs+['GLU','GL','X11'] + mlib, 'rhd_oglo', 'rhd_ogl.c', ['-DDOBJ', '-DNOSTEREO']), ) for p in GLHDI: @@ -98,20 +97,14 @@ if env.has_key('X11INCLUDE'): if xenv['RAD_STEREO'] == '-DSTEREO': GLSHDI = ( - #('glxs', sm_common, - # ['rt','GLU','GL','X11','Xext'] + mlib, - # 'rhd_glxs', 'rhd_glx.c' ['-DSTEREO']), - - #('glxso', [rhdobj] + sm_common, - # ['rgl','rt','GLU','GL','X11','Xext'] + mlib, - # 'rhd_glxo', 'rhd_glx.c' ['-DDOBJ', '-DSTEREO']), - + # oglsh ('ogls', ogl_common, - ['rgl','rt','GLU','GL','X11','Xext'] + mlib, + rgllibs+dlibs+['GLU','GL','X11','Xext'] + mlib, 'rhd_ogls', 'rhd_ogl.c' ['-DSTEREO']), + # oglsoh ('oglso', [rhdobj] + ogl_common, - ['rgl','rt','GLU','GL','X11','Xext'] + mlib, + rgllibs+dlibs+['GLU','GL','X11','Xext'] + mlib, 'rhd_oglso', 'rhd_ogl.c' ['-DDOBJ', '-DSTEREO']), ) for p in GLHDI: