Merge branch 'master' into cairocanvas
[ardour.git] / libs / pbd / wscript
index da0f9c0dd104f8068dae62c57217eca88a90e778..09af0f614bee378a034ff4ace824018a9e0bbc7d 100644 (file)
@@ -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
@@ -27,13 +28,65 @@ out = 'build'
 
 path_prefix = 'libs/pbd/'
 
+libpbd_sources = [
+    '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',
+    'enums.cc',
+    'epa.cc',
+    'error.cc',
+    'file_manager.cc',
+    'file_utils.cc',
+    'fpu.cc',
+    'id.cc',
+    'locale_guard.cc',
+    'malign.cc',
+    'mountpoint.cc',
+    'openuri.cc',
+    'pathexpand.cc',
+    'pathscanner.cc',
+    'pbd.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',
+]
+
 def options(opt):
     autowaf.set_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', 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')
@@ -58,58 +111,18 @@ def build(bld):
     bld(rule = 'python ${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
-            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'):
+        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' ]
+        obj.defines      = []
 
     if bld.is_defined('DEBUG_RT_ALLOC'):
         obj.source += 'debug_rt_alloc.c'
@@ -121,12 +134,13 @@ def build(bld):
     obj.uselib       = 'GLIBMM SIGCPP XML UUID SNDFILE GIOMM'
     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.defines     += [ 'PACKAGE="' + I18N_PACKAGE + '"' ]
+    
     if bld.env['build_target'] == 'x86_64':
         obj.defines += [ 'USE_X86_64_ASM' ]
 
@@ -140,6 +154,7 @@ def build(bld):
                 test/signals_test.cc
                 test/convert_test.cc
                 test/filesystem_test.cc
+                test/test_common.cc
         '''.split()
         testobj.target       = 'run-tests'
         testobj.includes     = obj.includes + ['test', '../pbd']