X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fkbmap.h;h=edadfaa9c641881f5e57f3c4b95f853561b5ed2e;hb=35204f8f33d7400a5fefeffea533fb4cb4097211;hp=f2a9cd12601447c41c8b57a18ebadcb287b0ccc8;hpb=0be0fcfd5907d448cd51addf83ed7032719a0692;p=lyx.git diff --git a/src/kbmap.h b/src/kbmap.h index f2a9cd1260..edadfaa9c6 100644 --- a/src/kbmap.h +++ b/src/kbmap.h @@ -14,11 +14,18 @@ #ifndef KBMAP_H #define KBMAP_H -#include "LString.h" +#include "funcrequest.h" + #include "frontends/key_state.h" #include "frontends/LyXKeySym.h" +#include + #include +#include + + +namespace lyx { class kb_sequence; @@ -31,35 +38,50 @@ public: * occurs. * See kb_sequence::parse for the syntax of the seq string */ - string::size_type bind(string const & seq, int action); + std::string::size_type bind(std::string const & seq, FuncRequest const & func); // Parse a bind file - bool kb_keymap::read(string const & bind_file); + bool read(std::string const & bind_file); /// print all available keysyms - string const print() const; + std::string const print() const; /** * Look up a key press in the keymap. * @param key the keysym * @param mod the modifiers * @param seq the current key sequence so far - * @return the action / LFUN_PREFIX / LFUN_UNKNOWN_ACTION + * @return the action / LFUN_COMMAND_PREFIX / LFUN_UNKNOWN_ACTION */ - int lookup(LyXKeySymPtr key, - key_modifier::state mod, kb_sequence * seq) const; + FuncRequest const & + lookup(LyXKeySymPtr key, + key_modifier::state mod, kb_sequence * seq) const; + + /// + typedef std::deque Bindings; /// Given an action, find all keybindings. - string const findbinding(int action, - string const & prefix = string()) const; + Bindings findbindings(FuncRequest const & func) const; + + /// Given an action, print the keybindings. + std::string const printbindings(FuncRequest const & func) const; + + /** + * Given an action, find the first 1-key binding (if it exists). + * The LyXKeySym pointer is 0 is no key is found. + * [only used by the Qt/Mac frontend] + */ + std::pair + find1keybinding(FuncRequest const & func) const; + /** * Returns a string of the given keysym, with modifiers. * @param key the key as a keysym * @param mod the modifiers */ - static string const printKeysym(LyXKeySymPtr key, - key_modifier::state mod); + static std::string const printKeySym(LyXKeySym const & key, + key_modifier::state mod); typedef std::pair modifier_pair; @@ -76,17 +98,26 @@ private: boost::shared_ptr table; /// Action for !prefix keys - int action; + FuncRequest func; }; /** * Define an action for a key sequence. * @param r internal recursion level */ - void defkey(kb_sequence * seq, int action, unsigned int r = 0); + void defkey(kb_sequence * seq, FuncRequest const & func, + unsigned int r = 0); /// Returns a string of the given key - string const printKey(kb_key const & key) const; + std::string const printKey(kb_key const & key) const; + + /** + * Given an action, find all keybindings + * @param func the action + * @param prefix a sequence to prepend the results + */ + Bindings findbindings(FuncRequest const & func, + kb_sequence const & prefix) const; /// is the table empty ? bool empty() const { @@ -98,4 +129,10 @@ private: Table table; }; +/// Implementation is in lyx_main.C +extern kb_keymap & theTopLevelKeymap(); + + +} // namespace lyx + #endif // KBMAP_H