ProcessorBox: allow to receive PluginInfoPtr drops
[ardour.git] / gtk2_ardour / processor_box.h
index fcc70a60748b944c7f8a5ee8f7771ad6f2e55aa6..3367534b07cbb9ba6b93d99dbb15e7fb03b46a6f 100644 (file)
@@ -75,14 +75,14 @@ namespace ARDOUR {
 
 class ProcessorBox;
 
-class ProcessorWindowProxy : public WM::ProxyBase 
+class ProcessorWindowProxy : public WM::ProxyBase
 {
   public:
     ProcessorWindowProxy (std::string const &, ProcessorBox *, boost::weak_ptr<ARDOUR::Processor>);
     ~ProcessorWindowProxy();
 
     Gtk::Window* get (bool create = false);
-    
+
     boost::weak_ptr<ARDOUR::Processor> processor () const {
            return _processor;
     }
@@ -118,7 +118,7 @@ public:
 
        bool is_selectable() const {return _selectable;}
        void set_selectable(bool s) { _selectable = s; }
-       
+
        enum Position {
                PreFader,
                Fader,
@@ -152,7 +152,7 @@ protected:
 private:
        bool _selectable;
        bool _unknown_processor;
-       void led_clicked();
+       void led_clicked(GdkEventButton *);
        void processor_active_changed ();
        void processor_property_changed (const PBD::PropertyChange&);
        void processor_configuration_changed (const ARDOUR::ChanCount in, const ARDOUR::ChanCount out);
@@ -183,12 +183,13 @@ private:
                std::string name () const {
                        return _name;
                }
-               
+
                Gtk::Alignment box;
 
        private:
                void slider_adjusted ();
                void button_clicked ();
+               void button_clicked_event (GdkEventButton *);
                void control_changed ();
                std::string state_id () const;
                void set_tooltip ();
@@ -290,6 +291,8 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        void select_all_inserts ();
        void select_all_sends ();
 
+       void all_visible_processors_active(bool state);
+
        void hide_things ();
 
        bool edit_aux_send(boost::shared_ptr<ARDOUR::Processor>);
@@ -305,11 +308,14 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
         void generic_edit_processor (boost::shared_ptr<ARDOUR::Processor>);
 
        void update_gui_object_state (ProcessorEntry *);
-       
+
        sigc::signal<void,boost::shared_ptr<ARDOUR::Processor> > ProcessorSelected;
        sigc::signal<void,boost::shared_ptr<ARDOUR::Processor> > ProcessorUnselected;
 
        static void register_actions();
+#ifndef NDEBUG
+       static bool show_all_processors;
+#endif
 
   private:
 
@@ -342,6 +348,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        Gtkmm2ext::DnDVBox<ProcessorEntry> processor_display;
        Gtk::ScrolledWindow    processor_scroller;
 
+       void plugin_drop (Gtk::SelectionData const &, ProcessorEntry* position, Glib::RefPtr<Gdk::DragContext> const & context);
        void object_drop (Gtkmm2ext::DnDVBox<ProcessorEntry> *, ProcessorEntry *, Glib::RefPtr<Gdk::DragContext> const &);
 
        Width _width;
@@ -378,7 +385,6 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARD
        void processors_reordered (const Gtk::TreeModel::Path&, const Gtk::TreeModel::iterator&, int*);
        void compute_processor_sort_keys ();
 
-       void all_visible_processors_active(bool state);
        void ab_plugins ();
 
        typedef std::vector<boost::shared_ptr<ARDOUR::Processor> > ProcSelection;