// -*- 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 \* ==================================================================== */ #ifndef KBMAP_H #define KBMAP_H #ifdef __GNUG__ #pragma interface #endif #include #include #include "commandtags.h" #include "LString.h" 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. */ string::size_type bind(string const & seq, kb_action action); /// print all available keysyms 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 */ kb_action lookup(unsigned int key, unsigned int mod, kb_sequence * seq) const; /// Given an action, find all keybindings. string const findbinding(kb_action action, string const & prefix = string()) const; /** * Returns a string of the given keysym, with modifiers. * @param key the key * @param mod the modifiers */ static string const printKeysym(unsigned int key, unsigned int mod); /// return the ISO value of a keysym static char getiso(unsigned int i); private: /// struct kb_key { /// Keysym unsigned int code; /// Modifier masks unsigned int mod; /// Keymap for prefix keys boost::shared_ptr table; /// Action for !prefix keys kb_action action; }; /** * Define an action for a key sequence. * @param r internal recursion level */ void defkey(kb_sequence * seq, kb_action action, unsigned int r = 0); /// Returns a string of the given key string const printKey(kb_key const & key) const; /// is the table empty ? bool empty() const { return table.empty(); } /// typedef std::list Table; /// Table table; }; #endif