session prefs editor gets renamed as session properties
[ardour.git] / gtk2_ardour / public_editor.h
index 1677c2ee49aa3ef67ef1c3315bce10ffef62ee17..bb498a8c4f4eff0c6f89b04697a6cce54911ad5d 100644 (file)
@@ -52,6 +52,10 @@ namespace Gtk {
        class Menu;
 }
 
+namespace Gtkmm2ext { 
+        class TearOff;
+}
+
 class Editor;
 class TimeAxisViewItem;
 class TimeAxisView;
@@ -94,6 +98,8 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual bool have_idled() const = 0;
        virtual void first_idle() = 0;
 
+       virtual void setup_tooltips() = 0;
+
        /** Attach this editor to a Session.
         * @param s Session to connect to.
         */
@@ -137,7 +143,7 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        /** Set the mouse mode (gain, object, range, timefx etc.)
         * @param m Mouse mode (defined in editing_syms.h)
         * @param force Perform the effects of the change even if no change is required
-        * (ie even if the current mouse mode is equal to \ref m)
+        * (ie even if the current mouse mode is equal to @param m)
         */
        virtual void set_mouse_mode (Editing::MouseMode m, bool force = false) = 0;
 
@@ -167,20 +173,13 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
         */
        virtual bool sound_notes () const = 0;
 
-       /** Possibly start the audition of a region.  If \ref r is 0, or not an AudioRegion
-        * any current audition is cancelled.  If we are currently auditioning \ref r,
-        * the audition will be cancelled.  Otherwise an audition of \ref r will start.
+       /** Possibly start the audition of a region.  If @param r is 0, or not an AudioRegion
+        * any current audition is cancelled.  If we are currently auditioning @param r,
+        * the audition will be cancelled.  Otherwise an audition of @param r will start.
         * \param r Region to consider.
         */
        virtual void consider_auditioning (boost::shared_ptr<ARDOUR::Region> r) = 0;
 
-       /** Set whether waveforms should be shown while recording audio tracks.
-        * @param yn true to show waveforms, otherwise false.
-        */
-       virtual void set_show_waveforms_recording (bool yn) = 0;
-
-       /** @return true if waveforms are being shown while recording, otherwise false */
-       virtual bool show_waveforms_recording () const = 0;
        virtual void new_region_from_selection () = 0;
        virtual void separate_region_from_selection () = 0;
 
@@ -224,7 +223,11 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual void select_all_tracks () = 0;
        virtual void set_selected_track (TimeAxisView&, Selection::Operation op = Selection::Set, bool no_remove = false) = 0;
        virtual void set_selected_mixer_strip (TimeAxisView&) = 0;
-       virtual void hide_track_in_display (TimeAxisView& tv, bool temporary = false) = 0;
+       virtual void hide_track_in_display (TimeAxisView* tv, bool temporary = false) = 0;
+
+        virtual void set_stationary_playhead (bool yn) = 0;
+        virtual void toggle_stationary_playhead () = 0;
+        virtual bool stationary_playhead() const = 0;
 
        /** Set whether the editor should follow the playhead.
         * @param yn true to follow playhead, otherwise false.
@@ -247,7 +250,6 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual void temporal_zoom_step (bool coarser) = 0;
        virtual void scroll_tracks_down_line () = 0;
        virtual void scroll_tracks_up_line () = 0;
-       virtual bool new_regionviews_display_gain () = 0;
        virtual void prepare_for_cleanup () = 0;
        virtual void finish_cleanup () = 0;
        virtual void reset_x_origin (nframes64_t frame) = 0;
@@ -273,7 +275,7 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
 
        virtual RouteTimeAxisView* get_route_view_by_id (PBD::ID& id) = 0;
 
-       virtual void get_equivalent_regions (RegionView* rv, std::vector<RegionView*>&, ARDOUR::RouteGroup::Property) const = 0;
+       virtual void get_equivalent_regions (RegionView* rv, std::vector<RegionView*>&, PBD::PropertyID) const = 0;
 
        sigc::signal<void> ZoomFocusChanged;
        sigc::signal<void> ZoomChanged;
@@ -281,6 +283,8 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        sigc::signal<void> Realized;
        sigc::signal<void,nframes64_t> UpdateAllTransportClocks;
 
+        static sigc::signal<void> DropDownKeys;
+        
        Glib::RefPtr<Gtk::ActionGroup> editor_actions;
 
        virtual void reset_focus () = 0;
@@ -353,11 +357,17 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual TrackViewList axis_views_from_routes (boost::shared_ptr<ARDOUR::RouteList>) const = 0;
        virtual TrackViewList const & get_track_views () = 0;
        
+       virtual Gtkmm2ext::TearOff* mouse_mode_tearoff () const = 0;
+       virtual Gtkmm2ext::TearOff* tools_tearoff () const = 0;
+
        /// Singleton instance, set up by Editor::Editor()
 
        static PublicEditor* _instance;
 
        friend bool relay_key_press (GdkEventKey*, Gtk::Window*);
+       friend bool forward_key_press (GdkEventKey*);
+
+       PBD::Signal0<void> SnapChanged;
 };
 
 #endif // __gtk_ardour_public_editor_h__