X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fpbd%2Fwscript;h=05c2deb1aedfd135c02c3a9b573972e311148d62;hb=7e766be2cbe159a9d584009e0982a8fdb65c863b;hp=354d757be05426e5bcd4be751c573e75f2ec8fb1;hpb=e455805d2b97dfff89ff4c9cf0b22d282b7b8366;p=ardour.git diff --git a/libs/pbd/wscript b/libs/pbd/wscript index 354d757be0..05c2deb1ae 100644 --- a/libs/pbd/wscript +++ b/libs/pbd/wscript @@ -1,5 +1,6 @@ #!/usr/bin/env python from waflib.extras import autowaf as autowaf +from waflib import Options from waflib import TaskGen import os import sys @@ -15,6 +16,7 @@ LIBPBD_VERSION = "%s.%s.%s" % (MAJOR, MINOR, MICRO) # minor increment <=> compatible changes (additions) # micro increment <=> no interface changes LIBPBD_LIB_VERSION = '4.1.0' +LIBPBD_MAJOR_VERSION = '4' # Variables for 'waf dist' APPNAME = 'libpbd' @@ -27,87 +29,129 @@ out = 'build' path_prefix = 'libs/pbd/' +libpbd_sources = [ + 'basename.cc', + 'base_ui.cc', + 'boost_debug.cc', + 'cartesian.cc', + 'command.cc', + 'configuration_variable.cc', + 'convert.cc', + 'controllable.cc', + 'crossthread.cc', + 'cpus.cc', + 'debug.cc', + 'demangle.cc', + 'enumwriter.cc', + 'event_loop.cc', + 'enums.cc', + 'epa.cc', + 'error.cc', + 'ffs.cc', + 'file_archive.cc', + 'file_utils.cc', + 'fpu.cc', + 'id.cc', + 'locale_guard.cc', + 'localtime_r.cc', + 'malign.cc', + 'md5.cc', + 'mountpoint.cc', + 'openuri.cc', + 'pathexpand.cc', + 'pbd.cc', + 'pool.cc', + 'property_list.cc', + 'pthread_utils.cc', + 'reallocpool.cc', + 'receiver.cc', + 'resource.cc', + 'search_path.cc', + 'semutils.cc', + 'shortpath.cc', + 'signals.cc', + 'stacktrace.cc', + 'stateful_diff_command.cc', + 'stateful.cc', + 'strreplace.cc', + 'strsplit.cc', + 'system_exec.cc', + 'textreceiver.cc', + 'timer.cc', + 'timing.cc', + 'tlsf.cc', + 'transmitter.cc', + 'undo.cc', + 'uuid.cc', + 'whitespace.cc', + 'xml++.cc', +] + def options(opt): + opt.load('compiler_cxx') autowaf.set_options(opt) + opt.add_option('--ppc', action='store_true', default=False, dest='ppc', + help='Compile with -arch ppc (OS X ONLY)') + opt.add_option('--dist-target', type='string', default='auto', dest='dist_target', + help='Specify the target for cross-compiling [auto,none,x86,i386,i686,x86_64,tiger,leopard,mingw,msvc]') + opt.add_option('--internal-shared-libs', action='store_true', default=True, dest='internal_shared_libs', + help='Build internal libs as shared libraries') def configure(conf): conf.load('compiler_cxx') - autowaf.build_version_files(path_prefix+'pbd/version.h', path_prefix+'version.cc', - 'libpbd', MAJOR, MINOR, MICRO) autowaf.configure(conf) autowaf.check_pkg(conf, 'libxml-2.0', uselib_store='XML') autowaf.check_pkg(conf, 'sigc++-2.0', uselib_store='SIGCPP', atleast_version='2.0') - if sys.platform != 'darwin': - autowaf.check_pkg(conf, 'uuid', uselib_store='UUID') + autowaf.check_pkg(conf, 'libcurl', uselib_store='CURL', atleast_version='7.0.0', mandatory=True) + autowaf.check_pkg(conf, 'libarchive', uselib_store='ARCHIVE', atleast_version='3.0.0', mandatory=True) + autowaf.check_pkg(conf, 'glibmm-2.4', uselib_store='GLIBMM', atleast_version='2.32.0', mandatory=True) + autowaf.check_pkg(conf, 'giomm-2.4', uselib_store='GIOMM', atleast_version='2.2', mandatory=True) conf.check(function_name='getmntent', header_name='mntent.h', define_name='HAVE_GETMNTENT',mandatory=False) conf.check(header_name='execinfo.h', define_name='HAVE_EXECINFO',mandatory=False) conf.check(header_name='unistd.h', define_name='HAVE_UNISTD',mandatory=False) - if conf.check_cc(function_name='posix_memalign', header_name='stdlib.h', cflags='-D_XOPEN_SOURCE=600',mandatory=False) == False: - conf.define ('NO_POSIX_MEMALIGN',1) - - conf.write_config_header('libpbd-config.h', remove=False) + if not Options.options.ppc: + conf.check_cc(function_name='posix_memalign', header_name='stdlib.h', cflags='-D_XOPEN_SOURCE=600', define_name='HAVE_POSIX_MEMALIGN', mandatory=False) + conf.check(function_name='localtime_r', header_name='time.h', define_name='HAVE_LOCALTIME_R',mandatory=False) # Boost headers autowaf.check_header(conf, 'cxx', 'boost/shared_ptr.hpp') autowaf.check_header(conf, 'cxx', 'boost/weak_ptr.hpp') - # autowaf.check_header(conf, 'cxx', 'boost/uuid/uuid.hpp') + if Options.options.dist_target == 'mingw': + conf.check(compiler='cxx', + lib='ole32', + mandatory=True, + uselib_store='OLE') + + if Options.options.internal_shared_libs: + conf.define('INTERNAL_SHARED_LIBS', 1) + + conf.write_config_header('libpbd-config.h', remove=False) def build(bld): + if not autowaf.is_child(): # Building standalone, install dev stuff + # C++ Headers + includedir = '${INCLUDEDIR}/pbd-%s/pbd' % LIBPBD_MAJOR_VERSION + bld.install_files(includedir, bld.path.ant_glob('pbd/*.h')) + bld.install_files(includedir, 'build/pbd/signals_generated.h') + + # Pkgconfig file + autowaf.build_pc(bld, 'libpbd', LIBPBD_VERSION, LIBPBD_MAJOR_VERSION, [], + {'LIBPBD_VERSION' : LIBPBD_VERSION, + 'LIBPBD_MAJOR_VERSION' : LIBPBD_MAJOR_VERSION}) + + # Make signals_generated.h using signals.py + bld(rule = sys.executable + ' ${SRC} ${TGT}', source = 'pbd/signals.py', target = 'pbd/signals_generated.h') + # Library - obj = bld(features = 'cxx cxxshlib') - obj.source = ''' - basename.cc - base_ui.cc - boost_debug.cc - cartesian.cc - command.cc - convert.cc - controllable.cc - controllable_descriptor.cc - clear_dir.cc - crossthread.cc - cpus.cc - debug.cc - enumwriter.cc - event_loop.cc - dmalloc.cc - enums.cc - epa.cc - error.cc - filesystem.cc - filesystem_paths.cc - file_manager.cc - file_utils.cc - fpu.cc - id.cc - locale_guard.cc - malign.cc - mountpoint.cc - openuri.cc - pathscanner.cc - pool.cc - property_list.cc - pthread_utils.cc - receiver.cc - search_path.cc - semutils.cc - shortpath.cc - signals.cc - sndfile_manager.cc - stacktrace.cc - stateful_diff_command.cc - stateful.cc - strreplace.cc - strsplit.cc - textreceiver.cc - transmitter.cc - undo.cc - uuid.cc - version.cc - whitespace.cc - xml++.cc - ''' + if bld.is_defined ('INTERNAL_SHARED_LIBS'): + obj = bld.shlib(features = 'cxx cxxshlib', source=libpbd_sources) + obj.defines = [ 'LIBPBD_DLL_EXPORTS=1' ] + else: + obj = bld.stlib(features = 'cxx cxxstlib', source=libpbd_sources) + obj.cxxflags = [ '-fPIC' ] + obj.cflags = [ '-fPIC' ] + obj.defines = [] if bld.is_defined('DEBUG_RT_ALLOC'): obj.source += 'debug_rt_alloc.c' @@ -116,17 +160,27 @@ def build(bld): obj.includes = ['.'] obj.name = 'libpbd' obj.target = 'pbd' - obj.uselib = 'GLIBMM SIGCPP XML UUID SNDFILE GIOMM' + obj.uselib = 'GLIBMM SIGCPP XML UUID SNDFILE GIOMM ARCHIVE CURL' if sys.platform == 'darwin': TaskGen.task_gen.mappings['.mm'] = TaskGen.task_gen.mappings['.cc'] - obj.source += 'cocoa_open_uri.mm' + if 'cocoa_open_uri.mm' not in obj.source: + obj.source += [ 'cocoa_open_uri.mm' ] obj.uselib += ' OSX' obj.vnum = LIBPBD_LIB_VERSION - obj.install_path = os.path.join(bld.env['LIBDIR'], 'ardour3') - obj.defines = ['PACKAGE="' + I18N_PACKAGE + '"'] + obj.install_path = bld.env['LIBDIR'] + obj.defines += [ 'PACKAGE="' + I18N_PACKAGE + '"' ] + + if sys.platform.startswith('netbsd'): + obj.linkflags = '-lexecinfo' if bld.env['build_target'] == 'x86_64': obj.defines += [ 'USE_X86_64_ASM' ] + if bld.env['build_target'] == 'mingw': + obj.defines += [ 'NO_POSIX_MEMALIGN' ] + obj.source += [ 'windows_special_dirs.cc' ] + obj.source += [ 'windows_timer_utils.cc' ] + obj.source += [ 'windows_mmcss.cc' ] + obj.uselib += ' OLE' if bld.env['BUILD_TESTS'] and bld.is_defined('HAVE_CPPUNIT'): # Unit tests @@ -134,16 +188,23 @@ def build(bld): testobj.source = ''' test/testrunner.cc test/xpath.cc + test/mutex_test.cc test/scalar_properties.cc test/signals_test.cc test/convert_test.cc + test/filesystem_test.cc + test/natsort_test.cc + test/reallocpool_test.cc + test/xml_test.cc + test/test_common.cc '''.split() + if bld.env['build_target'] == 'mingw': + testobj.source += [ 'test/windows_timer_utils_test.cc' ] testobj.target = 'run-tests' testobj.includes = obj.includes + ['test', '../pbd'] testobj.uselib = 'CPPUNIT XML SNDFILE' testobj.use = 'libpbd' - testobj.linkflags = ['-lrt'] - - -def shutdown(): - autowaf.shutdown() + testobj.name = 'libpbd-tests' + testobj.defines = [ 'PACKAGE="' + I18N_PACKAGE + '"' ] + if sys.platform != 'darwin' and bld.env['build_target'] != 'mingw': + testobj.linkflags = ['-lrt']