X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2FSConscript;h=22ef8bdd66ce2c0baeb81242b5691173cbcf2390;hb=7295d8e9f675f4441ab626c0655b2d2e6663e47e;hp=55fa26ec857db124d3cc9a7257e4a6f97ebce36a;hpb=fe13d08874f08b723df53116e5655c3d229a657e;p=ardour.git diff --git a/gtk2_ardour/SConscript b/gtk2_ardour/SConscript index 55fa26ec85..22ef8bdd66 100644 --- a/gtk2_ardour/SConscript +++ b/gtk2_ardour/SConscript @@ -4,36 +4,41 @@ import os import os.path import glob -Import('env install_prefix final_prefix config_prefix libraries i18n version') +Import('env install_prefix final_prefix config_prefix libraries i18n ardour_version') gtkardour = env.Copy() +gtkmmtests = env.Copy() # # this defines the version number of the GTK interface to ardour # -domain = 'gtk_ardour' +domain = 'gtk2_ardour' gtkardour.Append(DOMAIN=domain, MAJOR=1,MINOR=0,MICRO=2) gtkardour.Append(CCFLAGS="-DPACKAGE=\\\"" + domain + "\\\"") gtkardour.Append(CXXFLAGS="-DPACKAGE=\\\"" + domain + "\\\"") -gtkardour.Append(CXXFLAGS="-DLIBSIGC_DISABLE_DEPRECATED") +gtkardour.Append(CXXFLAGS=["-DLIBSIGC_DISABLE_DEPRECATED", "-DGLIBMM_DEFAULT_SIGNAL_HANDLERS_ENABLED", "-DGLIBMM_EXCEPTIONS_ENABLED", "-DGLIBMM_PROPERTIES_ENABLED"]) +gtkardour.Append(CPPPATH="#/") # for top level svn_revision.h #gtkardour.Append(CXXFLAGS="-DFLOWCANVAS_AA") gtkardour.Append(PACKAGE=domain) gtkardour.Append(POTFILE=domain + '.pot') +if gtkardour['DIST_TARGET'] == 'panther' or gtkardour['DIST_TARGET'] == 'tiger': + gtkardour.Append (LINKFLAGS="-Xlinker -headerpad -Xlinker 2048") + gtkardour.Merge ([ libraries['ardour'], libraries['ardour_cp'], libraries['gtkmm2ext'], libraries['midi++2'], - libraries['pbd3'], + libraries['pbd'], libraries['gtkmm2'], libraries['glib2'], libraries['libgnomecanvas2'], libraries['libgnomecanvasmm'], libraries['sysmidi'], - libraries['sndfile'], + libraries['sndfile-ardour'], libraries['flac'], libraries['lrdf'], libraries['glibmm2'], @@ -44,9 +49,23 @@ gtkardour.Merge ([ libraries['gtk2'], libraries['xml'], libraries['xslt'], - libraries['soundtouch'], libraries['samplerate'], - libraries['jack'] + libraries['jack'], + libraries['cairomm'], + libraries['asound'] +]) + +gtkmmtests.Append(CXXFLAGS="-DLIBSIGC_DISABLE_DEPRECATED") + +gtkmmtests.Merge ([ + libraries['gtkmm2'], + libraries['glib2'], + libraries['glibmm2'], + libraries['pangomm'], + libraries['atkmm'], + libraries['gdkmm2'], + libraries['sigc2'], + libraries['gtk2'] ]) if gtkardour['DMALLOC']: @@ -57,15 +76,33 @@ if gtkardour['FFT_ANALYSIS']: gtkardour.Merge ([libraries['fftw3f']]) gtkardour.Append(CCFLAGS='-DFFT_ANALYSIS') +if gtkardour['RUBBERBAND']: + gtkardour.Merge ([ libraries['rubberband'], libraries['vamp'], libraries['fftw3f'], libraries['fftw3'] ]) +else: + gtkardour.Merge ([ libraries['soundtouch'] ]) + skipped_files=Split(""" connection_editor.cc """) +audiounit_files=Split(""" +au_pluginui.mm +""") + +gtkosx_files=Split(""" +sync-menu.c +cocoacarbon.mm +""") + +x11_files=Split(""" +x11.cc +""") gtkardour_files=Split(""" about.cc actions.cc add_route_dialog.cc +add_midi_cc_track_dialog.cc ardour_dialog.cc ardour_ui.cc ardour_ui2.cc @@ -76,21 +113,31 @@ ardour_ui_mixer.cc ardour_ui_options.cc audio_clock.cc audio_time_axis.cc -automation_gain_line.cc +audio_region_editor.cc +control_point.cc automation_line.cc -automation_pan_line.cc automation_time_axis.cc +automation_streamview.cc +automation_controller.cc +automation_region_view.cc +bundle_manager.cc +midi_port_dialog.cc +midi_time_axis.cc +midi_scroomer.cc +midi_streamview.cc axis_view.cc -canvas-imageframe.c canvas-simpleline.c simpleline.cc canvas-simplerect.c simplerect.cc +lineset.cc canvas-waveview.c -color_manager.cc +diamond.cc +canvas-midi-event.cc crossfade_edit.cc crossfade_view.cc curvetest.cc +enums.cc editing.cc editor.cc editor_actions.cc @@ -102,7 +149,6 @@ editor_cursors.cc editor_edit_groups.cc editor_export_audio.cc editor_hscroller.cc -editor_imageframe.cc editor_keyboard.cc editor_keys.cc editor_markers.cc @@ -114,92 +160,109 @@ editor_region_list.cc editor_route_list.cc editor_rulers.cc editor_scrub.cc +editor_selection.cc editor_selection_list.cc editor_tempodisplay.cc editor_timefx.cc +engine_dialog.cc export_dialog.cc export_session_dialog.cc export_region_dialog.cc export_range_markers_dialog.cc -gain_automation_time_axis.cc gain_meter.cc +generic_pluginui.cc ghostregion.cc -grouped_buttons.cc gtk-custom-hruler.c gtk-custom-ruler.c -imageframe.cc -imageframe_socket_handler.cc -imageframe_time_axis.cc -imageframe_time_axis_group.cc -imageframe_time_axis_view.cc -imageframe_view.cc io_selector.cc +port_matrix.cc keyboard.cc +keyeditor.cc +latency_gui.cc +level_meter.cc location_ui.cc main.cc marker.cc -marker_time_axis.cc -marker_time_axis_view.cc -marker_view.cc -meter_bridge.cc -meter_bridge_strip.cc mixer_strip.cc mixer_ui.cc new_session_dialog.cc option_editor.cc opts.cc -pan_automation_time_axis.cc + +panner.cc panner2d.cc panner_ui.cc +piano_roll_header.cc playlist_selector.cc plugin_selector.cc plugin_ui.cc prompter.cc public_editor.cc -redirect_automation_line.cc -redirect_automation_time_axis.cc -redirect_box.cc -region_editor.cc +processor_box.cc region_gain_line.cc region_selection.cc -regionview.cc +region_view.cc +audio_region_view.cc +midi_region_view.cc +tape_region_view.cc route_params_ui.cc -route_redirect_selection.cc +route_processor_selection.cc route_ui.cc selection.cc sfdb_ui.cc send_ui.cc +splash.cc streamview.cc -taperegionview.cc +audio_streamview.cc tempo_dialog.cc +theme_manager.cc time_axis_view.cc time_axis_view_item.cc +route_time_axis.cc time_selection.cc +ui_config.cc utils.cc version.cc -visual_time_axis.cc waveview.cc +tempo_lines.cc """) - fft_analysis_files=Split(""" analysis_window.cc fft_graph.cc fft_result.cc """) -pixmap_files=glob.glob('pixmaps/*.xpm') +pixmap_files = glob.glob('pixmaps/*.xpm') +icon_files = glob.glob ('icons/*.png') intl_files = gtkardour_files + glob.glob('*.h') +evtest_files=Split(""" +evtest.cc +""") + mtest_files=Split(""" mtest.cc """) + +rcu_files=Split(""" +rcu.cc +""") + itest_files=Split(""" itest.cc """) +stest_files=Split(""" +stest.cc +""") + +tt_files=Split (""" +tt.cc +""") + extra_sources = [] vst_files = [ 'vst_pluginui.cc' ] @@ -207,7 +270,26 @@ vst_files = [ 'vst_pluginui.cc' ] if env['VST']: extra_sources += vst_files gtkardour.Append (CCFLAGS="-DVST_SUPPORT", CPPPATH="#libs/fst") - + +if env['LV2']: + gtkardour.Append (CCFLAGS="-DHAVE_SLV2") + gtkardour.Merge ([libraries['slv2']]) + + +if gtkardour['GTKOSX']: + extra_sources += gtkosx_files + gtkardour.Append (CCFLAGS="-DTOP_MENUBAR -DGTKOSX") + gtkardour.Append (LINKFLAGS=" -framework AppKit -framework CoreAudioKit") + + if gtkardour['AUDIOUNITS']: + extra_sources += audiounit_files + gtkardour.Append(CCFLAGS='-DHAVE_AUDIOUNITS') + gtkardour.Merge([libraries['appleutility']]) + +else: + extra_sources += x11_files + + if env['FFT_ANALYSIS']: extra_sources += fft_analysis_files @@ -220,26 +302,148 @@ versionflag = '-DVERSIONSTRING=\\\"' + env['VERSION'] + '\\\"' gtkardour.Append(CXXFLAGS=versionflag) -gtkardour.VersionBuild(['version.cc','version.h'], 'SConscript') - -executable = 'ardour.bin' +executable = 'ardour-' + ardour_version ardour = gtkardour.Program(target = executable, source = gtkardour_files + extra_sources) ardourlib = gtkardour.SharedLibrary(target = 'ardourgtk', source = gtkardour_files + extra_sources) +evest = gtkmmtests.Program(target = 'evtest', source = evtest_files) mtest = gtkardour.Program(target = 'mtest', source = mtest_files) itest = gtkardour.Program(target = 'itest', source = itest_files) +rcu = gtkardour.Program(target = 'rcu', source = rcu_files) +tt = gtkmmtests.Program(target = 'tt', source = tt_files) + +my_font_dict = { } + +if gtkardour['DIST_TARGET'] == 'panther' or gtkardour['DIST_TARGET'] == 'tiger': + # + # OS X font rendering is different even with X11 + # + my_font_dict['%FONT_TINY%'] = 'Lucida Grande 7' + my_font_dict['%FONT_SMALLERER%'] = 'Lucida Grande 8' + my_font_dict['%FONT_SMALLER%'] = 'Lucida Grande 9' + my_font_dict['%FONT_SMALL%'] = 'Lucida Grande 10' + my_font_dict['%FONT_NORMAL%'] = 'Lucida Grande 11' + my_font_dict['%FONT_BIG%'] = 'Lucida Grande 12' + my_font_dict['%FONT_BIGGER%'] = 'Lucida Grande 14' + my_font_dict['%FONT_LARGE%'] = 'Lucida Grande 18' + my_font_dict['%FONT_LARGER%'] = 'Lucida Grande 28' + my_font_dict['%FONT_HUGER%'] = 'Lucida Grande 36' + my_font_dict['%FONT_MASSIVE%'] = 'Lucida Grande 60' + my_font_dict['%FONT_BOLD_TINY%'] = 'Lucida Grande bold 7' + my_font_dict['%FONT_BOLD_SMALLER%'] = 'Lucida Grande bold 9' + my_font_dict['%FONT_BOLD_SMALL%'] = 'Lucida Grande bold 10' + my_font_dict['%FONT_BOLD_NORMAL%'] = 'Lucida Grande bold 11' + my_font_dict['%FONT_BOLD_BIG%'] = 'Lucida Grande bold 13' + my_font_dict['%FONT_BOLD_BIGGER%'] = 'Lucida Grande bold 14' + my_font_dict['%FONT_BOLD_LARGE%'] = 'Lucida Grande bold 20' + my_font_dict['%FONT_BOLD_LARGER%'] = 'Lucida Grande bold 25' + my_font_dict['%FONT_BOLD_HUGER%'] = 'Lucida Grande bold 36' + my_font_dict['%FONT_BOLD_MASSIVE%'] = 'Lucida Grande bold 60' + my_font_dict['%FONT_ITALIC_TINY%'] = 'Lucida Grande italic 7' + my_font_dict['%FONT_ITALIC_SMALLER%'] = 'Lucida Grande italic 9' + my_font_dict['%FONT_ITALIC_SMALL%'] = 'Lucida Grande italic 10' + my_font_dict['%FONT_ITALIC_NORMAL%'] = 'Lucida Grande italic 11' + my_font_dict['%FONT_ITALIC_BIG%'] = 'Lucida Grande italic 15' + my_font_dict['%FONT_ITALIC_BIGGER%'] = 'Lucida Grande italic 16' + my_font_dict['%FONT_ITALIC_LARGE%'] = 'Lucida Grande italic 20' + my_font_dict['%FONT_ITALIC_LARGER%'] = 'Lucida Grande italic 28' + my_font_dict['%FONT_ITALIC_HUGER%'] = 'Lucida Grande italic 36' + my_font_dict['%FONT_ITALIC_MASSIVE%'] = 'Lucida Grande italic 60' +else: + # + # Linux/X11 font rendering + # + my_font_dict['%FONT_TINY%'] = 'sans 4' + my_font_dict['%FONT_SMALLERER%'] = 'sans 6' + my_font_dict['%FONT_SMALLER%'] = 'sans 6' + my_font_dict['%FONT_SMALL%'] = 'sans 7' + my_font_dict['%FONT_NORMAL%'] = 'sans 8' + my_font_dict['%FONT_BIG%'] = 'sans 12' + my_font_dict['%FONT_BIGGER%'] = 'sans 14' + my_font_dict['%FONT_LARGE%'] = 'sans 18' + my_font_dict['%FONT_LARGER%'] = 'sans 24' + my_font_dict['%FONT_HUGER%'] = 'sans 34' + my_font_dict['%FONT_MASSIVE%'] = 'sans 60' + my_font_dict['%FONT_BOLD_TINY%'] = 'sans bold 4' + my_font_dict['%FONT_BOLD_SMALLER%'] = 'sans bold 6' + my_font_dict['%FONT_BOLD_SMALL%'] = 'sans bold 7' + my_font_dict['%FONT_BOLD_NORMAL%'] = 'sans bold 8' + my_font_dict['%FONT_BOLD_BIG%'] = 'sans bold 12' + my_font_dict['%FONT_BOLD_BIGGER%'] = 'sans bold 14' + my_font_dict['%FONT_BOLD_LARGE%'] = 'sans bold 18' + my_font_dict['%FONT_BOLD_LARGER%'] = 'sans bold 24' + my_font_dict['%FONT_BOLD_HUGE%'] = 'sans bold 25' + my_font_dict['%FONT_BOLD_HUGER%'] = 'sans bold 34' + my_font_dict['%FONT_BOLD_MASSIVE%'] = 'sans bold 60' + my_font_dict['%FONT_ITALIC_TINY%'] = 'sans italic 4' + my_font_dict['%FONT_ITALIC_SMALLER%'] = 'sans italic 6' + my_font_dict['%FONT_ITALIC_SMALL%'] = 'sans italic 7' + my_font_dict['%FONT_ITALIC_NORMAL%'] = 'sans italic 8' + my_font_dict['%FONT_ITALIC_BIG%'] = 'sans italic 12' + my_font_dict['%FONT_ITALIC_BIGGER%'] = 'sans italic 14' + my_font_dict['%FONT_ITALIC_LARGE%'] = 'sans italic 18' + my_font_dict['%FONT_ITALIC_LARGER%'] = 'sans italic 24' + my_font_dict['%FONT_ITALIC_HUGE%'] = 'sans italic 25' + my_font_dict['%FONT_ITALIC_HUGER%'] = 'sans italic 34' + my_font_dict['%FONT_ITALIC_MASSIVE%'] = 'sans italic 60' + +ardour_dark_theme = env.SubstInFile ('ardour3_ui_dark.rc', 'ardour3_ui_dark.rc.in', SUBST_DICT = my_font_dict) +ardour_light_theme = env.SubstInFile ('ardour3_ui_light.rc', 'ardour3_ui_light.rc.in', SUBST_DICT = my_font_dict) my_subst_dict = { } -my_subst_dict['%INSTALL_PREFIX%'] = install_prefix + +# +# null substitution just to avoid ardour.bindings being in svn +# + +keybindings_dict = { } + +if gtkardour['GTKOSX'] and gtkardour['NATIVE_OSX_KEYS']: + # + # Command(Mod1), Alt(Mod5), Ctrl, Shift + # + keybindings_dict['%PRIMARY%'] = 'Mod5' + keybindings_dict['%SECONDARY%'] = 'Alt' + keybindings_dict['%TERTIARY%'] = 'Shift' + keybindings_dict['%LEVEL4%'] = 'Ctrl' + keybindings_dict['%WINDOW%'] = 'Mod5' +else: + # + # Ctrl, Alt, Shift, Mod3(Meta) + # + keybindings_dict['%PRIMARY%'] = 'Ctrl' + keybindings_dict['%SECONDARY%'] = 'Alt' + keybindings_dict['%TERTIARY%'] = 'Shift' + keybindings_dict['%LEVEL4%'] = 'Mod2' + keybindings_dict['%WINDOW%'] = 'Alt' + +ardourbindings = env.SubstInFile ('ardour.bindings', 'ardour.bindings.in', SUBST_DICT = keybindings_dict); +ardoursaeDEbindings = env.SubstInFile ('ardour-sae-de.bindings', 'ardour-sae-de.bindings.in', SUBST_DICT = keybindings_dict); +ardoursaeANSIbindings = env.SubstInFile ('ardour-sae-ansi.bindings', 'ardour-sae-ansi.bindings.in', SUBST_DICT = keybindings_dict); + +my_subst_dict['%INSTALL_PREFIX%'] = final_prefix +my_subst_dict['%LIBDIR%'] = env['LIBDIR'] +my_subst_dict['%VERSION%'] = ardour_version ardoursh = env.SubstInFile ('ardour.sh','ardour.sh.in', SUBST_DICT = my_subst_dict); env.AddPostAction (ardoursh, Chmod ('$TARGET', 0755)) +ardourdev = env.SubstInFile ('ardev_common.sh','ardev_common.sh.in', SUBST_DICT = my_subst_dict); +env.AddPostAction (ardourdev, Chmod ('$TARGET', 0755)) + +Default(ardourbindings) +Default(ardoursaeDEbindings) +Default(ardoursaeANSIbindings) +Default(ardourdev) +Default(ardoursh) +Default(ardour_dark_theme) +Default(ardour_light_theme) + if env['VST']: Default(ardourlib) # the library - into the library dir - env.Alias('install', env.Install(os.path.join(install_prefix, 'lib/ardour2'), ardourlib)) + env.Alias('install', env.Install(os.path.join(install_prefix, env['LIBDIR'], 'ardour3'), ardourlib)) else: if env['VERSIONED']: @@ -250,35 +454,53 @@ else: #install # the executable - into the library dir - env.Alias('install', env.Install(os.path.join(install_prefix, 'lib/ardour2'), ardour)) + env.Alias('install', env.Install(os.path.join(install_prefix, env['LIBDIR'], 'ardour3'), ardour)) # the script - into the bin dir - env.Alias('install', env.InstallAs(os.path.join(install_prefix, 'bin')+'/ardour2', ardoursh)) + env.Alias('install', env.InstallAs(os.path.join(install_prefix, 'bin')+'/ardour3', ardoursh)) if env['NLS']: - Export('gtkardour', 'intl_files') - SConscript ('po/SConscript') + i18n (gtkardour, gtkardour_files+skipped_files+fft_analysis_files, env) # configuration files -env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour2'), 'ardour2_ui.rc')) -env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour2'), 'ardour.menus')) -env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour2'), 'ardour.bindings')) -env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour2'), 'ardour.colors')) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), ardour_dark_theme)) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), ardour_light_theme)) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), 'ardour.menus')) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), 'ardour-sae.menus')) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), 'ardour.bindings')) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), 'ardour-sae-ansi.bindings')) +env.Alias('install', env.Install(os.path.join(config_prefix, 'ardour3'), 'ardour-sae-de.bindings')) # data files -env.Alias('install', env.Install(os.path.join(install_prefix, 'share/ardour2'), 'splash.ppm')) -env.Alias('install', env.Install(os.path.join(install_prefix, 'share/ardour2/pixmaps'), pixmap_files)) +env.Alias('install', env.Install(os.path.join(install_prefix, 'share', 'ardour3'), 'splash.png')) +env.Alias('install', env.Install(os.path.join(install_prefix, 'share', 'ardour3', 'pixmaps'), pixmap_files)) +env.Alias('install', env.Install(os.path.join(install_prefix, 'share', 'ardour3', 'icons'), icon_files)) +env.Alias ('version', gtkardour.VersionBuild(['version.cc','version.h'], [])) #dist env.Alias ('tarball', env.Distribute (env['DISTTREE'], [ 'SConscript', 'i18n.h', 'gettext.h', 'ardour.sh.in', - 'ardour2_ui.rc', 'splash.ppm', - 'ardour.menus', 'ardour.bindings', 'ardour.colors', + 'ardev_common.sh.in', + 'ardev', 'ardbg', + 'ardour3_ui_dark.rc.in', 'ardour3_ui_light.rc.in', 'splash.png', + 'ardour.menus', 'ardour-sae.menus', + 'ardour.bindings.in', + 'ardour-sae-ansi.bindings.in', + 'ardour-sae-de.bindings.in', + 'ardour3_ui_default.conf', 'editor_xpms' ] + - gtkardour_files + vst_files + pixmap_files + - glob.glob('po/*.po') + glob.glob('*.h'))) + gtkardour_files + + vst_files + + pixmap_files + + icon_files + + skipped_files + + audiounit_files + + gtkosx_files + + x11_files + + fft_analysis_files + + glob.glob('po/*.po') + glob.glob('*.h'))) # generate a prototype full-featured ardour_ui.rc file