From d981b7feb7183a325d44f22ece4c963366658cef Mon Sep 17 00:00:00 2001 From: Tim Blechmann Date: Tue, 1 Nov 2005 21:24:31 +0000 Subject: updated build system svn path=/trunk/externals/tb/; revision=3810 --- chaos/SConstruct | 196 ++++++++++++++++++++++++++++++++++++++++++------------ chaos/package.txt | 6 ++ 2 files changed, 159 insertions(+), 43 deletions(-) diff --git a/chaos/SConstruct b/chaos/SConstruct index 3dcf513..499e76a 100644 --- a/chaos/SConstruct +++ b/chaos/SConstruct @@ -1,43 +1,153 @@ -systems = Split("""bernoulli - bungalow_tent - circle_map - coupled_logistic - chua - delayed_logistic - driven_anharmonic - driven_van_der_pol - duffing_map - gauss_map - gaussian_map - henon_map - hydrogen - ikeda_laser_map - latoocarfian - latoomutalpha - latoomutbeta - latoomutgamma - logistic - lorenz - lozi_map - roessler - sine_map - standard_map - tent_map""") - -sources = [] - -env = Environment(CCFLAGS = '-O3 -g -mtune=pentium-m -march=pentium-m -mmmx -msse -msse2 -mfpmath=sse -I~/pd/devel/pd/src/ -I/usr/local/include/flext -DFLEXT_SYS_PD -DFLEXT_THREADS -DFLEXT_SHARED') - -for system in systems: - sources.append(system+"_dsp.cpp") - sources.append(system+"_msg.cpp") - sources.append(system+"_search.cpp") -sources += Split("main.cpp ode_base.cpp") - -sources = map(lambda x: "./src/"+x, sources) - -chaos = env.SharedLibrary('chaos', sources, LIBS = 'flext-pd_d', - SHLIBPREFIX='', SHLIBSUFFIX='.pd_linux') - -env.Install('/usr/local/lib/pd/extra',chaos) -env.Alias('install', '/usr/local/lib/pd/extra') +# scons script for flext build system +# Copyright (C) 2005 Tim Blechmann +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; see the file COPYING. If not, write to +# the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +# Boston, MA 02111-1307, USA. + +import sys + +env = Environment(CCFLAGS = '-DFLEXT_SYS_PD -DFLEXT_THREADS') + +env.SConsignFile() +env.CacheDir('./obj') + +opt = Options(['options.cache']) +opt.AddOptions( + BoolOption('debug', 'Build with debugging symbols', False), + ('optimize', 'Optimize for specific architecture', None), + ('icc', 'Build with intel c compiler', False), + BoolOption('simd', 'build with simd instructions', False), + ('prefix', 'install prefix', '/usr/local'), + ('flext_path', 'flext path', None), + ('pd_path', 'pd path', None), + ) + +opt.Update(env) + +opt.Save('options.cache',env) +Help(opt.GenerateHelpText(env)) + + +if env.Dictionary().has_key('icc') and env['icc']: + env.Replace(CC="icc", + SHCC="icc", + CXX="icc", + LINK="icc", + SHCXX="icc", + SHLINK="icc", + ) + env.Append(LINKFLAGS="-static-libcxa") + + env.Append(CCFLAGS=' -ip') + env.Append(LINKFLAGS='-ip') + print "Using intel c compiler" + + +if env.Dictionary().has_key('flext_path'): + env.Append(CPPPATH=[env['flext_path']]) +else: + env.Append(CPPPATH=['../../grill/flext/source']) + + +if env.Dictionary().has_key('pd_path'): + env.Append(CPPPATH=[env['pd_path']]) + +if env.Dictionary().has_key('optimize'): + if env['optimize']: + env.Append(CCFLAGS=' -O3 '+env['optimize']) + env.Append(LINKFLAGS=' -O3 '+env['optimize']) + +if env.Dictionary().has_key('simd') and env['simd']: + env.Append(CCFLAGS=' -mfpmath=sse -msse -mmmx -msse2') + +if env.Dictionary().has_key('debug') and env['debug']: + env.Append(CCFLAGS=' -g ') + env.Append(CPPDEFINES=['_DEBUG']) + env.Append(LIBS = 'flext-pd') + env.Append(LINKFLAGS=' -g') +else: + env.Append(CPPDEFINES=['FLEXT_SHARED']) + env.Append(LIBS = 'flext-pd') + env.Append(CPPDEFINES="NDEBUG") + +###################################################################### +# +# read package.txt +# + +packagefile = open('./package.txt', 'r') + +desc = {} +line = packagefile.readline() +while line != "": + line = line.strip() + if len(line) > 0 and line[0] != '#' : + var, data = line.split('=') + + if len(data) == 0: + line = packagefile.readline() + continue + + while data [-1] == '\\': + nextline = packagefile.readline() + nextline = nextline.strip() + data = data + " " + nextline + + data = data.replace("\\", "") + desc[var] = data + + + line = packagefile.readline() +packagefile.close() + + +name = desc["NAME"] +if not desc.has_key("SRCDIR"): + desc["SRCDIR"] = "." + +sources = map (lambda x: desc["SRCDIR"] + '/' + x, + desc["SRCS"].split()) + +if desc.has_key("INCPATH"): + env.Append(CPPPATH=desc["INCPATH"].strip().replace("-I", "").split()) + + + +###################################################################### +# +# run custom.py +# +try: + sys.path.append("./build/") + import custom + try: + env, sources, headers = custom.custom(env,desc,sources) + except: + env, sources = custom.custom(env,desc,sources) +except: + pass + + + +###################################################################### +# +# build +# + +external = env.SharedLibrary(name, sources, SHLIBPREFIX='', SHLIBSUFFIX='.pd_linux') + +prefix = env['prefix'] +env.Install(prefix+'/lib/pd/extra',external) +env.Alias('install', prefix+'/lib/pd/extra') diff --git a/chaos/package.txt b/chaos/package.txt index a32c803..c132783 100644 --- a/chaos/package.txt +++ b/chaos/package.txt @@ -32,6 +32,9 @@ driven_anharmonic_search.cpp \ driven_van_der_pol_dsp.cpp \ driven_van_der_pol_msg.cpp \ driven_van_der_pol_search.cpp \ +duffing_dsp.cpp \ +duffing_msg.cpp \ +duffing_search.cpp \ duffing_map_dsp.cpp \ duffing_map_msg.cpp \ duffing_map_search.cpp \ @@ -62,6 +65,9 @@ latoomutbeta_search.cpp \ latoomutgamma_dsp.cpp \ latoomutgamma_msg.cpp \ latoomutgamma_search.cpp \ +linear_congruental_dsp.cpp \ +linear_congruental_msg.cpp \ +linear_congruental_search.cpp \ logistic_dsp.cpp \ logistic_msg.cpp \ logistic_search.cpp \ -- cgit v1.2.1