radically change Keyboard/Binding API design to disconnect Gtk::Action lookup from...
[ardour.git] / gtk2_ardour / editor.h
index 603103532f9d570284db4c02097057aaac92371a..8b500908532d915c4a5c34f817833c362fe143a0 100644 (file)
 #include "selection_memento.h"
 
 namespace Gtkmm2ext {
-       class TearOff;
        class Bindings;
 }
 
 namespace ARDOUR {
-       class RouteGroup;
-       class Playlist;
        class AudioPlaylist;
        class AudioRegion;
-       class Region;
-       class Location;
-       class TempoSection;
-       class Session;
-       class Filter;
+       class AudioTrack;
        class ChanCount;
+       class Filter;
+       class Location;
        class MidiOperator;
-       class Track;
+       class MidiRegion;
        class MidiTrack;
-       class AudioTrack;
+       class Playlist;
+       class Region;
+       class RouteGroup;
+       class Session;
+       class TempoSection;
+       class Track;
 }
 
 namespace LADSPA {
@@ -111,14 +111,16 @@ class EditorSnapshots;
 class EditorSummary;
 class GroupedButtons;
 class GUIObjectState;
-class Marker;
+class ArdourMarker;
 class MidiRegionView;
+class MidiExportDialog;
 class MixerStrip;
 class MouseCursors;
 class NoteBase;
 class PlaylistSelector;
 class PluginSelector;
 class ProgressReporter;
+class QuantizeDialog;
 class RhythmFerret;
 class RulerDialog;
 class Selection;
@@ -140,6 +142,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void             set_session (ARDOUR::Session *);
        ARDOUR::Session* session() const { return _session; }
 
+       Gtk::Window* use_own_window (bool and_fill_it);
+       
        void             first_idle ();
        virtual bool     have_idled () const { return _have_idled; }
 
@@ -262,7 +266,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void set_selected_regionview_from_region_list (boost::shared_ptr<ARDOUR::Region> region, Selection::Operation op = Selection::Set);
 
        void remove_tracks ();
-       
+
        /* tempo */
 
        void set_show_measures (bool yn);
@@ -281,15 +285,14 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void export_range ();
        void export_region ();
 
-       void add_transport_frame (Gtk::Container&);
-       void add_toplevel_menu (Gtk::Container&);
-       Gtk::HBox& get_status_bar_packer()  { return status_bar_hpacker; }
+       bool process_midi_export_dialog (MidiExportDialog& dialog, boost::shared_ptr<ARDOUR::MidiRegion> midi_region);
 
        void               set_zoom_focus (Editing::ZoomFocus);
        Editing::ZoomFocus get_zoom_focus () const { return zoom_focus; }
        framecnt_t         get_current_zoom () const { return samples_per_pixel; }
        void               cycle_zoom_focus ();
        void temporal_zoom_step (bool coarser);
+       void temporal_zoom_step_mouse_focus (bool coarser);
        void ensure_time_axis_view_is_visible (TimeAxisView const & tav, bool at_top);
        void tav_zoom_step (bool coarser);
        void tav_zoom_smooth (bool coarser, bool force_all);
@@ -361,23 +364,24 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void ensure_float (Gtk::Window&);
 
-       void show_window ();
-
        void scroll_tracks_down_line ();
        void scroll_tracks_up_line ();
-       
+
        bool scroll_up_one_track (bool skip_child_views = false);
        bool scroll_down_one_track (bool skip_child_views = false);
 
+       void scroll_left_step ();
+       void scroll_right_step ();
+
+       void scroll_left_half_page ();
+       void scroll_right_half_page ();
+
        void prepare_for_cleanup ();
        void finish_cleanup ();
 
        void maximise_editing_space();
        void restore_editing_space();
 
-       void update_tearoff_visibility();
-       void reattach_all_tearoffs ();
-
        double get_y_origin () const;
        void reset_x_origin (framepos_t);
        void reset_x_origin_to_follow_playhead ();
@@ -409,6 +413,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        int get_regionview_count_from_region_list (boost::shared_ptr<ARDOUR::Region>);
 
+       void do_ptimport(std::string path, ARDOUR::SrcQuality quality);
+
        void do_import (std::vector<std::string>              paths,
                        Editing::ImportDisposition            disposition,
                        Editing::ImportMode                   mode,
@@ -431,9 +437,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        TrackViewList axis_views_from_routes (boost::shared_ptr<ARDOUR::RouteList>) const;
 
-       Gtkmm2ext::TearOff* mouse_mode_tearoff () const { return _mouse_mode_tearoff; }
-       Gtkmm2ext::TearOff* tools_tearoff () const { return _tools_tearoff; }
-
        void snap_to (framepos_t&       first,
                      ARDOUR::RoundMode direction = ARDOUR::RoundNearest,
                      bool              for_mark  = false,
@@ -500,7 +503,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        TimeAxisView* stepping_axis_view () {
                return _stepping_axis_view;
        }
-       
+
        void set_stepping_axis_view (TimeAxisView* v) {
                _stepping_axis_view = v;
        }
@@ -527,7 +530,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void split_regions_at (framepos_t, RegionSelection&);
        void split_region_at_points (boost::shared_ptr<ARDOUR::Region>, ARDOUR::AnalysisFeatureList&, bool can_ferret, bool select_new = false);
        RegionSelection get_regions_from_selection_and_mouse (framepos_t);
-       
+
        void mouse_add_new_tempo_event (framepos_t where);
        void mouse_add_new_meter_event (framepos_t where);
        void edit_tempo_section (ARDOUR::TempoSection*);
@@ -641,8 +644,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        uint32_t location_cd_marker_color;
 
        struct LocationMarkers {
-               Marker* start;
-               Marker* end;
+               ArdourMarker* start;
+               ArdourMarker* end;
                bool    valid;
 
                LocationMarkers () : start(0), end(0), valid (true) {}
@@ -663,9 +666,9 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        };
 
        LocationMarkers  *find_location_markers (ARDOUR::Location *) const;
-       ARDOUR::Location* find_location_from_marker (Marker *, bool& is_start) const;
-       Marker* find_marker_from_location_id (PBD::ID const &, bool) const;
-       Marker* entered_marker;
+       ARDOUR::Location* find_location_from_marker (ArdourMarker *, bool& is_start) const;
+       ArdourMarker* find_marker_from_location_id (PBD::ID const &, bool) const;
+       ArdourMarker* entered_marker;
        bool _show_marker_lines;
 
        typedef std::map<ARDOUR::Location*,LocationMarkers *> LocationMarkerMap;
@@ -673,7 +676,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void update_marker_labels ();
        void update_marker_labels (ArdourCanvas::Container *);
-       void check_marker_label (Marker *);
+       void check_marker_label (ArdourMarker *);
 
        /** A set of lists of Markers that are in each of the canvas groups
         *  for the marker sections at the top of the editor.  These lists
@@ -681,8 +684,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
         *  a marker has moved we can decide whether we need to update the labels
         *  for all markers or for just a few.
         */
-       std::map<ArdourCanvas::Container *, std::list<Marker *> > _sorted_marker_lists;
-       void remove_sorted_marker (Marker *);
+       std::map<ArdourCanvas::Container *, std::list<ArdourMarker *> > _sorted_marker_lists;
+       void remove_sorted_marker (ArdourMarker *);
 
        void hide_marker (ArdourCanvas::Item*, GdkEvent*);
        void clear_marker_display ();
@@ -716,7 +719,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void mapped_use_new_playlist (RouteTimeAxisView&, uint32_t, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
        void mapped_use_copy_playlist (RouteTimeAxisView&, uint32_t, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
        void mapped_clear_playlist (RouteTimeAxisView&, uint32_t);
-       
+
        void button_selection (ArdourCanvas::Item* item, GdkEvent* event, ItemType item_type);
        bool button_release_can_deselect;
        bool _mouse_changed_selection;
@@ -768,9 +771,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void add_routes (ARDOUR::RouteList&);
        void timeaxisview_deleted (TimeAxisView *);
 
-       Gtk::HBox           global_hpacker;
-       Gtk::VBox           global_vpacker;
-       Gtk::VBox           vpacker;
+       Gtk::HBox global_hpacker;
+       Gtk::VBox global_vpacker;
 
        /* Cursor stuff.  Do not use directly, use via CursorContext. */
        friend class CursorContext;
@@ -806,13 +808,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Gtk::VBox                 time_bars_vbox;
 
        ArdourCanvas::Pixbuf     *logo_item;
-#if 0    
-    /* these will be needed when we have canvas rulers */
-       ArdourCanvas::Container      *minsec_group;
-       ArdourCanvas::Container      *bbt_group;
-       ArdourCanvas::Container      *timecode_group;
-       ArdourCanvas::Container      *frame_group;
-#endif
 
        ArdourCanvas::Container      *tempo_group;
        ArdourCanvas::Container      *meter_group;
@@ -1032,7 +1027,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void    selected_marker_to_selection_end   ();
 
        void    select_all_selectables_using_cursor (EditorCursor *, bool);
-       void    select_all_selectables_using_edit (bool);
+       void    select_all_selectables_using_edit (bool, bool);
        void    select_all_selectables_between (bool within);
        void    select_range_between ();
 
@@ -1178,8 +1173,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void register_region_actions ();
 
        void load_bindings ();
-       Gtkmm2ext::ActionMap editor_action_map;
-       Gtkmm2ext::Bindings  key_bindings;
 
        /* CUT/COPY/PASTE */
 
@@ -1243,7 +1236,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void region_fill_track ();
        void audition_playlist_region_standalone (boost::shared_ptr<ARDOUR::Region>);
-       void audition_playlist_region_via_route (boost::shared_ptr<ARDOUR::Region>, ARDOUR::Route&);
        void split_multichannel_region();
        void reverse_region ();
        void strip_region_silence ();
@@ -1256,14 +1248,17 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void legatize_regions (const RegionSelection& rs, bool shrink_only);
        void transform_region ();
        void transform_regions (const RegionSelection& rs);
+       void transpose_region ();
+       void transpose_regions (const RegionSelection& rs);
        void insert_patch_change (bool from_context);
        void fork_region ();
 
        void do_insert_time ();
        void insert_time (framepos_t, framecnt_t, Editing::InsertTimeOption, bool, bool, bool, bool, bool, bool);
 
-       void do_cut_time ();
-       void cut_time (framepos_t pos, framecnt_t distance, Editing::InsertTimeOption opt, bool ignore_music_glue, bool markers_too, bool tempo_too);
+       void do_remove_time ();
+       void remove_time (framepos_t pos, framecnt_t distance, Editing::InsertTimeOption opt, bool ignore_music_glue, bool markers_too,
+                       bool glued_markers_too, bool locked_markers_too, bool tempo_too);
 
        void tab_to_transient (bool forward);
 
@@ -1315,6 +1310,18 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void insert_region_list_selection (float times);
 
+       /* PT import */
+       void external_pt_dialog ();
+       typedef struct ptflookup {
+               uint16_t index1;
+               uint16_t index2;
+               PBD::ID  id;
+
+               bool operator ==(const struct ptflookup& other) {
+                       return (this->index1 == other.index1);
+               }
+       } ptflookup_t;
+
        /* import & embed */
 
        void add_external_audio_action (Editing::ImportMode);
@@ -1464,8 +1471,13 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        int scrub_reverse_distance;
        void scrub (framepos_t, double);
 
-       void keyboard_selection_begin ();
-       void keyboard_selection_finish (bool add);
+       void set_punch_start_from_edit_point ();
+       void set_punch_end_from_edit_point ();
+       void set_loop_start_from_edit_point ();
+       void set_loop_end_from_edit_point ();
+
+       void keyboard_selection_begin ( Editing::EditIgnoreOption = Editing::EDIT_IGNORE_NONE );
+       void keyboard_selection_finish (bool add, Editing::EditIgnoreOption = Editing::EDIT_IGNORE_NONE);
        bool have_pending_keyboard_selection;
        framepos_t pending_keyboard_selection_start;
 
@@ -1552,7 +1564,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        bool canvas_region_view_name_event (GdkEvent* event,ArdourCanvas::Item*, RegionView*);
        bool canvas_feature_line_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*);
        bool canvas_stream_view_event (GdkEvent* event,ArdourCanvas::Item*, RouteTimeAxisView*);
-       bool canvas_marker_event (GdkEvent* event,ArdourCanvas::Item*, Marker*);
+       bool canvas_marker_event (GdkEvent* event,ArdourCanvas::Item*, ArdourMarker*);
        bool canvas_tempo_marker_event (GdkEvent* event,ArdourCanvas::Item*, TempoMarker*);
        bool canvas_meter_marker_event (GdkEvent* event,ArdourCanvas::Item*, MeterMarker*);
        bool canvas_automation_track_event(GdkEvent* event, ArdourCanvas::Item*, AutomationTimeAxisView*);
@@ -1640,7 +1652,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void marker_menu_edit ();
        void marker_menu_remove ();
        void marker_menu_rename ();
-       void rename_marker (Marker *marker);
+       void rename_marker (ArdourMarker *marker);
        void toggle_marker_menu_lock ();
        void toggle_marker_menu_glue ();
        void marker_menu_hide ();
@@ -1677,13 +1689,13 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Gtk::Menu* cd_marker_menu;
        ArdourCanvas::Item* marker_menu_item;
 
-       typedef std::list<Marker*> Marks;
+       typedef std::list<ArdourMarker*> Marks;
        Marks metric_marks;
 
        void remove_metric_marks ();
        void draw_metric_marks (const ARDOUR::Metrics& metrics);
 
-       void compute_current_bbt_points (framepos_t left, framepos_t right, 
+       void compute_current_bbt_points (framepos_t left, framepos_t right,
                                         ARDOUR::TempoMap::BBTPointList::const_iterator& begin,
                                         ARDOUR::TempoMap::BBTPointList::const_iterator& end);
 
@@ -1719,7 +1731,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Gtk::Table               toolbar_selection_clock_table;
        Gtk::Label               toolbar_selection_cursor_label;
 
-       Gtkmm2ext::TearOff*      _mouse_mode_tearoff;
        ArdourButton mouse_select_button;
        ArdourButton mouse_draw_button;
        ArdourButton mouse_move_button;
@@ -1778,23 +1789,17 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Glib::RefPtr<Gtk::RadioAction> zoom_focus_action (Editing::ZoomFocus);
 
        Gtk::HBox           _zoom_box;
-       Gtkmm2ext::TearOff* _zoom_tearoff;
        void                zoom_adjustment_changed();
 
        void setup_toolbar ();
 
        void setup_tooltips ();
 
-       Gtkmm2ext::TearOff*     _tools_tearoff;
        Gtk::HBox                toolbar_hbox;
        Gtk::EventBox            toolbar_base;
        Gtk::Frame               toolbar_frame;
        Gtk::Viewport           _toolbar_viewport;
 
-       /* midi toolbar */
-
-       Gtk::HBox                panic_box;
-
        void setup_midi_toolbar ();
 
        /* selection process */
@@ -1834,10 +1839,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        ArdourCanvas::Rectangle*  cd_marker_bar_drag_rect;
        ArdourCanvas::Rectangle*  range_bar_drag_rect;
        ArdourCanvas::Rectangle*  transport_bar_drag_rect;
-
-#ifdef GTKOSX
-       ArdourCanvas::Rectangle     *bogus_background_rect;
-#endif
        ArdourCanvas::Rectangle     *transport_bar_range_rect;
        ArdourCanvas::Rectangle     *transport_bar_preroll_rect;
        ArdourCanvas::Rectangle     *transport_bar_postroll_rect;
@@ -2009,8 +2010,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        int pitch_shift (RegionSelection&, float cents);
        void pitch_shift_region ();
 
-       void transpose_region ();
-
        /* editor-mixer strip */
 
        MixerStrip *current_mixer_strip;
@@ -2019,8 +2018,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void cms_new (boost::shared_ptr<ARDOUR::Route>);
        void current_mixer_strip_hidden ();
 
-       void detach_tearoff (Gtk::Box* b, Gtk::Window* w);
-       void reattach_tearoff (Gtk::Box* b, Gtk::Window* w, int32_t n);
 #ifdef GTKOSX
        void ensure_all_elements_drawn ();
 #endif
@@ -2083,9 +2080,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void toggle_gain_envelope_active ();
        void reset_region_gain_envelopes ();
 
-       bool on_key_press_event (GdkEventKey*);
-       bool on_key_release_event (GdkEventKey*);
-
        void session_state_saved (std::string);
 
        Glib::RefPtr<Gtk::Action>              undo_action;
@@ -2097,8 +2091,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void history_changed ();
 
-       Gtk::HBox      status_bar_hpacker;
-
        Editing::EditPoint _edit_point;
 
        ArdourDropdown edit_point_selector;
@@ -2236,6 +2228,15 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void update_bring_in_message (Gtk::Label* label, uint32_t n, uint32_t total, std::string name);
        void bring_all_sources_into_session ();
 
+       QuantizeDialog* quantize_dialog;
+       MainMenuDisabler* _main_menu_disabler;
+
+       /* private helper functions to help with registering axis */
+
+       Glib::RefPtr<Gtk::Action> reg_sens (Glib::RefPtr<Gtk::ActionGroup> group, char const * name, char const * label, sigc::slot<void> slot);
+       void toggle_reg_sens (Glib::RefPtr<Gtk::ActionGroup> group, char const * name, char const * label, sigc::slot<void> slot);
+       void radio_reg_sens (Glib::RefPtr<Gtk::ActionGroup> action_group, Gtk::RadioAction::Group& radio_group, char const * name, char const * label, sigc::slot<void> slot);
+
        friend class Drag;
        friend class RegionDrag;
        friend class RegionMoveDrag;