Fix erroneous parameter passed to Editor::motion_handler. Makes autoscroll work...
[ardour.git] / gtk2_ardour / route_time_axis.h
index 73d3295aaf7dd2578d318a6de945c96340f2af47..95cbfa8c76e6760e97bd00ed0563e8fad479dd4e 100644 (file)
@@ -20,6 +20,9 @@
 #ifndef __ardour_route_time_axis_h__
 #define __ardour_route_time_axis_h__
 
+#include <list>
+#include <set>
+
 #include <gtkmm/table.h>
 #include <gtkmm/button.h>
 #include <gtkmm/box.h>
@@ -31,9 +34,9 @@
 
 #include <gtkmm2ext/selector.h>
 #include <gtkmm2ext/slider_controller.h>
-#include <list>
 
-#include <ardour/types.h>
+#include "ardour/playlist.h"
+#include "ardour/types.h"
 
 #include "ardour_dialog.h"
 #include "route_ui.h"
@@ -42,7 +45,6 @@
 #include "canvas.h"
 #include "gain_meter.h"
 
-
 namespace ARDOUR {
        class Session;
        class Region;
@@ -64,6 +66,7 @@ class AutomationTimeAxisView;
 class AutomationLine;
 class ProcessorAutomationLine;
 class TimeSelection;
+class RouteGroupMenu;
 
 class RouteTimeAxisView : public RouteUI, public TimeAxisView
 {
@@ -72,6 +75,7 @@ public:
        virtual ~RouteTimeAxisView ();
 
        void show_selection (TimeSelection&);
+       void set_button_names ();
 
        void set_samples_per_unit (double);
        void set_height (uint32_t h);
@@ -80,10 +84,11 @@ public:
        void selection_click (GdkEventButton*);
        void set_selected_points (PointSelection&);
        void set_selected_regionviews (RegionSelection&);
-       void get_selectables (nframes_t start, nframes_t end, double top, double bot, list<Selectable *>&);
-       void get_inverted_selectables (Selection&, list<Selectable*>&);
+       void get_selectables (nframes_t start, nframes_t end, double top, double bot, std::list<Selectable *>&);
+       void get_inverted_selectables (Selection&, std::list<Selectable*>&);
        bool show_automation(Evoral::Parameter param);
        void set_layer_display (LayerDisplay d);
+       LayerDisplay layer_display () const;
                
        boost::shared_ptr<ARDOUR::Region> find_next_region (nframes_t pos, ARDOUR::RegionPoint, int32_t dir);
        nframes64_t find_next_region_boundary (nframes64_t pos, int32_t dir);
@@ -95,9 +100,13 @@ public:
        TimeAxisView::Children get_child_list();
 
        /* The editor calls these when mapping an operation across multiple tracks */
-       void use_new_playlist (bool prompt);
-       void use_copy_playlist (bool prompt);
+       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 clear_playlist ();
+
+       /* group playlist name resolving */
+       std::string resolve_new_group_playlist_name(std::string &, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
+
        
        void build_playlist_menu (Gtk::Menu *);
 
@@ -110,7 +119,7 @@ public:
        /* This is a bit nasty to expose :/ */
        struct RouteAutomationNode {
                Evoral::Parameter                         param;
-           Gtk::CheckMenuItem*                       menu_item;
+               Gtk::CheckMenuItem*                       menu_item;
                boost::shared_ptr<AutomationTimeAxisView> track;
            
                RouteAutomationNode (Evoral::Parameter par, Gtk::CheckMenuItem* mi, boost::shared_ptr<AutomationTimeAxisView> tr)
@@ -123,14 +132,14 @@ public:
 
        XMLNode* get_automation_child_xml_node (Evoral::Parameter param) { return RouteUI::get_automation_child_xml_node (param); }
        
-       typedef map<Evoral::Parameter, RouteAutomationNode*> AutomationTracks;
+       typedef std::map<Evoral::Parameter, RouteAutomationNode*> AutomationTracks;
        AutomationTracks automation_tracks() { return _automation_tracks; }
 
        boost::shared_ptr<AutomationTimeAxisView> automation_child(Evoral::Parameter param);
        
-       string              name() const;
+       std::string         name() const;
        StreamView*         view() const { return _view; }
-       ARDOUR::RouteGroup* edit_group() const;
+       ARDOUR::RouteGroup* route_group() const;
        boost::shared_ptr<ARDOUR::Playlist> playlist() const;
 
        void fast_update ();
@@ -149,9 +158,9 @@ protected:
 
        struct ProcessorAutomationNode {
                Evoral::Parameter                         what;
-           Gtk::CheckMenuItem*                       menu_item;
+               Gtk::CheckMenuItem*                       menu_item;
                boost::shared_ptr<AutomationTimeAxisView> view;
-           RouteTimeAxisView&                        parent;
+               RouteTimeAxisView&                        parent;
 
            ProcessorAutomationNode (Evoral::Parameter w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p)
                    : what (w), menu_item (mitem), parent (p) {}
@@ -163,7 +172,7 @@ protected:
            boost::shared_ptr<ARDOUR::Processor> processor;
            bool                                 valid;
            Gtk::Menu*                           menu;
-           vector<ProcessorAutomationNode*>     lines;
+           std::vector<ProcessorAutomationNode*>     lines;
 
            ProcessorAutomationInfo (boost::shared_ptr<ARDOUR::Processor> i) 
                    : processor (i), valid (true), menu (0) {}
@@ -179,7 +188,7 @@ protected:
 
        void processors_changed ();
        
-       void add_processor_to_subplugin_menu (boost::shared_ptr<ARDOUR::Processor>);
+       void add_processor_to_subplugin_menu (boost::weak_ptr<ARDOUR::Processor>);
        void remove_processor_automation_node (ProcessorAutomationNode* pan);
 
        void processor_menu_item_toggled (RouteTimeAxisView::ProcessorAutomationInfo*,
@@ -200,7 +209,7 @@ protected:
        find_processor_automation_curve (boost::shared_ptr<ARDOUR::Processor> i, Evoral::Parameter);
 
        void add_processor_automation_curve (boost::shared_ptr<ARDOUR::Processor> r, Evoral::Parameter);
-       void add_existing_processor_automation_curves (boost::shared_ptr<ARDOUR::Processor>);
+       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);
        
@@ -214,8 +223,7 @@ protected:
 
        virtual void label_view ();
        
-       void add_edit_group_menu_item (ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*);
-       void set_edit_group_from_menu (ARDOUR::RouteGroup *);
+       void set_route_group_from_menu (ARDOUR::RouteGroup *);
 
        void reset_samples_per_unit ();
 
@@ -228,11 +236,9 @@ protected:
        void align_style_changed ();
        void set_align_style (ARDOUR::AlignStyle);
        
-       virtual void set_playlist (boost::shared_ptr<ARDOUR::Playlist>);
        void         playlist_click ();
        void         show_playlist_selector ();
        void         playlist_changed ();
-       void         playlist_modified ();
 
        void rename_current_playlist ();
        
@@ -262,7 +268,7 @@ protected:
        Gtk::HBox   other_button_hbox;
        Gtk::Table  button_table;
        Gtk::Button processor_button;
-       Gtk::Button edit_group_button;
+       Gtk::Button route_group_button;
        Gtk::Button playlist_button;
        Gtk::Button size_button;
        Gtk::Button automation_button;
@@ -271,38 +277,39 @@ protected:
        
        Gtk::Menu           subplugin_menu;
        Gtk::Menu*          automation_action_menu;
-       Gtk::Menu           edit_group_menu;
+       RouteGroupMenu*     route_group_menu;
        Gtk::RadioMenuItem* align_existing_item;
        Gtk::RadioMenuItem* align_capture_item;
        Gtk::RadioMenuItem* normal_track_mode_item;
+       Gtk::RadioMenuItem* non_layered_track_mode_item;
        Gtk::RadioMenuItem* destructive_track_mode_item;
        Gtk::Menu*          playlist_menu;
        Gtk::Menu*          playlist_action_menu;
        Gtk::MenuItem*      playlist_item;
        Gtk::Menu*          mode_menu;
+       Gtk::Menu*          color_mode_menu;
 
-       virtual Gtk::Menu* build_mode_menu() { return NULL; }
+       virtual Gtk::Menu* build_mode_menu() { return 0; }
+       virtual Gtk::Menu* build_color_mode_menu() { return 0; }
 
        void use_playlist (boost::weak_ptr<ARDOUR::Playlist>);
 
        ArdourCanvas::SimpleRect* timestretch_rect;
 
        void set_track_mode (ARDOUR::TrackMode);
-       void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item);
+       void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item, Gtk::RadioMenuItem* reset_item_2);
        void track_mode_changed ();
 
-       list<ProcessorAutomationInfo*> processor_automation;
+       std::list<ProcessorAutomationInfo*> processor_automation;
 
-       typedef vector<boost::shared_ptr<AutomationLine> > ProcessorAutomationCurves;
+       typedef std::vector<boost::shared_ptr<AutomationLine> > ProcessorAutomationCurves;
        ProcessorAutomationCurves processor_automation_curves;
        
        // Set from XML so context menu automation buttons can be correctly initialized
-       set<Evoral::Parameter> _show_automation;
+       std::set<Evoral::Parameter> _show_automation;
 
        AutomationTracks _automation_tracks;
 
-       sigc::connection modified_connection;
-
        void post_construct ();
        
        GainMeterBase gm;
@@ -312,9 +319,9 @@ protected:
        XMLNode* underlay_xml_node;
        bool set_underlay_state();
 
-       typedef list<StreamView*> UnderlayList;
+       typedef std::list<StreamView*> UnderlayList;
        UnderlayList _underlay_streams;
-       typedef list<RouteTimeAxisView*> UnderlayMirrorList;
+       typedef std::list<RouteTimeAxisView*> UnderlayMirrorList;
        UnderlayMirrorList _underlay_mirrors;
 };