lots of odds and ends to do with solo isolate and its GUI
[ardour.git] / gtk2_ardour / plugin_selector.h
index 2e673d8de777152ef5a8fe394cfbab6e9c9d0575..a9f9803809643b8cf9bab620b28abbbe002ebee6 100644 (file)
@@ -26,6 +26,7 @@
 #include <gtkmm2ext/selector.h>
 
 #include "ardour/plugin.h"
+#include "ardour/session_handle.h"
 #include "plugin_interest.h"
 
 namespace ARDOUR {
@@ -37,21 +38,20 @@ class PluginSelector : public ArdourDialog
 {
   public:
        PluginSelector (ARDOUR::PluginManager *);
+       ~PluginSelector ();
 
        void set_interested_object (PluginInterestedObject&);
 
        int run (); // XXX should we try not to overload the non-virtual Gtk::Dialog::run() ?
 
-       void set_session (ARDOUR::Session*);
        void on_show ();
 
-       Gtk::Menu& plugin_menu ();
+       Gtk::Menu* plugin_menu ();
        void show_manager ();
 
   private:
        PluginInterestedObject* interested_object;
 
-       ARDOUR::Session* session;
        Gtk::ScrolledWindow scroller;   // Available plugins
        Gtk::ScrolledWindow ascroller;  // Added plugins
 
@@ -114,6 +114,7 @@ class PluginSelector : public ArdourDialog
        void vst_refiller (const std::string&);
        void au_refiller (const std::string&);
 
+       Gtk::Menu* _plugin_menu;
        ARDOUR::PluginManager *manager;
 
        void row_clicked(GdkEventButton *);
@@ -132,11 +133,12 @@ class PluginSelector : public ArdourDialog
        bool in_row_change;
 
        void plugin_chosen_from_menu (const ARDOUR::PluginInfoPtr&);
-       Gtk::Menu* _menu;
 
        Gtk::Menu* create_favs_menu (ARDOUR::PluginInfoList&);
        Gtk::Menu* create_by_creator_menu (ARDOUR::PluginInfoList&);
        Gtk::Menu* create_by_category_menu (ARDOUR::PluginInfoList&);
+       void build_plugin_menu ();
+       PBD::ScopedConnection plugin_list_changed_connection;
 };
 
 #endif // __ardour_plugin_selector_h__