allow use of Return, KP_Enter and more in key binding editor; better display of such...
[ardour.git] / wscript
diff --git a/wscript b/wscript
index 2e5d3066759943902160f680eb6e69ad83b00bc9..41976d96277ed427b2c81369e47c91ea4cd6d293 100644 (file)
--- a/wscript
+++ b/wscript
@@ -27,6 +27,7 @@ children = [
        'libs/surfaces',
        'libs/ardour',
        'libs/gtkmm2ext',
+       'libs/clearlooks-newer',
        'gtk2_ardour'
 ]
 
@@ -80,7 +81,7 @@ def create_stored_revision():
                sys.exit(-1)
 
        try:
-               text =  '#include <ardour/svn_revision.h>\n'
+               text =  '#include "ardour/svn_revision.h"\n'
                text += 'namespace ARDOUR { extern const char* svn_revision = \"' + rev + '\"; }\n'
                print 'Writing svn revision info to libs/ardour/svn_revision.cc'
                o = file('libs/ardour/svn_revision.cc', 'w')
@@ -90,7 +91,6 @@ def create_stored_revision():
                print 'Could not open libs/ardour/svn_revision.cc for writing\n'
                sys.exit(-1)
 
-
 def set_compiler_flags (conf,opt):
        #
        # Compiler flags and other system-dependent stuff
@@ -210,7 +210,7 @@ def set_compiler_flags (conf,opt):
                        debug_flags.append ("-DUSE_X86_64_ASM")
                if build_host_supports_sse != 1:
                        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)"
-               if conf.check_cc(function_name='posix_memalign', header_name='stdlib.h') == False:
+               if conf.check_cc(function_name='posix_memalign', header_name='stdlib.h', ccflags='-D_XOPEN_SOURCE=600') == False:
                        optimization_flags.append("-DNO_POSIX_MEMALIGN")
 
        # end optimization section
@@ -365,6 +365,101 @@ def configure(conf):
        create_stored_revision()
        autowaf.set_recursive()
        autowaf.configure(conf)
+       
+       if sys.platform == 'darwin':
+               #
+               #       Define OSX as a uselib to use when compiling
+               #       on Darwin to add all applicable flags at once
+               #
+               conf.env.append_value('CXXFLAGS_OSX', "-mmacosx-version-min=10.4")
+               conf.env.append_value('CCFLAGS_OSX', "-mmacosx-version-min=10.4")
+               conf.env.append_value('CXXFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk")
+               conf.env.append_value('CCFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk")
+               conf.env.append_value('LINKFLAGS_OSX', "-mmacosx-version-min=10.4")
+               conf.env.append_value('LINKFLAGS_OSX', "-isysroot /Developer/SDKs/MacOSX10.4u.sdk")
+               
+               conf.env.append_value('LINKFLAGS_OSX', "-sysroot /Developer/SDKs/MacOSX10.4u.sdk")
+               conf.env.append_value('LINKFLAGS_OSX', "-F/System/Library/Frameworks")
+
+               conf.env.append_value('CXXFLAGS_OSX', "-msse")
+               conf.env.append_value('CCFLAGS_OSX', "-msse")
+               conf.env.append_value('CXXFLAGS_OSX', "-msse2")
+               conf.env.append_value('CCFLAGS_OSX', "-msse2")
+               #
+               #       TODO: The previous sse flags NEED to be based
+               #       off processor type.  Need to add in a check
+               #       for that.
+               #
+               
+               conf.env.append_value('LINKFLAGS_OSX', ['-undefined', 'suppress'])
+               conf.env.append_value('LINKFLAGS_OSX', "-flat_namespace")
+               #
+               #       The previous 2 flags avoid circular dependencies
+               #       between libardour and libardour_cp on OS X.
+               #       ld reported -undefined suppress as an unknown option
+               #       in one of the tests ran, removing it for the moment
+               #
+               conf.env.append_value('CXXFLAGS_OSX', "-F/System/Library/Frameworks")
+               conf.env.append_value('CCFLAGS_OSX', "-F/System/Library/Frameworks")
+
+
+       if Options.options.gtkosx:
+               #
+               #       Define Include Paths for GTKOSX
+               #
+               conf.env.append_value('CPPPATH_GTKOSX', "/usr/include/")
+               conf.env.append_value('CPPPATH_GTKOSX', "/usr/include/c++/4.0.0")
+               conf.env.append_value('CPPPATH_GTKOSX', "/usr/include/c++/4.0.0/i686-apple-darwin8/")
+               #
+               #       TODO: Fix the above include path, it needs to be
+               #       defined based off what is read in the configuration
+               #       stage about the machine(PPC, X86, X86_64, etc.)
+               #
+               conf.env.append_value('CPPPATH_GTKOSX', "/usr/lib/gcc/i686-apple-darwin9/4.0.1/include/")
+               #
+               #       TODO: Likewise this needs to be defined not only
+               #       based off the machine characteristics, but also
+               #       based off the version of GCC being used.
+               #
+               conf.env.append_value('CPPPATH_GTKOSX', "/System/Library/Frameworks/")
+               conf.env.append_value('CXXFLAGS_GTKOSX', '-DTOP_MENUBAR')
+               conf.env.append_value('CXXFLAGS_GTKOSX', '-DGTKOSX')
+               conf.env.append_value('LINKFLAGS_GTKOSX', "-framework AppKit")
+               conf.env.append_value('LINKFLAGS_GTKOSX', "-Xlinker -headerpad")
+               conf.env.append_value('LINKFLAGS_GTKOSX', "-Xlinker 2048")
+               conf.env.append_value('CPPPATH_GTKOSX', "/System/Library/Frameworks/CoreServices.framework/Frameworks/CarbonCore.framework/Headers/")
+               #
+               #       I had a note the previous was for MacTypes.h
+               #
+       
+       if Options.options.coreaudio:
+          #conf.env.append_value('LINKFLAGS_COREAUDIO', "-framework CoreAudioKit")
+          #conf.env.append_value('LINKFLAGS_COREAUDIO', "-framework AudioToolbox")
+          #conf.env.append_value('LINKFLAGS_COREAUDIO', "-framework CoreServices")
+          conf.check_cc (header_name = '/System/Library/Frameworks/CoreAudio.framework/Headers/CoreAudio.h',
+                                         define_name = 'HAVE_COREAUDIO', linkflags = ['-framework', 'CoreAudio'])
+          conf.check_cxx (header_name = '/System/Library/Frameworks/AudioToolbox.framework/Headers/ExtendedAudioFile.h',
+                                         linkflags = [ '-framework', 'AudioToolbox' ])
+          conf.check_cc (header_name = '/System/Library/Frameworks/CoreFoundation.framework/Headers/CoreFoundation.h',
+                                         linkflags = ['-framework', 'CoreFoundation'])
+          conf.check_cc (header_name = '/System/Library/Frameworks/CoreServices.framework/Headers/CoreServices.h',
+                                         linkflags = ['-framework', 'CoreServices'])
+          #
+          #    TODO: For some reason the above doesn't seem to be correctly adding the
+          #    the link flags, so we will add them manually.
+          #
+          conf.env.append_value('LINKFLAGS_COREAUDIO', ['-framework', 'CoreServices'])
+          conf.env.append_value('LINKFLAGS_COREAUDIO', ['-framework', 'CoreFoundation'])
+          conf.env.append_value('LINKFLAGS_COREAUDIO', ['-framework', 'AudioToolbox'])
+          conf.env.append_value('LINKFLAGS_COREAUDIO', ['-framework', 'CoreAudio'])
+
+       if Options.options.audiounits:
+          #conf.env.append_value('CXXFLAGS_AUDIOUNITS', "-DHAVE_AUDIOUNITS")
+          conf.env.append_value('LINKFLAGS_AUDIOUNITS', "-framework AudioToolbox")
+          conf.env.append_value('LINKFLAGS_AUDIOUNITS', "-framework CoreServices")
+          conf.check_cc (header_name = '/System/Library/Frameworks/AudioUnit.framework/Headers/AudioUnit.h',
+                                         define_name = 'HAVE_AUDIOUNITS', linkflags = [ '-framework', 'AudioUnit' ])
+
        autowaf.check_pkg(conf, 'glib-2.0', uselib_store='GLIB', atleast_version='2.2')
        autowaf.check_pkg(conf, 'glibmm-2.4', uselib_store='GLIBMM', atleast_version='2.14.0')
        if sys.platform == 'darwin':
@@ -435,6 +530,29 @@ def build(bld):
        for i in children:
                bld.add_subdirs(i)
 
+       # ideally, we'd like to use the OS-provided MIDI API
+       # for default ports. that doesn't work on at least
+       # Fedora (Nov 9th, 2009) so use JACK MIDI on linux.
+       
+       if sys.platform == 'darwin':
+               rc_subst_dict = {
+                       'MIDITAG'    : 'control',
+                       'MIDITYPE'   : 'coremidi',
+                       'JACK_INPUT' : 'auditioner'
+                       }
+       else:
+               rc_subst_dict = {
+                       'MIDITAG'    : 'control',
+                       'MIDITYPE'   : 'jack',
+                       'JACK_INPUT' : 'auditioner'
+                       }
+
+       obj              = bld.new_task_gen('subst')
+       obj.source       = 'ardour.rc.in'
+       obj.target       = 'ardour_system.rc'
+       obj.dict         = rc_subst_dict
+       obj.install_path = '${CONFIGDIR}/ardour3'
+
 def i18n(bld):
        bld.recurse (i18n_children)