X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Fkbmap.h;h=b8eabff92d5db56af79b0c4c992b48f942e3711e;hb=de3c8e5b80effa940c92980032389c868f377d6b;hp=390d63c2057cddc496eca093247479c54a15e987;hpb=9548351ef8ceaa1c779267e4eeccd3a0d83a0374;p=lyx.git diff --git a/src/kbmap.h b/src/kbmap.h index 390d63c205..b8eabff92d 100644 --- a/src/kbmap.h +++ b/src/kbmap.h @@ -1,28 +1,29 @@ // -*- C++ -*- /** * \file kbmap.h - * Copyright 1995-2002 the LyX Team - * Read the file COPYING + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. * - * \author Lars Gullik Bjønnes - * \author John Levon + * \author Lars Gullik Bjønnes + * \author Jean-Marc Lasgouttes + * \author John Levon + * + * Full author contact details are available in file CREDITS. */ #ifndef KBMAP_H #define KBMAP_H -#ifdef __GNUG__ -#pragma interface -#endif +#include "funcrequest.h" -#include "LString.h" #include "frontends/key_state.h" #include -#include +#include class kb_sequence; +class LyXKeySym; /// Defines key maps and actions for key sequences class kb_keymap { @@ -31,12 +32,18 @@ public: * Bind a key sequence to an action. * @return 0 on success, or position in string seq where error * 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 read(std::string const & bind_file); /// print all available keysyms - string const print() const; + std::string const print() const; + /// + typedef boost::shared_ptr LyXKeySymPtr; /** * Look up a key press in the keymap. * @param key the keysym @@ -44,22 +51,21 @@ public: * @param seq the current key sequence so far * @return the action / LFUN_PREFIX / LFUN_UNKNOWN_ACTION */ - int lookup(unsigned int key, - key_modifier::state mod, kb_sequence * seq) const; + FuncRequest const & + lookup(LyXKeySymPtr key, + key_modifier::state mod, kb_sequence * seq) const; /// Given an action, find all keybindings. - string const findbinding(int action, - string const & prefix = string()) const; + std::string const findbinding(FuncRequest const & func, + std::string const & prefix = std::string()) const; /** * Returns a string of the given keysym, with modifiers. - * @param key the key + * @param key the key as a keysym * @param mod the modifiers */ - static string const printKeysym(unsigned int key, key_modifier::state mod); - - /// return the ISO value of a keysym - static char getiso(unsigned int i); + static std::string const printKeySym(LyXKeySym const & key, + key_modifier::state mod); typedef std::pair modifier_pair; @@ -67,7 +73,7 @@ private: /// struct kb_key { /// Keysym - unsigned int code; + LyXKeySymPtr code; /// Modifier masks modifier_pair mod; @@ -76,25 +82,25 @@ 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; /// is the table empty ? bool empty() const { return table.empty(); } /// - typedef std::list Table; + typedef std::vector Table; /// Table table; };