Merge with 2.0-ongoing R2943.
[ardour.git] / gtk2_ardour / SConscript
index 65f8dfca732bb618ee8297bd6b539ec1d06d8902..22ef8bdd66ce2c0baeb81242b5691173cbcf2390 100644 (file)
@@ -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