Fix key-forwarding to linuxVST UIs
[ardour.git] / gtk2_ardour / io_selector.h
index f8822cf1afc061726702d12fbfdd5eafe1b827b2..a9810f2d7a3de1f5bd04469603b68b0c58c1f170 100644 (file)
 
 */
 
-#ifndef __ardour_ui_io_selector_h__
-#define __ardour_ui_io_selector_h__
+#ifndef __gtkardour_io_selector_h__
+#define __gtkardour_io_selector_h__
 
-#include "ardour_dialog.h"
 #include "port_matrix.h"
-#include "i18n.h"
-
-namespace ARDOUR {
-       class PortInsert;
-}
+#include "ardour_window.h"
 
 class IOSelector : public PortMatrix
 {
-  public:
-       IOSelector (Gtk::Window*, ARDOUR::Session&, boost::shared_ptr<ARDOUR::IO>);
+public:
+       IOSelector (Gtk::Window*, ARDOUR::Session *, boost::shared_ptr<ARDOUR::IO>);
 
        void set_state (ARDOUR::BundleChannel c[2], bool);
        PortMatrixNode::State get_state (ARDOUR::BundleChannel c[2]) const;
 
-       std::string disassociation_verb () const {
-               return _("Disconnect");
-       }
+       std::string disassociation_verb () const;
+       std::string channel_noun () const;
 
-       std::string channel_noun () const {
-               return _("port");
-       }
+       ARDOUR::Session* session() const { return _session; }
 
        uint32_t n_io_ports () const;
        boost::shared_ptr<ARDOUR::IO> const io () { return _io; }
@@ -61,19 +53,24 @@ class IOSelector : public PortMatrix
                return _other;
        }
 
-  private:
+private:
+
+       void setup_type ();
+       void io_changed ();
+       void io_changed_proxy ();
 
        int _other;
        int _ours;
        boost::shared_ptr<ARDOUR::IO> _io;
        boost::shared_ptr<PortGroup> _port_group;
        bool _find_inputs_for_io_outputs;
+       PBD::ScopedConnection _io_connection;
 };
 
-class IOSelectorWindow : public Gtk::Window
+class IOSelectorWindow : public ArdourWindow
 {
   public:
-       IOSelectorWindow (ARDOUR::Session&, boost::shared_ptr<ARDOUR::IO>, bool can_cancel = false);
+       IOSelectorWindow (ARDOUR::Session *, boost::shared_ptr<ARDOUR::IO>, bool can_cancel = false);
 
        IOSelector& selector() { return _selector; }
 
@@ -88,44 +85,4 @@ class IOSelectorWindow : public Gtk::Window
        bool wm_delete (GdkEventAny*);
 };
 
-
-class PortInsertUI : public Gtk::VBox
-{
-  public:
-       PortInsertUI (Gtk::Window*, ARDOUR::Session&, boost::shared_ptr<ARDOUR::PortInsert>);
-
-       void redisplay ();
-       void finished (IOSelector::Result);
-
-  private:
-       IOSelector input_selector;
-       IOSelector output_selector;
-};
-
-class PortInsertWindow : public ArdourDialog
-{
-  public:
-       PortInsertWindow (ARDOUR::Session&, boost::shared_ptr<ARDOUR::PortInsert>, bool can_cancel = false);
-
-  protected:
-       void on_map ();
-
-  private:
-       PortInsertUI _portinsertui;
-       Gtk::VBox vbox;
-
-       Gtk::Button ok_button;
-       Gtk::Button cancel_button;
-       Gtk::Frame button_frame;
-
-       void cancel ();
-       void accept ();
-
-       void plugin_going_away ();
-       sigc::connection going_away_connection;
-
-       bool wm_delete (GdkEventAny*);
-};
-
-
-#endif
+#endif /* __gtkardour_io_selector_h__ */