Remove unused code.
[ardour.git] / gtk2_ardour / processor_box.h
index bd5f18b947dc432abb3b9b76ac3c0af1f2d75b8d..bf02caf3d7be6fb5d2dde0eaf052f421350a8176 100644 (file)
 #include "send_ui.h"
 #include "enums.h"
 #include "window_proxy.h"
+#include "ardour_button.h"
 
 class MotionController;
 class PluginSelector;
 class PluginUIWindow;
-class RouteRedirectSelection;
+class RouteProcessorSelection;
 class MixerStrip;
 
 namespace ARDOUR {
@@ -106,14 +107,14 @@ public:
        Gtk::EventBox& action_widget ();
        Gtk::Widget& widget ();
        std::string drag_text () const;
-       void set_visual_state (Gtk::StateType);
+       void set_visual_state (Gtkmm2ext::VisualState, bool);
 
        enum Position {
                PreFader,
                Fader,
                PostFader
        };
-       
+
        void set_position (Position);
        boost::shared_ptr<ARDOUR::Processor> processor () const;
        void set_enum_width (Width);
@@ -123,24 +124,19 @@ public:
        virtual void hide_things () {}
 
 protected:
-       
-       virtual void setup_visuals ();
-       
+       ArdourButton _button;
        Gtk::VBox _vbox;
        Position _position;
-       
-private:
 
-       void active_toggled ();
+       virtual void setup_visuals ();
+
+private:
+       void led_clicked();
        void processor_active_changed ();
        void processor_property_changed (const PBD::PropertyChange&);
-       std::string name () const;
+       std::string name (Width) const;
+       void setup_tooltip ();
 
-       Gtk::Frame _frame;
-       Gtk::EventBox _event_box;
-       Gtk::Label _name;
-       Gtk::HBox _hbox;
-       Gtk::CheckButton _active;
        boost::shared_ptr<ARDOUR::Processor> _processor;
        Width _width;
        Gtk::StateType _visual_state;
@@ -161,12 +157,14 @@ public:
 private:
        void show_gain ();
        void gain_adjusted ();
-       
+       void setup_gain_adjustment ();
+
        boost::shared_ptr<ARDOUR::Send> _send;
        Gtk::Adjustment _adjustment;
        Gtkmm2ext::HSliderController _fader;
        bool _ignore_gain_change;
-       PBD::ScopedConnection send_gain_connection;
+       PBD::ScopedConnectionList _send_connections;
+       ARDOUR::DataType _data_type;
 
        static Glib::RefPtr<Gdk::Pixbuf> _slider;
 };
@@ -177,7 +175,7 @@ public:
        PluginInsertProcessorEntry (boost::shared_ptr<ARDOUR::PluginInsert>, Width);
 
        void hide_things ();
-       
+
 private:
        void setup_visuals ();
        void plugin_insert_splitting_changed ();
@@ -196,8 +194,18 @@ private:
 class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARDOUR::SessionHandlePtr
 {
   public:
+       enum ProcessorOperation {
+               ProcessorsCut,
+               ProcessorsCopy,
+               ProcessorsPaste,
+               ProcessorsDelete,
+               ProcessorsSelectAll,
+               ProcessorsToggleActive,
+               ProcessorsAB,
+       };
+
        ProcessorBox (ARDOUR::Session*, boost::function<PluginSelector*()> get_plugin_selector,
-                     RouteRedirectSelection&, MixerStrip* parent, bool owner_is_mixer = false);
+                     RouteProcessorSelection&, MixerStrip* parent, bool owner_is_mixer = false);
        ~ProcessorBox ();
 
        void set_route (boost::shared_ptr<ARDOUR::Route>);
@@ -205,6 +213,8 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
 
        void update();
 
+       void processor_operation (ProcessorOperation);
+
        void select_all_processors ();
        void deselect_all_processors ();
        void select_all_plugins ();
@@ -215,7 +225,8 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
 
        Gtk::Window* get_processor_ui (boost::shared_ptr<ARDOUR::Processor>) const;
        void toggle_edit_processor (boost::shared_ptr<ARDOUR::Processor>);
-       
+       void toggle_processor_controls (boost::shared_ptr<ARDOUR::Processor>);
+
        sigc::signal<void,boost::shared_ptr<ARDOUR::Processor> > ProcessorSelected;
        sigc::signal<void,boost::shared_ptr<ARDOUR::Processor> > ProcessorUnselected;
 
@@ -225,7 +236,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
 
        /* prevent copy construction */
        ProcessorBox (ProcessorBox const &);
-       
+
        boost::shared_ptr<ARDOUR::Route>  _route;
        MixerStrip*         _parent_strip; // null if in RouteParamsUI
        bool                _owner_is_mixer;
@@ -237,14 +248,15 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
 
        boost::shared_ptr<ARDOUR::Processor> _processor_being_created;
 
-       ARDOUR::Placement _placement;
+       /** Index at which to place a new plugin (based on where the menu was opened), or -1 to
+        *  put at the end of the plugin list.
+        */
+       int _placement;
 
-       RouteRedirectSelection& _rr_selection;
+       RouteProcessorSelection& _rr_selection;
 
        void route_going_away ();
 
-       void selection_changed ();
-
        Gtkmm2ext::DnDVBox<ProcessorEntry> processor_display;
        Gtk::ScrolledWindow    processor_scroller;
 
@@ -252,9 +264,6 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
 
        Width _width;
 
-       Gtk::Menu *send_action_menu;
-       void build_send_action_menu ();
-
        void new_send ();
        void show_send_controls ();
 
@@ -262,7 +271,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        gint processor_menu_map_handler (GdkEventAny *ev);
        Gtk::Menu * build_processor_menu ();
        void build_processor_tooltip (Gtk::EventBox&, std::string);
-       void show_processor_menu (gint arg);
+       void show_processor_menu (int);
        Gtk::Menu* build_possible_aux_menu();
 
        void choose_aux (boost::weak_ptr<ARDOUR::Route>);
@@ -277,8 +286,6 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
 
        bool enter_notify (GdkEventCrossing *ev);
        bool leave_notify (GdkEventCrossing *ev);
-       bool processor_key_press_event (GdkEventKey *);
-       bool processor_key_release_event (GdkEventKey *);
        bool processor_button_press_event (GdkEventButton *, ProcessorEntry *);
        bool processor_button_release_event (GdkEventButton *, ProcessorEntry *);
        void redisplay_processors ();
@@ -286,24 +293,23 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        void reordered ();
        void report_failed_reorder ();
        void route_processors_changed (ARDOUR::RouteProcessorChange);
+       void processor_menu_unmapped ();
 
        void processors_reordered (const Gtk::TreeModel::Path&, const Gtk::TreeModel::iterator&, int*);
        void compute_processor_sort_keys ();
 
-       void all_processors_active(bool state);
-       void all_plugins_active(bool state);
+       void all_visible_processors_active(bool state);
        void ab_plugins ();
 
        typedef std::vector<boost::shared_ptr<ARDOUR::Processor> > ProcSelection;
 
        void cut_processors (const ProcSelection&);
-       void cut_processors ();
        void copy_processors (const ProcSelection&);
-       void copy_processors ();
        void delete_processors (const ProcSelection&);
-       void delete_processors ();
        void paste_processors ();
        void paste_processors (boost::shared_ptr<ARDOUR::Processor> before);
+       void processors_up ();
+       void processors_down ();
 
        void delete_dragged_processors (const std::list<boost::shared_ptr<ARDOUR::Processor> >&);
        void clear_processors ();
@@ -313,12 +319,13 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        void for_selected_processors (void (ProcessorBox::*pmf)(boost::shared_ptr<ARDOUR::Processor>));
        void get_selected_processors (ProcSelection&) const;
 
-        bool can_cut() const;
+       bool can_cut() const;
 
        static Glib::RefPtr<Gtk::Action> cut_action;
        static Glib::RefPtr<Gtk::Action> paste_action;
        static Glib::RefPtr<Gtk::Action> rename_action;
        static Glib::RefPtr<Gtk::Action> edit_action;
+       static Glib::RefPtr<Gtk::Action> controls_action;
        void paste_processor_state (const XMLNodeList&, boost::shared_ptr<ARDOUR::Processor>);
 
        void activate_processor (boost::shared_ptr<ARDOUR::Processor>);
@@ -332,7 +339,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        void on_size_allocate (Gtk::Allocation &);
 
        void setup_entry_positions ();
-       
+
        static ProcessorBox* _current_processor_box;
 
        static void rb_choose_aux (boost::weak_ptr<ARDOUR::Route>);
@@ -353,6 +360,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        static void rb_deactivate_all ();
        static void rb_ab_plugins ();
        static void rb_edit ();
+       static void rb_controls ();
 
        void route_property_changed (const PBD::PropertyChange&);
        std::string generate_processor_title (boost::shared_ptr<ARDOUR::PluginInsert> pi);