4 # and there we have it, or do we?
22 EnsureSConsVersion(0, 96)
24 ardour_version = '2.8.2'
29 # Command-line options
32 opts = Options('scache.conf')
34 ('ARCH', 'Set architecture-specific compilation flags by hand (all flags as 1 argument)',''),
35 ('WINDOWS_KEY', 'Set X Modifier (Mod1,Mod2,Mod3,Mod4,Mod5) for "Windows" key', 'Mod4><Super'),
36 BoolOption('AUDIOUNITS', 'Compile with Apple\'s AudioUnit library. (experimental)', 0),
37 BoolOption('COREAUDIO', 'Compile with Apple\'s CoreAudio library', 0),
38 BoolOption('GTKOSX', 'Compile for use with GTK-OSX, not GTK-X11', 0),
39 BoolOption('OLDFONTS', 'Old school font sizes', 0),
40 BoolOption('DEBUG', 'Set to build with debugging information and no optimizations', 0),
41 BoolOption('STL_DEBUG', 'Set to build with Standard Template Library Debugging', 0),
42 PathOption('DESTDIR', 'Set the intermediate install "prefix"', '/'),
43 EnumOption('DIST_TARGET', 'Build target for cross compiling packagers', 'auto', allowed_values=('auto', 'i386', 'i686', 'x86_64', 'powerpc', 'tiger', 'panther', 'leopard', 'none' ), ignorecase=2),
44 BoolOption('DMALLOC', 'Compile and link using the dmalloc library', 0),
45 BoolOption('EXTRA_WARN', 'Compile with -Wextra, -ansi, and -pedantic. Might break compilation. For pedants', 0),
46 BoolOption('FFT_ANALYSIS', 'Include FFT analysis window', 1),
47 BoolOption('FREESOUND', 'Include Freesound database lookup', 0),
48 BoolOption('FPU_OPTIMIZATION', 'Build runtime checked assembler code', 1),
49 BoolOption('LIBLO', 'Compile with support for liblo library', 1),
50 BoolOption('NLS', 'Set to turn on i18n support', 1),
51 PathOption('PREFIX', 'Set the install "prefix"', '/usr/local'),
52 BoolOption('SURFACES', 'Build support for control surfaces', 1),
53 BoolOption('WIIMOTE', 'Build the wiimote control surface', 0),
54 ('DIST_LIBDIR', 'Explicitly set library dir. If not set, Fedora-style defaults are used (typically lib or lib64)', ''),
55 BoolOption('SYSLIBS', 'USE AT YOUR OWN RISK: CANCELS ALL SUPPORT FROM ARDOUR AUTHORS: Use existing system versions of various libraries instead of internal ones', 0),
56 BoolOption('UNIVERSAL', 'Compile as universal binary. Requires that external libraries are already universal.', 0),
57 BoolOption('VERSIONED', 'Add revision information to ardour/gtk executable name inside the build directory', 0),
58 BoolOption('VST', 'Compile with support for VST', 0),
59 BoolOption('LV2', 'Compile with support for LV2 (if slv2 is available)', 1),
60 BoolOption('GPROFILE', 'Compile with support for gprofile (Developers only)', 0),
61 BoolOption('FREEDESKTOP', 'Install MIME type, icons and .desktop file as per the freedesktop.org spec (requires xdg-utils and shared-mime-info). "scons uninstall" removes associations in desktop database', 0),
62 BoolOption('TRANZPORT', 'Compile with support for Frontier Designs (if libusb is available)', 1),
63 BoolOption('AUBIO', "Use Paul Brossier's aubio library for feature detection (if available)", 1),
64 BoolOption('AUSTATE', "Build with support for AU settings & presets saving/loading", 0)
67 #----------------------------------------------------------------------
68 # a handy helper that provides a way to merge compile/link information
69 # from multiple different "environments"
70 #----------------------------------------------------------------------
72 class LibraryInfo(Environment):
73 def __init__(self,*args,**kw):
74 Environment.__init__ (self,*args,**kw)
75 self.ENV_update(os.environ)
77 def Merge (self,others):
79 self.Append (LIBS = other.get ('LIBS',[]))
80 self.Append (LIBPATH = other.get ('LIBPATH', []))
81 self.Append (CPPPATH = other.get('CPPPATH', []))
82 self.Append (LINKFLAGS = other.get('LINKFLAGS', []))
83 self.Append (CCFLAGS = other.get('CCFLAGS', []))
84 self.Replace(LIBPATH = list(Set(self.get('LIBPATH', []))))
85 self.Replace(CPPPATH = list(Set(self.get('CPPPATH',[]))))
86 #doing LINKFLAGS breaks -framework
87 #doing LIBS break link order dependency
89 def ENV_update(self, src_ENV):
90 for k in src_ENV.keys():
91 if k in self['ENV'].keys() and k in [ 'PATH', 'LD_LIBRARY_PATH',
92 'LIB', 'PKG_CONFIG_PATH', 'INCLUDE' ]:
93 self['ENV'][k]=SCons.Util.AppendPath(self['ENV'][k], src_ENV[k])
95 self['ENV'][k]=src_ENV[k]
97 env = LibraryInfo (options = opts,
99 VERSION = ardour_version,
100 TARBALL='ardour-' + ardour_version + '.tar.bz2',
102 DISTTREE = '#ardour-' + ardour_version,
103 DISTCHECKDIR = '#ardour-' + ardour_version + '/check'
106 env.ENV_update(os.environ)
108 #----------------------------------------------------------------------
110 #----------------------------------------------------------------------
112 # Handy subst-in-file builder
115 def do_subst_in_file(targetfile, sourcefile, dict):
116 """Replace all instances of the keys of dict with their values.
117 For example, if dict is {'%VERSION%': '1.2345', '%BASE%': 'MyProg'},
118 then all instances of %VERSION% in the file will be replaced with 1.2345 etc.
121 f = open(sourcefile, 'rb')
125 raise SCons.Errors.UserError, "Can't read source file %s"%sourcefile
126 for (k,v) in dict.items():
127 contents = re.sub(k, v, contents)
129 f = open(targetfile, 'wb')
133 raise SCons.Errors.UserError, "Can't write target file %s"%targetfile
136 def subst_in_file(target, source, env):
137 if not env.has_key('SUBST_DICT'):
138 raise SCons.Errors.UserError, "SubstInFile requires SUBST_DICT to be set."
139 d = dict(env['SUBST_DICT']) # copy it
140 for (k,v) in d.items():
142 d[k] = env.subst(v())
143 elif SCons.Util.is_String(v):
146 raise SCons.Errors.UserError, "SubstInFile: key %s: %s must be a string or callable"%(k, repr(v))
147 for (t,s) in zip(target, source):
148 return do_subst_in_file(str(t), str(s), d)
150 def subst_in_file_string(target, source, env):
151 """This is what gets printed on the console."""
152 return '\n'.join(['Substituting vars from %s into %s'%(str(s), str(t))
153 for (t,s) in zip(target, source)])
155 def subst_emitter(target, source, env):
156 """Add dependency from substituted SUBST_DICT to target.
157 Returns original target, source tuple unchanged.
159 d = env['SUBST_DICT'].copy() # copy it
160 for (k,v) in d.items():
162 d[k] = env.subst(v())
163 elif SCons.Util.is_String(v):
165 Depends(target, SCons.Node.Python.Value(d))
166 # Depends(target, source) # this doesn't help the install-sapphire-linux.sh problem
167 return target, source
169 subst_action = Action (subst_in_file, subst_in_file_string)
170 env['BUILDERS']['SubstInFile'] = Builder(action=subst_action, emitter=subst_emitter)
173 # internationalization
176 # po_builder: builder function to copy po files to the parent directory while updating them
178 # first source: .po file
179 # second source: .pot file
182 def po_builder(target,source,env):
183 os.spawnvp (os.P_WAIT, 'cp', ['cp', str(source[0]), str(target[0])])
189 print 'Updating ' + str(target[0])
190 return os.spawnvp (os.P_WAIT, 'msgmerge', args)
192 po_bld = Builder (action = po_builder)
193 env.Append(BUILDERS = {'PoBuild' : po_bld})
195 # mo_builder: builder function for (binary) message catalogs (.mo)
197 # first source: .po file
200 def mo_builder(target,source,env):
204 target[0].get_path(),
207 return os.spawnvp (os.P_WAIT, 'msgfmt', args)
209 mo_bld = Builder (action = mo_builder)
210 env.Append(BUILDERS = {'MoBuild' : mo_bld})
212 # pot_builder: builder function for message templates (.pot)
214 # source: list of C/C++ etc. files to extract messages from
217 def pot_builder(target,source,env):
222 '-o', target[0].get_path(),
223 "--default-domain=" + env['PACKAGE'],
224 '--copyright-holder="Paul Davis"' ]
225 args += [ src.get_path() for src in source ]
227 return os.spawnvp (os.P_WAIT, 'xgettext', args)
229 pot_bld = Builder (action = pot_builder)
230 env.Append(BUILDERS = {'PotBuild' : pot_bld})
233 # utility function, not a builder
236 def i18n (buildenv, sources, installenv):
237 domain = buildenv['PACKAGE']
238 potfile = buildenv['POTFILE']
240 installenv.Alias ('potupdate', buildenv.PotBuild (potfile, sources))
242 p_oze = [ os.path.basename (po) for po in glob.glob ('po/*.po') ]
243 languages = [ po.replace ('.po', '') for po in p_oze ]
245 for po_file in p_oze:
246 buildenv.PoBuild(po_file, ['po/'+po_file, potfile])
247 mo_file = po_file.replace (".po", ".mo")
248 installenv.Alias ('install', buildenv.MoBuild (mo_file, po_file))
249 installenv.Alias ('msgupdate', buildenv.MoBuild (mo_file, po_file))
251 for lang in languages:
252 modir = (os.path.join (install_prefix, 'share/locale/' + lang + '/LC_MESSAGES/'))
253 moname = domain + '.mo'
254 installenv.Alias('install', installenv.InstallAs (os.path.join (modir, moname), lang + '.mo'))
257 def fetch_svn_revision (path):
261 cmd += " | awk '/^Revision:/ { print $2}'"
262 return commands.getoutput (cmd)
264 def create_stored_revision (target = None, source = None, env = None):
265 if os.path.exists('.svn'):
266 rev = fetch_svn_revision ('.');
268 text = "#include <ardour/svn_revision.h>\n"
269 text += "namespace ARDOUR {\n";
270 text += "extern const char* svn_revision = \"" + rev + "\";\n";
272 print '============> writing svn revision info to libs/ardour/svn_revision.cc\n'
273 o = file ('libs/ardour/svn_revision.cc', 'w')
277 print "Could not open libs/ardour/svn_revision.cc for writing\n"
280 if not os.path.exists('libs/ardour/ardour/svn_revision.h'):
281 print "This release of ardour is missing libs/ardour/ardour/svn_revision.h. Blame the packager."
285 # A generic builder for version.cc files
287 # note: requires that DOMAIN, MAJOR, MINOR, MICRO are set in the construction environment
288 # note: assumes one source files, the header that declares the version variables
291 def version_builder (target, source, env):
293 text = "int " + env['DOMAIN'] + "_major_version = " + str (env['MAJOR']) + ";\n"
294 text += "int " + env['DOMAIN'] + "_minor_version = " + str (env['MINOR']) + ";\n"
295 text += "int " + env['DOMAIN'] + "_micro_version = " + str (env['MICRO']) + ";\n"
298 o = file (target[0].get_path(), 'w')
302 print "Could not open", target[0].get_path(), " for writing\n"
305 text = "#ifndef __" + env['DOMAIN'] + "_version_h__\n"
306 text += "#define __" + env['DOMAIN'] + "_version_h__\n"
307 text += "extern const char* " + env['DOMAIN'] + "_revision;\n"
308 text += "extern int " + env['DOMAIN'] + "_major_version;\n"
309 text += "extern int " + env['DOMAIN'] + "_minor_version;\n"
310 text += "extern int " + env['DOMAIN'] + "_micro_version;\n"
311 text += "#endif /* __" + env['DOMAIN'] + "_version_h__ */\n"
314 o = file (target[1].get_path(), 'w')
318 print "Could not open", target[1].get_path(), " for writing\n"
323 version_bld = Builder (action = version_builder)
324 env.Append (BUILDERS = {'VersionBuild' : version_bld})
327 # a builder that makes a hard link from the 'source' executable to a name with
328 # a "build ID" based on the most recent CVS activity that might be reasonably
329 # related to version activity. this relies on the idea that the SConscript
330 # file that builds the executable is updated with new version info and committed
331 # to the source code repository whenever things change.
334 def versioned_builder(target,source,env):
335 w, r = os.popen2( "LANG= svn info | awk '/^Revision:/ { print $2}'")
337 last_revision = r.readline().strip()
340 if last_revision == "":
341 print "No SVN info found - versioned executable cannot be built"
344 print "The current build ID is " + last_revision
346 tagged_executable = source[0].get_path() + '-' + last_revision
348 if os.path.exists (tagged_executable):
349 print "Replacing existing executable with the same build tag."
350 os.unlink (tagged_executable)
352 return os.link (source[0].get_path(), tagged_executable)
354 verbuild = Builder (action = versioned_builder)
355 env.Append (BUILDERS = {'VersionedExecutable' : verbuild})
358 # source tar file builder
361 def distcopy (target, source, env):
362 treedir = str (target[0])
366 except OSError, (errnum, strerror):
367 if errnum != errno.EEXIST:
368 print 'mkdir ', treedir, ':', strerror
372 # we don't know what characters might be in the file names
373 # so quote them all before passing them to the shell
375 all_files = ([ str(s) for s in source ])
376 cmd += " ".join ([ "'%s'" % quoted for quoted in all_files])
377 cmd += ' | (cd ' + treedir + ' && tar xf -)'
381 def tarballer (target, source, env):
382 cmd = 'tar -jcf ' + str (target[0]) + ' ' + str(source[0]) + " --exclude '*~'" + " --exclude .svn --exclude '.svn/*'"
383 print 'running ', cmd, ' ... '
387 dist_bld = Builder (action = distcopy,
388 target_factory = SCons.Node.FS.default_fs.Entry,
389 source_factory = SCons.Node.FS.default_fs.Entry,
392 tarball_bld = Builder (action = tarballer,
393 target_factory = SCons.Node.FS.default_fs.Entry,
394 source_factory = SCons.Node.FS.default_fs.Entry)
396 env.Append (BUILDERS = {'Distribute' : dist_bld})
397 env.Append (BUILDERS = {'Tarball' : tarball_bld})
403 def pushEnvironment(context):
404 if os.environ.has_key('PATH'):
405 context['ENV']['PATH'] = os.environ['PATH']
407 if os.environ.has_key('PKG_CONFIG_PATH'):
408 context['ENV']['PKG_CONFIG_PATH'] = os.environ['PKG_CONFIG_PATH']
410 if os.environ.has_key('CC'):
411 context['CC'] = os.environ['CC']
413 if os.environ.has_key('CXX'):
414 context['CXX'] = os.environ['CXX']
416 if os.environ.has_key('DISTCC_HOSTS'):
417 context['ENV']['DISTCC_HOSTS'] = os.environ['DISTCC_HOSTS']
418 context['ENV']['HOME'] = os.environ['HOME']
420 pushEnvironment (env)
422 #######################
423 # Dependency Checking #
424 #######################
428 'glib-2.0' : '2.10.1',
429 'gthread-2.0' : '2.10.1',
430 'gtk+-2.0' : '2.8.1',
431 'libxml-2.0' : '2.6.0',
432 'samplerate' : '0.1.0',
436 'libgnomecanvas-2.0' : '2.0'
439 def DependenciesRequiredMessage():
440 print 'You do not have the necessary dependencies required to build ardour'
441 print 'Please consult http://ardour.org/building for more information'
443 def CheckPKGConfig(context, version):
444 context.Message( 'Checking for pkg-config version >= %s... ' %version )
445 ret = context.TryAction('pkg-config --atleast-pkgconfig-version=%s' % version)[0]
446 context.Result( ret )
449 def CheckPKGVersion(context, name, version):
450 context.Message( 'Checking for %s... ' % name )
451 ret = context.TryAction('pkg-config --atleast-version=%s %s' %(version,name) )[0]
452 context.Result( ret )
455 def CheckPKGExists(context, name):
456 context.Message ('Checking for %s...' % name)
457 ret = context.TryAction('pkg-config --exists %s' % name)[0]
461 conf = Configure(env, custom_tests = { 'CheckPKGConfig' : CheckPKGConfig,
462 'CheckPKGVersion' : CheckPKGVersion })
464 # I think a more recent version is needed on win32
465 min_pkg_config_version = '0.8.0'
467 if not conf.CheckPKGConfig(min_pkg_config_version):
468 print 'pkg-config >= %s not found.' % min_pkg_config_version
471 for pkg, version in deps.iteritems():
472 if not conf.CheckPKGVersion( pkg, version ):
473 print '%s >= %s not found.' %(pkg, version)
474 DependenciesRequiredMessage()
479 # ----------------------------------------------------------------------
480 # Construction environment setup
481 # ----------------------------------------------------------------------
485 libraries['core'] = LibraryInfo (CCFLAGS = '-Ilibs')
487 conf = env.Configure (custom_tests = { 'CheckPKGExists' : CheckPKGExists } )
489 if conf.CheckPKGExists ('fftw3f'):
490 libraries['fftw3f'] = LibraryInfo()
491 libraries['fftw3f'].ParseConfig('pkg-config --cflags --libs fftw3f')
493 if conf.CheckPKGExists ('fftw3'):
494 libraries['fftw3'] = LibraryInfo()
495 libraries['fftw3'].ParseConfig('pkg-config --cflags --libs fftw3')
497 if conf.CheckPKGExists ('aubio'):
498 libraries['aubio'] = LibraryInfo()
499 libraries['aubio'].ParseConfig('pkg-config --cflags --libs aubio')
506 if env['FFT_ANALYSIS']:
508 # Check for fftw3 header as well as the library
511 conf = Configure(libraries['fftw3'])
513 if conf.CheckHeader ('fftw3.h') == False:
514 print ('Ardour cannot be compiled without the FFTW3 headers, which do not seem to be installed')
520 # Check for curl header as well as the library
523 libraries['curl'] = LibraryInfo()
525 conf = Configure(libraries['curl'])
527 if conf.CheckHeader ('curl/curl.h') == False:
528 print ('Ardour cannot be compiled without the curl headers, which do not seem to be installed')
531 libraries['curl'].ParseConfig('pkg-config --cflags --libs libcurl')
534 print 'FREESOUND support is not enabled. Build with \'scons FREESOUND=1\' to enable.'
537 conf = env.Configure(custom_tests = { 'CheckPKGVersion' : CheckPKGVersion})
539 if conf.CheckPKGVersion('slv2', '0.6.1'):
540 libraries['slv2'] = LibraryInfo()
541 libraries['slv2'].ParseConfig('pkg-config --cflags --libs slv2')
542 env.Append (CCFLAGS="-DHAVE_LV2")
544 print 'LV2 support is not enabled (SLV2 not found or older than 0.6.0)'
548 print 'LV2 support is not enabled. Build with \'scons LV2=1\' to enable.'
550 if not env['WIIMOTE']:
551 print 'WIIMOTE not enabled. Build with \'scons WIIMOTE=1\' to enable support.'
553 libraries['jack'] = LibraryInfo()
554 libraries['jack'].ParseConfig('pkg-config --cflags --libs jack')
556 libraries['xml'] = LibraryInfo()
557 libraries['xml'].ParseConfig('pkg-config --cflags --libs libxml-2.0')
559 libraries['xslt'] = LibraryInfo()
560 libraries['xslt'].ParseConfig('pkg-config --cflags --libs libxslt')
562 libraries['lrdf'] = LibraryInfo()
563 libraries['lrdf'].ParseConfig('pkg-config --cflags --libs lrdf')
565 libraries['raptor'] = LibraryInfo()
566 libraries['raptor'].ParseConfig('pkg-config --cflags --libs raptor')
568 libraries['samplerate'] = LibraryInfo()
569 libraries['samplerate'].ParseConfig('pkg-config --cflags --libs samplerate')
571 libraries['glib2'] = LibraryInfo()
572 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs glib-2.0')
573 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gobject-2.0')
574 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gmodule-2.0')
575 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gthread-2.0')
577 libraries['freetype2'] = LibraryInfo()
578 libraries['freetype2'].ParseConfig ('pkg-config --cflags --libs freetype2')
580 libraries['gtk2'] = LibraryInfo()
581 libraries['gtk2'].ParseConfig ('pkg-config --cflags --libs gtk+-2.0')
583 libraries['pango'] = LibraryInfo()
584 libraries['pango'].ParseConfig ('pkg-config --cflags --libs pango')
586 libraries['libgnomecanvas2'] = LibraryInfo()
587 libraries['libgnomecanvas2'].ParseConfig ('pkg-config --cflags --libs libgnomecanvas-2.0')
589 #libraries['flowcanvas'] = LibraryInfo(LIBS='flowcanvas', LIBPATH='#/libs/flowcanvas', CPPPATH='#libs/flowcanvas')
591 # The Ardour Control Protocol Library
593 libraries['ardour_cp'] = LibraryInfo (LIBS='ardour_cp', LIBPATH='#libs/surfaces/control_protocol',
594 CPPPATH='#libs/surfaces/control_protocol')
596 # The Ardour backend/engine
598 libraries['ardour'] = LibraryInfo (LIBS='ardour', LIBPATH='#libs/ardour', CPPPATH='#libs/ardour')
599 libraries['midi++2'] = LibraryInfo (LIBS='midi++', LIBPATH='#libs/midi++2', CPPPATH='#libs/midi++2')
600 libraries['pbd'] = LibraryInfo (LIBS='pbd', LIBPATH='#libs/pbd', CPPPATH='#libs/pbd')
601 libraries['gtkmm2ext'] = LibraryInfo (LIBS='gtkmm2ext', LIBPATH='#libs/gtkmm2ext', CPPPATH='#libs/gtkmm2ext')
604 # SCons should really do this for us
606 conf = env.Configure ()
608 have_cxx = conf.TryAction (Action (str(env['CXX']) + ' --version'))
610 print "This system has no functional C++ compiler. You cannot build Ardour from source without one."
613 print "Congratulations, you have a functioning C++ compiler."
619 # Compiler flags and other system-dependent stuff
623 if env['GPROFILE'] == 1:
624 debug_flags = [ '-g', '-pg' ]
626 debug_flags = [ '-g' ]
628 # guess at the platform, used to define compiler flags
630 config_guess = os.popen("tools/config.guess").read()[:-1]
636 config = config_guess.split ("-")
638 print "system triple: " + config_guess
641 if env['DIST_TARGET'] == 'auto':
642 if config[config_arch] == 'apple':
643 # The [.] matches to the dot after the major version, "." would match any character
644 if re.search ("darwin[0-7][.]", config[config_kernel]) != None:
645 env['DIST_TARGET'] = 'panther'
646 if re.search ("darwin8[.]", config[config_kernel]) != None:
647 env['DIST_TARGET'] = 'tiger'
649 env['DIST_TARGET'] = 'leopard'
651 if re.search ("x86_64", config[config_cpu]) != None:
652 env['DIST_TARGET'] = 'x86_64'
653 elif re.search("i[0-5]86", config[config_cpu]) != None:
654 env['DIST_TARGET'] = 'i386'
655 elif re.search("powerpc", config[config_cpu]) != None:
656 env['DIST_TARGET'] = 'powerpc'
658 env['DIST_TARGET'] = 'i686'
659 print "\n*******************************"
660 print "detected DIST_TARGET = " + env['DIST_TARGET']
661 print "*******************************\n"
664 if config[config_cpu] == 'powerpc' and env['DIST_TARGET'] != 'none':
666 # Apple/PowerPC optimization options
668 # -mcpu=7450 does not reliably work with gcc 3.*
670 if env['DIST_TARGET'] == 'panther' or env['DIST_TARGET'] == 'tiger':
671 if config[config_arch] == 'apple':
672 ## opt_flags.extend ([ "-mcpu=7450", "-faltivec"])
673 # to support g3s but still have some optimization for above
674 opt_flags.extend ([ "-mcpu=G3", "-mtune=7450"])
676 opt_flags.extend ([ "-mcpu=7400", "-maltivec", "-mabi=altivec"])
678 opt_flags.extend([ "-mcpu=750", "-mmultiple" ])
679 opt_flags.extend (["-mhard-float", "-mpowerpc-gfxopt"])
680 opt_flags.extend (["-Os"])
682 elif ((re.search ("i[0-9]86", config[config_cpu]) != None) or (re.search ("x86_64", config[config_cpu]) != None)) and env['DIST_TARGET'] != 'none':
684 build_host_supports_sse = 0
687 # ARCH_X86 means anything in the x86 family from i386 to x86_64
688 # USE_X86_64_ASM is used to distingush 32 and 64 bit assembler
691 if (re.search ("(i[0-9]86|x86_64)", config[config_cpu]) != None):
692 debug_flags.append ("-DARCH_X86")
693 opt_flags.append ("-DARCH_X86")
695 if config[config_kernel] == 'linux' :
697 if env['DIST_TARGET'] != 'i386':
699 flag_line = os.popen ("cat /proc/cpuinfo | grep '^flags'").read()[:-1]
700 x86_flags = flag_line.split (": ")[1:][0].split ()
702 if "mmx" in x86_flags:
703 opt_flags.append ("-mmmx")
704 if "sse" in x86_flags:
705 build_host_supports_sse = 1
706 if "3dnow" in x86_flags:
707 opt_flags.append ("-m3dnow")
709 if config[config_cpu] == "i586":
710 opt_flags.append ("-march=i586")
711 elif config[config_cpu] == "i686":
712 opt_flags.append ("-march=i686")
714 if ((env['DIST_TARGET'] == 'i686') or (env['DIST_TARGET'] == 'x86_64')) and build_host_supports_sse:
715 opt_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
716 debug_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
720 # everything must be 32 bit for VST (we're not replicating Cakewalk's hack, yet ...)
722 opt_flags.extend(["-m32"])
723 debug_flags.extend(["-m32"])
725 # end of processor-specific section
727 # optimization section
728 if env['FPU_OPTIMIZATION']:
729 if env['DIST_TARGET'] == 'tiger' or env['DIST_TARGET'] == 'leopard':
730 opt_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
731 debug_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
732 libraries['core'].Append(LINKFLAGS= '-framework Accelerate')
733 elif env['DIST_TARGET'] == 'i686' or env['DIST_TARGET'] == 'x86_64':
734 opt_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
735 debug_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
736 if env['DIST_TARGET'] == 'x86_64' and not env['VST']:
737 opt_flags.append ("-DUSE_X86_64_ASM")
738 debug_flags.append ("-DUSE_X86_64_ASM")
739 if build_host_supports_sse != 1:
740 print "\nWarning: you are building Ardour with SSE support even though your system does not support these instructions. (This may not be anerror, especially if you are a package maintainer)"
741 # end optimization section
743 # handle x86/x86_64 libdir properly
745 if env['DIST_LIBDIR'] == '':
746 if env['DIST_TARGET'] == 'x86_64':
747 env['LIBDIR']='lib64'
751 env['LIBDIR'] = env['DIST_LIBDIR']
757 if env['DIST_TARGET'] == 'x86_64' and env['VST']:
758 print "\n\n=================================================="
759 print "You cannot use VST plugins with a 64 bit host. Please run scons with VST=0"
760 print "\nIt is theoretically possible to build a 32 bit host on a 64 bit system."
761 print "However, this is tricky and not recommended for beginners."
765 # a single way to test if we're on OS X
768 if env['DIST_TARGET'] in ['panther', 'tiger', 'leopard' ]:
770 # force tiger or later, to avoid issues on PPC which defaults
771 # back to 10.1 if we don't tell it otherwise.
772 env.Append (CCFLAGS="-DMAC_OS_X_VERSION_MIN_REQUIRED=1040")
774 if env['DIST_TARGET'] == 'leopard':
775 # need this to really build against the 10.4 SDK when building on leopard
776 # ideally this would be configurable, but lets just do that later when we need it
777 env.Append(CCFLAGS="-mmacosx-version-min=10.4 -isysroot /Developer/SDKs/MacOSX10.4u.sdk")
778 env.Append(LINKFLAGS="-mmacosx-version-min=10.4 -isysroot /Developer/SDKs/MacOSX10.4u.sdk")
784 # save off guessed arch element in an env
786 env.Append(CONFIG_ARCH=config[config_arch])
790 # ARCH="..." overrides all
793 if env['ARCH'] != '':
794 opt_flags = env['ARCH'].split()
797 # prepend boiler plate optimization flags
802 "-fomit-frame-pointer",
808 if env['DEBUG'] == 1:
809 env.Append(CCFLAGS=" ".join (debug_flags))
810 env.Append(LINKFLAGS=" ".join (debug_flags))
812 env.Append(CCFLAGS=" ".join (opt_flags))
813 env.Append(LINKFLAGS=" ".join (opt_flags))
815 if env['STL_DEBUG'] == 1:
816 env.Append(CXXFLAGS="-D_GLIBCXX_DEBUG")
818 if env['UNIVERSAL'] == 1:
819 env.Append(CCFLAGS="-arch i386 -arch ppc")
820 env.Append(LINKFLAGS="-arch i386 -arch ppc")
827 env.Append(CCFLAGS="-Wall")
828 env.Append(CXXFLAGS="-Woverloaded-virtual")
830 if env['EXTRA_WARN']:
831 env.Append(CCFLAGS="-Wextra -pedantic -ansi")
832 env.Append(CXXFLAGS="-ansi")
833 # env.Append(CFLAGS="-iso")
836 env.Append(CCFLAGS="-DHAVE_LIBLO")
840 # fix scons nitpickiness on APPLE
844 def prep_libcheck(topenv, libinfo):
847 # rationale: GTK-Quartz uses jhbuild and installs to ~/gtk/inst by default.
848 # All libraries needed should be built against this location
850 GTKROOT = os.path.expanduser ('~/gtk/inst')
851 libinfo.Append(CPPPATH= GTKROOT + "/include", LIBPATH= GTKROOT + "/lib")
852 libinfo.Append(CXXFLAGS="-I" + GTKROOT + "/include", LINKFLAGS="-L" + GTKROOT + "/lib")
854 prep_libcheck(env, env)
858 # these are part of the Ardour source tree because they are C++
861 libraries['vamp'] = LibraryInfo (LIBS='vampsdk',
862 LIBPATH='#libs/vamp-sdk',
863 CPPPATH='#libs/vamp-sdk')
864 libraries['vamphost'] = LibraryInfo (LIBS='vamphostsdk',
865 LIBPATH='#libs/vamp-sdk',
866 CPPPATH='#libs/vamp-sdk')
868 env['RUBBERBAND'] = False
870 conf = Configure (env)
872 if conf.CheckHeader ('fftw3.h'):
873 env['RUBBERBAND'] = True
874 libraries['rubberband'] = LibraryInfo (LIBS='rubberband',
875 LIBPATH='#libs/rubberband',
876 CPPPATH='#libs/rubberband',
877 CCFLAGS='-DUSE_RUBBERBAND')
880 print "-------------------------------------------------------------------------"
881 print "You do not have the FFTW single-precision development package installed."
882 print "This prevents Ardour from using the Rubberband library for timestretching"
883 print "and pitchshifting. It will fall back on SoundTouch for timestretch, and "
884 print "pitchshifting will not be available."
885 print "-------------------------------------------------------------------------"
893 libraries['usb'] = LibraryInfo ()
894 prep_libcheck(env, libraries['usb'])
896 conf = Configure (libraries['usb'])
897 if conf.CheckLib ('usb', 'usb_interrupt_write'):
902 # check for linux/input.h while we're at it for powermate
903 if conf.CheckHeader('linux/input.h'):
904 have_linux_input = True
906 have_linux_input = False
908 libraries['usb'] = conf.Finish ()
911 # Check for wiimote dependencies
914 wiimoteConf = env.Configure ( )
915 if not wiimoteConf.CheckHeader('cwiid.h'):
916 print 'WIIMOTE configured but you are missing libcwiid!'
918 if not wiimoteConf.CheckHeader('bluetooth/bluetooth.h'):
919 print 'WIIMOTE configured but you are missing the libbluetooth headers which you need to compile wiimote support!'
927 libraries['flac'] = LibraryInfo ()
928 prep_libcheck(env, libraries['flac'])
929 libraries['flac'].Append(CPPPATH="/usr/local/include", LIBPATH="/usr/local/lib")
932 # june 1st 2007: look for a function that is in FLAC 1.1.2 and not in later versions
933 # since the version of libsndfile we have internally does not support
934 # the new API that libFLAC has adopted
937 conf = Configure (libraries['flac'])
938 if conf.CheckLib ('FLAC', 'FLAC__seekable_stream_decoder_init', language='CXX'):
939 conf.env.Append(CCFLAGS='-DHAVE_FLAC')
944 libraries['flac'] = conf.Finish ()
946 # or if that fails...
947 #libraries['flac'] = LibraryInfo (LIBS='FLAC')
949 # boost (we don't link against boost, just use some header files)
951 libraries['boost'] = LibraryInfo ()
952 prep_libcheck(env, libraries['boost'])
953 libraries['boost'].Append(CPPPATH="/usr/local/include", LIBPATH="/usr/local/lib")
954 conf = Configure (libraries['boost'])
955 if conf.CheckHeader ('boost/shared_ptr.hpp', language='CXX') == False:
956 print "Boost header files do not appear to be installed. You also might be running a buggy version of scons. Try scons 0.97 if you can."
959 libraries['boost'] = conf.Finish ()
965 libraries['lo'] = LibraryInfo ()
966 prep_libcheck(env, libraries['lo'])
968 conf = Configure (libraries['lo'])
969 if conf.CheckLib ('lo', 'lo_server_new') == False:
970 print "liblo does not appear to be installed."
973 libraries['lo'] = conf.Finish ()
978 libraries['dmalloc'] = LibraryInfo ()
979 prep_libcheck(env, libraries['dmalloc'])
982 # look for the threaded version
985 conf = Configure (libraries['dmalloc'])
986 if conf.CheckLib ('dmallocth', 'dmalloc_shutdown'):
987 have_libdmalloc = True
989 have_libdmalloc = False
991 libraries['dmalloc'] = conf.Finish ()
994 # ensure FREEDESKTOP target is doable..
997 conf = env.Configure ()
998 if env['FREEDESKTOP']:
999 have_update_mime_database = conf.TryAction (Action ('update-mime-database -v'))
1000 if have_update_mime_database[0] != 1:
1001 print "Warning. You have no update-mime-database command in your PATH. FREEDESKTOP is now disabled."
1002 env['FREEDESKTOP'] = 0
1003 have_gtk_update_icon_cache = conf.TryAction (Action ('gtk-update-icon-cache -?'))
1004 if have_gtk_update_icon_cache[0] != 1:
1005 print "Warning. You have no gtk-update-icon-cache command in your PATH. FREEDESKTOP is now disabled."
1006 env['FREEDESKTOP'] = 0
1007 have_update_desktop_database = conf.TryAction (Action ('update-desktop-database -?'))
1008 if have_update_desktop_database[0] != 1:
1009 print "Warning. You have no update-desktop-database command in your PATH. FREEDESKTOP is now disabled."
1010 env['FREEDESKTOP'] = 0
1014 # Audio/MIDI library (needed for MIDI, since audio is all handled via JACK)
1017 conf = Configure(env)
1019 if conf.CheckCHeader('alsa/asoundlib.h'):
1020 libraries['sysmidi'] = LibraryInfo (LIBS='asound')
1021 env['SYSMIDI'] = 'ALSA Sequencer'
1022 subst_dict['%MIDITAG%'] = "seq"
1023 subst_dict['%MIDITYPE%'] = "alsa/sequencer"
1024 elif conf.CheckCHeader('/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h'):
1025 # this line is needed because scons can't handle -framework in ParseConfig() yet.
1027 # We need Carbon as well as the rest
1028 libraries['sysmidi'] = LibraryInfo (
1029 LINKFLAGS = ' -framework CoreMIDI -framework CoreFoundation -framework CoreAudio -framework CoreServices -framework AudioUnit -framework AudioToolbox -framework Carbon -bind_at_load' )
1031 libraries['sysmidi'] = LibraryInfo (
1032 LINKFLAGS = ' -framework CoreMIDI -framework CoreFoundation -framework CoreAudio -framework CoreServices -framework AudioUnit -framework AudioToolbox -bind_at_load' )
1033 env['SYSMIDI'] = 'CoreMIDI'
1034 subst_dict['%MIDITAG%'] = "ardour"
1035 subst_dict['%MIDITYPE%'] = "coremidi"
1037 print "It appears you don't have the required MIDI libraries installed. For Linux this means you are missing the development package for ALSA libraries."
1043 clearlooks_version = 'libs/clearlooks-newer'
1045 clearlooks_version = 'libs/clearlooks-older'
1051 'sigc++-2.0' : '2.0',
1052 'gtkmm-2.4' : '2.8',
1053 'libgnomecanvasmm-2.6' : '2.12.0'
1056 conf = Configure(env, custom_tests = { 'CheckPKGConfig' : CheckPKGConfig,
1057 'CheckPKGVersion' : CheckPKGVersion })
1059 for pkg, version in syslibdeps.iteritems():
1060 if not conf.CheckPKGVersion( pkg, version ):
1061 print '%s >= %s not found.' %(pkg, version)
1062 DependenciesRequiredMessage()
1067 libraries['sigc2'] = LibraryInfo()
1068 libraries['sigc2'].ParseConfig('pkg-config --cflags --libs sigc++-2.0')
1069 libraries['glibmm2'] = LibraryInfo()
1070 libraries['glibmm2'].ParseConfig('pkg-config --cflags --libs glibmm-2.4')
1071 libraries['cairomm'] = LibraryInfo()
1072 libraries['cairomm'].ParseConfig('pkg-config --cflags --libs cairomm-1.0')
1073 libraries['gdkmm2'] = LibraryInfo()
1074 libraries['gdkmm2'].ParseConfig ('pkg-config --cflags --libs gdkmm-2.4')
1075 libraries['gtkmm2'] = LibraryInfo()
1076 libraries['gtkmm2'].ParseConfig ('pkg-config --cflags --libs gtkmm-2.4')
1077 libraries['atkmm'] = LibraryInfo()
1078 libraries['atkmm'].ParseConfig ('pkg-config --cflags --libs atkmm-1.6')
1079 libraries['pangomm'] = LibraryInfo()
1080 libraries['pangomm'].ParseConfig ('pkg-config --cflags --libs pangomm-1.4')
1081 libraries['libgnomecanvasmm'] = LibraryInfo()
1082 libraries['libgnomecanvasmm'].ParseConfig ('pkg-config --cflags --libs libgnomecanvasmm-2.6')
1085 # cannot use system one for the time being
1088 libraries['sndfile-ardour'] = LibraryInfo(LIBS='libsndfile-ardour',
1089 LIBPATH='#libs/libsndfile',
1090 CPPPATH=['#libs/libsndfile/src'])
1092 # libraries['libglademm'] = LibraryInfo()
1093 # libraries['libglademm'].ParseConfig ('pkg-config --cflags --libs libglademm-2.4')
1095 # libraries['flowcanvas'] = LibraryInfo(LIBS='flowcanvas', LIBPATH='#/libs/flowcanvas', CPPPATH='#libs/flowcanvas')
1096 libraries['soundtouch'] = LibraryInfo()
1097 libraries['soundtouch'].ParseConfig ('pkg-config --cflags --libs soundtouch-1.0')
1098 # Comment the previous line and uncomment this for old versions of Debian:
1099 #libraries['soundtouch'].ParseConfig ('pkg-config --cflags --libs libSoundTouch')
1101 libraries['appleutility'] = LibraryInfo(LIBS='libappleutility',
1102 LIBPATH='#libs/appleutility',
1103 CPPPATH='#libs/appleutility')
1116 'libs/vamp-plugins/',
1117 # these are unconditionally included but have
1118 # tests internally to avoid compilation etc
1122 # this is unconditionally included but has
1123 # tests internally to avoid compilation etc
1124 # if COREAUDIO is not set
1129 # 'libs/flowcanvas',
1136 libraries['sigc2'] = LibraryInfo(LIBS='sigc++2',
1137 LIBPATH='#libs/sigc++2',
1138 CPPPATH='#libs/sigc++2')
1139 libraries['glibmm2'] = LibraryInfo(LIBS='glibmm2',
1140 LIBPATH='#libs/glibmm2',
1141 CPPPATH='#libs/glibmm2')
1142 libraries['pangomm'] = LibraryInfo(LIBS='pangomm',
1143 LIBPATH='#libs/gtkmm2/pango',
1144 CPPPATH='#libs/gtkmm2/pango')
1145 libraries['cairomm'] = LibraryInfo(LIBS='cairomm',
1146 LIBPATH='#libs/cairomm',
1147 CPPPATH='#libs/cairomm')
1148 libraries['atkmm'] = LibraryInfo(LIBS='atkmm',
1149 LIBPATH='#libs/gtkmm2/atk',
1150 CPPPATH='#libs/gtkmm2/atk')
1151 libraries['gdkmm2'] = LibraryInfo(LIBS='gdkmm2',
1152 LIBPATH='#libs/gtkmm2/gdk',
1153 CPPPATH='#libs/gtkmm2/gdk')
1154 libraries['gtkmm2'] = LibraryInfo(LIBS='gtkmm2',
1155 LIBPATH="#libs/gtkmm2/gtk",
1156 CPPPATH='#libs/gtkmm2/gtk/')
1157 libraries['libgnomecanvasmm'] = LibraryInfo(LIBS='libgnomecanvasmm',
1158 LIBPATH='#libs/libgnomecanvasmm',
1159 CPPPATH='#libs/libgnomecanvasmm')
1161 libraries['soundtouch'] = LibraryInfo(LIBS='soundtouch',
1162 LIBPATH='#libs/soundtouch',
1163 CPPPATH=['#libs', '#libs/soundtouch'])
1164 libraries['sndfile-ardour'] = LibraryInfo(LIBS='libsndfile-ardour',
1165 LIBPATH='#libs/libsndfile',
1166 CPPPATH=['#libs/libsndfile', '#libs/libsndfile/src'])
1167 # libraries['libglademm'] = LibraryInfo(LIBS='libglademm',
1168 # LIBPATH='#libs/libglademm',
1169 # CPPPATH='#libs/libglademm')
1170 libraries['appleutility'] = LibraryInfo(LIBS='libappleutility',
1171 LIBPATH='#libs/appleutility',
1172 CPPPATH='#libs/appleutility')
1186 'libs/vamp-plugins/',
1187 # these are unconditionally included but have
1188 # tests internally to avoid compilation etc
1192 # this is unconditionally included but has
1193 # tests internally to avoid compilation etc
1194 # if COREAUDIO is not set
1200 'libs/gtkmm2/pango',
1204 'libs/libgnomecanvasmm',
1211 # * always build the LGPL control protocol lib, since we link against it from libardour
1212 # * ditto for generic MIDI
1213 # * tranzport & wiimote check whether they should build internally, but we need them here
1214 # so that they are included in the tarball
1217 surface_subdirs = [ 'libs/surfaces/control_protocol',
1218 'libs/surfaces/generic_midi',
1219 'libs/surfaces/tranzport',
1220 'libs/surfaces/mackie',
1221 'libs/surfaces/powermate',
1222 'libs/surfaces/wiimote'
1227 env['TRANZPORT'] = 1
1229 env['TRANZPORT'] = 0
1230 print 'Disabled building Tranzport code because libusb could not be found'
1232 if have_linux_input:
1233 env['POWERMATE'] = 1
1235 env['POWERMATE'] = 0
1236 print 'Disabled building Powermate code because linux/input.h could not be found'
1238 if os.access ('libs/surfaces/sony9pin', os.F_OK):
1239 surface_subdirs += [ 'libs/surfaces/sony9pin' ]
1241 env['POWERMATE'] = 0
1242 env['TRANZPORT'] = 0
1245 # timestretch libraries
1248 timefx_subdirs = ['libs/soundtouch']
1249 if env['RUBBERBAND']:
1250 timefx_subdirs += ['libs/rubberband']
1252 opts.Save('scache.conf', env)
1253 Help(opts.GenerateHelpText(env))
1255 final_prefix = '$PREFIX'
1258 install_prefix = '$DESTDIR/$PREFIX'
1260 install_prefix = env['PREFIX']
1262 subst_dict['%INSTALL_PREFIX%'] = install_prefix;
1263 subst_dict['%FINAL_PREFIX%'] = final_prefix;
1264 subst_dict['%PREFIX%'] = final_prefix;
1266 if env['PREFIX'] == '/usr':
1267 final_config_prefix = '/etc'
1269 final_config_prefix = env['PREFIX'] + '/etc'
1271 config_prefix = '$DESTDIR' + final_config_prefix
1274 # everybody needs this
1277 env.Merge ([ libraries['core'] ])
1284 conf = Configure (env)
1286 nls_error = 'This system is not configured for internationalized applications. An english-only version will be built:'
1287 print 'Checking for internationalization support ...'
1288 have_gettext = conf.TryAction(Action('xgettext --version'))
1289 if have_gettext[0] != 1:
1290 nls_error += ' No xgettext command.'
1293 print "Found xgettext"
1295 have_msgmerge = conf.TryAction(Action('msgmerge --version'))
1296 if have_msgmerge[0] != 1:
1297 nls_error += ' No msgmerge command.'
1300 print "Found msgmerge"
1302 if not conf.CheckCHeader('libintl.h'):
1303 nls_error += ' No libintl.h.'
1309 print "International version will be built."
1313 env.Append(CCFLAGS="-DENABLE_NLS")
1315 Export('env install_prefix final_prefix config_prefix final_config_prefix libraries i18n ardour_version subst_dict use_flac')
1318 # the configuration file may be system dependent
1321 conf = env.Configure ()
1323 if conf.CheckCHeader('/System/Library/Frameworks/CoreAudio.framework/Versions/A/Headers/CoreAudio.h'):
1324 subst_dict['%JACK_INPUT%'] = "coreaudio:Built-in Audio:in"
1325 subst_dict['%JACK_OUTPUT%'] = "coreaudio:Built-in Audio:out"
1327 subst_dict['%JACK_INPUT%'] = "alsa_pcm:playback_"
1328 subst_dict['%JACK_OUTPUT%'] = "alsa_pcm:capture_"
1330 # posix_memalign available
1331 if not conf.CheckFunc('posix_memalign'):
1332 print 'Did not find posix_memalign(), using malloc'
1333 env.Append(CCFLAGS='-DNO_POSIX_MEMALIGN')
1338 # Which GTK tooltips API
1340 gtktestenv = env.Clone ()
1345 conf = gtktestenv.Configure ()
1347 if conf.CheckFunc('gtk_widget_set_tooltip_text'):
1348 env.Append (CXXFLAGS='-DGTK_NEW_TOOLTIP_API')
1353 # generate the per-user and system rc files from the same source
1355 sysrcbuild = env.SubstInFile ('ardour_system.rc','ardour.rc.in', SUBST_DICT = subst_dict)
1357 # add to the substitution dictionary
1359 subst_dict['%VERSION%'] = ardour_version[0:3]
1360 subst_dict['%EXTRA_VERSION%'] = ardour_version[3:]
1361 subst_dict['%REVISION_STRING%'] = ''
1362 if os.path.exists('.svn'):
1363 subst_dict['%REVISION_STRING%'] = '.' + fetch_svn_revision ('.') + 'svn'
1365 # specbuild = env.SubstInFile ('ardour.spec','ardour.spec.in', SUBST_DICT = subst_dict)
1367 the_revision = env.Command ('frobnicatory_decoy', [], create_stored_revision)
1368 remove_ardour = env.Command ('frobnicatory_decoy2', [],
1369 [ Delete ('$PREFIX/etc/ardour2'),
1370 Delete ('$PREFIX/lib/ardour2'),
1371 Delete ('$PREFIX/bin/ardour2'),
1372 Delete ('$PREFIX/share/ardour2')])
1374 env.Alias('revision', the_revision)
1375 env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour2'), 'ardour_system.rc'))
1376 env.Alias('uninstall', remove_ardour)
1378 Default (sysrcbuild)
1382 Precious (env['DISTTREE'])
1384 env.Distribute (env['DISTTREE'],
1386 'COPYING', 'PACKAGER_README', 'README',
1388 'tools/config.guess',
1389 'icons/icon/ardour_icon_mac_mask.png',
1390 'icons/icon/ardour_icon_mac.png',
1391 'icons/icon/ardour_icon_tango_16px_blue.png',
1392 'icons/icon/ardour_icon_tango_16px_red.png',
1393 'icons/icon/ardour_icon_tango_22px_blue.png',
1394 'icons/icon/ardour_icon_tango_22px_red.png',
1395 'icons/icon/ardour_icon_tango_32px_blue.png',
1396 'icons/icon/ardour_icon_tango_32px_red.png',
1397 'icons/icon/ardour_icon_tango_48px_blue.png',
1398 'icons/icon/ardour_icon_tango_48px_red.png'
1400 glob.glob ('ardour.1*') +
1401 glob.glob ('libs/clearlooks-newer/*.c') +
1402 glob.glob ('libs/clearlooks-newer/*.h') +
1403 glob.glob ('libs/clearlooks-newer/SConscript')
1406 srcdist = env.Tarball(env['TARBALL'], [ env['DISTTREE'], the_revision ])
1407 env.Alias ('srctar', srcdist)
1410 # don't leave the distree around
1413 env.AddPreAction (env['DISTTREE'], Action ('rm -rf ' + str (File (env['DISTTREE']))))
1414 env.AddPostAction (srcdist, Action ('rm -rf ' + str (File (env['DISTTREE']))))
1417 # Update revision info before going into subdirs
1420 create_stored_revision()
1426 for subdir in coredirs:
1427 SConscript (subdir + '/SConscript')
1429 for sublistdir in [ subdirs, timefx_subdirs, gtk_subdirs, surface_subdirs ]:
1430 for subdir in sublistdir:
1431 SConscript (subdir + '/SConscript')
1434 env.Clean ('scrub', [ 'scache.conf', '.sconf_temp', '.sconsign.dblite', 'config.log'])