From 68e943265edf04e63a8e8b8f62bab20f99d9c637 Mon Sep 17 00:00:00 2001 From: Paul Davis Date: Wed, 10 Sep 2008 15:03:30 +0000 Subject: merge from 2.0-ongoing @ 3581 git-svn-id: svn://localhost/ardour2/branches/3.0@3711 d708f5d6-7413-0410-9779-e7cbd77b26cf --- gtk2_ardour/keyboard.h | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) (limited to 'gtk2_ardour/keyboard.h') diff --git a/gtk2_ardour/keyboard.h b/gtk2_ardour/keyboard.h index de2a0929ed..e6d5065e86 100644 --- a/gtk2_ardour/keyboard.h +++ b/gtk2_ardour/keyboard.h @@ -20,18 +20,19 @@ #ifndef __ardour_keyboard_h__ #define __ardour_keyboard_h__ +#include #include #include #include #include +#include #include #include #include "selection.h" -using std::vector; using std::string; class Keyboard : public sigc::trackable, PBD::Stateful @@ -43,7 +44,7 @@ class Keyboard : public sigc::trackable, PBD::Stateful XMLNode& get_state (void); int set_state (const XMLNode&); - typedef vector State; + typedef std::vector State; typedef uint32_t ModifierMask; static uint32_t PrimaryModifier; @@ -114,12 +115,23 @@ class Keyboard : public sigc::trackable, PBD::Stateful static void magic_widget_drop_focus (); static void setup_keybindings (); + static void keybindings_changed (); static void save_keybindings (); static bool load_keybindings (std::string path); static void set_can_save_keybindings (bool yn); static std::string current_binding_name () { return _current_binding_name; } static std::map binding_files; + struct AccelKeyLess { + bool operator() (const Gtk::AccelKey a, const Gtk::AccelKey b) const { + if (a.get_key() != b.get_key()) { + return a.get_key() < b.get_key(); + } else { + return a.get_mod() < b.get_mod(); + } + } + }; + private: static Keyboard* _the_keyboard; @@ -134,8 +146,13 @@ class Keyboard : public sigc::trackable, PBD::Stateful static Gtk::Window* current_window; static std::string user_keybindings_path; static bool can_save_keybindings; + static bool bindings_changed_after_save_became_legal; static std::string _current_binding_name; + typedef std::pair two_strings; + + static std::map release_keys; + static gint _snooper (GtkWidget*, GdkEventKey*, gpointer); gint snooper (GtkWidget*, GdkEventKey*); -- cgit v1.2.3