Fix up state save/load of location lock/glue settings.
[ardour.git] / gtk2_ardour / processor_box.h
index 06a47538025ea92cea816824dcafe17206468fe4..1e4257d22b16d207a2299dc8ed100b112ef40f55 100644 (file)
 #ifndef __ardour_gtk_processor_box__
 #define __ardour_gtk_processor_box__
 
+#include <cmath>
 #include <vector>
 
-#include <cmath>
+#include <boost/function.hpp>
+
 #include <gtkmm/box.h>
 #include <gtkmm/eventbox.h>
 #include <gtkmm/menu.h>
@@ -34,6 +36,7 @@
 #include <gtkmm2ext/pixfader.h>
 
 #include "pbd/stateful.h"
+#include "pbd/signals.h"
 
 #include "ardour/types.h"
 #include "ardour/ardour.h"
@@ -41,6 +44,7 @@
 #include "ardour/port_insert.h"
 #include "ardour/processor.h"
 #include "ardour/route.h"
+#include "ardour/session_handle.h"
 
 #include "pbd/fastlog.h"
 
@@ -76,7 +80,8 @@ public:
        Gtk::Widget& widget ();
        std::string drag_text () const;
        boost::shared_ptr<ARDOUR::Processor> processor () const;
-       void set_width (Width);
+       void set_enum_width (Width);
+       virtual void set_pixel_width (int) {}
 
 protected:
        
@@ -86,7 +91,7 @@ private:
 
        void active_toggled ();
        void processor_active_changed ();
-       void processor_name_changed ();
+       void processor_property_changed (const PBD::PropertyChange&);
        std::string name () const;
        
        Gtk::EventBox _event_box;
@@ -95,6 +100,8 @@ private:
        Gtk::CheckButton _active;
        boost::shared_ptr<ARDOUR::Processor> _processor;
        Width _width;
+       PBD::ScopedConnection active_connection;
+       PBD::ScopedConnection name_connection;
 };
 
 class SendProcessorEntry : public ProcessorEntry
@@ -104,6 +111,9 @@ public:
 
        static void setup_slider_pix ();
 
+       void set_enum_width (Width, int);
+       void set_pixel_width (int);
+
 private:
        void show_gain ();
        void gain_adjusted ();
@@ -112,15 +122,16 @@ private:
        Gtk::Adjustment _adjustment;
        Gtkmm2ext::HSliderController _fader;
        bool _ignore_gain_change;
-       
+       PBD::ScopedConnection send_gain_connection;
+
        static Glib::RefPtr<Gdk::Pixbuf> _slider;
 };
 
-class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
+class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARDOUR::SessionHandlePtr
 {
   public:
-       ProcessorBox (ARDOUR::Session&, sigc::slot<PluginSelector*> get_plugin_selector,
-                       RouteRedirectSelection&, MixerStrip* parent, bool owner_is_mixer = false);
+       ProcessorBox (ARDOUR::Session*, boost::function<PluginSelector*()> get_plugin_selector,
+                     RouteRedirectSelection&, MixerStrip* parent, bool owner_is_mixer = false);
        ~ProcessorBox ();
 
        void set_route (boost::shared_ptr<ARDOUR::Route>);
@@ -141,13 +152,12 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
 
   private:
        boost::shared_ptr<ARDOUR::Route>  _route;
-       ARDOUR::Session &   _session;
        MixerStrip*         _parent_strip; // null if in RouteParamsUI
        bool                _owner_is_mixer;
        bool                 ab_direction;
-       std::vector<sigc::connection> connections;
+       PBD::ScopedConnectionList connections;
 
-       sigc::slot<PluginSelector*> _get_plugin_selector;
+       boost::function<PluginSelector*()> _get_plugin_selector;
 
        boost::shared_ptr<ARDOUR::Processor> _processor_being_created;
 
@@ -187,7 +197,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
        void return_io_finished (IOSelector::Result, boost::weak_ptr<ARDOUR::Processor>, IOSelectorWindow*);
        void choose_insert ();
        void choose_plugin ();
-       void use_plugins (const SelectedPlugins&);
+       bool use_plugins (const SelectedPlugins&);
 
        bool no_processor_redisplay;
 
@@ -200,6 +210,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
        void redisplay_processors ();
        void add_processor_to_display (boost::weak_ptr<ARDOUR::Processor>);
        void reordered ();
+       void route_processors_changed (ARDOUR::RouteProcessorChange);
 
        void remove_processor_gui (boost::shared_ptr<ARDOUR::Processor>);
 
@@ -227,9 +238,13 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
        void rename_processors ();
 
        void for_selected_processors (void (ProcessorBox::*pmf)(boost::shared_ptr<ARDOUR::Processor>));
-       void get_selected_processors (ProcSelection&);
+       void get_selected_processors (ProcSelection&) 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;
        void paste_processor_state (const XMLNodeList&, boost::shared_ptr<ARDOUR::Processor>);
 
        void activate_processor (boost::shared_ptr<ARDOUR::Processor>);
@@ -241,6 +256,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
        gint idle_delete_processor (boost::weak_ptr<ARDOUR::Processor>);
 
        void weird_plugin_dialog (ARDOUR::Plugin& p, ARDOUR::Route::ProcessorStreams streams);
+       void on_size_allocate (Gtk::Allocation &);
 
        static ProcessorBox* _current_processor_box;
 
@@ -263,7 +279,7 @@ class ProcessorBox : public Gtk::HBox, public PluginInterestedObject
        static void rb_ab_plugins ();
        static void rb_edit ();
 
-       void route_name_changed ();
+       void route_property_changed (const PBD::PropertyChange&);
        std::string generate_processor_title (boost::shared_ptr<ARDOUR::PluginInsert> pi);
 };