replace ::cast_dynamic() with relevant ActionManager::get_*_action() calls
[ardour.git] / gtk2_ardour / route_time_axis.h
index 45b8afd82dc4930313fc5f78f48bb71fcf777dfe..48af0f82b25c42ef376ec9b5309329bcaf5674fb 100644 (file)
 #include <gtkmm/checkmenuitem.h>
 #include <gtkmm/adjustment.h>
 
-#include <gtkmm2ext/selector.h>
-#include <gtkmm2ext/slider_controller.h>
+#include "widgets/ardour_button.h"
 
 #include "ardour/playlist.h"
 #include "ardour/types.h"
 
-#include "ardour_button.h"
 #include "ardour_dialog.h"
 #include "route_ui.h"
 #include "enums.h"
-#include "time_axis_view.h"
+#include "stripable_time_axis.h"
 #include "gain_meter.h"
 
 namespace ARDOUR {
@@ -70,12 +68,20 @@ class AutomationLine;
 class ProcessorAutomationLine;
 class TimeSelection;
 class RouteGroupMenu;
+class ItemCounts;
 
-class RouteTimeAxisView : public RouteUI, public TimeAxisView
+class RouteTimeAxisView : public RouteUI, public StripableTimeAxisView
 {
 public:
-       RouteTimeAxisView (PublicEditor&, ARDOUR::Session*, ArdourCanvas::Canvas& canvas);
-       virtual ~RouteTimeAxisView ();
+       RouteTimeAxisView (PublicEditor&, ARDOUR::Session*, ArdourCanvas::Canvas& canvas);
+       virtual ~RouteTimeAxisView ();
+
+       std::string name()  const;
+       Gdk::Color color () const;
+       bool marked_for_display () const;
+       bool set_marked_for_display (bool);
+
+       boost::shared_ptr<ARDOUR::Stripable> stripable() const { return RouteUI::stripable(); }
 
        void set_route (boost::shared_ptr<ARDOUR::Route>);
 
@@ -83,23 +89,23 @@ public:
        void set_button_names ();
 
        void set_samples_per_pixel (double);
-       void set_height (uint32_t h);
-       void show_timestretch (framepos_t start, framepos_t end, int layers, int layer);
+       void set_height (uint32_t h, TrackHeightMode m = OnlySelf);
+       void show_timestretch (samplepos_t start, samplepos_t end, int layers, int layer);
        void hide_timestretch ();
        void selection_click (GdkEventButton*);
        void set_selected_points (PointSelection&);
        void set_selected_regionviews (RegionSelection&);
-       void get_selectables (ARDOUR::framepos_t start, ARDOUR::framepos_t end, double top, double bot, std::list<Selectable *>&);
+       void get_selectables (ARDOUR::samplepos_t start, ARDOUR::samplepos_t end, double top, double bot, std::list<Selectable *>&, bool within = false);
        void get_inverted_selectables (Selection&, std::list<Selectable*>&);
        void set_layer_display (LayerDisplay d, bool apply_to_selection = false);
        LayerDisplay layer_display () const;
 
-       boost::shared_ptr<ARDOUR::Region> find_next_region (framepos_t pos, ARDOUR::RegionPoint, int32_t dir);
-       framepos_t find_next_region_boundary (framepos_t pos, int32_t dir);
+       boost::shared_ptr<ARDOUR::Region> find_next_region (samplepos_t pos, ARDOUR::RegionPoint, int32_t dir);
+       samplepos_t find_next_region_boundary (samplepos_t pos, int32_t dir);
 
        /* Editing operations */
        void cut_copy_clear (Selection&, Editing::CutCopyOp);
-       bool paste (ARDOUR::framepos_t, unsigned paste_count, float times, Selection&, size_t nth);
+       bool paste (ARDOUR::samplepos_t, const Selection&, PasteContext& ctx, const int32_t sub_num);
        RegionView* combine_regions ();
        void uncombine_regions ();
        void uncombine_region (RegionView*);
@@ -107,8 +113,7 @@ public:
        void fade_range (TimeSelection&);
 
        /* The editor calls these when mapping an operation across multiple tracks */
-       void use_new_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
-       void use_copy_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
+       void use_new_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &, bool copy);
        void clear_playlist ();
 
        /* group playlist name resolving */
@@ -122,15 +127,8 @@ public:
 
        int set_state (const XMLNode&, int version);
 
-       virtual void create_automation_child (const Evoral::Parameter& param, bool show) = 0;
-
-       typedef std::map<Evoral::Parameter, boost::shared_ptr<AutomationTimeAxisView> > AutomationTracks;
-       AutomationTracks automation_tracks() { return _automation_tracks; }
-
-       boost::shared_ptr<AutomationTimeAxisView> automation_child(Evoral::Parameter param);
        virtual Gtk::CheckMenuItem* automation_child_menu_item (Evoral::Parameter);
 
-       std::string         name() const;
        StreamView*         view() const { return _view; }
        ARDOUR::RouteGroup* route_group() const;
        boost::shared_ptr<ARDOUR::Playlist> playlist() const;
@@ -155,30 +153,30 @@ protected:
                boost::shared_ptr<AutomationTimeAxisView> view;
                RouteTimeAxisView&                        parent;
 
-           ProcessorAutomationNode (Evoral::Parameter w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p)
+               ProcessorAutomationNode (Evoral::Parameter w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p)
                    : what (w), menu_item (mitem), parent (p) {}
 
-           ~ProcessorAutomationNode ();
+               ~ProcessorAutomationNode ();
        };
 
        struct ProcessorAutomationInfo {
-           boost::shared_ptr<ARDOUR::Processor> processor;
-           bool                                 valid;
-           Gtk::Menu*                           menu;
-           std::vector<ProcessorAutomationNode*>     lines;
+               boost::shared_ptr<ARDOUR::Processor> processor;
+               bool                                 valid;
+               Gtk::Menu*                           menu;
+               std::vector<ProcessorAutomationNode*>     lines;
 
-           ProcessorAutomationInfo (boost::shared_ptr<ARDOUR::Processor> i)
+               ProcessorAutomationInfo (boost::shared_ptr<ARDOUR::Processor> i)
                    : processor (i), valid (true), menu (0) {}
 
-           ~ProcessorAutomationInfo ();
+               ~ProcessorAutomationInfo ();
        };
 
 
        void update_diskstream_display ();
 
-       gint route_group_click  (GdkEventButton *);
+       bool route_group_click  (GdkEventButton *);
 
-       void processors_changed (ARDOUR::RouteProcessorChange);
+       virtual void processors_changed (ARDOUR::RouteProcessorChange);
 
        virtual void add_processor_to_subplugin_menu (boost::weak_ptr<ARDOUR::Processor>);
        void remove_processor_automation_node (ProcessorAutomationNode* pan);
@@ -189,7 +187,6 @@ protected:
        void processor_automation_track_hidden (ProcessorAutomationNode*,
                                               boost::shared_ptr<ARDOUR::Processor>);
 
-       void automation_track_hidden (Evoral::Parameter param);
 
        ProcessorAutomationNode*
        find_processor_automation_node (boost::shared_ptr<ARDOUR::Processor> i, Evoral::Parameter);
@@ -200,62 +197,57 @@ protected:
        void add_processor_automation_curve (boost::shared_ptr<ARDOUR::Processor> r, Evoral::Parameter);
        void add_existing_processor_automation_curves (boost::weak_ptr<ARDOUR::Processor>);
 
-       void add_automation_child(Evoral::Parameter param, boost::shared_ptr<AutomationTimeAxisView> track, bool show=true);
 
        void reset_processor_automation_curves ();
 
        void take_name_changed (void *src);
        void route_property_changed (const PBD::PropertyChange&);
-       void name_entry_changed ();
+       bool name_entry_changed (std::string const&);
+
+       virtual void toggle_channel_selector () {}
 
        void blink_rec_display (bool onoff);
 
        virtual void label_view ();
 
-       void reset_samples_per_pixel ();
-
        virtual void build_automation_action_menu (bool);
        virtual void append_extra_display_menu_items () {}
        void         build_display_menu ();
 
        void set_align_choice (Gtk::RadioMenuItem*, ARDOUR::AlignChoice, bool apply_to_selection = false);
 
-       void         playlist_click ();
+       bool         playlist_click (GdkEventButton *);
        void         show_playlist_selector ();
        void         playlist_changed ();
 
        void rename_current_playlist ();
 
-       void         automation_click ();
+       bool         automation_click (GdkEventButton *);
 
        virtual void show_all_automation (bool apply_to_selection = false);
        virtual void show_existing_automation (bool apply_to_selection = false);
        virtual void hide_all_automation (bool apply_to_selection = false);
 
-       void timestretch (framepos_t start, framepos_t end);
+       void timestretch (samplepos_t start, samplepos_t end);
        void speed_changed ();
        void map_frozen ();
        void color_handler ();
        void region_view_added (RegionView*);
        void create_gain_automation_child (const Evoral::Parameter &, bool);
+       void create_trim_automation_child (const Evoral::Parameter &, bool);
        void create_mute_automation_child (const Evoral::Parameter &, bool);
        void setup_processor_menu_and_curves ();
        void route_color_changed ();
-        bool can_edit_name() const;
-
-       boost::shared_ptr<AutomationTimeAxisView> gain_track;
-       boost::shared_ptr<AutomationTimeAxisView> mute_track;
+       bool can_edit_name() const;
 
        StreamView*           _view;
-       ArdourCanvas::Canvas& parent_canvas;
-       bool                  no_redraw;
 
        Gtk::HBox   other_button_hbox;
        Gtk::Table  button_table;
-       ArdourButton route_group_button;
-       ArdourButton playlist_button;
-       ArdourButton automation_button;
-       ArdourButton number_label;
+       ArdourWidgets::ArdourButton route_group_button;
+       ArdourWidgets::ArdourButton playlist_button;
+       ArdourWidgets::ArdourButton automation_button;
+       ArdourWidgets::ArdourButton number_label;
 
        Gtk::Menu           subplugin_menu;
        Gtk::Menu*          automation_action_menu;
@@ -272,8 +264,6 @@ protected:
 
        ArdourCanvas::Rectangle* timestretch_rect;
 
-       void set_track_mode (ARDOUR::TrackMode, bool apply_to_selection = false);
-
        /** Information about all automatable processor parameters that apply to
         *  this route.  The Amp processor is not included in this list.
         */
@@ -281,11 +271,6 @@ protected:
 
        typedef std::vector<boost::shared_ptr<AutomationLine> > ProcessorAutomationCurves;
        ProcessorAutomationCurves processor_automation_curves;
-
-       AutomationTracks _automation_tracks;
-       typedef std::map<Evoral::Parameter, Gtk::CheckMenuItem*> ParameterMenuMap;
-       /** parameter -> menu item map for the main automation menu */
-       ParameterMenuMap _main_automation_menu_map;
        /** parameter -> menu item map for the plugin automation menu */
        ParameterMenuMap _subplugin_menu_map;
 
@@ -303,13 +288,28 @@ protected:
 
        bool _ignore_set_layer_display;
 
+protected:
+       void update_pan_track_visibility ();
+
+       /** Ensure that we have the appropriate automation lanes for panners.
+        *
+        *  @param show true to show any new views that we create, otherwise false.
+        */
+       void ensure_pan_views (bool show = true);
+
+       std::list<boost::shared_ptr<AutomationTimeAxisView> > pan_tracks;
+       Gtk::CheckMenuItem* pan_automation_item;
+
 private:
 
        void remove_child (boost::shared_ptr<TimeAxisView>);
        void update_playlist_tip ();
        void parameter_changed (std::string const & p);
        void update_track_number_visibility();
+
+       void drop_instrument_ref ();
+       void reread_midnam ();
+       PBD::ScopedConnectionList midnam_connection;
 };
 
 #endif /* __ardour_route_time_axis_h__ */
-