fix load+save of plugin parameter automation
[ardour.git] / gtk2_ardour / public_editor.h
index e520e30a890bcfa1d412ccb00401c677ec25e3d3..a393b11e4c0df1298f22b8d90817f9506d0b85b8 100644 (file)
@@ -52,6 +52,10 @@ namespace Gtk {
        class Menu;
 }
 
+namespace Gtkmm2ext { 
+        class TearOff;
+}
+
 class Editor;
 class TimeAxisViewItem;
 class TimeAxisView;
@@ -75,6 +79,7 @@ class MarkerTimeAxis;
 class ImageFrameView;
 class ImageFrameTimeAxis;
 class MarkerView;
+class DragManager;
 
 /// Representation of the interface of the Editor class
 
@@ -83,26 +88,26 @@ class MarkerView;
  * of PublicEditor need not be recompiled if private methods or member variables
  * change.
  */
-class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway {
+class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
   public:
        PublicEditor ();
        virtual ~PublicEditor ();
 
-       typedef TrackSelection TrackViewList;
-
        /** @return Singleton PublicEditor instance */
        static PublicEditor& instance () { return *_instance; }
 
        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.
         */
-       virtual void connect_to_session (ARDOUR::Session* s) = 0;
+       virtual void set_session (ARDOUR::Session* s) = 0;
 
        /** @return The Session that we are editing, or 0 */
-       virtual ARDOUR::Session* current_session () const = 0;
+       virtual ARDOUR::Session* session () const = 0;
 
        /** Set the snap type.
         * @param t Snap type (defined in editing_syms.h)
@@ -139,7 +144,7 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
        /** 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;
 
@@ -169,20 +174,13 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
         */
        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;
 
@@ -226,7 +224,11 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
        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.
@@ -241,16 +243,13 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
 
        /** @return true if the playhead is currently being dragged, otherwise false */
        virtual bool dragging_playhead () const = 0;
-       virtual double get_physical_screen_width() const = 0;
        virtual void ensure_float (Gtk::Window&) = 0;
        virtual void show_window () = 0;
-       virtual TrackViewList* get_valid_views (TimeAxisView*, ARDOUR::RouteGroup* grp = 0) = 0;
        virtual nframes64_t leftmost_position() const = 0;
        virtual nframes64_t current_page_frames() const = 0;
        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;
@@ -274,9 +273,9 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
        virtual TimeAxisView* get_named_time_axis(const std::string & name)  = 0;
 #endif
 
-       virtual RouteTimeAxisView* get_route_view_by_id (PBD::ID& id) = 0;
+       virtual RouteTimeAxisView* get_route_view_by_route_id (PBD::ID& id) const = 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;
@@ -284,6 +283,8 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
        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;
@@ -302,6 +303,7 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
        virtual bool canvas_frame_handle_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
        virtual bool canvas_region_view_name_highlight_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
        virtual bool canvas_region_view_name_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
+       virtual bool canvas_feature_line_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
        virtual bool canvas_stream_view_event (GdkEvent* event, ArdourCanvas::Item*, RouteTimeAxisView*) = 0;
        virtual bool canvas_marker_event (GdkEvent* event, ArdourCanvas::Item*, Marker*) = 0;
        virtual bool canvas_zoom_rect_event (GdkEvent* event, ArdourCanvas::Item*) = 0;
@@ -353,11 +355,24 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulThingWithGoingAway
 
        virtual void center_screen (nframes64_t) = 0;
 
+       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;
+
+       virtual DragManager* drags () const = 0;
+       virtual void maybe_autoscroll (bool, bool) = 0;
+       virtual void stop_canvas_autoscroll () = 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__