X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2FSConscript;h=52943dd8fd035a98c27bb8ba4e91ac0fa08f06c2;hb=e374518ca9c4643874eee3877e270eef32d95f18;hp=d7beb6277299148df21c875efdebf32a98ea3160;hpb=638336eee5c7ce79faa526f2890634dc82785d62;p=ardour.git diff --git a/libs/ardour/SConscript b/libs/ardour/SConscript index d7beb62772..52943dd8fd 100644 --- a/libs/ardour/SConscript +++ b/libs/ardour/SConscript @@ -6,20 +6,23 @@ import glob Import('env final_prefix install_prefix final_config_prefix libraries i18n') -ardour = env.Copy() +ardour = env.Clone() # # this defines the version number of libardour # -domain = 'libardour' +domain = 'libardour3' -ardour.Append(DOMAIN = domain, MAJOR = 2, MINOR = 0, MICRO = 0) +ardour.Append(DOMAIN = domain, MAJOR = 3, MINOR = 0, MICRO = 0) ardour.Append(CXXFLAGS = "-DPACKAGE=\\\"" + domain + "\\\"") -ardour.Append(CXXFLAGS="-DLIBSIGC_DISABLE_DEPRECATED") +ardour.Append(CXXFLAGS=["-DLIBSIGC_DISABLE_DEPRECATED", "-DGLIBMM_EXCEPTIONS_ENABLED"]) ardour.Append(PACKAGE = domain) ardour.Append(POTFILE = domain + '.pot') +if ardour['IS_OSX']: + ardour.Append (LINKFLAGS="-Xlinker -headerpad -Xlinker 2048") + # # explicitly reference the control protocol LGPL library for includes # @@ -27,49 +30,118 @@ ardour.Append(POTFILE = domain + '.pot') ardour.Append(CPPPATH = '#libs/surfaces/control_protocol') ardour_files=Split(""" -diskstream.cc +amp.cc +analyser.cc +audio_buffer.cc audio_diskstream.cc audio_library.cc audio_playlist.cc -track.cc +audio_playlist_importer.cc +audio_port.cc +audio_region_importer.cc audio_track.cc +audio_track_importer.cc +audioanalyser.cc audioengine.cc +audiofile_tagger.cc audiofilesource.cc -audiofilter.cc audioregion.cc audiosource.cc auditioner.cc +automatable.cc automation.cc -automation_event.cc +automation_control.cc +automation_list.cc +beats_frames_converter.cc +broadcast_info.cc +buffer.cc +buffer_set.cc +bundle.cc +chan_count.cc +chan_mapping.cc configuration.cc -connection.cc control_protocol_manager.cc +control_protocol_search_path.cc crossfade.cc -curve.cc cycle_timer.cc default_click.cc +delivery.cc +directory_names.cc +diskstream.cc +element_import_handler.cc +element_importer.cc +enums.cc +event_type_map.cc +export_channel.cc +export_channel_configuration.cc +export_file_io.cc +export_filename.cc +export_format_base.cc +export_format_manager.cc +export_format_specification.cc +export_formats.cc +export_handler.cc +export_preset.cc +export_processor.cc +export_profile_manager.cc +export_status.cc +export_timespan.cc +export_utilities.cc +file_source.cc +filename_extensions.cc +filesystem_paths.cc +filter.cc +find_session.cc gain.cc gdither.cc globals.cc import.cc -insert.cc io.cc +io_processor.cc +internal_send.cc +internal_return.cc +interpolation.cc jack_slave.cc ladspa_plugin.cc location.cc +location_importer.cc +meter.cc +midi_buffer.cc +midi_clock_slave.cc +midi_diskstream.cc +midi_model.cc +midi_patch_manager.cc +midi_playlist.cc +midi_port.cc +midi_region.cc +midi_ring_buffer.cc +midi_source.cc +midi_state_tracker.cc +midi_stretch.cc +midi_track.cc +mix.cc mtc_slave.cc +mute_master.cc named_selection.cc +onset_detector.cc panner.cc pcm_utils.cc playlist.cc playlist_factory.cc plugin.cc +plugin_insert.cc plugin_manager.cc port.cc +port_insert.cc +port_set.cc +processor.cc +quantize.cc +rc_configuration.cc recent_sessions.cc -redirect.cc region.cc region_factory.cc +resampled_source.cc +return.cc reverse.cc route.cc route_group.cc @@ -78,44 +150,61 @@ session.cc session_butler.cc session_click.cc session_command.cc +session_configuration.cc +session_directory.cc session_events.cc session_export.cc +session_metadata.cc session_midi.cc session_process.cc session_state.cc +session_state_utils.cc session_time.cc -session_timefx.cc session_transport.cc +session_utils.cc +smf_source.cc sndfile_helpers.cc +sndfileimportable.cc sndfilesource.cc source.cc source_factory.cc +strip_silence.cc +svn_revision.cc +tape_file_matcher.cc +template_utils.cc tempo.cc +tempo_map_importer.cc +ticker.cc +track.cc +transient_detector.cc +user_bundle.cc utils.cc version.cc -mix.cc """) arch_specific_objects = [ ] -osc_files = [ 'osc.cc' ] vst_files = [ 'vst_plugin.cc', 'session_vst.cc' ] +lv2_files = [ 'lv2_plugin.cc', 'lv2_event_buffer.cc', 'uri_map.cc' ] audiounit_files = [ 'audio_unit.cc' ] -coreaudio_files = [ 'coreaudiosource.cc' ] +coreaudio_files = [ 'coreaudiosource.cc', 'caimportable.cc' ] extra_sources = [ ] +timefx_sources = [ ] if ardour['VST']: extra_sources += vst_files ardour.Append(CCFLAGS="-DVST_SUPPORT", CPPPATH="#libs/fst") -if ardour['LIBLO']: - extra_sources += osc_files +if ardour['LV2']: + extra_sources += lv2_files + ardour.Append(CCFLAGS="-DHAVE_SLV2") ardour.Append(CCFLAGS="-D_REENTRANT -D_LARGEFILE_SOURCE -D_LARGEFILE64_SOURCE") -ardour.Append(CXXFLAGS="-DDATA_DIR=\\\""+final_prefix+"/share\\\"") -ardour.Append(CXXFLAGS="-DMODULE_DIR=\\\""+final_prefix+"/lib\\\"") -ardour.Append(CXXFLAGS="-DCONFIG_DIR=\\\""+final_config_prefix+"\\\"") -ardour.Append(CXXFLAGS="-DLOCALEDIR=\\\""+final_prefix+"/share/locale\\\"") +ardour.Append(CXXFLAGS="-DDATA_DIR=\\\"" + os.path.join (final_prefix, 'share') + "\\\"") +ardour.Append(CXXFLAGS="-DMODULE_DIR=\\\"" + os.path.join (final_prefix, env['LIBDIR']) + "\\\"") +ardour.Append(CXXFLAGS="-DVAMP_DIR=\\\"" + os.path.join (final_prefix, env['LIBDIR'], 'ardour3', 'vamp') + "\\\"") +ardour.Append(CXXFLAGS="-DCONFIG_DIR=\\\"" + final_config_prefix + "\\\"") +ardour.Append(CXXFLAGS="-DLOCALEDIR=\\\"" + os.path.join (final_prefix, 'share', 'locale') + "\\\"") ardour.Merge ([ libraries['jack'] ]) @@ -165,16 +254,35 @@ int main(int argc, char** argv) return 0; } """ - def CheckJackVideoFrameOffset(context): context.Message('Checking for JackVideoFrameOffset in jack_position_bits_t enum...') result = context.TryLink(jack_video_frame_offset_test, '.c') context.Result(result) return result + +# +# See if JACK supports jack_recompute_total_latency() (single port version) +# + +jack_port_latency_test = """ +#include +int main(int argc, char **argv) +{ + jack_recompute_total_latency ((jack_client_t*) 0, (jack_port_t*) 0); + return 0; +} +""" +def CheckJackRecomputeLatency(context): + context.Message('Checking for jack_recompute_total_latency()...') + result = context.TryLink(jack_port_latency_test, '.c') + context.Result(result) + return result + conf = Configure(ardour, custom_tests = { 'CheckJackClientOpen' : CheckJackClientOpen, 'CheckJackRecomputeLatencies' : CheckJackRecomputeLatencies, + 'CheckJackRecomputeLatency' : CheckJackRecomputeLatency, 'CheckJackVideoFrameOffset' : CheckJackVideoFrameOffset }) @@ -184,14 +292,12 @@ if conf.CheckJackClientOpen(): if conf.CheckJackRecomputeLatencies(): ardour.Append(CXXFLAGS="-DHAVE_JACK_RECOMPUTE_LATENCIES") +if conf.CheckJackRecomputeLatency(): + ardour.Append(CXXFLAGS="-DHAVE_JACK_RECOMPUTE_LATENCY") + if conf.CheckJackVideoFrameOffset(): ardour.Append(CXXFLAGS="-DHAVE_JACK_VIDEO_SUPPORT") -if conf.CheckFunc('jack_port_ensure_monitor'): - env.Append(CCFLAGS='-DHAVE_JACK_PORT_ENSURE_MONITOR') -else: - print '\nWARNING: You need at least svn revision 985 of jack for hardware monitoring to work correctly.\n' - # # Optional header files # @@ -205,14 +311,19 @@ if conf.CheckCHeader('sys/vfs.h'): if conf.CheckCHeader('/System/Library/Frameworks/CoreMIDI.framework/Headers/CoreMIDI.h'): ardour.Append(LINKFLAGS="-framework CoreMIDI") +if conf.CheckCHeader('/System/Library/Frameworks/AudioToolbox.framework/Headers/ExtendedAudioFile.h'): + ardour.Append(LINKFLAGS="-framework AudioToolbox") + +if conf.CheckCHeader('/System/Library/Frameworks/CoreAudio.framework/Headers/CoreAudio.h'): + ardour.Append(CXXFLAGS="-DHAVE_WEAK_COREAUDIO") + if conf.CheckCHeader('/System/Library/Frameworks/AudioUnit.framework/Headers/AudioUnit.h') and ardour['AUDIOUNITS']: ardour.Append(CXXFLAGS="-DHAVE_AUDIOUNITS") ardour.Append(LINKFLAGS="-framework AudioUnit") extra_sources += audiounit_files -if conf.CheckCHeader('/System/Library/Frameworks/AudioToolbox.framework/Headers/ExtendedAudioFile.h') and ardour['COREAUDIO']: +if ardour['COREAUDIO']: ardour.Append(CXXFLAGS="-DHAVE_COREAUDIO") - ardour.Append(LINKFLAGS="-framework AudioToolbox") extra_sources += coreaudio_files if env['CONFIG_ARCH'] == 'apple': @@ -225,29 +336,42 @@ ardour = conf.Finish () ardour.Merge ([ libraries['core'], - libraries['xml'], - libraries['sndfile-ardour'], - libraries['raptor'], + libraries['fftw3'], + libraries['fftw3f'], + libraries['glib2'], + libraries['glibmm2'], libraries['lrdf'], + libraries['midi++2'], + libraries['evoral'], + libraries['smf'], + libraries['pbd'], + libraries['raptor'], libraries['samplerate'], libraries['sigc2'], - libraries['pbd'], - libraries['soundtouch'], - libraries['midi++2'], - libraries['glib2'], - libraries['glibmm2'] + libraries['sndfile'], + libraries['taglib'], + libraries['vamp'], + libraries['vamphost'], + libraries['xml'] ]) -if ardour['LIBLO']: - ardour.Merge ([ libraries['lo'] ]) +if ardour['RUBBERBAND']: + ardour.Merge ([ libraries['rubberband']]) + timefx_sources += [ 'rb_effect.cc' ] +else: + ardour.Merge ([ libraries['soundtouch'] ]) + timefx_sources += [ 'st_stretch.cc', 'st_pitch.cc' ] + +if ardour['LV2']: + ardour.Merge ([ libraries['slv2'] ]) if ardour['COREAUDIO'] or ardour['AUDIOUNITS']: - ardour.Merge ([ libraries['appleutility'] ]) + ardour.Merge ([ libraries['appleutility'] ]) def SharedAsmObjectEmitter(target, source, env): - for tgt in target: - tgt.attributes.shared = 1 - return (target, source) + for tgt in target: + tgt.attributes.shared = 1 + return (target, source) env['BUILDERS']['SharedAsmObject'] = Builder (action = '$CXX -c -fPIC $SOURCE -o $TARGET', @@ -255,28 +379,47 @@ env['BUILDERS']['SharedAsmObject'] = Builder (action = '$CXX -c -fPIC $SOURCE -o suffix = '$SHOBJSUFFIX', src_suffix = '.s', single_source = 1) +# +# handle objects that should always be compiled with -msse in their own +# special environment, which is exactly like "ardour" but unconditionally +# includes -msse +# + + +always_sse_objects = [] +sse_env = ardour.Clone() +sse_env.Append (CXXFLAGS="-msse") if env['FPU_OPTIMIZATION']: if env['DIST_TARGET'] == "i386": arch_specific_objects = env.SharedAsmObject('sse_functions.os', 'sse_functions.s') + always_sse_objects += [ sse_env.SharedObject (source = 'sse_functions_xmm.cc') ] if env['DIST_TARGET'] == "i686": arch_specific_objects = env.SharedAsmObject('sse_functions.os', 'sse_functions.s') + always_sse_objects += [ sse_env.SharedObject (source = 'sse_functions_xmm.cc') ] if env['DIST_TARGET'] == "x86_64": arch_specific_objects = env.SharedAsmObject('sse_functions_64bit.os', 'sse_functions_64bit.s') + always_sse_objects += [ sse_env.SharedObject (source = 'sse_functions_xmm.cc') ] -libardour = ardour.SharedLibrary('ardour', ardour_files + extra_sources + arch_specific_objects) +libardour = ardour.SharedLibrary('ardour', ardour_files + always_sse_objects + timefx_sources + extra_sources + arch_specific_objects) Default(libardour) if env['NLS']: - i18n (ardour, ardour_files + vst_files + coreaudio_files + audiounit_files, env) + i18n (ardour, ardour_files + vst_files + coreaudio_files + timefx_sources + audiounit_files, env) -env.Alias('install', env.Install(os.path.join(install_prefix, 'lib/ardour2'), libardour)) +env.Alias('install', env.Install(os.path.join(install_prefix, env['LIBDIR'], 'ardour3'), libardour)) env.Alias('version', ardour.VersionBuild(['version.cc', 'ardour/version.h'], [])) env.Alias('tarball', env.Distribute (env['DISTTREE'], - [ 'SConscript', 'i18n.h', 'gettext.h', 'sse_functions.s', 'sse_functions_64bit.s' ] + - ardour_files + osc_files + vst_files + coreaudio_files + audiounit_files + + [ 'SConscript', 'i18n.h', 'gettext.h' ] + + [ 'sse_functions_xmm.cc', 'sse_functions.s', 'sse_functions_64bit.s' ] + + [ 'rb_effect.cc', 'st_stretch.cc', 'st_pitch.cc' ] + + ardour_files + + vst_files + + coreaudio_files + + audiounit_files + + lv2_files + glob.glob('po/*.po') + glob.glob('ardour/*.h')))