// -*- C++ -*-
-/* ======================================================================= *\
- File : kbmap.h, kbmap.h,v 1.3 1996/12/10 04:35:57 larsbj Exp
- Author : chb, 30.Oct.1995
- Docu : see kbmap.C
- Purpose: class definitions for XKeyEvent keymap handling
- \* ==================================================================== */
+/**
+ * \file kbmap.h
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
+ *
+ * \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 <X11/Xlib.h>
+#include "frontends/key_state.h"
+#include "frontends/LyXKeySym.h"
-#include "LString.h"
+#include "support/docstream.h"
-#define KB_PREALLOC 16
-#define KB_HASHSIZE 128 // yes, yes - I know. 128 is not exactly prime :-)
-// ... but we are dealing with ASCII chars mostly.
+#include <boost/shared_ptr.hpp>
-class kb_keymap;
-class kb_sequence;
+#include <vector>
+#include <deque>
-///
-struct kb_key {
- /// Keysym
- unsigned int code;
-
- /// Modifier masks
- unsigned int mod;
-
- /// Keymap for prefix keys
- kb_keymap *table;
-
- /// Action for !prefix keys
- int action;
-};
+namespace lyx {
+
+class kb_sequence;
/// Defines key maps and actions for key sequences
class kb_keymap {
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
+ */
+ 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
+ * @param forgui true if the string should use translations and
+ * special characters.
+ */
+ docstring const print(bool forgui) 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_COMMAND_PREFIX / LFUN_UNKNOWN_ACTION
+ */
+ FuncRequest const &
+ lookup(LyXKeySymPtr key,
+ key_modifier::state mod, kb_sequence * seq) const;
+
///
- kb_keymap() {
- size = 0;
- table = 0;
- }
- ///
- ~kb_keymap();
-
- /// Bind a key-sequence to an action
- /** Returns 0 on success. Otherwise, position in string where
- error occured. */
- int bind(char const* seq, int action);
-
- ///
- int print(char* buf, int maxlen) const;
-
- /// Look up a key in the keymap
- int lookup(KeySym key, unsigned mod, kb_sequence *seq);
+ typedef std::deque<kb_sequence> Bindings;
/// Given an action, find all keybindings.
- string findbinding(int action) const;
+ Bindings findbindings(FuncRequest const & func) const;
+
+ /// Given an action, print the keybindings.
+ docstring 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<LyXKeySym const *, key_modifier::state>
+ 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 std::string const printKeySym(LyXKeySym const & key,
+ key_modifier::state mod);
+
+ typedef std::pair<key_modifier::state, key_modifier::state> modifier_pair;
+
private:
- /// Define a new key sequence
- int defkey(kb_sequence *seq, int action, int idx = 0);
-
- /// Size of the table (<0: hashtab)
- int size;
-
- /// Holds the defined keys
- /** Both kinds of tables ends with NoSymbol */
- union
- {
- /// Table for linear array
- kb_key *table;
-
- /// Hash table holding key lists
- kb_key **htable;
+ ///
+ struct kb_key {
+ /// Keysym
+ LyXKeySymPtr code;
+
+ /// Modifier masks
+ modifier_pair mod;
+
+ /// Keymap for prefix keys
+ boost::shared_ptr<kb_keymap> table;
+
+ /// Action for !prefix keys
+ FuncRequest func;
};
-};
+ /**
+ * Define an action for a key sequence.
+ * @param r internal recursion level
+ */
+ void defkey(kb_sequence * seq, FuncRequest const & func,
+ unsigned int r = 0);
-/// Holds a key sequence and the current and standard keymaps
-class kb_sequence {
-public:
- ///
- kb_sequence() {
- stdmap = curmap = 0;
- sequence = staticseq;
- modifiers = staticmod;
- length = 0;
- size = KB_PREALLOC;
- }
-
- ///
-
-
- ///
- ~kb_sequence()
- {
- if (sequence != staticseq) {
- delete sequence;
- delete modifiers;
- }
+ /**
+ * 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 {
+ return table.empty();
}
-
- /// Add a key to the key sequence and look it up in the curmap
- /** Add a key to the key sequence and look it up in the curmap
- if the latter is defined. */
- int addkey(KeySym key, unsigned mod, unsigned nmod = 0);
-
///
- int print(char *buf, int maxlen, bool when_defined = false) const; //RVDK_PATCH_5
-
- ///
- int printOptions(char *buf, int maxlen) const;
-
- /// Make length negative to mark the sequence as deleted
- void delseq();
-
+ typedef std::vector<kb_key> Table;
///
- char getiso();
-
- ///
- KeySym getsym();
-
- ///
- void reset();
-
- ///
- int parse(char const *s);
-
- /// Keymap to use if a new sequence is starting
- kb_keymap *stdmap;
-
- /// Keymap to use for the next key
- kb_keymap *curmap;
-
- /// Array holding the current key sequence
- /** If sequence[length-1] < 0xff it can be used as ISO8859 char */
- unsigned int *sequence;
-
- ///
- unsigned int *modifiers;
-
- /// Current length of key sequence
- int length;
-
-private:
- /// Static array preallocated for sequence
- unsigned int staticseq[KB_PREALLOC];
-
- ///
- unsigned int staticmod[KB_PREALLOC];
-
- /// Physically allocated storage size
- int size;
+ Table table;
};
-#endif
+/// Implementation is in lyx_main.C
+extern kb_keymap & theTopLevelKeymap();
+
+
+} // namespace lyx
+
+#endif // KBMAP_H