4 # and there we have it, or do we?
22 EnsureSConsVersion(0, 96)
24 ardour_version = '3.0'
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'),
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('SYSLIBS', 'USE AT YOUR OWN RISK: CANCELS ALL SUPPORT FROM ARDOUR AUTHORS: Use existing system versions of various libraries instead of internal ones', 0),
54 BoolOption('UNIVERSAL', 'Compile as universal binary. Requires that external libraries are already universal.', 0),
55 BoolOption('VERSIONED', 'Add revision information to ardour/gtk executable name inside the build directory', 0),
56 BoolOption('VST', 'Compile with support for VST', 0),
57 BoolOption('LV2', 'Compile with support for LV2 (if slv2 is available)', 1),
58 BoolOption('GPROFILE', 'Compile with support for gprofile (Developers only)', 0),
59 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),
60 BoolOption('TRANZPORT', 'Compile with support for Frontier Designs (if libusb is available)', 1),
61 BoolOption('AUBIO', "Use Paul Brossier's aubio library for feature detection (if available)", 1)
64 #----------------------------------------------------------------------
65 # a handy helper that provides a way to merge compile/link information
66 # from multiple different "environments"
67 #----------------------------------------------------------------------
69 class LibraryInfo(Environment):
70 def __init__(self,*args,**kw):
71 Environment.__init__ (self,*args,**kw)
73 def Merge (self,others):
75 self.Append (LIBS = other.get ('LIBS',[]))
76 self.Append (LIBPATH = other.get ('LIBPATH', []))
77 self.Append (CPPPATH = other.get('CPPPATH', []))
78 self.Append (LINKFLAGS = other.get('LINKFLAGS', []))
79 self.Append (CCFLAGS = other.get('CCFLAGS', []))
80 self.Replace(LIBPATH = list(Set(self.get('LIBPATH', []))))
81 self.Replace(CPPPATH = list(Set(self.get('CPPPATH',[]))))
82 #doing LINKFLAGS breaks -framework
83 #doing LIBS break link order dependency
85 def ENV_update(self, src_ENV):
86 for k in src_ENV.keys():
87 if k in self['ENV'].keys() and k in [ 'PATH', 'LD_LIBRARY_PATH',
89 self['ENV'][k]=SCons.Util.AppendPath(self['ENV'][k], src_ENV[k])
91 self['ENV'][k]=src_ENV[k]
93 env = LibraryInfo (options = opts,
95 VERSION = ardour_version,
96 TARBALL='ardour-' + ardour_version + '.tar.bz2',
98 DISTTREE = '#ardour-' + ardour_version,
99 DISTCHECKDIR = '#ardour-' + ardour_version + '/check'
102 env.ENV_update(os.environ)
104 #----------------------------------------------------------------------
106 #----------------------------------------------------------------------
108 # Handy subst-in-file builder
111 def do_subst_in_file(targetfile, sourcefile, dict):
112 """Replace all instances of the keys of dict with their values.
113 For example, if dict is {'%VERSION%': '1.2345', '%BASE%': 'MyProg'},
114 then all instances of %VERSION% in the file will be replaced with 1.2345 etc.
117 f = open(sourcefile, 'rb')
121 raise SCons.Errors.UserError, "Can't read source file %s"%sourcefile
122 for (k,v) in dict.items():
123 contents = re.sub(k, v, contents)
125 f = open(targetfile, 'wb')
129 raise SCons.Errors.UserError, "Can't write target file %s"%targetfile
132 def subst_in_file(target, source, env):
133 if not env.has_key('SUBST_DICT'):
134 raise SCons.Errors.UserError, "SubstInFile requires SUBST_DICT to be set."
135 d = dict(env['SUBST_DICT']) # copy it
136 for (k,v) in d.items():
138 d[k] = env.subst(v())
139 elif SCons.Util.is_String(v):
142 raise SCons.Errors.UserError, "SubstInFile: key %s: %s must be a string or callable"%(k, repr(v))
143 for (t,s) in zip(target, source):
144 return do_subst_in_file(str(t), str(s), d)
146 def subst_in_file_string(target, source, env):
147 """This is what gets printed on the console."""
148 return '\n'.join(['Substituting vars from %s into %s'%(str(s), str(t))
149 for (t,s) in zip(target, source)])
151 def subst_emitter(target, source, env):
152 """Add dependency from substituted SUBST_DICT to target.
153 Returns original target, source tuple unchanged.
155 d = env['SUBST_DICT'].copy() # copy it
156 for (k,v) in d.items():
158 d[k] = env.subst(v())
159 elif SCons.Util.is_String(v):
161 Depends(target, SCons.Node.Python.Value(d))
162 # Depends(target, source) # this doesn't help the install-sapphire-linux.sh problem
163 return target, source
165 subst_action = Action (subst_in_file, subst_in_file_string)
166 env['BUILDERS']['SubstInFile'] = Builder(action=subst_action, emitter=subst_emitter)
169 # internationalization
172 # po_builder: builder function to copy po files to the parent directory while updating them
174 # first source: .po file
175 # second source: .pot file
178 def po_builder(target,source,env):
179 os.spawnvp (os.P_WAIT, 'cp', ['cp', str(source[0]), str(target[0])])
185 print 'Updating ' + str(target[0])
186 return os.spawnvp (os.P_WAIT, 'msgmerge', args)
188 po_bld = Builder (action = po_builder)
189 env.Append(BUILDERS = {'PoBuild' : po_bld})
191 # mo_builder: builder function for (binary) message catalogs (.mo)
193 # first source: .po file
196 def mo_builder(target,source,env):
200 target[0].get_path(),
203 return os.spawnvp (os.P_WAIT, 'msgfmt', args)
205 mo_bld = Builder (action = mo_builder)
206 env.Append(BUILDERS = {'MoBuild' : mo_bld})
208 # pot_builder: builder function for message templates (.pot)
210 # source: list of C/C++ etc. files to extract messages from
213 def pot_builder(target,source,env):
218 '-o', target[0].get_path(),
219 "--default-domain=" + env['PACKAGE'],
220 '--copyright-holder="Paul Davis"' ]
221 args += [ src.get_path() for src in source ]
223 return os.spawnvp (os.P_WAIT, 'xgettext', args)
225 pot_bld = Builder (action = pot_builder)
226 env.Append(BUILDERS = {'PotBuild' : pot_bld})
229 # utility function, not a builder
232 def i18n (buildenv, sources, installenv):
233 domain = buildenv['PACKAGE']
234 potfile = buildenv['POTFILE']
236 installenv.Alias ('potupdate', buildenv.PotBuild (potfile, sources))
238 p_oze = [ os.path.basename (po) for po in glob.glob ('po/*.po') ]
239 languages = [ po.replace ('.po', '') for po in p_oze ]
241 for po_file in p_oze:
242 buildenv.PoBuild(po_file, ['po/'+po_file, potfile])
243 mo_file = po_file.replace (".po", ".mo")
244 installenv.Alias ('install', buildenv.MoBuild (mo_file, po_file))
245 installenv.Alias ('msgupdate', buildenv.MoBuild (mo_file, po_file))
247 for lang in languages:
248 modir = (os.path.join (install_prefix, 'share/locale/' + lang + '/LC_MESSAGES/'))
249 moname = domain + '.mo'
250 installenv.Alias('install', installenv.InstallAs (os.path.join (modir, moname), lang + '.mo'))
253 def fetch_svn_revision (path):
257 cmd += " | awk '/^Revision:/ { print $2}'"
258 return commands.getoutput (cmd)
260 def create_stored_revision (target = None, source = None, env = None):
261 if os.path.exists('.svn'):
262 rev = fetch_svn_revision ('.');
264 text = "#ifndef __ardour_svn_revision_h__\n"
265 text += "#define __ardour_svn_revision_h__\n"
266 text += "static const char* ardour_svn_revision = \"" + rev + "\";\n";
268 print '============> writing svn revision info to svn_revision.h\n'
269 o = file ('svn_revision.h', 'w')
273 print "Could not open svn_revision.h for writing\n"
276 print "You cannot use \"scons revision\" on without using a checked out"
277 print "copy of the Ardour source code repository"
281 # A generic builder for version.cc files
283 # note: requires that DOMAIN, MAJOR, MINOR, MICRO are set in the construction environment
284 # note: assumes one source files, the header that declares the version variables
287 def version_builder (target, source, env):
289 text = "int " + env['DOMAIN'] + "_major_version = " + str (env['MAJOR']) + ";\n"
290 text += "int " + env['DOMAIN'] + "_minor_version = " + str (env['MINOR']) + ";\n"
291 text += "int " + env['DOMAIN'] + "_micro_version = " + str (env['MICRO']) + ";\n"
294 o = file (target[0].get_path(), 'w')
298 print "Could not open", target[0].get_path(), " for writing\n"
301 text = "#ifndef __" + env['DOMAIN'] + "_version_h__\n"
302 text += "#define __" + env['DOMAIN'] + "_version_h__\n"
303 text += "extern const char* " + env['DOMAIN'] + "_revision;\n"
304 text += "extern int " + env['DOMAIN'] + "_major_version;\n"
305 text += "extern int " + env['DOMAIN'] + "_minor_version;\n"
306 text += "extern int " + env['DOMAIN'] + "_micro_version;\n"
307 text += "#endif /* __" + env['DOMAIN'] + "_version_h__ */\n"
310 o = file (target[1].get_path(), 'w')
314 print "Could not open", target[1].get_path(), " for writing\n"
319 version_bld = Builder (action = version_builder)
320 env.Append (BUILDERS = {'VersionBuild' : version_bld})
323 # a builder that makes a hard link from the 'source' executable to a name with
324 # a "build ID" based on the most recent CVS activity that might be reasonably
325 # related to version activity. this relies on the idea that the SConscript
326 # file that builds the executable is updated with new version info and committed
327 # to the source code repository whenever things change.
330 def versioned_builder(target,source,env):
331 w, r = os.popen2( "LANG= svn info | awk '/^Revision:/ { print $2}'")
333 last_revision = r.readline().strip()
336 if last_revision == "":
337 print "No SVN info found - versioned executable cannot be built"
340 print "The current build ID is " + last_revision
342 tagged_executable = source[0].get_path() + '-' + last_revision
344 if os.path.exists (tagged_executable):
345 print "Replacing existing executable with the same build tag."
346 os.unlink (tagged_executable)
348 return os.link (source[0].get_path(), tagged_executable)
350 verbuild = Builder (action = versioned_builder)
351 env.Append (BUILDERS = {'VersionedExecutable' : verbuild})
354 # source tar file builder
357 def distcopy (target, source, env):
358 treedir = str (target[0])
362 except OSError, (errnum, strerror):
363 if errnum != errno.EEXIST:
364 print 'mkdir ', treedir, ':', strerror
368 # we don't know what characters might be in the file names
369 # so quote them all before passing them to the shell
371 all_files = ([ str(s) for s in source ])
372 cmd += " ".join ([ "'%s'" % quoted for quoted in all_files])
373 cmd += ' | (cd ' + treedir + ' && tar xf -)'
377 def tarballer (target, source, env):
378 cmd = 'tar -jcf ' + str (target[0]) + ' ' + str(source[0]) + " --exclude '*~'" + " --exclude .svn --exclude '.svn/*'"
379 print 'running ', cmd, ' ... '
383 dist_bld = Builder (action = distcopy,
384 target_factory = SCons.Node.FS.default_fs.Entry,
385 source_factory = SCons.Node.FS.default_fs.Entry,
388 tarball_bld = Builder (action = tarballer,
389 target_factory = SCons.Node.FS.default_fs.Entry,
390 source_factory = SCons.Node.FS.default_fs.Entry)
392 env.Append (BUILDERS = {'Distribute' : dist_bld})
393 env.Append (BUILDERS = {'Tarball' : tarball_bld})
396 # Make sure they know what they are doing
400 if os.path.isfile('.personal_use_only'):
401 print "Enabling VST support. Note that distributing a VST-enabled ardour\nis a violation of several different licences.\nBuild with VST=false if you intend to distribute ardour to others."
403 sys.stdout.write ("Are you building Ardour for personal use (rather than distribution to others)? [no]: ")
404 answer = sys.stdin.readline ()
405 answer = answer.rstrip().strip()
406 if answer == "yes" or answer == "y":
407 fh = open('.personal_use_only', 'w')
409 print "OK, VST support will be enabled"
411 print 'You cannot build Ardour with VST support for distribution to others.\nIt is a violation of several different licenses. Build with VST=false.'
414 if os.path.isfile('.personal_use_only'):
415 os.remove('.personal_use_only')
421 def pushEnvironment(context):
422 if os.environ.has_key('PATH'):
423 context.Append(PATH = os.environ['PATH'])
425 if os.environ.has_key('PKG_CONFIG_PATH'):
426 context.Append(PKG_CONFIG_PATH = os.environ['PKG_CONFIG_PATH'])
428 if os.environ.has_key('CC'):
429 context['CC'] = os.environ['CC']
431 if os.environ.has_key('CXX'):
432 context['CXX'] = os.environ['CXX']
434 if os.environ.has_key('DISTCC_HOSTS'):
435 context['ENV']['DISTCC_HOSTS'] = os.environ['DISTCC_HOSTS']
436 context['ENV']['HOME'] = os.environ['HOME']
438 pushEnvironment (env)
440 #######################
441 # Dependency Checking #
442 #######################
446 'glib-2.0' : '2.10.1',
447 'gthread-2.0' : '2.10.1',
448 'gtk+-2.0' : '2.8.1',
449 'libxml-2.0' : '2.6.0',
450 'samplerate' : '0.1.0',
454 'libgnomecanvas-2.0' : '2.0',
458 def DependenciesRequiredMessage():
459 print 'You do not have the necessary dependencies required to build ardour'
460 print 'Please consult http://ardour.org/building for more information'
462 def CheckPKGConfig(context, version):
463 context.Message( 'Checking for pkg-config version >= %s... ' %version )
464 ret = context.TryAction('pkg-config --atleast-pkgconfig-version=%s' % version)[0]
465 context.Result( ret )
468 def CheckPKGVersion(context, name, version):
469 context.Message( 'Checking for %s... ' % name )
470 ret = context.TryAction('pkg-config --atleast-version=%s %s' %(version,name) )[0]
471 context.Result( ret )
474 def CheckPKGExists(context, name):
475 context.Message ('Checking for %s...' % name)
476 ret = context.TryAction('pkg-config --exists %s' % name)[0]
480 conf = Configure(env, custom_tests = { 'CheckPKGConfig' : CheckPKGConfig,
481 'CheckPKGVersion' : CheckPKGVersion })
483 # I think a more recent version is needed on win32
484 min_pkg_config_version = '0.8.0'
486 if not conf.CheckPKGConfig(min_pkg_config_version):
487 print 'pkg-config >= %s not found.' % min_pkg_config_version
490 for pkg, version in deps.iteritems():
491 if not conf.CheckPKGVersion( pkg, version ):
492 print '%s >= %s not found.' %(pkg, version)
493 DependenciesRequiredMessage()
498 # ----------------------------------------------------------------------
499 # Construction environment setup
500 # ----------------------------------------------------------------------
504 libraries['core'] = LibraryInfo (CCFLAGS = '-Ilibs')
506 #libraries['sndfile'] = LibraryInfo()
507 #libraries['sndfile'].ParseConfig('pkg-config --cflags --libs sndfile')
509 libraries['lrdf'] = LibraryInfo()
510 libraries['lrdf'].ParseConfig('pkg-config --cflags --libs lrdf')
512 libraries['raptor'] = LibraryInfo()
513 libraries['raptor'].ParseConfig('pkg-config --cflags --libs raptor')
515 libraries['samplerate'] = LibraryInfo()
516 libraries['samplerate'].ParseConfig('pkg-config --cflags --libs samplerate')
518 conf = env.Configure (custom_tests = { 'CheckPKGExists' : CheckPKGExists } )
520 if conf.CheckPKGExists ('fftw3f'):
521 libraries['fftw3f'] = LibraryInfo()
522 libraries['fftw3f'].ParseConfig('pkg-config --cflags --libs fftw3f')
524 if conf.CheckPKGExists ('fftw3'):
525 libraries['fftw3'] = LibraryInfo()
526 libraries['fftw3'].ParseConfig('pkg-config --cflags --libs fftw3')
528 if conf.CheckPKGExists ('aubio'):
529 libraries['aubio'] = LibraryInfo()
530 libraries['aubio'].ParseConfig('pkg-config --cflags --libs aubio')
537 if env['FFT_ANALYSIS']:
539 # Check for fftw3 header as well as the library
542 conf = Configure(libraries['fftw3'])
544 if conf.CheckHeader ('fftw3.h') == False:
545 print ('Ardour cannot be compiled without the FFTW3 headers, which do not seem to be installed')
551 # Check for curl header as well as the library
554 libraries['curl'] = LibraryInfo()
556 conf = Configure(libraries['curl'])
558 if conf.CheckHeader ('curl/curl.h') == False:
559 print ('Ardour cannot be compiled without the curl headers, which do not seem to be installed')
562 libraries['curl'].ParseConfig('pkg-config --cflags --libs libcurl')
565 print 'FREESOUND support is not enabled. Build with \'scons FREESOUND=1\' to enable.'
568 conf = env.Configure(custom_tests = { 'CheckPKGVersion' : CheckPKGVersion})
570 if conf.CheckPKGVersion('slv2', '0.6.0'):
571 libraries['slv2'] = LibraryInfo()
572 libraries['slv2'].ParseConfig('pkg-config --cflags --libs slv2')
573 env.Append (CCFLAGS="-DHAVE_LV2")
575 print 'LV2 support is not enabled (SLV2 not found or older than 0.6.0)'
579 print 'LV2 support is not enabled. Build with \'scons LV2=1\' to enable.'
581 libraries['jack'] = LibraryInfo()
582 libraries['jack'].ParseConfig('pkg-config --cflags --libs jack')
584 libraries['xml'] = LibraryInfo()
585 libraries['xml'].ParseConfig('pkg-config --cflags --libs libxml-2.0')
587 libraries['xslt'] = LibraryInfo()
588 libraries['xslt'].ParseConfig('pkg-config --cflags --libs libxslt')
590 libraries['glib2'] = LibraryInfo()
591 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs glib-2.0')
592 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gobject-2.0')
593 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gmodule-2.0')
594 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gthread-2.0')
596 libraries['freetype2'] = LibraryInfo()
597 libraries['freetype2'].ParseConfig ('pkg-config --cflags --libs freetype2')
599 libraries['gtk2'] = LibraryInfo()
600 libraries['gtk2'].ParseConfig ('pkg-config --cflags --libs gtk+-2.0')
602 libraries['pango'] = LibraryInfo()
603 libraries['pango'].ParseConfig ('pkg-config --cflags --libs pango')
605 libraries['pangocairo'] = LibraryInfo()
606 libraries['pangocairo'].ParseConfig ('pkg-config --cflags --libs pangocairo')
608 libraries['libgnomecanvas2'] = LibraryInfo()
609 libraries['libgnomecanvas2'].ParseConfig ('pkg-config --cflags --libs libgnomecanvas-2.0')
611 #libraries['flowcanvas'] = LibraryInfo(LIBS='flowcanvas', LIBPATH='#/libs/flowcanvas', CPPPATH='#libs/flowcanvas')
613 # The Ardour Control Protocol Library
615 libraries['ardour_cp'] = LibraryInfo (LIBS='ardour_cp', LIBPATH='#libs/surfaces/control_protocol',
616 CPPPATH='#libs/surfaces/control_protocol')
618 # The Ardour backend/engine
620 libraries['ardour'] = LibraryInfo (LIBS='ardour', LIBPATH='#libs/ardour', CPPPATH='#libs/ardour')
621 libraries['midi++2'] = LibraryInfo (LIBS='midi++', LIBPATH='#libs/midi++2', CPPPATH='#libs/midi++2')
622 libraries['pbd'] = LibraryInfo (LIBS='pbd', LIBPATH='#libs/pbd', CPPPATH='#libs/pbd')
623 libraries['gtkmm2ext'] = LibraryInfo (LIBS='gtkmm2ext', LIBPATH='#libs/gtkmm2ext', CPPPATH='#libs/gtkmm2ext')
626 # SCons should really do this for us
628 conf = env.Configure ()
630 have_cxx = conf.TryAction (Action (str(env['CXX']) + ' --version'))
632 print "This system has no functional C++ compiler. You cannot build Ardour from source without one."
635 print "Congratulations, you have a functioning C++ compiler."
641 # Compiler flags and other system-dependent stuff
645 if env['GPROFILE'] == 1:
646 debug_flags = [ '-g', '-pg' ]
648 debug_flags = [ '-g' ]
650 # guess at the platform, used to define compiler flags
652 config_guess = os.popen("tools/config.guess").read()[:-1]
658 config = config_guess.split ("-")
660 print "system triple: " + config_guess
663 if env['DIST_TARGET'] == 'auto':
664 if config[config_arch] == 'apple':
665 # The [.] matches to the dot after the major version, "." would match any character
666 if re.search ("darwin[0-7][.]", config[config_kernel]) != None:
667 env['DIST_TARGET'] = 'panther'
668 if re.search ("darwin8[.]", config[config_kernel]) != None:
669 env['DIST_TARGET'] = 'tiger'
671 env['DIST_TARGET'] = 'leopard'
673 if re.search ("x86_64", config[config_cpu]) != None:
674 env['DIST_TARGET'] = 'x86_64'
675 elif re.search("i[0-5]86", config[config_cpu]) != None:
676 env['DIST_TARGET'] = 'i386'
677 elif re.search("powerpc", config[config_cpu]) != None:
678 env['DIST_TARGET'] = 'powerpc'
680 env['DIST_TARGET'] = 'i686'
681 print "\n*******************************"
682 print "detected DIST_TARGET = " + env['DIST_TARGET']
683 print "*******************************\n"
686 if config[config_cpu] == 'powerpc' and env['DIST_TARGET'] != 'none':
688 # Apple/PowerPC optimization options
690 # -mcpu=7450 does not reliably work with gcc 3.*
692 if env['DIST_TARGET'] == 'panther' or env['DIST_TARGET'] == 'tiger':
693 if config[config_arch] == 'apple':
694 ## opt_flags.extend ([ "-mcpu=7450", "-faltivec"])
695 # to support g3s but still have some optimization for above
696 opt_flags.extend ([ "-mcpu=G3", "-mtune=7450"])
698 opt_flags.extend ([ "-mcpu=7400", "-maltivec", "-mabi=altivec"])
700 opt_flags.extend([ "-mcpu=750", "-mmultiple" ])
701 opt_flags.extend (["-mhard-float", "-mpowerpc-gfxopt"])
702 opt_flags.extend (["-Os"])
704 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':
706 build_host_supports_sse = 0
708 debug_flags.append ("-DARCH_X86")
709 opt_flags.append ("-DARCH_X86")
711 if config[config_kernel] == 'linux' :
713 if env['DIST_TARGET'] != 'i386':
715 flag_line = os.popen ("cat /proc/cpuinfo | grep '^flags'").read()[:-1]
716 x86_flags = flag_line.split (": ")[1:][0].split ()
718 if "mmx" in x86_flags:
719 opt_flags.append ("-mmmx")
720 if "sse" in x86_flags:
721 build_host_supports_sse = 1
722 if "3dnow" in x86_flags:
723 opt_flags.append ("-m3dnow")
725 if config[config_cpu] == "i586":
726 opt_flags.append ("-march=i586")
727 elif config[config_cpu] == "i686":
728 opt_flags.append ("-march=i686")
730 if ((env['DIST_TARGET'] == 'i686') or (env['DIST_TARGET'] == 'x86_64')) and build_host_supports_sse:
731 opt_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
732 debug_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
733 # end of processor-specific section
735 # optimization section
736 if env['FPU_OPTIMIZATION']:
737 if env['DIST_TARGET'] == 'tiger' or env['DIST_TARGET'] == 'leopard':
738 opt_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
739 debug_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
740 libraries['core'].Append(LINKFLAGS= '-framework Accelerate')
741 elif env['DIST_TARGET'] == 'i686' or env['DIST_TARGET'] == 'x86_64':
742 opt_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
743 debug_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
744 if env['DIST_TARGET'] == 'x86_64':
745 opt_flags.append ("-DUSE_X86_64_ASM")
746 debug_flags.append ("-DUSE_X86_64_ASM")
747 if build_host_supports_sse != 1:
748 print "\nWarning: you are building Ardour with SSE support even though your system does not support these instructions. (This may not be an error, especially if you are a package maintainer)"
749 # end optimization section
751 # handle x86/x86_64 libdir properly
753 if env['DIST_TARGET'] == 'x86_64':
754 env['LIBDIR']='lib64'
759 # a single way to test if we're on OS X
762 if env['DIST_TARGET'] in ['panther', 'tiger', 'leopard' ]:
764 # force tiger or later, to avoid issues on PPC which defaults
765 # back to 10.1 if we don't tell it otherwise.
766 env.Append (CCFLAGS="-DMAC_OS_X_VERSION_MIN_REQUIRED=1040")
768 if env['DIST_TARGET'] == 'leopard':
769 # need this to really build against the 10.4 SDK when building on leopard
770 # ideally this would be configurable, but lets just do that later when we need it
771 env.Append(CCFLAGS="-mmacosx-version-min=10.4 -isysroot /Developer/SDKs/MacOSX10.4u.sdk")
772 env.Append(LINKFLAGS="-mmacosx-version-min=10.4 -isysroot /Developer/SDKs/MacOSX10.4u.sdk")
778 # save off guessed arch element in an env
780 env.Append(CONFIG_ARCH=config[config_arch])
784 # ARCH="..." overrides all
787 if env['ARCH'] != '':
788 opt_flags = env['ARCH'].split()
791 # prepend boiler plate optimization flags
796 "-fomit-frame-pointer",
802 if env['DEBUG'] == 1:
803 env.Append(CCFLAGS=" ".join (debug_flags))
804 env.Append(LINKFLAGS=" ".join (debug_flags))
806 env.Append(CCFLAGS=" ".join (opt_flags))
807 env.Append(LINKFLAGS=" ".join (opt_flags))
809 if env['STL_DEBUG'] == 1:
810 env.Append(CXXFLAGS="-D_GLIBCXX_DEBUG")
812 if env['UNIVERSAL'] == 1:
813 env.Append(CCFLAGS="-arch i386 -arch ppc")
814 env.Append(LINKFLAGS="-arch i386 -arch ppc")
821 env.Append(CCFLAGS="-Wall")
822 env.Append(CXXFLAGS="-Woverloaded-virtual")
824 if env['EXTRA_WARN']:
825 env.Append(CCFLAGS="-Wextra -pedantic -ansi")
826 env.Append(CXXFLAGS="-ansi")
827 # env.Append(CFLAGS="-iso")
830 env.Append(CCFLAGS="-DHAVE_LIBLO")
834 # fix scons nitpickiness on APPLE
838 def prep_libcheck(topenv, libinfo):
841 # rationale: GTK-Quartz uses jhbuild and installs to /opt/gtk by default.
842 # All libraries needed should be built against this location
843 # However.. now jhbuild installs to ~/gtk/inst by default.. changed to accomodate this
845 GTKROOT = os.path.expanduser ('~/gtk/inst')
846 libinfo.Append(CPPPATH= GTKROOT + "/include", LIBPATH= GTKROOT + "/lib")
847 libinfo.Append(CXXFLAGS="-I" + GTKROOT + "/include", LINKFLAGS="-L" + GTKROOT + "/lib")
848 #libinfo.Append(CPPPATH="/opt/local/include", LIBPATH="/opt/local/lib")
849 #libinfo.Append(CXXFLAGS="-I/opt/local/include", LINKFLAGS="-L/opt/local/lib")
851 prep_libcheck(env, env)
855 # these are part of the Ardour source tree because they are C++
858 libraries['vamp'] = LibraryInfo (LIBS='vampsdk',
859 LIBPATH='#libs/vamp-sdk',
860 CPPPATH='#libs/vamp-sdk')
861 libraries['vamphost'] = LibraryInfo (LIBS='vamphostsdk',
862 LIBPATH='#libs/vamp-sdk',
863 CPPPATH='#libs/vamp-sdk')
865 env['RUBBERBAND'] = False
867 conf = Configure (env)
869 if conf.CheckHeader ('fftw3.h'):
870 env['RUBBERBAND'] = True
871 libraries['rubberband'] = LibraryInfo (LIBS='rubberband',
872 LIBPATH='#libs/rubberband',
873 CPPPATH='#libs/rubberband',
874 CCFLAGS='-DUSE_RUBBERBAND')
877 print "-------------------------------------------------------------------------"
878 print "You do not have the FFTW single-precision development package installed."
879 print "This prevents Ardour from using the Rubberband library for timestretching"
880 print "and pitchshifting. It will fall back on SoundTouch for timestretch, and "
881 print "pitchshifting will not be available."
882 print "-------------------------------------------------------------------------"
890 libraries['usb'] = LibraryInfo ()
891 prep_libcheck(env, libraries['usb'])
893 conf = Configure (libraries['usb'])
894 if conf.CheckLib ('usb', 'usb_interrupt_write'):
899 # check for linux/input.h while we're at it for powermate
900 if conf.CheckHeader('linux/input.h'):
901 have_linux_input = True
903 have_linux_input = False
905 libraries['usb'] = conf.Finish ()
910 libraries['flac'] = LibraryInfo ()
911 prep_libcheck(env, libraries['flac'])
912 libraries['flac'].Append(CPPPATH="/usr/local/include", LIBPATH="/usr/local/lib")
915 # june 1st 2007: look for a function that is in FLAC 1.1.2 and not in later versions
916 # since the version of libsndfile we have internally does not support
917 # the new API that libFLAC has adopted
920 conf = Configure (libraries['flac'])
921 if conf.CheckLib ('FLAC', 'FLAC__seekable_stream_decoder_init', language='CXX'):
922 conf.env.Append(CCFLAGS='-DHAVE_FLAC')
927 libraries['flac'] = conf.Finish ()
929 # or if that fails...
930 #libraries['flac'] = LibraryInfo (LIBS='FLAC')
932 # boost (we don't link against boost, just use some header files)
934 libraries['boost'] = LibraryInfo ()
935 prep_libcheck(env, libraries['boost'])
936 libraries['boost'].Append(CPPPATH="/usr/local/include", LIBPATH="/usr/local/lib")
937 conf = Configure (libraries['boost'])
938 if conf.CheckHeader ('boost/shared_ptr.hpp', language='CXX') == False:
939 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."
942 libraries['boost'] = conf.Finish ()
948 libraries['lo'] = LibraryInfo ()
949 prep_libcheck(env, libraries['lo'])
951 conf = Configure (libraries['lo'])
952 if conf.CheckLib ('lo', 'lo_server_new') == False:
953 print "liblo does not appear to be installed."
956 libraries['lo'] = conf.Finish ()
961 libraries['dmalloc'] = LibraryInfo ()
962 prep_libcheck(env, libraries['dmalloc'])
965 # look for the threaded version
968 conf = Configure (libraries['dmalloc'])
969 if conf.CheckLib ('dmallocth', 'dmalloc_shutdown'):
970 have_libdmalloc = True
972 have_libdmalloc = False
974 libraries['dmalloc'] = conf.Finish ()
977 # ensure FREEDESKTOP target is doable..
980 conf = env.Configure ()
981 if env['FREEDESKTOP']:
982 have_update_mime_database = conf.TryAction (Action ('update-mime-database -v'))
983 if have_update_mime_database[0] != 1:
984 print "Warning. You have no update-mime-database command in your PATH. FREEDESKTOP is now disabled."
985 env['FREEDESKTOP'] = 0
986 have_gtk_update_icon_cache = conf.TryAction (Action ('gtk-update-icon-cache -?'))
987 if have_gtk_update_icon_cache[0] != 1:
988 print "Warning. You have no gtk-update-icon-cache command in your PATH. FREEDESKTOP is now disabled."
989 env['FREEDESKTOP'] = 0
990 have_update_desktop_database = conf.TryAction (Action ('update-desktop-database -?'))
991 if have_update_desktop_database[0] != 1:
992 print "Warning. You have no update-desktop-database command in your PATH. FREEDESKTOP is now disabled."
993 env['FREEDESKTOP'] = 0
997 # Audio/MIDI library (needed for MIDI, since audio is all handled via JACK)
1000 conf = Configure(env)
1002 # ALSA, for engine dialog
1003 libraries['asound'] = LibraryInfo ()
1005 if conf.CheckCHeader('alsa/asoundlib.h'):
1006 libraries['asound'] = LibraryInfo (LIBS='asound')
1008 if conf.CheckCHeader('jack/midiport.h'):
1009 libraries['sysmidi'] = LibraryInfo (LIBS='jack')
1010 env['SYSMIDI'] = 'JACK MIDI'
1011 subst_dict['%MIDITAG%'] = "control"
1012 subst_dict['%MIDITYPE%'] = "jack"
1013 print "Using JACK MIDI"
1014 elif conf.CheckCHeader('alsa/asoundlib.h'):
1015 libraries['sysmidi'] = LibraryInfo (LIBS='asound')
1016 env['SYSMIDI'] = 'ALSA Sequencer'
1017 subst_dict['%MIDITAG%'] = "seq"
1018 subst_dict['%MIDITYPE%'] = "alsa/sequencer"
1019 print "Using ALSA MIDI"
1020 elif conf.CheckCHeader('/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h'):
1021 # this line is needed because scons can't handle -framework in ParseConfig() yet.
1023 # We need Carbon as well as the rest
1024 libraries['sysmidi'] = LibraryInfo (
1025 LINKFLAGS = ' -framework CoreMIDI -framework CoreFoundation -framework CoreAudio -framework CoreServices -framework AudioUnit -framework AudioToolbox -framework Carbon -bind_at_load' )
1027 libraries['sysmidi'] = LibraryInfo (
1028 LINKFLAGS = ' -framework CoreMIDI -framework CoreFoundation -framework CoreAudio -framework CoreServices -framework AudioUnit -framework AudioToolbox -bind_at_load' )
1029 env['SYSMIDI'] = 'CoreMIDI'
1030 subst_dict['%MIDITAG%'] = "ardour"
1031 subst_dict['%MIDITYPE%'] = "coremidi"
1033 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."
1042 'sigc++-2.0' : '2.0',
1043 'gtkmm-2.4' : '2.8',
1044 'libgnomecanvasmm-2.6' : '2.12.0'
1047 conf = Configure(env, custom_tests = { 'CheckPKGConfig' : CheckPKGConfig,
1048 'CheckPKGVersion' : CheckPKGVersion })
1050 for pkg, version in syslibdeps.iteritems():
1051 if not conf.CheckPKGVersion( pkg, version ):
1052 print '%s >= %s not found.' %(pkg, version)
1053 DependenciesRequiredMessage()
1058 libraries['sigc2'] = LibraryInfo()
1059 libraries['sigc2'].ParseConfig('pkg-config --cflags --libs sigc++-2.0')
1060 libraries['glibmm2'] = LibraryInfo()
1061 libraries['glibmm2'].ParseConfig('pkg-config --cflags --libs glibmm-2.4')
1062 libraries['cairo'] = LibraryInfo()
1063 libraries['cairo'].ParseConfig('pkg-config --cflags --libs cairo')
1064 libraries['cairomm'] = LibraryInfo()
1065 libraries['cairomm'].ParseConfig('pkg-config --cflags --libs cairomm-1.0')
1066 libraries['gdkmm2'] = LibraryInfo()
1067 libraries['gdkmm2'].ParseConfig ('pkg-config --cflags --libs gdkmm-2.4')
1068 libraries['gtkmm2'] = LibraryInfo()
1069 libraries['gtkmm2'].ParseConfig ('pkg-config --cflags --libs gtkmm-2.4')
1070 libraries['atkmm'] = LibraryInfo()
1071 libraries['atkmm'].ParseConfig ('pkg-config --cflags --libs atkmm-1.6')
1072 libraries['pangomm'] = LibraryInfo()
1073 libraries['pangomm'].ParseConfig ('pkg-config --cflags --libs pangomm-1.4')
1074 libraries['libgnomecanvasmm'] = LibraryInfo()
1075 libraries['libgnomecanvasmm'].ParseConfig ('pkg-config --cflags --libs libgnomecanvasmm-2.6')
1078 # cannot use system one for the time being
1081 libraries['sndfile-ardour'] = LibraryInfo(LIBS='libsndfile-ardour',
1082 LIBPATH='#libs/libsndfile',
1083 CPPPATH=['#libs/libsndfile/src'])
1085 # libraries['libglademm'] = LibraryInfo()
1086 # libraries['libglademm'].ParseConfig ('pkg-config --cflags --libs libglademm-2.4')
1088 # libraries['flowcanvas'] = LibraryInfo(LIBS='flowcanvas', LIBPATH='#/libs/flowcanvas', CPPPATH='#libs/flowcanvas')
1089 libraries['soundtouch'] = LibraryInfo()
1090 libraries['soundtouch'].ParseConfig ('pkg-config --cflags --libs soundtouch-1.0')
1091 # Comment the previous line and uncomment this for some versions of Debian:
1092 #libraries['soundtouch'].ParseConfig ('pkg-config --cflags --libs libSoundTouch')
1094 libraries['appleutility'] = LibraryInfo(LIBS='libappleutility',
1095 LIBPATH='#libs/appleutility',
1096 CPPPATH='#libs/appleutility')
1109 'libs/vamp-plugins/',
1110 # these are unconditionally included but have
1111 # tests internally to avoid compilation etc
1115 # this is unconditionally included but has
1116 # tests internally to avoid compilation etc
1117 # if COREAUDIO is not set
1122 # 'libs/flowcanvas',
1129 libraries['cairo'] = LibraryInfo()
1130 libraries['cairo'].ParseConfig('pkg-config --cflags --libs cairo')
1132 libraries['gtk2-unix-print'] = LibraryInfo()
1133 libraries['gtk2-unix-print'].ParseConfig('pkg-config --cflags --libs gtk+-unix-print-2.0')
1135 libraries['sigc2'] = LibraryInfo(LIBS='sigc++2',
1136 LIBPATH='#libs/sigc++2',
1137 CPPPATH='#libs/sigc++2')
1138 libraries['glibmm2'] = LibraryInfo(LIBS='glibmm2',
1139 LIBPATH='#libs/glibmm2',
1140 CPPPATH='#libs/glibmm2/glib')
1141 libraries['pangomm'] = LibraryInfo(LIBS='pangomm',
1142 LIBPATH='#libs/gtkmm2/pango',
1143 CPPPATH='#libs/gtkmm2/pango')
1144 libraries['atkmm'] = LibraryInfo(LIBS='atkmm',
1145 LIBPATH='#libs/gtkmm2/atk',
1146 CPPPATH='#libs/gtkmm2/atk')
1147 libraries['cairomm'] = LibraryInfo(LIBS='cairomm',
1148 LIBPATH='#libs/cairomm',
1149 CPPPATH='#libs/cairomm')
1150 libraries['gdkmm2'] = LibraryInfo(LIBS='gdkmm2',
1151 LIBPATH='#libs/gtkmm2/gdk',
1152 CPPPATH='#libs/gtkmm2/gdk')
1153 libraries['gtkmm2'] = LibraryInfo(LIBS='gtkmm2',
1154 LIBPATH="#libs/gtkmm2/gtk",
1155 CPPPATH='#libs/gtkmm2/gtk/')
1156 libraries['libgnomecanvasmm'] = LibraryInfo(LIBS='libgnomecanvasmm',
1157 LIBPATH='#libs/libgnomecanvasmm',
1158 CPPPATH='#libs/libgnomecanvasmm')
1160 libraries['soundtouch'] = LibraryInfo(LIBS='soundtouch',
1161 LIBPATH='#libs/soundtouch',
1162 CPPPATH=['#libs', '#libs/soundtouch'])
1163 libraries['sndfile-ardour'] = LibraryInfo(LIBS='libsndfile-ardour',
1164 LIBPATH='#libs/libsndfile',
1165 CPPPATH=['#libs/libsndfile', '#libs/libsndfile/src'])
1166 # libraries['libglademm'] = LibraryInfo(LIBS='libglademm',
1167 # LIBPATH='#libs/libglademm',
1168 # CPPPATH='#libs/libglademm')
1169 libraries['appleutility'] = LibraryInfo(LIBS='libappleutility',
1170 LIBPATH='#libs/appleutility',
1171 CPPPATH='#libs/appleutility')
1185 'libs/vamp-plugins/',
1186 # these are unconditionally included but have
1187 # tests internally to avoid compilation etc
1191 # this is unconditionally included but has
1192 # tests internally to avoid compilation etc
1193 # if COREAUDIO is not set
1199 'libs/gtkmm2/pango',
1203 'libs/libgnomecanvasmm',
1211 # * always build the LGPL control protocol lib, since we link against it from libardour
1212 # * ditto for generic MIDI
1213 # * tranzport checks whether it should build internally, but we need here so that
1214 # its 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'
1226 env['TRANZPORT'] = 1
1228 env['TRANZPORT'] = 0
1229 print 'Disabled building Tranzport code because libusb could not be found'
1231 if have_linux_input:
1232 env['POWERMATE'] = 1
1234 env['POWERMATE'] = 0
1235 print 'Disabled building Powermate code because linux/input.h could not be found'
1237 if os.access ('libs/surfaces/sony9pin', os.F_OK):
1238 surface_subdirs += [ 'libs/surfaces/sony9pin' ]
1240 env['POWERMATE'] = 0
1241 env['TRANZPORT'] = 0
1244 # timestretch libraries
1247 timefx_subdirs = ['libs/soundtouch']
1248 if env['RUBBERBAND']:
1249 timefx_subdirs += ['libs/rubberband']
1251 opts.Save('scache.conf', env)
1252 Help(opts.GenerateHelpText(env))
1254 final_prefix = '$PREFIX'
1257 install_prefix = '$DESTDIR/$PREFIX'
1259 install_prefix = env['PREFIX']
1261 subst_dict['%INSTALL_PREFIX%'] = install_prefix;
1262 subst_dict['%FINAL_PREFIX%'] = final_prefix;
1263 subst_dict['%PREFIX%'] = final_prefix;
1265 if env['PREFIX'] == '/usr':
1266 final_config_prefix = '/etc'
1268 final_config_prefix = env['PREFIX'] + '/etc'
1270 config_prefix = '$DESTDIR' + final_config_prefix
1273 # everybody needs this
1276 env.Merge ([ libraries['core'] ])
1283 conf = Configure (env)
1285 nls_error = 'This system is not configured for internationalized applications. An english-only version will be built:'
1286 print 'Checking for internationalization support ...'
1287 have_gettext = conf.TryAction(Action('xgettext --version'))
1288 if have_gettext[0] != 1:
1289 nls_error += ' No xgettext command.'
1292 print "Found xgettext"
1294 have_msgmerge = conf.TryAction(Action('msgmerge --version'))
1295 if have_msgmerge[0] != 1:
1296 nls_error += ' No msgmerge command.'
1299 print "Found msgmerge"
1301 if not conf.CheckCHeader('libintl.h'):
1302 nls_error += ' No libintl.h.'
1308 print "International version will be built."
1312 env.Append(CCFLAGS="-DENABLE_NLS")
1314 Export('env install_prefix final_prefix config_prefix final_config_prefix libraries i18n ardour_version subst_dict use_flac')
1317 # the configuration file may be system dependent
1320 conf = env.Configure ()
1322 if conf.CheckCHeader('/System/Library/Frameworks/CoreAudio.framework/Versions/A/Headers/CoreAudio.h'):
1323 subst_dict['%JACK_INPUT%'] = "coreaudio:Built-in Audio:in"
1324 subst_dict['%JACK_OUTPUT%'] = "coreaudio:Built-in Audio:out"
1326 subst_dict['%JACK_INPUT%'] = "alsa_pcm:playback_"
1327 subst_dict['%JACK_OUTPUT%'] = "alsa_pcm:capture_"
1329 # posix_memalign available
1330 if not conf.CheckFunc('posix_memalign'):
1331 print 'Did not find posix_memalign(), using malloc'
1332 env.Append(CCFLAGS='-DNO_POSIX_MEMALIGN')
1337 # generate the per-user and system rc files from the same source
1339 sysrcbuild = env.SubstInFile ('ardour_system.rc','ardour.rc.in', SUBST_DICT = subst_dict)
1341 # add to the substitution dictionary
1343 subst_dict['%VERSION%'] = ardour_version[0:3]
1344 subst_dict['%EXTRA_VERSION%'] = ardour_version[3:]
1345 subst_dict['%REVISION_STRING%'] = ''
1346 if os.path.exists('.svn'):
1347 subst_dict['%REVISION_STRING%'] = '.' + fetch_svn_revision ('.') + 'svn'
1349 # specbuild = env.SubstInFile ('ardour.spec','ardour.spec.in', SUBST_DICT = subst_dict)
1351 the_revision = env.Command ('frobnicatory_decoy', [], create_stored_revision)
1352 remove_ardour = env.Command ('frobnicatory_decoy2', [],
1353 [ Delete ('$PREFIX/etc/ardour3'),
1354 Delete ('$PREFIX/lib/ardour3'),
1355 Delete ('$PREFIX/bin/ardour3'),
1356 Delete ('$PREFIX/share/ardour3')])
1358 env.Alias('revision', the_revision)
1359 env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), 'ardour_system.rc'))
1360 env.Alias('uninstall', remove_ardour)
1362 Default (sysrcbuild)
1366 Precious (env['DISTTREE'])
1368 env.Distribute (env['DISTTREE'],
1369 [ 'SConstruct', 'svn_revision.h',
1370 'COPYING', 'PACKAGER_README', 'README',
1372 'tools/config.guess',
1373 'icons/icon/ardour_icon_mac_mask.png',
1374 'icons/icon/ardour_icon_mac.png',
1375 'icons/icon/ardour_icon_tango_16px_blue.png',
1376 'icons/icon/ardour_icon_tango_16px_red.png',
1377 'icons/icon/ardour_icon_tango_22px_blue.png',
1378 'icons/icon/ardour_icon_tango_22px_red.png',
1379 'icons/icon/ardour_icon_tango_32px_blue.png',
1380 'icons/icon/ardour_icon_tango_32px_red.png',
1381 'icons/icon/ardour_icon_tango_48px_blue.png',
1382 'icons/icon/ardour_icon_tango_48px_red.png'
1384 glob.glob ('DOCUMENTATION/AUTHORS*') +
1385 glob.glob ('DOCUMENTATION/CONTRIBUTORS*') +
1386 glob.glob ('DOCUMENTATION/TRANSLATORS*') +
1387 glob.glob ('DOCUMENTATION/BUILD*') +
1388 glob.glob ('DOCUMENTATION/FAQ*') +
1389 glob.glob ('DOCUMENTATION/README*')
1392 srcdist = env.Tarball(env['TARBALL'], [ env['DISTTREE'], the_revision ])
1393 env.Alias ('srctar', srcdist)
1396 # don't leave the distree around
1399 env.AddPreAction (env['DISTTREE'], Action ('rm -rf ' + str (File (env['DISTTREE']))))
1400 env.AddPostAction (srcdist, Action ('rm -rf ' + str (File (env['DISTTREE']))))
1406 for subdir in coredirs:
1407 SConscript (subdir + '/SConscript')
1409 for sublistdir in [ subdirs, timefx_subdirs, gtk_subdirs, surface_subdirs ]:
1410 for subdir in sublistdir:
1411 SConscript (subdir + '/SConscript')
1414 env.Clean ('scrub', [ 'scache.conf', '.sconf_temp', '.sconsign.dblite', 'config.log'])