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:
parent
1d2938b162
commit
4f387f390e
6
gtk2_ardour/ardev-win
Normal file
6
gtk2_ardour/ardev-win
Normal 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 "$@"
|
@ -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
56
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
|
||||
|
Loading…
Reference in New Issue
Block a user