--- ray/src/common/SConscript 2016/03/10 01:49:56 1.18 +++ ray/src/common/SConscript 2016/03/18 22:54:22 1.20 @@ -10,22 +10,26 @@ getlibpath = env.StaticObject(source='getlibpath.c', CPPFLAGS='-DDEFPATH="\\"%s\\""' % env['RAD_RLIBDIR'].replace('\\','/')) tmapcolrs = env.StaticObject(source='tmapcolrs.c', CPPFLAGS='-DPCOND=\\"pcond\\"') -ezxml = env.Object('ezxml.c', +ezxml = env.StaticObject('ezxml.c', CPPDEFINES=env.get('CPPDEFINES',[]) + env.get('EZXML_CPPDEFINES',[])) +objs = [getlibpath, tmapcolrs, ezxml] +# the definition of addobjnotify conflicts with definitions in other files +# that are more essential to the library. +# We need to pass this one around and include it individually +addobjn = env.StaticObject(source='addobjnotify.c') +env['ADDOBJNOTIFY'] = addobjn + # source and object dependencies RTSCENE = Split('''cone.c face.c free_os.c instance.c readobj.c readoct.c otypes.c objset.c octree.c readfargs.c modobject.c - font.c mesh.c readmesh.c tmesh.c sceneio.c xf.c''') #addobjnotify.c - -RTMGFOBJ = Split('''mgf_parser.c mgf_object.c mgf_xf.c mgf_context.c''') -RTCOLOR = Split('''spec_rgb.c''') -RTTMAP = Split('''tonemap.c tmapluv.c tmaptiff.c tmap16bit.c''') + [tmapcolrs] -RTPIC = Split('color.c colrops.c resolu.c image.c bmpfile.c falsecolor.c' - )+ RTCOLOR + RTTMAP - + font.c mesh.c readmesh.c tmesh.c sceneio.c xf.c''') +RTPIC = Split('''color.c colrops.c resolu.c image.c bmpfile.c falsecolor.c + tonemap.c tmapluv.c tmap16bit.c tmaptiff.c''') RTERROR = Split('''error.c eputs.c wputs.c quit.c''') -RTCONT = Split('''lookup.c savestr.c savqstr.c bsdf.c ccolor.c ccyrgb.c bsdf_m.c bsdf_t.c disk2square.c hilbert.c loadbsdf.c interp2d.c triangulate.c ezxml''') +RTCONT = Split('''lookup.c savestr.c savqstr.c ccolor.c ccyrgb.c + spec_rgb.c bsdf.c bsdf_m.c bsdf_t.c loadbsdf.c + disk2square.c hilbert.c interp2d.c triangulate.c''') RTMATH = Split('''fvect.c invmat4.c linregr.c mat4.c tcos.c urand.c urind.c zeroes.c dircode.c clip.c multisamp.c plocate.c byteswap.c''' ) + env.get('RAD_MATHCOMPAT', []) @@ -34,48 +38,21 @@ RTFUNC = Split('''biggerlib.c caldefn.c calexpr.c calf RTIO = Split('''fdate.c fgetline.c fgetval.c fgetword.c fputword.c loadvars.c portio.c wordfile.c words.c header.c timegm.c cvtcmd.c''') RTARGS = Split('''badarg.c expandarg.c''') + env.get('RAD_ARGSCOMPAT', []) -RTPATH = Split('''getpath.c gethomedir.c paths.c''') + [getlibpath] -RTLAMPS = Split('''fropen.c rexpr.c lamps.c''')+ [getlibpath] -REETZ = Split('''g3affine.c g3flist.c g3sphere.c g3vector.c gbasic.c - maxheap.c''') - +RTPATH = Split('''getpath.c gethomedir.c paths.c''') +RTLAMPS = Split('''fropen.c rexpr.c lamps.c''') RTPROC = Split('''process.c''') + env.get('RAD_PROCESS', []) - RTMEM = Split('ealloc.c bmalloc.c') RTNET = Split('myhostname.c') -RTDUMMY = Split('addobjnotify.c') -STD = (RTERROR + RTPATH + RTARGS + RTIO + RTMATH + RTCONT + RTMEM + - RTFUNC + RTPROC + RTLAMPS) +librtrad = env.StaticLibrary(target=radlib('rtrad'), + source=RTERROR + RTPATH + RTARGS + RTIO + RTMATH + RTCONT + RTMEM + + RTFUNC + RTPROC + RTLAMPS + RTSCENE + RTPIC + RTNET + objs) -ALL = RTSCENE + RTPIC + STD + RTNET +MGF = Split('''mgf_parser.c mgf_object.c mgf_xf.c mgf_context.c''') +libmgf = env.StaticLibrary(target=radlib('mgf'), source=MGF) -# build libraries -rtscene = env.StaticLibrary(target=radlib('rtscene'), source=RTSCENE) -libmgf = env.StaticLibrary(target=radlib('mgf'), source=RTMGFOBJ) -rterror = env.StaticLibrary(target=radlib('rterror'), source=RTERROR) -rtpath = env.StaticLibrary(target=radlib('rtpath'), source=RTPATH) -rtargs = env.StaticLibrary(target=radlib('rtargs'), source=RTARGS) -rtio = env.StaticLibrary(target=radlib('rtio'), source=RTIO) -rtmath = env.StaticLibrary(target=radlib('rtmath'), source=RTMATH) -rtcont = env.StaticLibrary(target=radlib('rtcont'), source=RTCONT) -rtmem = env.StaticLibrary(target=radlib('rtmem'), source=RTMEM) -rtfunc = env.StaticLibrary(target=radlib('rtfunc'), source=RTFUNC) -rtproc = env.StaticLibrary(target=radlib('rtproc'), source=RTPROC) -rtcolor = env.StaticLibrary(target=radlib('rtcolor'), source=RTCOLOR) -rtlamps = env.StaticLibrary(target=radlib('rtlamps'), source=RTLAMPS) -reetz = env.StaticLibrary(target=radlib('reetz'), source=REETZ) -rtpic = env.StaticLibrary(target=radlib('rtpic'), source=RTPIC) -rtnet = env.StaticLibrary(target=radlib('rtnet'), source=RTNET) -# librtdummy is needed, because addobjnotify has different sizes depending -# on the program, and in some cases isn't actually needed at all. -# It should really be a pointer, and its content allocated -# dynamically during program initialization. -rtdummy = env.StaticLibrary(target=radlib('rtdummy'), source=RTDUMMY) - -rtall = env.StaticLibrary(target=radlib('rtall'), source=ALL) -#librtrad = env.StaticLibrary(target=radlib('rtrad'), source=ALL) -#Default(librtrad) +REETZ = Split('g3affine.c g3flist.c g3sphere.c g3vector.c gbasic.c maxheap.c') +libreetz = env.StaticLibrary(target=radlib('reetz'), source=REETZ) LIBFILES = Split('tmesh.cal') env.Append(RAD_RLIBINSTALL=env.Install(env['RAD_RLIBDIR'], LIBFILES))