make mixbus packaging work, to some degree
[ardour2.git] / SConstruct
blob06b0884f5460a0219e3a2eca58b7ce9f2ffe21d7
1 # -*- python -*-
4 # and there we have it, or do we?
7 import os
8 import os.path
9 import sys
10 import re
11 import shutil
12 import glob
13 import errno
14 import time
15 import platform
16 import string
17 import commands
18 from sets import Set
19 import SCons.Node.FS
21 SConsignFile()
22 EnsureSConsVersion(0, 96)
24 ardour_version = '2.8'
26 subst_dict = { }
29 # Command-line options
32 opts = Options('scache.conf')
33 opts.AddOptions(
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 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),
55 BoolOption('UNIVERSAL', 'Compile as universal binary. Requires that external libraries are already universal.', 0),
56 BoolOption('VERSIONED', 'Add revision information to ardour/gtk executable name inside the build directory', 0),
57 BoolOption('VST', 'Compile with support for VST', 0),
58 BoolOption('LV2', 'Compile with support for LV2 (if slv2 is available)', 1),
59 BoolOption('GPROFILE', 'Compile with support for gprofile (Developers only)', 0),
60 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),
61 BoolOption('TRANZPORT', 'Compile with support for Frontier Designs (if libusb is available)', 1),
62 BoolOption('AUBIO', "Use Paul Brossier's aubio library for feature detection (if available)", 1),
63 BoolOption('AUSTATE', "Build with support for AU settings & presets saving/loading", 0)
66 #----------------------------------------------------------------------
67 # a handy helper that provides a way to merge compile/link information
68 # from multiple different "environments"
69 #----------------------------------------------------------------------
71 class LibraryInfo(Environment):
72 def __init__(self,*args,**kw):
73 Environment.__init__ (self,*args,**kw)
74 self.ENV_update(os.environ)
76 def Merge (self,others):
77 for other in others:
78 self.Append (LIBS = other.get ('LIBS',[]))
79 self.Append (LIBPATH = other.get ('LIBPATH', []))
80 self.Append (CPPPATH = other.get('CPPPATH', []))
81 self.Append (LINKFLAGS = other.get('LINKFLAGS', []))
82 self.Append (CCFLAGS = other.get('CCFLAGS', []))
83 self.Replace(LIBPATH = list(Set(self.get('LIBPATH', []))))
84 self.Replace(CPPPATH = list(Set(self.get('CPPPATH',[]))))
85 #doing LINKFLAGS breaks -framework
86 #doing LIBS break link order dependency
88 def ENV_update(self, src_ENV):
89 for k in src_ENV.keys():
90 if k in self['ENV'].keys() and k in [ 'PATH', 'LD_LIBRARY_PATH',
91 'LIB', 'PKG_CONFIG_PATH', 'INCLUDE' ]:
92 self['ENV'][k]=SCons.Util.AppendPath(self['ENV'][k], src_ENV[k])
93 else:
94 self['ENV'][k]=src_ENV[k]
96 env = LibraryInfo (options = opts,
97 CPPPATH = [ '.' ],
98 VERSION = ardour_version,
99 TARBALL='ardour-' + ardour_version + '.tar.bz2',
100 DISTFILES = [ ],
101 DISTTREE = '#ardour-' + ardour_version,
102 DISTCHECKDIR = '#ardour-' + ardour_version + '/check'
105 env.ENV_update(os.environ)
107 #----------------------------------------------------------------------
108 # Builders
109 #----------------------------------------------------------------------
111 # Handy subst-in-file builder
114 def do_subst_in_file(targetfile, sourcefile, dict):
115 """Replace all instances of the keys of dict with their values.
116 For example, if dict is {'%VERSION%': '1.2345', '%BASE%': 'MyProg'},
117 then all instances of %VERSION% in the file will be replaced with 1.2345 etc.
119 try:
120 f = open(sourcefile, 'rb')
121 contents = f.read()
122 f.close()
123 except:
124 raise SCons.Errors.UserError, "Can't read source file %s"%sourcefile
125 for (k,v) in dict.items():
126 contents = re.sub(k, v, contents)
127 try:
128 f = open(targetfile, 'wb')
129 f.write(contents)
130 f.close()
131 except:
132 raise SCons.Errors.UserError, "Can't write target file %s"%targetfile
133 return 0 # success
135 def subst_in_file(target, source, env):
136 if not env.has_key('SUBST_DICT'):
137 raise SCons.Errors.UserError, "SubstInFile requires SUBST_DICT to be set."
138 d = dict(env['SUBST_DICT']) # copy it
139 for (k,v) in d.items():
140 if callable(v):
141 d[k] = env.subst(v())
142 elif SCons.Util.is_String(v):
143 d[k]=env.subst(v)
144 else:
145 raise SCons.Errors.UserError, "SubstInFile: key %s: %s must be a string or callable"%(k, repr(v))
146 for (t,s) in zip(target, source):
147 return do_subst_in_file(str(t), str(s), d)
149 def subst_in_file_string(target, source, env):
150 """This is what gets printed on the console."""
151 return '\n'.join(['Substituting vars from %s into %s'%(str(s), str(t))
152 for (t,s) in zip(target, source)])
154 def subst_emitter(target, source, env):
155 """Add dependency from substituted SUBST_DICT to target.
156 Returns original target, source tuple unchanged.
158 d = env['SUBST_DICT'].copy() # copy it
159 for (k,v) in d.items():
160 if callable(v):
161 d[k] = env.subst(v())
162 elif SCons.Util.is_String(v):
163 d[k]=env.subst(v)
164 Depends(target, SCons.Node.Python.Value(d))
165 # Depends(target, source) # this doesn't help the install-sapphire-linux.sh problem
166 return target, source
168 subst_action = Action (subst_in_file, subst_in_file_string)
169 env['BUILDERS']['SubstInFile'] = Builder(action=subst_action, emitter=subst_emitter)
172 # internationalization
175 # po_builder: builder function to copy po files to the parent directory while updating them
177 # first source: .po file
178 # second source: .pot file
181 def po_builder(target,source,env):
182 os.spawnvp (os.P_WAIT, 'cp', ['cp', str(source[0]), str(target[0])])
183 args = [ 'msgmerge',
184 '--update',
185 str(target[0]),
186 str(source[1])
188 print 'Updating ' + str(target[0])
189 return os.spawnvp (os.P_WAIT, 'msgmerge', args)
191 po_bld = Builder (action = po_builder)
192 env.Append(BUILDERS = {'PoBuild' : po_bld})
194 # mo_builder: builder function for (binary) message catalogs (.mo)
196 # first source: .po file
199 def mo_builder(target,source,env):
200 args = [ 'msgfmt',
201 '-c',
202 '-o',
203 target[0].get_path(),
204 source[0].get_path()
206 return os.spawnvp (os.P_WAIT, 'msgfmt', args)
208 mo_bld = Builder (action = mo_builder)
209 env.Append(BUILDERS = {'MoBuild' : mo_bld})
211 # pot_builder: builder function for message templates (.pot)
213 # source: list of C/C++ etc. files to extract messages from
216 def pot_builder(target,source,env):
217 args = [ 'xgettext',
218 '--keyword=_',
219 '--keyword=N_',
220 '--from-code=UTF-8',
221 '-o', target[0].get_path(),
222 "--default-domain=" + env['PACKAGE'],
223 '--copyright-holder="Paul Davis"' ]
224 args += [ src.get_path() for src in source ]
226 return os.spawnvp (os.P_WAIT, 'xgettext', args)
228 pot_bld = Builder (action = pot_builder)
229 env.Append(BUILDERS = {'PotBuild' : pot_bld})
232 # utility function, not a builder
235 def i18n (buildenv, sources, installenv):
236 domain = buildenv['PACKAGE']
237 potfile = buildenv['POTFILE']
239 installenv.Alias ('potupdate', buildenv.PotBuild (potfile, sources))
241 p_oze = [ os.path.basename (po) for po in glob.glob ('po/*.po') ]
242 languages = [ po.replace ('.po', '') for po in p_oze ]
244 for po_file in p_oze:
245 buildenv.PoBuild(po_file, ['po/'+po_file, potfile])
246 mo_file = po_file.replace (".po", ".mo")
247 installenv.Alias ('install', buildenv.MoBuild (mo_file, po_file))
248 installenv.Alias ('msgupdate', buildenv.MoBuild (mo_file, po_file))
250 for lang in languages:
251 modir = (os.path.join (install_prefix, 'share/locale/' + lang + '/LC_MESSAGES/'))
252 moname = domain + '.mo'
253 installenv.Alias('install', installenv.InstallAs (os.path.join (modir, moname), lang + '.mo'))
256 def fetch_svn_revision (path):
257 cmd = "LANG= "
258 cmd += "svn info "
259 cmd += path
260 cmd += " | awk '/^Revision:/ { print $2}'"
261 return commands.getoutput (cmd)
263 def create_stored_revision (target = None, source = None, env = None):
264 if os.path.exists('.svn'):
265 rev = fetch_svn_revision ('.');
266 try:
267 text = "#include <ardour/svn_revision.h>\n"
268 text += "namespace ARDOUR {\n";
269 text += "extern const char* svn_revision = \"" + rev + "\";\n";
270 text += "}\n";
271 print '============> writing svn revision info to libs/ardour/svn_revision.cc\n'
272 o = file ('libs/ardour/svn_revision.cc', 'w')
273 o.write (text)
274 o.close ()
275 except IOError:
276 print "Could not open libs/ardour/svn_revision.cc for writing\n"
277 sys.exit (-1)
278 else:
279 if not os.path.exists('libs/ardour/ardour/svn_revision.h'):
280 print "This release of ardour is missing libs/ardour/ardour/svn_revision.h. Blame the packager."
281 sys.exit (-1)
284 # A generic builder for version.cc files
286 # note: requires that DOMAIN, MAJOR, MINOR, MICRO are set in the construction environment
287 # note: assumes one source files, the header that declares the version variables
290 def version_builder (target, source, env):
292 text = "int " + env['DOMAIN'] + "_major_version = " + str (env['MAJOR']) + ";\n"
293 text += "int " + env['DOMAIN'] + "_minor_version = " + str (env['MINOR']) + ";\n"
294 text += "int " + env['DOMAIN'] + "_micro_version = " + str (env['MICRO']) + ";\n"
296 try:
297 o = file (target[0].get_path(), 'w')
298 o.write (text)
299 o.close ()
300 except IOError:
301 print "Could not open", target[0].get_path(), " for writing\n"
302 sys.exit (-1)
304 text = "#ifndef __" + env['DOMAIN'] + "_version_h__\n"
305 text += "#define __" + env['DOMAIN'] + "_version_h__\n"
306 text += "extern const char* " + env['DOMAIN'] + "_revision;\n"
307 text += "extern int " + env['DOMAIN'] + "_major_version;\n"
308 text += "extern int " + env['DOMAIN'] + "_minor_version;\n"
309 text += "extern int " + env['DOMAIN'] + "_micro_version;\n"
310 text += "#endif /* __" + env['DOMAIN'] + "_version_h__ */\n"
312 try:
313 o = file (target[1].get_path(), 'w')
314 o.write (text)
315 o.close ()
316 except IOError:
317 print "Could not open", target[1].get_path(), " for writing\n"
318 sys.exit (-1)
320 return None
322 version_bld = Builder (action = version_builder)
323 env.Append (BUILDERS = {'VersionBuild' : version_bld})
326 # a builder that makes a hard link from the 'source' executable to a name with
327 # a "build ID" based on the most recent CVS activity that might be reasonably
328 # related to version activity. this relies on the idea that the SConscript
329 # file that builds the executable is updated with new version info and committed
330 # to the source code repository whenever things change.
333 def versioned_builder(target,source,env):
334 w, r = os.popen2( "LANG= svn info | awk '/^Revision:/ { print $2}'")
336 last_revision = r.readline().strip()
337 w.close()
338 r.close()
339 if last_revision == "":
340 print "No SVN info found - versioned executable cannot be built"
341 return -1
343 print "The current build ID is " + last_revision
345 tagged_executable = source[0].get_path() + '-' + last_revision
347 if os.path.exists (tagged_executable):
348 print "Replacing existing executable with the same build tag."
349 os.unlink (tagged_executable)
351 return os.link (source[0].get_path(), tagged_executable)
353 verbuild = Builder (action = versioned_builder)
354 env.Append (BUILDERS = {'VersionedExecutable' : verbuild})
357 # source tar file builder
360 def distcopy (target, source, env):
361 treedir = str (target[0])
363 try:
364 os.mkdir (treedir)
365 except OSError, (errnum, strerror):
366 if errnum != errno.EEXIST:
367 print 'mkdir ', treedir, ':', strerror
369 cmd = 'tar cf - '
371 # we don't know what characters might be in the file names
372 # so quote them all before passing them to the shell
374 all_files = ([ str(s) for s in source ])
375 cmd += " ".join ([ "'%s'" % quoted for quoted in all_files])
376 cmd += ' | (cd ' + treedir + ' && tar xf -)'
377 p = os.popen (cmd)
378 return p.close ()
380 def tarballer (target, source, env):
381 cmd = 'tar -jcf ' + str (target[0]) + ' ' + str(source[0]) + " --exclude '*~'" + " --exclude .svn --exclude '.svn/*'"
382 print 'running ', cmd, ' ... '
383 p = os.popen (cmd)
384 return p.close ()
386 dist_bld = Builder (action = distcopy,
387 target_factory = SCons.Node.FS.default_fs.Entry,
388 source_factory = SCons.Node.FS.default_fs.Entry,
389 multi = 1)
391 tarball_bld = Builder (action = tarballer,
392 target_factory = SCons.Node.FS.default_fs.Entry,
393 source_factory = SCons.Node.FS.default_fs.Entry)
395 env.Append (BUILDERS = {'Distribute' : dist_bld})
396 env.Append (BUILDERS = {'Tarball' : tarball_bld})
398 ####################
399 # push environment
400 ####################
402 def pushEnvironment(context):
403 if os.environ.has_key('PATH'):
404 context.Append(PATH = os.environ['PATH'])
405 context['ENV']['PATH'] = os.environ['PATH']
407 if os.environ.has_key('PKG_CONFIG_PATH'):
408 context.Append(PKG_CONFIG_PATH = os.environ['PKG_CONFIG_PATH'])
409 context['ENV']['PKG_CONFIG_PATH'] = os.environ['PKG_CONFIG_PATH']
411 if os.environ.has_key('CC'):
412 context['CC'] = os.environ['CC']
414 if os.environ.has_key('CXX'):
415 context['CXX'] = os.environ['CXX']
417 if os.environ.has_key('DISTCC_HOSTS'):
418 context['ENV']['DISTCC_HOSTS'] = os.environ['DISTCC_HOSTS']
419 context['ENV']['HOME'] = os.environ['HOME']
421 pushEnvironment (env)
423 #######################
424 # Dependency Checking #
425 #######################
427 deps = \
429 'glib-2.0' : '2.10.1',
430 'gthread-2.0' : '2.10.1',
431 'gtk+-2.0' : '2.8.1',
432 'libxml-2.0' : '2.6.0',
433 'samplerate' : '0.1.0',
434 'raptor' : '1.4.2',
435 'lrdf' : '0.4.0',
436 'jack' : '0.109.0',
437 'libgnomecanvas-2.0' : '2.0',
440 def DependenciesRequiredMessage():
441 print 'You do not have the necessary dependencies required to build ardour'
442 print 'Please consult http://ardour.org/building for more information'
444 def CheckPKGConfig(context, version):
445 context.Message( 'Checking for pkg-config version >= %s... ' %version )
446 ret = context.TryAction('pkg-config --atleast-pkgconfig-version=%s' % version)[0]
447 context.Result( ret )
448 return ret
450 def CheckPKGVersion(context, name, version):
451 context.Message( 'Checking for %s... ' % name )
452 ret = context.TryAction('pkg-config --atleast-version=%s %s' %(version,name) )[0]
453 context.Result( ret )
454 return ret
456 def CheckPKGExists(context, name):
457 context.Message ('Checking for %s...' % name)
458 ret = context.TryAction('pkg-config --exists %s' % name)[0]
459 context.Result (ret)
460 return ret
462 conf = Configure(env, custom_tests = { 'CheckPKGConfig' : CheckPKGConfig,
463 'CheckPKGVersion' : CheckPKGVersion })
465 # I think a more recent version is needed on win32
466 min_pkg_config_version = '0.8.0'
468 if not conf.CheckPKGConfig(min_pkg_config_version):
469 print 'pkg-config >= %s not found.' % min_pkg_config_version
470 Exit(1)
472 for pkg, version in deps.iteritems():
473 if not conf.CheckPKGVersion( pkg, version ):
474 print '%s >= %s not found.' %(pkg, version)
475 DependenciesRequiredMessage()
476 Exit(1)
478 env = conf.Finish()
480 # ----------------------------------------------------------------------
481 # Construction environment setup
482 # ----------------------------------------------------------------------
484 libraries = { }
486 libraries['core'] = LibraryInfo (CCFLAGS = '-Ilibs')
488 #libraries['sndfile'] = LibraryInfo()
489 #libraries['sndfile'].ParseConfig('pkg-config --cflags --libs sndfile')
491 libraries['lrdf'] = LibraryInfo()
492 libraries['lrdf'].ParseConfig('pkg-config --cflags --libs lrdf')
494 libraries['raptor'] = LibraryInfo()
495 libraries['raptor'].ParseConfig('pkg-config --cflags --libs raptor')
497 libraries['samplerate'] = LibraryInfo()
498 libraries['samplerate'].ParseConfig('pkg-config --cflags --libs samplerate')
500 conf = env.Configure (custom_tests = { 'CheckPKGExists' : CheckPKGExists } )
502 if conf.CheckPKGExists ('fftw3f'):
503 libraries['fftw3f'] = LibraryInfo()
504 libraries['fftw3f'].ParseConfig('pkg-config --cflags --libs fftw3f')
506 if conf.CheckPKGExists ('fftw3'):
507 libraries['fftw3'] = LibraryInfo()
508 libraries['fftw3'].ParseConfig('pkg-config --cflags --libs fftw3')
510 if conf.CheckPKGExists ('aubio'):
511 libraries['aubio'] = LibraryInfo()
512 libraries['aubio'].ParseConfig('pkg-config --cflags --libs aubio')
513 env['AUBIO'] = 1
514 else:
515 env['AUBIO'] = 0
517 env = conf.Finish ()
519 if env['FFT_ANALYSIS']:
521 # Check for fftw3 header as well as the library
524 conf = Configure(libraries['fftw3'])
526 if conf.CheckHeader ('fftw3.h') == False:
527 print ('Ardour cannot be compiled without the FFTW3 headers, which do not seem to be installed')
528 sys.exit (1)
529 conf.Finish()
531 if env['FREESOUND']:
533 # Check for curl header as well as the library
536 libraries['curl'] = LibraryInfo()
538 conf = Configure(libraries['curl'])
540 if conf.CheckHeader ('curl/curl.h') == False:
541 print ('Ardour cannot be compiled without the curl headers, which do not seem to be installed')
542 sys.exit (1)
543 else:
544 libraries['curl'].ParseConfig('pkg-config --cflags --libs libcurl')
545 conf.Finish()
546 else:
547 print 'FREESOUND support is not enabled. Build with \'scons FREESOUND=1\' to enable.'
549 if env['LV2']:
550 conf = env.Configure(custom_tests = { 'CheckPKGVersion' : CheckPKGVersion})
552 if conf.CheckPKGVersion('slv2', '0.6.1'):
553 libraries['slv2'] = LibraryInfo()
554 libraries['slv2'].ParseConfig('pkg-config --cflags --libs slv2')
555 env.Append (CCFLAGS="-DHAVE_LV2")
556 else:
557 print 'LV2 support is not enabled (SLV2 not found or older than 0.6.0)'
558 env['LV2'] = 0
559 conf.Finish()
560 else:
561 print 'LV2 support is not enabled. Build with \'scons LV2=1\' to enable.'
563 if not env['WIIMOTE']:
564 print 'WIIMOTE not enabled. Build with \'scons WIIMOTE=1\' to enable support.'
566 libraries['jack'] = LibraryInfo()
567 libraries['jack'].ParseConfig('pkg-config --cflags --libs jack')
569 libraries['xml'] = LibraryInfo()
570 libraries['xml'].ParseConfig('pkg-config --cflags --libs libxml-2.0')
572 libraries['xslt'] = LibraryInfo()
573 libraries['xslt'].ParseConfig('pkg-config --cflags --libs libxslt')
575 libraries['glib2'] = LibraryInfo()
576 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs glib-2.0')
577 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gobject-2.0')
578 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gmodule-2.0')
579 libraries['glib2'].ParseConfig ('pkg-config --cflags --libs gthread-2.0')
581 libraries['freetype2'] = LibraryInfo()
582 libraries['freetype2'].ParseConfig ('pkg-config --cflags --libs freetype2')
584 libraries['gtk2'] = LibraryInfo()
585 libraries['gtk2'].ParseConfig ('pkg-config --cflags --libs gtk+-2.0')
587 libraries['pango'] = LibraryInfo()
588 libraries['pango'].ParseConfig ('pkg-config --cflags --libs pango')
590 libraries['libgnomecanvas2'] = LibraryInfo()
591 libraries['libgnomecanvas2'].ParseConfig ('pkg-config --cflags --libs libgnomecanvas-2.0')
593 #libraries['flowcanvas'] = LibraryInfo(LIBS='flowcanvas', LIBPATH='#/libs/flowcanvas', CPPPATH='#libs/flowcanvas')
595 # The Ardour Control Protocol Library
597 libraries['ardour_cp'] = LibraryInfo (LIBS='ardour_cp', LIBPATH='#libs/surfaces/control_protocol',
598 CPPPATH='#libs/surfaces/control_protocol')
600 # The Ardour backend/engine
602 libraries['ardour'] = LibraryInfo (LIBS='ardour', LIBPATH='#libs/ardour', CPPPATH='#libs/ardour')
603 libraries['midi++2'] = LibraryInfo (LIBS='midi++', LIBPATH='#libs/midi++2', CPPPATH='#libs/midi++2')
604 libraries['pbd'] = LibraryInfo (LIBS='pbd', LIBPATH='#libs/pbd', CPPPATH='#libs/pbd')
605 libraries['gtkmm2ext'] = LibraryInfo (LIBS='gtkmm2ext', LIBPATH='#libs/gtkmm2ext', CPPPATH='#libs/gtkmm2ext')
608 # SCons should really do this for us
610 conf = env.Configure ()
612 have_cxx = conf.TryAction (Action (str(env['CXX']) + ' --version'))
613 if have_cxx[0] != 1:
614 print "This system has no functional C++ compiler. You cannot build Ardour from source without one."
615 sys.exit (1)
616 else:
617 print "Congratulations, you have a functioning C++ compiler."
619 env = conf.Finish()
623 # Compiler flags and other system-dependent stuff
626 opt_flags = []
627 if env['GPROFILE'] == 1:
628 debug_flags = [ '-g', '-pg' ]
629 else:
630 debug_flags = [ '-g' ]
632 # guess at the platform, used to define compiler flags
634 config_guess = os.popen("tools/config.guess").read()[:-1]
636 config_cpu = 0
637 config_arch = 1
638 config_kernel = 2
639 config_os = 3
640 config = config_guess.split ("-")
642 print "system triple: " + config_guess
644 # Autodetect
645 if env['DIST_TARGET'] == 'auto':
646 if config[config_arch] == 'apple':
647 # The [.] matches to the dot after the major version, "." would match any character
648 if re.search ("darwin[0-7][.]", config[config_kernel]) != None:
649 env['DIST_TARGET'] = 'panther'
650 if re.search ("darwin8[.]", config[config_kernel]) != None:
651 env['DIST_TARGET'] = 'tiger'
652 else:
653 env['DIST_TARGET'] = 'leopard'
654 else:
655 if re.search ("x86_64", config[config_cpu]) != None:
656 env['DIST_TARGET'] = 'x86_64'
657 elif re.search("i[0-5]86", config[config_cpu]) != None:
658 env['DIST_TARGET'] = 'i386'
659 elif re.search("powerpc", config[config_cpu]) != None:
660 env['DIST_TARGET'] = 'powerpc'
661 else:
662 env['DIST_TARGET'] = 'i686'
663 print "\n*******************************"
664 print "detected DIST_TARGET = " + env['DIST_TARGET']
665 print "*******************************\n"
668 if config[config_cpu] == 'powerpc' and env['DIST_TARGET'] != 'none':
670 # Apple/PowerPC optimization options
672 # -mcpu=7450 does not reliably work with gcc 3.*
674 if env['DIST_TARGET'] == 'panther' or env['DIST_TARGET'] == 'tiger':
675 if config[config_arch] == 'apple':
676 ## opt_flags.extend ([ "-mcpu=7450", "-faltivec"])
677 # to support g3s but still have some optimization for above
678 opt_flags.extend ([ "-mcpu=G3", "-mtune=7450"])
679 else:
680 opt_flags.extend ([ "-mcpu=7400", "-maltivec", "-mabi=altivec"])
681 else:
682 opt_flags.extend([ "-mcpu=750", "-mmultiple" ])
683 opt_flags.extend (["-mhard-float", "-mpowerpc-gfxopt"])
684 opt_flags.extend (["-Os"])
686 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':
688 build_host_supports_sse = 0
691 # ARCH_X86 means anything in the x86 family from i386 to x86_64
692 # USE_X86_64_ASM is used to distingush 32 and 64 bit assembler
695 if (re.search ("(i[0-9]86|x86_64)", config[config_cpu]) != None):
696 debug_flags.append ("-DARCH_X86")
697 opt_flags.append ("-DARCH_X86")
699 if config[config_kernel] == 'linux' :
701 if env['DIST_TARGET'] != 'i386':
703 flag_line = os.popen ("cat /proc/cpuinfo | grep '^flags'").read()[:-1]
704 x86_flags = flag_line.split (": ")[1:][0].split ()
706 if "mmx" in x86_flags:
707 opt_flags.append ("-mmmx")
708 if "sse" in x86_flags:
709 build_host_supports_sse = 1
710 if "3dnow" in x86_flags:
711 opt_flags.append ("-m3dnow")
713 if config[config_cpu] == "i586":
714 opt_flags.append ("-march=i586")
715 elif config[config_cpu] == "i686":
716 opt_flags.append ("-march=i686")
718 if ((env['DIST_TARGET'] == 'i686') or (env['DIST_TARGET'] == 'x86_64')) and build_host_supports_sse:
719 opt_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
720 debug_flags.extend (["-msse", "-mfpmath=sse", "-DUSE_XMMINTRIN"])
722 if (env['VST']):
724 # everything must be 32 bit for VST (we're not replicating Cakewalk's hack, yet ...)
726 opt_flags.extend(["-m32"])
727 debug_flags.extend(["-m32"])
729 # end of processor-specific section
731 # optimization section
732 if env['FPU_OPTIMIZATION']:
733 if env['DIST_TARGET'] == 'tiger' or env['DIST_TARGET'] == 'leopard':
734 opt_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
735 debug_flags.append ("-DBUILD_VECLIB_OPTIMIZATIONS");
736 libraries['core'].Append(LINKFLAGS= '-framework Accelerate')
737 elif env['DIST_TARGET'] == 'i686' or env['DIST_TARGET'] == 'x86_64':
738 opt_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
739 debug_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
740 if env['DIST_TARGET'] == 'x86_64' and not env['VST']:
741 opt_flags.append ("-DUSE_X86_64_ASM")
742 debug_flags.append ("-DUSE_X86_64_ASM")
743 if build_host_supports_sse != 1:
744 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)"
745 # end optimization section
747 # handle x86/x86_64 libdir properly
749 if env['DIST_TARGET'] == 'x86_64':
750 env['LIBDIR']='lib64'
751 else:
752 env['LIBDIR']='lib'
755 # no VST on x86_64
758 if env['DIST_TARGET'] == 'x86_64' and env['VST']:
759 print "\n\n=================================================="
760 print "You cannot use VST plugins with a 64 bit host. Please run scons with VST=0"
761 print "\nIt is theoretically possible to build a 32 bit host on a 64 bit system."
762 print "However, this is tricky and not recommended for beginners."
763 sys.exit (-1)
766 # a single way to test if we're on OS X
769 if env['DIST_TARGET'] in ['panther', 'tiger', 'leopard' ]:
770 env['IS_OSX'] = 1
771 # force tiger or later, to avoid issues on PPC which defaults
772 # back to 10.1 if we don't tell it otherwise.
773 env.Append (CCFLAGS="-DMAC_OS_X_VERSION_MIN_REQUIRED=1040")
775 if env['DIST_TARGET'] == 'leopard':
776 # need this to really build against the 10.4 SDK when building on leopard
777 # ideally this would be configurable, but lets just do that later when we need it
778 env.Append(CCFLAGS="-mmacosx-version-min=10.4 -isysroot /Developer/SDKs/MacOSX10.4u.sdk")
779 env.Append(LINKFLAGS="-mmacosx-version-min=10.4 -isysroot /Developer/SDKs/MacOSX10.4u.sdk")
781 else:
782 env['IS_OSX'] = 0
785 # save off guessed arch element in an env
787 env.Append(CONFIG_ARCH=config[config_arch])
791 # ARCH="..." overrides all
794 if env['ARCH'] != '':
795 opt_flags = env['ARCH'].split()
798 # prepend boiler plate optimization flags
801 opt_flags[:0] = [
802 "-O3",
803 "-fomit-frame-pointer",
804 "-ffast-math",
805 "-fstrength-reduce",
806 "-pipe"
809 if env['DEBUG'] == 1:
810 env.Append(CCFLAGS=" ".join (debug_flags))
811 env.Append(LINKFLAGS=" ".join (debug_flags))
812 else:
813 env.Append(CCFLAGS=" ".join (opt_flags))
814 env.Append(LINKFLAGS=" ".join (opt_flags))
816 if env['STL_DEBUG'] == 1:
817 env.Append(CXXFLAGS="-D_GLIBCXX_DEBUG")
819 if env['UNIVERSAL'] == 1:
820 env.Append(CCFLAGS="-arch i386 -arch ppc")
821 env.Append(LINKFLAGS="-arch i386 -arch ppc")
825 # warnings flags
828 env.Append(CCFLAGS="-Wall")
829 env.Append(CXXFLAGS="-Woverloaded-virtual")
831 if env['EXTRA_WARN']:
832 env.Append(CCFLAGS="-Wextra -pedantic -ansi")
833 env.Append(CXXFLAGS="-ansi")
834 # env.Append(CFLAGS="-iso")
836 if env['LIBLO']:
837 env.Append(CCFLAGS="-DHAVE_LIBLO")
841 # fix scons nitpickiness on APPLE
845 def prep_libcheck(topenv, libinfo):
846 if topenv['IS_OSX']:
848 # rationale: GTK-Quartz uses jhbuild and installs to ~/gtk/inst by default.
849 # All libraries needed should be built against this location
850 if topenv['GTKOSX']:
851 GTKROOT = os.path.expanduser ('~/gtk/inst')
852 libinfo.Append(CPPPATH= GTKROOT + "/include", LIBPATH= GTKROOT + "/lib")
853 libinfo.Append(CXXFLAGS="-I" + GTKROOT + "/include", LINKFLAGS="-L" + GTKROOT + "/lib")
855 prep_libcheck(env, env)
859 # these are part of the Ardour source tree because they are C++
862 libraries['vamp'] = LibraryInfo (LIBS='vampsdk',
863 LIBPATH='#libs/vamp-sdk',
864 CPPPATH='#libs/vamp-sdk')
865 libraries['vamphost'] = LibraryInfo (LIBS='vamphostsdk',
866 LIBPATH='#libs/vamp-sdk',
867 CPPPATH='#libs/vamp-sdk')
869 env['RUBBERBAND'] = False
871 conf = Configure (env)
873 if conf.CheckHeader ('fftw3.h'):
874 env['RUBBERBAND'] = True
875 libraries['rubberband'] = LibraryInfo (LIBS='rubberband',
876 LIBPATH='#libs/rubberband',
877 CPPPATH='#libs/rubberband',
878 CCFLAGS='-DUSE_RUBBERBAND')
879 else:
880 print ""
881 print "-------------------------------------------------------------------------"
882 print "You do not have the FFTW single-precision development package installed."
883 print "This prevents Ardour from using the Rubberband library for timestretching"
884 print "and pitchshifting. It will fall back on SoundTouch for timestretch, and "
885 print "pitchshifting will not be available."
886 print "-------------------------------------------------------------------------"
887 print ""
889 conf.Finish()
892 # Check for libusb
894 libraries['usb'] = LibraryInfo ()
895 prep_libcheck(env, libraries['usb'])
897 conf = Configure (libraries['usb'])
898 if conf.CheckLib ('usb', 'usb_interrupt_write'):
899 have_libusb = True
900 else:
901 have_libusb = False
903 # check for linux/input.h while we're at it for powermate
904 if conf.CheckHeader('linux/input.h'):
905 have_linux_input = True
906 else:
907 have_linux_input = False
909 libraries['usb'] = conf.Finish ()
912 # Check for wiimote dependencies
914 if env['WIIMOTE']:
915 wiimoteConf = env.Configure ( )
916 if not wiimoteConf.CheckHeader('cwiid.h'):
917 print 'WIIMOTE configured but you are missing libcwiid!'
918 sys.exit(1)
919 if not wiimoteConf.CheckHeader('bluetooth/bluetooth.h'):
920 print 'WIIMOTE configured but you are missing the libbluetooth headers which you need to compile wiimote support!'
921 sys.exit(1)
922 wiimoteConf.Finish()
926 # Check for FLAC
928 libraries['flac'] = LibraryInfo ()
929 prep_libcheck(env, libraries['flac'])
930 libraries['flac'].Append(CPPPATH="/usr/local/include", LIBPATH="/usr/local/lib")
933 # june 1st 2007: look for a function that is in FLAC 1.1.2 and not in later versions
934 # since the version of libsndfile we have internally does not support
935 # the new API that libFLAC has adopted
938 conf = Configure (libraries['flac'])
939 if conf.CheckLib ('FLAC', 'FLAC__seekable_stream_decoder_init', language='CXX'):
940 conf.env.Append(CCFLAGS='-DHAVE_FLAC')
941 use_flac = True
942 else:
943 use_flac = False
945 libraries['flac'] = conf.Finish ()
947 # or if that fails...
948 #libraries['flac'] = LibraryInfo (LIBS='FLAC')
950 # boost (we don't link against boost, just use some header files)
952 libraries['boost'] = LibraryInfo ()
953 prep_libcheck(env, libraries['boost'])
954 libraries['boost'].Append(CPPPATH="/usr/local/include", LIBPATH="/usr/local/lib")
955 conf = Configure (libraries['boost'])
956 if conf.CheckHeader ('boost/shared_ptr.hpp', language='CXX') == False:
957 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."
958 sys.exit (1)
960 libraries['boost'] = conf.Finish ()
963 # Check for liblo
965 if env['LIBLO']:
966 libraries['lo'] = LibraryInfo ()
967 prep_libcheck(env, libraries['lo'])
969 conf = Configure (libraries['lo'])
970 if conf.CheckLib ('lo', 'lo_server_new') == False:
971 print "liblo does not appear to be installed."
972 sys.exit (1)
974 libraries['lo'] = conf.Finish ()
977 # Check for dmalloc
979 libraries['dmalloc'] = LibraryInfo ()
980 prep_libcheck(env, libraries['dmalloc'])
983 # look for the threaded version
986 conf = Configure (libraries['dmalloc'])
987 if conf.CheckLib ('dmallocth', 'dmalloc_shutdown'):
988 have_libdmalloc = True
989 else:
990 have_libdmalloc = False
992 libraries['dmalloc'] = conf.Finish ()
995 # ensure FREEDESKTOP target is doable..
998 conf = env.Configure ()
999 if env['FREEDESKTOP']:
1000 have_update_mime_database = conf.TryAction (Action ('update-mime-database -v'))
1001 if have_update_mime_database[0] != 1:
1002 print "Warning. You have no update-mime-database command in your PATH. FREEDESKTOP is now disabled."
1003 env['FREEDESKTOP'] = 0
1004 have_gtk_update_icon_cache = conf.TryAction (Action ('gtk-update-icon-cache -?'))
1005 if have_gtk_update_icon_cache[0] != 1:
1006 print "Warning. You have no gtk-update-icon-cache command in your PATH. FREEDESKTOP is now disabled."
1007 env['FREEDESKTOP'] = 0
1008 have_update_desktop_database = conf.TryAction (Action ('update-desktop-database -?'))
1009 if have_update_desktop_database[0] != 1:
1010 print "Warning. You have no update-desktop-database command in your PATH. FREEDESKTOP is now disabled."
1011 env['FREEDESKTOP'] = 0
1012 env = conf.Finish()
1015 # Audio/MIDI library (needed for MIDI, since audio is all handled via JACK)
1018 conf = Configure(env)
1020 if conf.CheckCHeader('alsa/asoundlib.h'):
1021 libraries['sysmidi'] = LibraryInfo (LIBS='asound')
1022 env['SYSMIDI'] = 'ALSA Sequencer'
1023 subst_dict['%MIDITAG%'] = "seq"
1024 subst_dict['%MIDITYPE%'] = "alsa/sequencer"
1025 elif conf.CheckCHeader('/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h'):
1026 # this line is needed because scons can't handle -framework in ParseConfig() yet.
1027 if env['GTKOSX']:
1028 # We need Carbon as well as the rest
1029 libraries['sysmidi'] = LibraryInfo (
1030 LINKFLAGS = ' -framework CoreMIDI -framework CoreFoundation -framework CoreAudio -framework CoreServices -framework AudioUnit -framework AudioToolbox -framework Carbon -bind_at_load' )
1031 else:
1032 libraries['sysmidi'] = LibraryInfo (
1033 LINKFLAGS = ' -framework CoreMIDI -framework CoreFoundation -framework CoreAudio -framework CoreServices -framework AudioUnit -framework AudioToolbox -bind_at_load' )
1034 env['SYSMIDI'] = 'CoreMIDI'
1035 subst_dict['%MIDITAG%'] = "ardour"
1036 subst_dict['%MIDITYPE%'] = "coremidi"
1037 else:
1038 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."
1039 sys.exit (1)
1041 env = conf.Finish()
1043 if env['GTKOSX']:
1044 clearlooks_version = 'libs/clearlooks-newer'
1045 else:
1046 clearlooks_version = 'libs/clearlooks-older'
1048 if env['SYSLIBS']:
1050 syslibdeps = \
1052 'sigc++-2.0' : '2.0',
1053 'gtkmm-2.4' : '2.8',
1054 'libgnomecanvasmm-2.6' : '2.12.0'
1057 conf = Configure(env, custom_tests = { 'CheckPKGConfig' : CheckPKGConfig,
1058 'CheckPKGVersion' : CheckPKGVersion })
1060 for pkg, version in syslibdeps.iteritems():
1061 if not conf.CheckPKGVersion( pkg, version ):
1062 print '%s >= %s not found.' %(pkg, version)
1063 DependenciesRequiredMessage()
1064 Exit(1)
1066 env = conf.Finish()
1068 libraries['sigc2'] = LibraryInfo()
1069 libraries['sigc2'].ParseConfig('pkg-config --cflags --libs sigc++-2.0')
1070 libraries['glibmm2'] = LibraryInfo()
1071 libraries['glibmm2'].ParseConfig('pkg-config --cflags --libs glibmm-2.4')
1072 libraries['cairomm'] = LibraryInfo()
1073 libraries['cairomm'].ParseConfig('pkg-config --cflags --libs cairomm-1.0')
1074 libraries['gdkmm2'] = LibraryInfo()
1075 libraries['gdkmm2'].ParseConfig ('pkg-config --cflags --libs gdkmm-2.4')
1076 libraries['gtkmm2'] = LibraryInfo()
1077 libraries['gtkmm2'].ParseConfig ('pkg-config --cflags --libs gtkmm-2.4')
1078 libraries['atkmm'] = LibraryInfo()
1079 libraries['atkmm'].ParseConfig ('pkg-config --cflags --libs atkmm-1.6')
1080 libraries['pangomm'] = LibraryInfo()
1081 libraries['pangomm'].ParseConfig ('pkg-config --cflags --libs pangomm-1.4')
1082 libraries['libgnomecanvasmm'] = LibraryInfo()
1083 libraries['libgnomecanvasmm'].ParseConfig ('pkg-config --cflags --libs libgnomecanvasmm-2.6')
1086 # cannot use system one for the time being
1089 libraries['sndfile-ardour'] = LibraryInfo(LIBS='libsndfile-ardour',
1090 LIBPATH='#libs/libsndfile',
1091 CPPPATH=['#libs/libsndfile/src'])
1093 # libraries['libglademm'] = LibraryInfo()
1094 # libraries['libglademm'].ParseConfig ('pkg-config --cflags --libs libglademm-2.4')
1096 # libraries['flowcanvas'] = LibraryInfo(LIBS='flowcanvas', LIBPATH='#/libs/flowcanvas', CPPPATH='#libs/flowcanvas')
1097 libraries['soundtouch'] = LibraryInfo()
1098 libraries['soundtouch'].ParseConfig ('pkg-config --cflags --libs soundtouch-1.0')
1099 # Comment the previous line and uncomment this for old versions of Debian:
1100 #libraries['soundtouch'].ParseConfig ('pkg-config --cflags --libs libSoundTouch')
1102 libraries['appleutility'] = LibraryInfo(LIBS='libappleutility',
1103 LIBPATH='#libs/appleutility',
1104 CPPPATH='#libs/appleutility')
1106 coredirs = [
1107 'templates',
1108 'manual'
1111 subdirs = [
1112 'libs/libsndfile',
1113 'libs/pbd',
1114 'libs/midi++2',
1115 'libs/ardour',
1116 'libs/vamp-sdk',
1117 'libs/vamp-plugins/',
1118 # these are unconditionally included but have
1119 # tests internally to avoid compilation etc
1120 # if VST is not set
1121 'libs/fst',
1122 'vst',
1123 # this is unconditionally included but has
1124 # tests internally to avoid compilation etc
1125 # if COREAUDIO is not set
1126 'libs/appleutility'
1129 gtk_subdirs = [
1130 # 'libs/flowcanvas',
1131 'libs/gtkmm2ext',
1132 'gtk2_ardour',
1133 clearlooks_version
1136 else:
1137 libraries['sigc2'] = LibraryInfo(LIBS='sigc++2',
1138 LIBPATH='#libs/sigc++2',
1139 CPPPATH='#libs/sigc++2')
1140 libraries['glibmm2'] = LibraryInfo(LIBS='glibmm2',
1141 LIBPATH='#libs/glibmm2',
1142 CPPPATH='#libs/glibmm2')
1143 libraries['pangomm'] = LibraryInfo(LIBS='pangomm',
1144 LIBPATH='#libs/gtkmm2/pango',
1145 CPPPATH='#libs/gtkmm2/pango')
1146 libraries['cairomm'] = LibraryInfo(LIBS='cairomm',
1147 LIBPATH='#libs/cairomm',
1148 CPPPATH='#libs/cairomm')
1149 libraries['atkmm'] = LibraryInfo(LIBS='atkmm',
1150 LIBPATH='#libs/gtkmm2/atk',
1151 CPPPATH='#libs/gtkmm2/atk')
1152 libraries['gdkmm2'] = LibraryInfo(LIBS='gdkmm2',
1153 LIBPATH='#libs/gtkmm2/gdk',
1154 CPPPATH='#libs/gtkmm2/gdk')
1155 libraries['gtkmm2'] = LibraryInfo(LIBS='gtkmm2',
1156 LIBPATH="#libs/gtkmm2/gtk",
1157 CPPPATH='#libs/gtkmm2/gtk/')
1158 libraries['libgnomecanvasmm'] = LibraryInfo(LIBS='libgnomecanvasmm',
1159 LIBPATH='#libs/libgnomecanvasmm',
1160 CPPPATH='#libs/libgnomecanvasmm')
1162 libraries['soundtouch'] = LibraryInfo(LIBS='soundtouch',
1163 LIBPATH='#libs/soundtouch',
1164 CPPPATH=['#libs', '#libs/soundtouch'])
1165 libraries['sndfile-ardour'] = LibraryInfo(LIBS='libsndfile-ardour',
1166 LIBPATH='#libs/libsndfile',
1167 CPPPATH=['#libs/libsndfile', '#libs/libsndfile/src'])
1168 # libraries['libglademm'] = LibraryInfo(LIBS='libglademm',
1169 # LIBPATH='#libs/libglademm',
1170 # CPPPATH='#libs/libglademm')
1171 libraries['appleutility'] = LibraryInfo(LIBS='libappleutility',
1172 LIBPATH='#libs/appleutility',
1173 CPPPATH='#libs/appleutility')
1175 coredirs = [
1176 'templates',
1177 'manual'
1180 subdirs = [
1181 'libs/sigc++2',
1182 'libs/libsndfile',
1183 'libs/pbd',
1184 'libs/midi++2',
1185 'libs/ardour',
1186 'libs/vamp-sdk',
1187 'libs/vamp-plugins/',
1188 # these are unconditionally included but have
1189 # tests internally to avoid compilation etc
1190 # if VST is not set
1191 'libs/fst',
1192 'vst',
1193 # this is unconditionally included but has
1194 # tests internally to avoid compilation etc
1195 # if COREAUDIO is not set
1196 'libs/appleutility'
1199 gtk_subdirs = [
1200 'libs/glibmm2',
1201 'libs/gtkmm2/pango',
1202 'libs/gtkmm2/atk',
1203 'libs/gtkmm2/gdk',
1204 'libs/gtkmm2/gtk',
1205 'libs/libgnomecanvasmm',
1206 'libs/gtkmm2ext',
1207 'gtk2_ardour',
1208 clearlooks_version
1212 # * always build the LGPL control protocol lib, since we link against it from libardour
1213 # * ditto for generic MIDI
1214 # * tranzport & wiimote check whether they should build internally, but we need them here
1215 # so that they are included in the tarball
1218 surface_subdirs = [ 'libs/surfaces/control_protocol',
1219 'libs/surfaces/generic_midi',
1220 'libs/surfaces/tranzport',
1221 'libs/surfaces/mackie',
1222 'libs/surfaces/powermate',
1223 'libs/surfaces/wiimote'
1226 if env['SURFACES']:
1227 if have_libusb:
1228 env['TRANZPORT'] = 1
1229 else:
1230 env['TRANZPORT'] = 0
1231 print 'Disabled building Tranzport code because libusb could not be found'
1233 if have_linux_input:
1234 env['POWERMATE'] = 1
1235 else:
1236 env['POWERMATE'] = 0
1237 print 'Disabled building Powermate code because linux/input.h could not be found'
1239 if os.access ('libs/surfaces/sony9pin', os.F_OK):
1240 surface_subdirs += [ 'libs/surfaces/sony9pin' ]
1241 else:
1242 env['POWERMATE'] = 0
1243 env['TRANZPORT'] = 0
1246 # timestretch libraries
1249 timefx_subdirs = ['libs/soundtouch']
1250 if env['RUBBERBAND']:
1251 timefx_subdirs += ['libs/rubberband']
1253 opts.Save('scache.conf', env)
1254 Help(opts.GenerateHelpText(env))
1256 final_prefix = '$PREFIX'
1258 if env['DESTDIR'] :
1259 install_prefix = '$DESTDIR/$PREFIX'
1260 else:
1261 install_prefix = env['PREFIX']
1263 subst_dict['%INSTALL_PREFIX%'] = install_prefix;
1264 subst_dict['%FINAL_PREFIX%'] = final_prefix;
1265 subst_dict['%PREFIX%'] = final_prefix;
1267 if env['PREFIX'] == '/usr':
1268 final_config_prefix = '/etc'
1269 else:
1270 final_config_prefix = env['PREFIX'] + '/etc'
1272 config_prefix = '$DESTDIR' + final_config_prefix
1275 # everybody needs this
1278 env.Merge ([ libraries['core'] ])
1282 # i18n support
1285 conf = Configure (env)
1286 if env['NLS']:
1287 nls_error = 'This system is not configured for internationalized applications. An english-only version will be built:'
1288 print 'Checking for internationalization support ...'
1289 have_gettext = conf.TryAction(Action('xgettext --version'))
1290 if have_gettext[0] != 1:
1291 nls_error += ' No xgettext command.'
1292 env['NLS'] = 0
1293 else:
1294 print "Found xgettext"
1296 have_msgmerge = conf.TryAction(Action('msgmerge --version'))
1297 if have_msgmerge[0] != 1:
1298 nls_error += ' No msgmerge command.'
1299 env['NLS'] = 0
1300 else:
1301 print "Found msgmerge"
1303 if not conf.CheckCHeader('libintl.h'):
1304 nls_error += ' No libintl.h.'
1305 env['NLS'] = 0
1307 if env['NLS'] == 0:
1308 print nls_error
1309 else:
1310 print "International version will be built."
1311 env = conf.Finish()
1313 if env['NLS'] == 1:
1314 env.Append(CCFLAGS="-DENABLE_NLS")
1316 Export('env install_prefix final_prefix config_prefix final_config_prefix libraries i18n ardour_version subst_dict use_flac')
1319 # the configuration file may be system dependent
1322 conf = env.Configure ()
1324 if conf.CheckCHeader('/System/Library/Frameworks/CoreAudio.framework/Versions/A/Headers/CoreAudio.h'):
1325 subst_dict['%JACK_INPUT%'] = "coreaudio:Built-in Audio:in"
1326 subst_dict['%JACK_OUTPUT%'] = "coreaudio:Built-in Audio:out"
1327 else:
1328 subst_dict['%JACK_INPUT%'] = "alsa_pcm:playback_"
1329 subst_dict['%JACK_OUTPUT%'] = "alsa_pcm:capture_"
1331 # posix_memalign available
1332 if not conf.CheckFunc('posix_memalign'):
1333 print 'Did not find posix_memalign(), using malloc'
1334 env.Append(CCFLAGS='-DNO_POSIX_MEMALIGN')
1337 env = conf.Finish()
1339 # Which GTK tooltips API
1341 gtktestenv = env.Clone ()
1342 gtktestenv.Merge ([
1343 libraries['gtk2']
1346 conf = gtktestenv.Configure ()
1348 if conf.CheckFunc('gtk_widget_set_tooltip_text'):
1349 env.Append (CXXFLAGS='-DGTK_NEW_TOOLTIP_API')
1351 conf.Finish ()
1354 # generate the per-user and system rc files from the same source
1356 sysrcbuild = env.SubstInFile ('ardour_system.rc','ardour.rc.in', SUBST_DICT = subst_dict)
1358 # add to the substitution dictionary
1360 subst_dict['%VERSION%'] = ardour_version[0:3]
1361 subst_dict['%EXTRA_VERSION%'] = ardour_version[3:]
1362 subst_dict['%REVISION_STRING%'] = ''
1363 if os.path.exists('.svn'):
1364 subst_dict['%REVISION_STRING%'] = '.' + fetch_svn_revision ('.') + 'svn'
1366 # specbuild = env.SubstInFile ('ardour.spec','ardour.spec.in', SUBST_DICT = subst_dict)
1368 the_revision = env.Command ('frobnicatory_decoy', [], create_stored_revision)
1369 remove_ardour = env.Command ('frobnicatory_decoy2', [],
1370 [ Delete ('$PREFIX/etc/ardour2'),
1371 Delete ('$PREFIX/lib/ardour2'),
1372 Delete ('$PREFIX/bin/ardour2'),
1373 Delete ('$PREFIX/share/ardour2')])
1375 env.Alias('revision', the_revision)
1376 env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour2'), 'ardour_system.rc'))
1377 env.Alias('uninstall', remove_ardour)
1379 Default (sysrcbuild)
1381 # source tarball
1383 Precious (env['DISTTREE'])
1385 env.Distribute (env['DISTTREE'],
1386 [ 'SConstruct',
1387 'COPYING', 'PACKAGER_README', 'README',
1388 'ardour.rc.in',
1389 'tools/config.guess',
1390 'icons/icon/ardour_icon_mac_mask.png',
1391 'icons/icon/ardour_icon_mac.png',
1392 'icons/icon/ardour_icon_tango_16px_blue.png',
1393 'icons/icon/ardour_icon_tango_16px_red.png',
1394 'icons/icon/ardour_icon_tango_22px_blue.png',
1395 'icons/icon/ardour_icon_tango_22px_red.png',
1396 'icons/icon/ardour_icon_tango_32px_blue.png',
1397 'icons/icon/ardour_icon_tango_32px_red.png',
1398 'icons/icon/ardour_icon_tango_48px_blue.png',
1399 'icons/icon/ardour_icon_tango_48px_red.png'
1401 glob.glob ('ardour.1*') +
1402 glob.glob ('libs/clearlooks-newer/*.c') +
1403 glob.glob ('libs/clearlooks-newer/*.h') +
1404 glob.glob ('libs/clearlooks-newer/SConscript')
1407 srcdist = env.Tarball(env['TARBALL'], [ env['DISTTREE'], the_revision ])
1408 env.Alias ('srctar', srcdist)
1411 # don't leave the distree around
1414 env.AddPreAction (env['DISTTREE'], Action ('rm -rf ' + str (File (env['DISTTREE']))))
1415 env.AddPostAction (srcdist, Action ('rm -rf ' + str (File (env['DISTTREE']))))
1418 # Update revision info before going into subdirs
1421 create_stored_revision()
1424 # the subdirs
1427 for subdir in coredirs:
1428 SConscript (subdir + '/SConscript')
1430 for sublistdir in [ subdirs, timefx_subdirs, gtk_subdirs, surface_subdirs ]:
1431 for subdir in sublistdir:
1432 SConscript (subdir + '/SConscript')
1434 # cleanup
1435 env.Clean ('scrub', [ 'scache.conf', '.sconf_temp', '.sconsign.dblite', 'config.log'])