X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=libs%2Fardour%2Fwscript;h=dccf53735f6eccd41d4162993a4baa4512c44b83;hb=02ec346c2b8a8872bfb3b7f231556c0f514ff95f;hp=096a0bd20405450da58461b820e1c44c4e2bf589;hpb=c1ef7b14a3e1200817180cfaf6425e9bdf0eb51b;p=ardour.git diff --git a/libs/ardour/wscript b/libs/ardour/wscript index 096a0bd204..dccf53735f 100644 --- a/libs/ardour/wscript +++ b/libs/ardour/wscript @@ -21,8 +21,9 @@ LIBARDOUR_LIB_VERSION = '3.0.0' CURRENT_SESSION_FILE_VERSION = 3000 # Variables for 'waf dist' -APPNAME = 'libardour' +APPNAME = 'libardour3' VERSION = LIBARDOUR_VERSION +I18N_PACKAGE = 'libardour3' # Mandatory variables top = '.' @@ -102,7 +103,6 @@ libardour_sources = [ 'filesystem_paths.cc', 'filter.cc', 'find_session.cc', - 'gain.cc', 'globals.cc', 'graph.cc', 'graphnode.cc', @@ -170,6 +170,7 @@ libardour_sources = [ 'return.cc', 'reverse.cc', 'route.cc', + 'route_graph.cc', 'route_group.cc', 'route_group_member.cc', 'rb_effect.cc', @@ -215,7 +216,7 @@ libardour_sources = [ 'unknown_processor.cc', 'user_bundle.cc', 'utils.cc', - 'version.cc' + 'version.cc', ] def flac_supported(): @@ -254,19 +255,17 @@ def configure(conf): atleast_version='0.1.0') autowaf.check_pkg(conf, 'sigc++-2.0', uselib_store='SIGCPP', atleast_version='2.0') - autowaf.check_pkg(conf, 'lilv-0', uselib_store='LILV', - atleast_version='0.0.0', mandatory=False) - if conf.env['HAVE_LILV']: - autowaf.check_pkg(conf, 'suil-0', uselib_store='SUIL', - atleast_version='0.2.0', mandatory=False) - else: - autowaf.check_pkg(conf, 'slv2', uselib_store='SLV2', - atleast_version='0.6.4', mandatory=False) - if conf.env['HAVE_SLV2']: - autowaf.check_pkg(conf, 'rasqal', uselib_store='RASQAL', - atleast_version='0.9.14', mandatory=False) - autowaf.check_pkg(conf, 'soundtouch-1.0', uselib_store='SOUNDTOUCH', - mandatory=False) + if Options.options.lv2: + autowaf.check_pkg(conf, 'lilv-0', uselib_store='LILV', + atleast_version='0.0.0', mandatory=False) + autowaf.check_pkg(conf, 'lilv-0', uselib_store='NEW_LILV', + atleast_version='0.9.0', mandatory=False) + if conf.is_defined('HAVE_LILV'): + autowaf.check_pkg(conf, 'suil-0', uselib_store='SUIL', + atleast_version='0.2.0', mandatory=False) + +# autowaf.check_pkg(conf, 'soundtouch-1.0', uselib_store='SOUNDTOUCH', +# mandatory=False) autowaf.check_pkg(conf, 'cppunit', uselib_store='CPPUNIT', atleast_version='1.12.0', mandatory=False) autowaf.check_pkg(conf, 'ogg', uselib_store='OGG', atleast_version='1.1.2') @@ -282,13 +281,12 @@ def configure(conf): conf.define('CURRENT_SESSION_FILE_VERSION', CURRENT_SESSION_FILE_VERSION) - conf.check(header_name='sys/vfs.h', define_name='HAVE_SYS_VFS_H') - conf.check(header_name='wordexp.h', define_name='HAVE_WORDEXP') + conf.check(header_name='sys/vfs.h', define_name='HAVE_SYS_VFS_H',mandatory=False) conf.check(header_name='jack/session.h', uselib = [ 'JACK' ], define_name='HAVE_JACK_SESSION') - conf.check(header_name='unistd.h', define_name='HAVE_UNISTD') + conf.check(header_name='unistd.h', define_name='HAVE_UNISTD',mandatory=False) conf.check_cc(fragment = ''' #include @@ -303,9 +301,7 @@ int main(int argc, char **argv) { define_name = 'HAVE_JACK_ON_INFO_SHUTDOWN', okmsg = 'present') - missing_jack_message = '''missing - a version of JACK that supports \ -jack_port_set_latency_range() is required to compile Ardour3. Currently this\ -means using JACK version 0.120.1 from http://www.jackaudio.org/download''' + missing_jack_message = 'missing - a version of JACK that supports jack_port_set_latency_range() is required to compile Ardour3.' conf.check_cc(fragment = ''' #include @@ -338,7 +334,7 @@ int main(int argc, char **argv) { if ogg_supported(): conf.define ('HAVE_OGG', 1) - if conf.env['HAVE_LILV'] or conf.env['HAVE_SLV2']: + if Options.options.lv2 and conf.is_defined('HAVE_LILV'): conf.define ('LV2_SUPPORT', 1) conf.write_config_header('libardour-config.h', remove=False) @@ -359,7 +355,7 @@ def build(bld): obj.name = 'libardour' obj.target = 'ardour' obj.uselib = ['GLIBMM','GTHREAD','AUBIO','SIGCPP','XML','UUID', - 'JACK','SNDFILE','SAMPLERATE','LRDF','AUDIOUNIT', + 'JACK','SNDFILE','SAMPLERATE','LRDF','AUDIOUNITS', 'OSX','BOOST','CURL','DL'] obj.use = ['libpbd','libmidipp','libevoral','libvamphost', 'libvampplugin','libtaglib','librubberband', @@ -367,7 +363,7 @@ def build(bld): obj.vnum = LIBARDOUR_LIB_VERSION obj.install_path = os.path.join(bld.env['LIBDIR'], 'ardour3') obj.defines = [ - 'PACKAGE="libardour3"', + 'PACKAGE="' + I18N_PACKAGE + '"', 'DATA_DIR="' + os.path.normpath(bld.env['DATADIR']) + '"', 'CONFIG_DIR="' + os.path.normpath(bld.env['SYSCONFDIR']) + '"', 'MODULE_DIR="' + os.path.normpath(bld.env['LIBDIR']) + '"', @@ -382,33 +378,33 @@ def build(bld): #obj.uselib += ' SOUNDTOUCH ' #obj.add_objects = 'default/libs/surfaces/control_protocol/smpte_1.o' - if bld.env['HAVE_LILV']: - obj.source += [ 'lv2_plugin_lilv.cc', 'lv2_event_buffer.cc', + if bld.is_defined('HAVE_LILV') : + obj.source += [ 'lv2_plugin.cc', 'lv2_event_buffer.cc', 'uri_map.cc', 'rdff.c' ] obj.uselib += ['LILV'] - if bld.env['HAVE_SUIL']: + if bld.is_defined('HAVE_SUIL'): obj.uselib += ['SUIL'] - elif bld.env['HAVE_SLV2']: - obj.source += [ 'lv2_plugin.cc', 'lv2_event_buffer.cc', - 'uri_map.cc', 'rdff.c' ] - obj.uselib += ['SLV2','RASQAL'] - if bld.env['VST_SUPPORT']: - obj.source += [ 'vst_plugin.cc', 'session_vst.cc' ] + if bld.is_defined('WINDOWS_VST_SUPPORT'): + obj.source += [ 'windows_vst_plugin.cc'] obj.includes += [ '../fst' ] - obj.defines += [ 'VST_SUPPORT' ] - - if bld.env['LXVST_SUPPORT']: - obj.source += [ 'lxvst_plugin.cc', 'session_lxvst.cc', 'vstfx.cc', 'vstfxwin.cc', 'vstfxinfofile.cc' ] - obj.defines += [ 'LXVST_SUPPORT' ] - - - if bld.env['COREAUDIO']: + obj.defines += [ 'WINDOWS_VST_SUPPORT' ] + + if bld.is_defined('LXVST_SUPPORT'): + obj.source += [ 'lxvst_plugin.cc', 'linux_vst_support.cc', 'linux_vst_info_file.cc' ] + obj.defines += [ 'LXVST_SUPPORT' ] + + if bld.is_defined('WINDOWS_VST_SUPPORT') or bld.is_defined('LXVST_SUPPORT'): + obj.source += [ 'session_vst.cc', 'vst_plugin.cc' ] + + if bld.is_defined('HAVE_COREAUDIO'): obj.source += [ 'coreaudiosource.cc', 'caimportable.cc' ] obj.use += ['libappleutility'] + + if bld.is_defined('AUDIOUNIT_SUPPORT'): obj.source += [ 'audio_unit.cc' ] - if bld.env['FPU_OPTIMIZATION']: + if Options.options.fpu_optimization: if (bld.env['build_target'] == 'i386' or bld.env['build_target'] == 'i686'): obj.source += [ 'sse_functions_xmm.cc', 'sse_functions.s' ] @@ -416,25 +412,36 @@ def build(bld): obj.source += [ 'sse_functions_xmm.cc', 'sse_functions_64bit.s' ] # i18n - if bld.env['ENABLE_NLS']: + if bld.is_defined('ENABLE_NLS'): mo_files = bld.path.ant_glob('po/*.mo') for mo in mo_files: - lang = os.path.basename(mo).replace('.mo', '') + lang = os.path.basename(mo.srcpath()).replace('.mo', '') bld.install_as(os.path.join(bld.env['PREFIX'], 'share', 'locale', - lang, 'LC_MESSAGES', 'libardour3.mo'), + lang, 'LC_MESSAGES', I18N_PACKAGE + '.mo'), mo) - if bld.env['BUILD_TESTS'] and bld.env['HAVE_CPPUNIT']: + if bld.env['BUILD_TESTS'] and bld.is_defined('HAVE_CPPUNIT'): # Unit tests testobj = bld(features = 'cxx cxxprogram') testobj.source = ''' - test/bbt_test.cpp - test/interpolation_test.cpp - test/midi_clock_slave_test.cpp - test/resampled_source.cc - test/mantis_3356.cc - test/testrunner.cpp + test/dummy_lxvst.cc + test/test_needing_session.cc + test/test_needing_playlist_and_regions.cc + test/bbt_test.cc + test/tempo_test.cc + test/interpolation_test.cc + test/midi_clock_slave_test.cc + test/resampled_source_test.cc + test/framewalk_to_beats_test.cc + test/framepos_plus_beats_test.cc + test/framepos_minus_beats_test.cc + test/playlist_layering_test.cc + test/testrunner.cc '''.split() + +# Tests that don't work +# test/mantis_3356_test.cc + testobj.includes = obj.includes + ['test', '../pbd'] testobj.uselib = ['CPPUNIT','SIGCPP','JACK','GLIBMM','GTHREAD', 'SAMPLERATE','XML','LRDF','COREAUDIO'] @@ -460,8 +467,53 @@ def build(bld): elif bld.env['build_target'] == 'x86_64': testobj.source += [ 'sse_functions_64bit.s' ] + # Profiling + profilingobj = bld(features = 'cxx cxxprogram') + profilingobj.source = ''' + test/dummy_lxvst.cc + test/profiling/runpc.cc + '''.split() + + profilingobj.includes = obj.includes + profilingobj.uselib = ['CPPUNIT','SIGCPP','JACK','GLIBMM','GTHREAD', + 'SAMPLERATE','XML','LRDF','COREAUDIO'] + profilingobj.use = ['libpbd','libmidipp','libardour'] + profilingobj.name = 'libardour-profiling' + profilingobj.target = 'run-profiling' + profilingobj.install_path = '' + profilingobj.defines = [ + 'PACKAGE="libardour3profile"', + 'DATA_DIR="' + os.path.normpath(bld.env['DATADIR']) + '"', + 'CONFIG_DIR="' + os.path.normpath(bld.env['SYSCONFDIR']) + '"', + 'MODULE_DIR="' + os.path.normpath(bld.env['LIBDIR']) + '"', + 'LOCALEDIR="' + os.path.join( + os.path.normpath(bld.env['DATADIR']), 'locale') + '"', + 'VAMP_DIR="' + os.path.join( + os.path.normpath(bld.env['LIBDIR']), 'ardour3', 'vamp') + '"' + ] + if bld.env['FPU_OPTIMIZATION']: + profilingobj.source += [ 'sse_functions_xmm.cc' ] + if (bld.env['build_target'] == 'i386' + or bld.env['build_target'] == 'i686'): + profilingobj.source += [ 'sse_functions.s' ] + elif bld.env['build_target'] == 'x86_64': + profilingobj.source += [ 'sse_functions_64bit.s' ] + def shutdown(): autowaf.shutdown() def i18n(bld): - autowaf.build_i18n (bld, '.', 'libs/ardour', APPNAME, libardour_sources) + autowaf.build_i18n(bld, top, 'libs/ardour', I18N_PACKAGE, libardour_sources, + 'Paul Davis') + +def i18n_pot(bld): + autowaf.build_i18n(bld, top, 'libs/ardour', I18N_PACKAGE, libardour_sources, + 'Paul Davis') + +def i18n_po(bld): + autowaf.build_i18n_po(bld, top, 'libs/ardour', I18N_PACKAGE, libardour_sources, + 'Paul Davis') + +def i18n_mo(bld): + autowaf.build_i18n_mo(bld, top, 'libs/ardour', I18N_PACKAGE, libardour_sources, + 'Paul Davis')