Tweaked build and run for windows
authorGuy Sherman <guy@guysherman.com>
Sun, 16 Aug 2015 16:01:28 +0000 (18:01 +0200)
committerRobin Gareus <robin@gareus.org>
Sun, 16 Aug 2015 16:01:28 +0000 (18:01 +0200)
Quotes were appearing around the version number. Modified wscript to
remove quotes from VERSION and PROGRAM_VERSION.

One of the places windows looks for DLLs is in directories
listed in PATH. A new file called ardev-win which sets up the
contents of PATH and LD_LIBRARY_PATH as required.

gtk2_ardour/ardev-win [new file with mode: 0644]
gtk2_ardour/ardev_common.sh.in
wscript

diff --git a/gtk2_ardour/ardev-win b/gtk2_ardour/ardev-win
new file mode 100644 (file)
index 0000000..c7a8d4f
--- /dev/null
@@ -0,0 +1,6 @@
+#!/bin/sh
+TOP=`dirname "$0"`/..
+. $TOP/build/gtk2_ardour/ardev_common_waf.sh
+export UBUNTU_MENUPROXY=""
+export PATH=$libs/ptformat:$libs/qm-dsp:$libs/vamp-sdk:$libs/surfaces:$libs/surfaces/control_protocol:$libs/ardour:$libs/midi++2:$libs/pbd:$libs/rubberband:$libs/soundtouch:$libs/gtkmm2ext:$libs/gnomecanvas:$libs/libsndfile:$libs/appleutility:$libs/taglib:$libs/evoral:$libs/evoral/src/libsmf:$libs/audiographer:$libs/timecode:$libs/libltc:$libs/canvas:$libs/ardouralsautil${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}:$PATH
+exec $TOP/$EXECUTABLE "$@"
index eca77916c0ed9b82c57e894dbd39db5ad1af9fe8..cf372c0cca416fc46b309b83e43716ef68773fec 100644 (file)
@@ -5,9 +5,9 @@
 libs=$TOP/@LIBS@
 
 #
-# when running ardev, the various parts of Ardour have not been consolidated into the locations that they 
+# when running ardev, the various parts of Ardour have not been consolidated into the locations that they
 # would normally end up after an install. We therefore need to set up environment variables so that we
-# can find all the components. 
+# can find all the components.
 #
 
 export ARDOUR_PATH=$TOP/gtk2_ardour/icons:$TOP/gtk2_ardour/pixmaps:$TOP/build/gtk2_ardour:$TOP/gtk2_ardour:.
@@ -24,7 +24,7 @@ export EVORAL_TEST_PATH=$TOP/libs/evoral/test/testdata
 export MIDIPP_TEST_PATH=$TOP/patchfiles
 
 #
-# even though we set the above variables, ardour requires that these 
+# even though we set the above variables, ardour requires that these
 # two also be set. the above settings will override them.
 #
 
diff --git a/wscript b/wscript
index 0986252e799f105a4f530355b3021d886fd805ea..7fb80461e98a8896802e77d6d0a338db37bc2628 100644 (file)
--- a/wscript
+++ b/wscript
@@ -72,9 +72,9 @@ compiler_flags_dictionaries= {
         'c-strict' : ['-std=c99', '-pedantic', '-Wshadow'],
         # Flags used for "strict" compilation, C++ only (i.e. compiler will warn about language issues)
         'cxx-strict' : [ '-ansi', '-Wnon-virtual-dtor', '-Woverloaded-virtual', '-fstrict-overflow' ],
-        # Flags required for whatever consider the strictest possible compilation 
+        # Flags required for whatever consider the strictest possible compilation
         'ultra-strict' : ['-Wredundant-decls', '-Wstrict-prototypes', '-Wmissing-prototypes'],
-        # Flag to turn on C99 compliance by itself 
+        # Flag to turn on C99 compliance by itself
         'c99': '-std=c99',
         # Flag to enable AT&T assembler syntax
         'attasm': '-masm=att',
@@ -186,12 +186,22 @@ V = MAJOR + '.' + MINOR + '.' + MICRO
 VERSION = str (V.encode ('ascii', 'ignore'))
 PROGRAM_VERSION = str (MAJOR.encode ('ascii', 'ignore'))
 
+# It seems, that on msys2, with python3, it puts quotes around
+# the version number, which breaks the build.
+VERSION = VERSION.replace('\'', '')
+PROGRAM_VERSION = PROGRAM_VERSION.replace('\'', '')
+
+
 if len (sys.argv) > 1 and sys.argv[1] == 'dist':
         if not 'APPNAME' in os.environ:
                 print "You must define APPNAME in the environment when running ./waf dist"
                 sys.exit (1)
         APPNAME = os.environ['APPNAME'];
-                
+
+# It seems, that on msys2, with python3, it puts quotes around
+# the version number, which breaks the build.
+VERSION = VERSION.replace('\'', '')
+PROGRAM_VERSION = PROGRAM_VERSION.replace('\'', '')
 
 # Mandatory variables
 top = '.'
@@ -318,14 +328,14 @@ int main() { return 0; }''',
         else:
             compiler_name = 'gcc'
 
-    flags_dict = compiler_flags_dictionaries[compiler_name] 
+    flags_dict = compiler_flags_dictionaries[compiler_name]
     # Save the compiler flags because we need them at build time
     # when we need to add compiler specific flags in certain
     # libraries
     conf.env['compiler_flags_dict'] = flags_dict;
-    
+
     autowaf.set_basic_compiler_flags (conf,flags_dict)
-    
+
     if conf.options.asan:
         conf.check_cxx(cxxflags=["-fsanitize=address", "-fno-omit-frame-pointer"], linkflags=["-fsanitize=address"])
         cxx_flags.append('-fsanitize=address')
@@ -381,7 +391,7 @@ int main() { return 0; }''',
         #
         # stupid OS X 10.6 has a bug in math.h that prevents llrint and friends
         # from being visible.
-        # 
+        #
         compiler_flags.append ('-U__STRICT_ANSI__')
 
     if conf.options.cxx11 or conf.env['build_host'] in [ 'mavericks', 'yosemite' ]:
@@ -407,10 +417,10 @@ int main() { return 0; }''',
 
         #
         # ARCH_X86 means anything in the x86 family from i386 to x86_64
-        # the compile-time presence of the macro _LP64 is used to 
+        # the compile-time presence of the macro _LP64 is used to
         # distingush 32 and 64 bit assembler
         #
+
         compiler_flags.append ("-DARCH_X86")
 
         if platform == 'linux' :
@@ -438,7 +448,7 @@ int main() { return 0; }''',
 
         if not is_clang and ((conf.env['build_target'] == 'i686') or (conf.env['build_target'] == 'x86_64')) and build_host_supports_sse:
             compiler_flags.extend ([ flags_dict['sse'], flags_dict['fpmath-sse'], flags_dict['xmmintrinsics'] ])
-            
+
         if (conf.env['build_target'] == 'mingw'):
             if (re.search ("(x86_64|AMD64)", cpu) != None):
                 # on Windows sse is supported by 64 bit platforms only
@@ -446,7 +456,7 @@ int main() { return 0; }''',
 
                 # mingw GCC compiler to uses at&t (Unix specific) assembler dialect by default
                 # compiler_flags.append (["--mmnemonic=att", "msyntax=att")
-                
+
                 compiler_flags.extend ([ flags_dict['sse'], flags_dict['fpmath-sse'], flags_dict['xmmintrinsics'], flags_dict['attasm'] ])
 
     # end of processor-specific section
@@ -461,7 +471,7 @@ int main() { return 0; }''',
         elif conf.env['build_target'] == 'mingw':
                 # usability of the 64 bit windows assembler depends on the compiler target,
                 # not the build host, which in turn can only be inferred from the name
-                # of the compiler. 
+                # of the compiler.
                 if re.search ('x86_64-w64', str(conf.env['CC'])) != None:
                         compiler_flags.append ("-DBUILD_SSE_OPTIMIZATIONS")
         if not build_host_supports_sse:
@@ -580,9 +590,9 @@ int main() { return 0; }''',
         ('-DBOOST_SYSTEM_NO_DEPRECATED', '-D_ISOC9X_SOURCE',
          '-D_LARGEFILE64_SOURCE', '-D_FILE_OFFSET_BITS=64'))
     cxx_flags.extend(
-        ('-D__STDC_LIMIT_MACROS', '-D__STDC_FORMAT_MACROS', 
+        ('-D__STDC_LIMIT_MACROS', '-D__STDC_FORMAT_MACROS',
          '-DCANVAS_COMPATIBILITY', '-DCANVAS_DEBUG'))
-    
+
     if opt.nls:
         compiler_flags.append('-DENABLE_NLS')
 
@@ -590,7 +600,7 @@ int main() { return 0; }''',
     compiler_flags.append ('-DPROGRAM_VERSION="' + PROGRAM_VERSION + '"')
 
     conf.env['PROGRAM_NAME'] = Options.options.program_name
-    
+
     if opt.debug:
         conf.env.append_value('CFLAGS', debug_flags)
         conf.env.append_value('CXXFLAGS', debug_flags)
@@ -610,7 +620,7 @@ int main() { return 0; }''',
 
 def is_tracks_build (conf):
         return conf.env['PROGRAM_NAME'] == 'Tracks Live'
-    
+
 #----------------------------------------------------------------
 
 # Waf stages
@@ -779,7 +789,7 @@ def configure(conf):
     else:
         # libintl is part of the system, so use it
         autowaf.display_msg(conf, 'Will rely on libintl built into libc', 'yes')
-            
+
     user_ardour_root = os.path.expanduser (Options.options.depstack_root + '/a3/inst')
     if pkg_config_path is not None and pkg_config_path.find (user_ardour_root) >= 0:
         # told to search user_ardour_root
@@ -791,7 +801,7 @@ def configure(conf):
         autowaf.display_msg(conf, 'Will build against private Ardour dependency stack in ' + user_ardour_root, 'yes')
     else:
         autowaf.display_msg(conf, 'Will build against private Ardour dependency stack', 'no')
-        
+
     if Options.options.freebie:
         conf.env.append_value ('CFLAGS', '-DSILENCE_AFTER')
         conf.env.append_value ('CXXFLAGS', '-DSILENCE_AFTER')
@@ -862,7 +872,7 @@ def configure(conf):
             print ('No Carbon support available for this build\n')
 
 
-    if Options.options.internal_shared_libs: 
+    if Options.options.internal_shared_libs:
         conf.define('INTERNAL_SHARED_LIBS', 1)
 
     if Options.options.use_external_libs:
@@ -926,7 +936,7 @@ def configure(conf):
         conf.env.append_value('LIB', 'regex')
         # TODO this should only be necessary for a debug build
         conf.env.append_value('LIB', 'dbghelp')
-        
+
         # work around GdkDrawable BitBlt performance issue on windows
         # see http://gareus.org/wiki/ardour_windows_gdk_and_cairo
         conf.env.append_value('CFLAGS', '-DUSE_CAIRO_IMAGE_SURFACE')
@@ -944,7 +954,7 @@ def configure(conf):
         conf.env.append_value('CXXFLAGS', '-DUSE_CAIRO_IMAGE_SURFACE')
         # MORE STUFF PROBABLY NEEDED HERE
         conf.define ('WINDOWS', 1)
-        
+
     # Tell everyone that this is a waf build
 
     conf.env.append_value('CFLAGS', '-DWAF_BUILD')
@@ -1020,7 +1030,7 @@ def configure(conf):
         sys.exit(1)
 
     if conf.is_tracks_build():
-        # For Tracks, override backends on OS X or Windows    
+        # For Tracks, override backends on OS X or Windows
         if sys.platform == 'darwin' or sys.platform == 'mingw' or sys.platform == 'msvc':
             backends = [ 'wavesaudio' ]
 
@@ -1151,7 +1161,7 @@ def build(bld):
         bld.env.append_value ('CXXFLAGS', '-DUSE_TRACKS_CODE_FEATURES')
         bld.env.append_value ('CFLAGS', '-DUSE_TRACKS_CODE_FEATURES')
         lwrcase_dirname = 'trx'
-        
+
     # configuration files go here
     bld.env['CONFDIR'] = os.path.join(bld.env['SYSCONFDIR'], lwrcase_dirname)
     # data files loaded at run time go here