13
0

Tweaked build and run for windows

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.
This commit is contained in:
Guy Sherman 2015-08-16 18:01:28 +02:00 committed by Robin Gareus
parent 1d2938b162
commit 4f387f390e
3 changed files with 42 additions and 26 deletions

6
gtk2_ardour/ardev-win Normal file
View File

@ -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 "$@"

View 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.
#

56
wscript
View File

@ -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