lyx_mirror/src/kbsequence.h
Jean-Marc Lasgouttes 6b55f26eb8 Convert shortcut strings to unicode (required by Qt/Mac); restore
shortcuts in menus on the Mac.

	* src/frontends/qt4/QLPopupMenu.C (addBinding): remove special
	OS X code (and hopefully restore shortcuts for LyX/Mac).

	* src/lyxfunc.C (processKeySym, dispatch, sendDispatchMessage,
	viewStatusMessage): adapt to changes below.

	* src/MenuBackend.C (binding): adapt to changes below.

	* src/kbmap.C (printKey, print, printbindings): return a
	docstring; adapt to kbsequence changes.

	* src/kbsequence.C (print, printOptions): return a docstring.

	* src/frontends/LyXKeySym.h (print): return a docstring.

	* src/frontends/qt4/QLyXKeySym.C (print): return a docstring.
	(qprint): remove.



git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@16265 a592a061-630c-0410-9148-cb99ea01b6c8
2006-12-13 14:13:01 +00:00

121 lines
2.7 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 kbsequence.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
*
* Full author contact details are available in file CREDITS.
*/
#ifndef KBSEQUENCE_H
#define KBSEQUENCE_H
#include "frontends/key_state.h"
#include "frontends/LyXKeySym.h"
#include <string>
#include <vector>
namespace lyx {
class kb_keymap;
class FuncRequest;
/// Holds a key sequence and the current and standard keymaps
class kb_sequence {
public:
typedef std::vector<LyXKeySymPtr> KeySequence;
friend class kb_keymap;
///
kb_sequence(kb_keymap * std, kb_keymap * cur)
: stdmap(std), curmap(cur), deleted_(false) {}
/**
* Add a key to the key sequence and look it up in the curmap
* if the latter is defined.
* @param keysym the key to add
* @param mod modifier mask
* @param nmod which modifiers to mask out for equality test
* @return the action matching this key sequence or LFUN_UNKNOWN_ACTION
*/
FuncRequest const &
addkey(LyXKeySymPtr keysym, key_modifier::state mod,
key_modifier::state nmod = key_modifier::none);
/**
* Add a sequence of keys from a string to the sequence
* @return string::npos if OK, else error position in string
*
* Keys in the string must be separated with whitespace;
* Use the keysym names used by XStringToKeysym, f.ex.
* "Space", "a", "Return", ...
* Prefixes are S-, C-, M- for shift, control, meta
* Prefixes can also be ignored by using the Tilde "~"
* f.ex.: "~S-Space".
*/
std::string::size_type parse(std::string const & s);
/**
* Return the current sequence as a string.
* @see parse()
*/
docstring const print() const;
/**
* Return the current sequence and available options as
* a string. No options are added if no curmap kb map exists.
*/
docstring const printOptions() const;
/// Mark the sequence as deleted.
void mark_deleted();
/// Reset sequence to become "deleted"
void reset();
/// clear in full
void clear();
bool deleted() const {
return deleted_;
}
/// length of sequence
KeySequence::size_type length() const {
return sequence.size();
}
/// Keymap to use if a new sequence is starting
kb_keymap * stdmap;
/// Keymap to use for the next key
kb_keymap * curmap;
private:
/**
* Array holding the current key sequence as KeySyms.
* If sequence[length - 1] < 0xff it can be used as ISO8859 char
*/
KeySequence sequence;
typedef std::pair<key_modifier::state, key_modifier::state>
modifier_pair;
/// modifiers for keys in the sequence
std::vector<modifier_pair> modifiers;
/// is keysequence deleted ?
bool deleted_;
};
} // namespace lyx
#endif