1 |
< |
import os |
2 |
< |
|
3 |
< |
Import ('env') |
4 |
< |
|
5 |
< |
# math libs |
6 |
< |
mlib = env['RAD_MLIB'] |
7 |
< |
|
8 |
< |
# compose paths |
9 |
< |
def rbin(name): return os.path.join(env['RAD_BUILDBIN'], name) |
10 |
< |
def rlib(name): return os.path.join(env['RAD_BUILDLIB'], name) |
11 |
< |
def mgfs(src): return map(lambda s:os.path.join('mgflib', s), src) |
12 |
< |
|
13 |
< |
MGFSRC = Split('''parser.c context.c xf.c object.c lookup.c badarg.c |
14 |
< |
words.c |
15 |
< |
fvect.c''') |
16 |
< |
libmgf = env.StaticLibrary(rlib('mgf'), source=mgfs(MGFSRC)) |
17 |
< |
|
18 |
< |
MGFPROGS = ( |
19 |
< |
('mgfilt', Split('mgfilt.c')), |
20 |
< |
('mgf2inv', Split('mgf2inv.c cvrgb.c')), |
21 |
< |
('3ds2mgf', Split('3ds2mgf.c rayopt.c vect.c')), |
22 |
< |
) |
23 |
< |
for p in MGFPROGS: |
24 |
< |
prog = env.Program(target=rbin(p[0]), source=mgfs(p[1]), LIBS=mlib+['mgf']) |
25 |
< |
Default(prog) |
26 |
< |
env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], prog)]) |
27 |
< |
|
28 |
< |
trans = env.Object(source="trans.c") |
29 |
< |
|
30 |
< |
# standard targets |
31 |
< |
PROGS = [ |
32 |
< |
('ies2rad', ['ies2rad.c'], ['rtlamps','rtcolor','rtio','rtpath']+ mlib), |
33 |
< |
('arch2rad', ['arch2rad.c',trans],['rtcont','rtmem'] + mlib), |
34 |
< |
('nff2rad', ['nff2rad.c'], []), |
35 |
< |
('lampcolor', ['lampcolor.c'], ['rtlamps','rtcolor','rtio','rtpath']), |
36 |
< |
('tmesh2rad', ['tmesh2rad.c'], ['rtscene','rtmath'] + mlib), |
37 |
< |
('obj2rad', ['obj2rad.c',trans], |
38 |
< |
['rtscene','rtargs','rtio','rtcont','rtmem','rtmath','rterror'] + mlib), |
39 |
< |
('mgf2rad', ['mgf2rad.c'], ['rtscene','rtcolor','mgf'] + mlib), |
40 |
< |
('rad2mgf', ['rad2mgf.c'], |
41 |
< |
['rtproc', 'rtpath', # for win_popen() |
42 |
< |
'rtscene','rtio','rtcolor','rtcont','rtmem','rterror'] + mlib), |
43 |
< |
] |
44 |
< |
for p in PROGS: |
45 |
< |
prog = env.Program(target=rbin(p[0]), source=p[1], LIBS=p[2]) |
46 |
< |
Default(prog) |
47 |
< |
env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], prog)]) |
48 |
< |
|
49 |
< |
# meta targets |
50 |
< |
prog = env.Program(target=rbin('mgf2meta'), source=['mgf2meta.c'], |
51 |
< |
CPPPATH=env.get('CPPPATH', []) + [os.path.join('#src','meta')], |
52 |
< |
LIBS=['meta','rtmath','rtcont','rtmem','rterror','mgf'] + mlib) |
53 |
< |
env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], prog)]) |
54 |
< |
|
55 |
< |
LIBFILES = Split('source.cal tilt.cal window.cal') |
56 |
< |
env.Append(RAD_RLIBINSTALL=env.Install(env['RAD_RLIBDIR'], LIBFILES)) |
57 |
< |
|
58 |
< |
if os.name == 'posix': |
59 |
< |
for s in Split('''optics2rad'''): |
60 |
< |
Default(env.InstallCsh(rbin(s), s + '.csh')) |
1 |
> |
from __future__ import division, print_function, unicode_literals |
2 |
> |
|
3 |
> |
import os |
4 |
> |
|
5 |
> |
Import ('env') |
6 |
> |
|
7 |
> |
# math libs |
8 |
> |
mlib = env['RAD_MLIB'] |
9 |
> |
|
10 |
> |
# compose paths |
11 |
> |
def rbin(name): return os.path.join(env['RAD_BUILDBIN'], name) |
12 |
> |
|
13 |
> |
trans = env.Object(source="trans.c") |
14 |
> |
bsdfrep = env.Object(source="bsdfrep.c") |
15 |
> |
bsdfinterp = env.Object(source="bsdfinterp.c") |
16 |
> |
|
17 |
> |
# standard targets |
18 |
> |
PROGS = [ |
19 |
> |
('3ds2mgf', Split('3ds2mgf.c rayopt3ds.c vect3ds.c'), ['mgf','rtrad'] + mlib), |
20 |
> |
('ies2rad', ['ies2rad.c'], ['rtrad'] + mlib), |
21 |
> |
#('arch2rad', ['arch2rad.c',trans],['rtrad'] + mlib), |
22 |
> |
('nff2rad', ['nff2rad.c'], []), |
23 |
> |
('lampcolor', ['lampcolor.c'], ['rtrad'] ), |
24 |
> |
('tmesh2rad', ['tmesh2rad.c'], ['rtrad'] + mlib), |
25 |
> |
('obj2rad', ['obj2rad.c',trans], ['rtrad'] + mlib), |
26 |
> |
('mgf2rad', ['mgf2rad.c'], ['mgf','rtrad'] + mlib), |
27 |
> |
('rad2mgf', ['rad2mgf.c'], ['rtrad'] + mlib), |
28 |
> |
('mgfilt', ['mgfilt.c'], ['mgf','rtrad'] + mlib), |
29 |
> |
('mgf2inv', ['mgf2inv.c'], ['mgf','rtrad'] + mlib), |
30 |
> |
('pabopto2bsdf', |
31 |
> |
['pabopto2bsdf.c',bsdfrep,'bsdfrbf.c', 'bsdfmesh.c', 'bsdftrans.cpp',], |
32 |
> |
['rtrad'] + mlib), |
33 |
> |
('bsdf2klems',['bsdf2klems.c', bsdfrep, bsdfinterp,], ['rtrad'] + mlib), |
34 |
> |
('bsdf2ttree',['bsdf2ttree.c', bsdfrep, bsdfinterp,], ['rtrad'] + mlib), |
35 |
> |
('pkgBSDF', ['pkgBSDF.c', ], ['rtrad'] + mlib), |
36 |
> |
('epw2wea', ['epw2wea.c', ], ['rtrad'] + mlib), |
37 |
> |
('mgf2meta', ['mgf2meta.c'], ['meta', 'mgf','rtrad'] + mlib, |
38 |
> |
[os.path.join('#src','meta')]), |
39 |
> |
] |
40 |
> |
for p in PROGS: |
41 |
> |
if len(p) == 4: inclp = env.get('CPPPATH', []) + [os.path.join('#src','meta')], |
42 |
> |
else: inclp = env.get('CPPPATH', []) |
43 |
> |
prog = env.Program(target=rbin(p[0]), source=p[1], LIBS=p[2], CPPPATH=inclp) |
44 |
> |
Default(prog) |
45 |
> |
env.Append(RAD_BININSTALL=[env.Install(env['RAD_BINDIR'], prog)]) |
46 |
> |
|
47 |
> |
LIBFILES = Split('bsdf2rad.cal source.cal tilt.cal window.cal') |
48 |
> |
env.Append(RAD_RLIBINSTALL=env.Install(env['RAD_RLIBDIR'], LIBFILES)) |
49 |
> |
|
50 |
> |
if os.name == 'posix': |
51 |
> |
for s in Split('''optics2rad'''): |
52 |
> |
Default(env.InstallScript(rbin(s), s + '.csh')) |
53 |
> |
|
54 |
> |
# vim: set syntax=python: |
55 |
> |
# vi: set ts=4 sw=4 : |