lyx_mirror/src/kbmap.h
André Pönitz da65e2b7fb rename LFUN enum values according to their command (as used in th minibuffer/bind files
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@13801 a592a061-630c-0410-9148-cb99ea01b6c8
2006-05-05 20:23:12 +00:00

130 lines
3.0 KiB
C++
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// -*- C++ -*-
/**
* \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
#include "funcrequest.h"
#include "frontends/key_state.h"
#include "frontends/LyXKeySym.h"
#include <boost/shared_ptr.hpp>
#include <vector>
#include <deque>
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
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_COMMAND_PREFIX / LFUN_UNKNOWN_ACTION
*/
FuncRequest const &
lookup(LyXKeySymPtr key,
key_modifier::state mod, kb_sequence * seq) const;
///
typedef std::deque<kb_sequence> Bindings;
/// Given an action, find all keybindings.
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<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:
///
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);
/// Returns a string of the given key
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 {
return table.empty();
}
///
typedef std::vector<kb_key> Table;
///
Table table;
};
#endif // KBMAP_H