provide some Keyboard:: methods to get access to other versions of modifier names
[ardour.git] / libs / gtkmm2ext / gtkmm2ext / keyboard.h
1 /*
2     Copyright (C) 2001 Paul Davis
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 #ifndef __libgtkmm2ext_keyboard_h__
21 #define __libgtkmm2ext_keyboard_h__
22
23 #include <map>
24 #include <vector>
25 #include <string>
26
27 #include <gtk/gtk.h>
28 #include <gtkmm/accelkey.h>
29
30 #include "pbd/stateful.h"
31 #include "pbd/signals.h"
32
33 #include "gtkmm2ext/visibility.h"
34
35 namespace Gtk {
36         class Window;
37 }
38
39 namespace Gtkmm2ext {
40
41 class Bindings;
42 class ActionMap;
43
44 class LIBGTKMM2EXT_API Keyboard : public sigc::trackable, PBD::Stateful
45 {
46   public:
47         Keyboard ();
48         ~Keyboard ();
49
50         XMLNode& get_state (void);
51         int set_state (const XMLNode&, int version);
52
53         virtual void setup_keybindings () = 0;
54
55         typedef std::vector<uint32_t> State;
56         typedef uint32_t ModifierMask;
57
58         static uint32_t PrimaryModifier;
59         static uint32_t SecondaryModifier;
60         static uint32_t TertiaryModifier;
61         static uint32_t Level4Modifier;
62         static uint32_t CopyModifier;
63         static uint32_t RangeSelectModifier;
64         static uint32_t GainFineScaleModifier;
65         static uint32_t GainExtraFineScaleModifier;
66
67         // Modifiers for scroll wheel
68         static uint32_t ScrollZoomVerticalModifier;
69         static uint32_t ScrollZoomHorizontalModifier;
70         static uint32_t ScrollHorizontalModifier;
71
72         static const char* primary_modifier_name ();
73         static const char* secondary_modifier_name ();
74         static const char* tertiary_modifier_name ();
75         static const char* level4_modifier_name ();
76
77         static const char* primary_modifier_short_name ();
78         static const char* secondary_modifier_short_name ();
79         static const char* tertiary_modifier_short_name ();
80         static const char* level4_modifier_short_name ();
81
82         static void set_primary_modifier (uint32_t newval) {
83                 set_modifier (newval, PrimaryModifier);
84         }
85         static void set_secondary_modifier (uint32_t newval) {
86                 set_modifier (newval, SecondaryModifier);
87         }
88         static void set_tertiary_modifier (uint32_t newval) {
89                 set_modifier (newval, TertiaryModifier);
90         }
91         static void set_level4_modifier (uint32_t newval) {
92                 set_modifier (newval, Level4Modifier);
93         }
94         static void set_copy_modifier (uint32_t newval) {
95                 set_modifier (newval, CopyModifier);
96         }
97         static void set_range_select_modifier (uint32_t newval) {
98                 set_modifier (newval, RangeSelectModifier);
99         }
100
101         bool key_is_down (uint32_t keyval);
102
103         static GdkModifierType RelevantModifierKeyMask;
104
105         static bool no_modifier_keys_pressed(GdkEventButton* ev) {
106                 return (ev->state & RelevantModifierKeyMask) == 0;
107         }
108
109         static bool no_modifier_keys_pressed(GdkEventKey* ev) {
110                 return (ev->state & RelevantModifierKeyMask) == 0;
111         }
112
113         bool leave_window (GdkEventCrossing *ev, Gtk::Window*);
114         bool enter_window (GdkEventCrossing *ev, Gtk::Window*);
115         bool focus_in_window (GdkEventFocus *ev, Gtk::Window*);
116         bool focus_out_window (GdkEventFocus *ev, Gtk::Window*);
117
118         static bool modifier_state_contains (guint state, ModifierMask);
119         static bool modifier_state_equals   (guint state, ModifierMask);
120
121         static bool no_modifiers_active (guint state);
122
123         static void set_snap_modifier (guint);
124         /** @return Modifier mask to temporarily toggle grid setting; with this modifier
125          *  - magnetic or normal grid should become no grid and
126          *  - no grid should become normal grid
127          */
128         static ModifierMask snap_modifier () { return ModifierMask (snap_mod); }
129
130         static void set_snap_delta_modifier (guint);
131         /** @return Modifier mask to temporarily toggle between relative and absolute grid setting.
132          *  Absolute grid is for aligning objects with the grid lines.
133          *  Relative grid is for maintaining an initial position relative to the grid lines.
134          *  With this modifier:
135          *  - magnetic or normal grid should snap relative to an initial grid offset
136          *  - no grid should snap relative to the grid.
137          */
138         static ModifierMask snap_delta_modifier () { return ModifierMask (snap_delta_mod); }
139
140         static guint edit_button() { return edit_but; }
141         static void set_edit_button (guint);
142         static guint edit_modifier() { return edit_mod; }
143         static void set_edit_modifier(guint);
144
145         static guint delete_button() { return delete_but; }
146         static void set_delete_button(guint);
147         static guint delete_modifier() { return delete_mod; }
148         static void set_delete_modifier(guint);
149
150         static guint insert_note_button() { return insert_note_but; }
151         static void set_insert_note_button (guint);
152         static guint insert_note_modifier() { return insert_note_mod; }
153         static void set_insert_note_modifier(guint);
154
155         static bool is_edit_event (GdkEventButton*);
156         static bool is_delete_event (GdkEventButton*);
157         static bool is_insert_note_event (GdkEventButton*);
158         static bool is_context_menu_event (GdkEventButton*);
159         static bool is_button2_event (GdkEventButton*);
160
161         static Keyboard& the_keyboard() { return *_the_keyboard; }
162
163         static bool some_magic_widget_has_focus ();
164         static void magic_widget_grab_focus ();
165         static void magic_widget_drop_focus ();
166         static Gtk::Window* get_current_window () { return current_window; };
167
168         static void close_current_dialog ();
169
170         static void keybindings_changed ();
171         static void save_keybindings ();
172         static void set_can_save_keybindings (bool yn);
173         static std::string current_binding_name () { return _current_binding_name; }
174         static std::map<std::string,std::string> binding_files;
175
176         static bool catch_user_event_for_pre_dialog_focus (GdkEvent* ev, Gtk::Window* w);
177
178         static bool load_keybindings (std::string const& path);
179         static void save_keybindings (std::string const& path);
180
181         static std::string binding_filename_suffix;
182
183         int reset_bindings ();
184
185         sigc::signal0<void> ZoomVerticalModifierReleased;
186
187   protected:
188         static Keyboard* _the_keyboard;
189
190         guint           snooper_id;
191         State           state;
192
193         static guint     edit_but;
194         static guint     edit_mod;
195         static guint     delete_but;
196         static guint     delete_mod;
197         static guint     insert_note_but;
198         static guint     insert_note_mod;
199         static guint     snap_mod;
200         static guint     snap_delta_mod;
201         static guint     button2_modifiers;
202         static Gtk::Window* current_window;
203         static std::string user_keybindings_path;
204         static bool can_save_keybindings;
205         static bool bindings_changed_after_save_became_legal;
206         static std::string _current_binding_name;
207
208         typedef std::pair<std::string,std::string> two_strings;
209
210         static gint _snooper (GtkWidget*, GdkEventKey*, gpointer);
211         gint snooper (GtkWidget*, GdkEventKey*);
212
213         static void set_modifier (uint32_t newval, uint32_t& variable);
214
215         static bool _some_magic_widget_has_focus;
216
217         static Gtk::Window* pre_dialog_active_window;
218
219         static int read_keybindings (std::string const& path);
220         static int store_keybindings (std::string const& path);
221 };
222
223 } /* namespace */
224
225 #endif /* __libgtkmm2ext_keyboard_h__ */