X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fpbd%2Fwscript;h=6f872c987f301441c2ebe7518e3037403d7bd25e;hb=d13435a4e1d0e85654a8477ae99a7b41ff621159;hp=09af0f614bee378a034ff4ace824018a9e0bbc7d;hpb=36c233fe6ce570ce85224626ce7aba4a2607537f;p=ardour.git diff --git a/libs/pbd/wscript b/libs/pbd/wscript index 09af0f614b..6f872c987f 100644 --- a/libs/pbd/wscript +++ b/libs/pbd/wscript @@ -34,48 +34,53 @@ libpbd_sources = [ 'boost_debug.cc', 'cartesian.cc', 'command.cc', + 'configuration_variable.cc', 'convert.cc', 'controllable.cc', - 'controllable_descriptor.cc', - 'clear_dir.cc', 'crossthread.cc', 'cpus.cc', 'debug.cc', + 'demangle.cc', 'enumwriter.cc', 'event_loop.cc', 'enums.cc', 'epa.cc', 'error.cc', - 'file_manager.cc', + 'ffs.cc', 'file_utils.cc', 'fpu.cc', 'id.cc', 'locale_guard.cc', + 'localtime_r.cc', 'malign.cc', + 'md5.cc', 'mountpoint.cc', 'openuri.cc', 'pathexpand.cc', - 'pathscanner.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', - 'sndfile_manager.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', - 'version.cc', 'whitespace.cc', 'xml++.cc', ] @@ -85,40 +90,38 @@ def options(opt): def configure(conf): conf.load('compiler_cxx') - autowaf.build_version_files(path_prefix+'pbd/version.h', path_prefix+'version.cc', - 'libpbd', MAJOR, MINOR, MICRO, 'LIBPBD_API', 'pbd/libpbd_visibility.h') 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') 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) - conf.check_cc(function_name='posix_memalign', header_name='stdlib.h', cflags='-D_XOPEN_SOURCE=600', define_name='HAVE_POSIX_MEMALIGN', mandatory=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) conf.write_config_header('libpbd-config.h', remove=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') def build(bld): - + # Make signals_generated.h using signals.py - bld(rule = 'python ${SRC} ${TGT}', source = 'pbd/signals.py', target = 'pbd/signals_generated.h') + bld(rule = sys.executable + ' ${SRC} ${TGT}', source = 'pbd/signals.py', target = 'pbd/signals_generated.h') # Library if bld.is_defined ('INTERNAL_SHARED_LIBS'): - print('BUILD SHARED LIB') obj = bld.shlib(features = 'cxx cxxshlib', source=libpbd_sources) obj.defines = [ 'LIBPBD_DLL_EXPORTS=1' ] - obj.cxxflags = [ '-fvisibility=hidden' ] - obj.cflags = [ '-fvisibility=hidden' ] else: - print('BUILD STATIC LIB') obj = bld.stlib(features = 'cxx cxxstlib', source=libpbd_sources) obj.cxxflags = [ '-fPIC' ] obj.cflags = [ '-fPIC' ] @@ -138,11 +141,17 @@ def build(bld): 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.install_path = bld.env['LIBDIR'] obj.defines += [ 'PACKAGE="' + I18N_PACKAGE + '"' ] - + 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 @@ -150,20 +159,26 @@ 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.name = 'libpbd-tests' - if sys.platform != 'darwin': + testobj.defines = [ 'PACKAGE="' + I18N_PACKAGE + '"' ] + if sys.platform != 'darwin' and bld.env['build_target'] != 'mingw': testobj.linkflags = ['-lrt'] - def shutdown(): autowaf.shutdown()