Fix restoration of key bindings assigned to Windows+key, bug #7037
[ardour.git] / libs / gtkmm2ext / gtkmm2ext / binding_proxy.h
index dd9b94319df27df59d3257a1051d172d158e3c1d..7108c46eb2b8af8c66c760b698c09f272511ae65 100644 (file)
 #define __binding_proxy__
 
 #include <string>
+#include <boost/shared_ptr.hpp>
 
-#include <gtkmm2ext/popup.h>
+#include "pbd/signals.h"
+
+#include "gtkmm2ext/visibility.h"
+#include "gtkmm2ext/popup.h"
 
 namespace PBD {
        class Controllable;
 }
 
-class BindingProxy : public sigc::trackable
+class LIBGTKMM2EXT_API BindingProxy : public sigc::trackable
 {
    public:
-       BindingProxy (PBD::Controllable&);
+       BindingProxy (boost::shared_ptr<PBD::Controllable>);
+       BindingProxy ();
        virtual ~BindingProxy();
-       
+
        void set_bind_button_state (guint button, guint statemask);
-       void get_bind_button_state (guint &button, guint &statemask);
 
+       static bool is_bind_action (GdkEventButton *);
        bool button_press_handler (GdkEventButton *);
 
-       PBD::Controllable* get_controllable() { return &controllable; }
-  protected:
+       boost::shared_ptr<PBD::Controllable> get_controllable() const { return controllable; }
+       void set_controllable (boost::shared_ptr<PBD::Controllable>);
 
+  protected:
        Gtkmm2ext::PopUp*  prompter;
-       PBD::Controllable& controllable;
-       guint bind_button;
-       guint bind_statemask;
-       sigc::connection learning_connection;
+       boost::shared_ptr<PBD::Controllable> controllable;
+
+       static guint bind_button;
+       static guint bind_statemask;
+
+       PBD::ScopedConnection learning_connection;
        void learning_finished ();
        bool prompter_hiding (GdkEventAny *);
 };