#include "LyXAction.h"
#include "Lexer.h"
-#include "frontends/KeySymbol.h"
-
#include "support/filetools.h"
#include <sstream>
+#include <utility>
using std::endl;
using std::string;
+using std::make_pair;
namespace lyx {
using support::i18nLibFileSearch;
-string const KeyMap::printKeySym(KeySymbol const & key,
- key_modifier::state mod)
+string const KeyMap::printKeySym(KeySymbol const & key, KeyModifier mod)
{
string buf;
string const s = key.getSymbolName();
- if (mod & key_modifier::shift)
+ if (mod & ShiftModifier)
buf += "S-";
- if (mod & key_modifier::ctrl)
+ if (mod & ControlModifier)
buf += "C-";
- if (mod & key_modifier::alt)
+ if (mod & AltModifier)
buf += "M-";
buf += s;
FuncRequest const & KeyMap::lookup(KeySymbol const &key,
- key_modifier::state mod, KeySequence * seq) const
+ KeyModifier mod, KeySequence * seq) const
{
static FuncRequest const unknown(LFUN_UNKNOWN_ACTION);
Table::const_iterator end = table.end();
for (Table::const_iterator cit = table.begin(); cit != end; ++cit) {
- key_modifier::state mask(cit->mod.second);
- key_modifier::state check =
- static_cast<key_modifier::state>(mod & ~mask);
+ KeyModifier mask = cit->mod.second;
+ KeyModifier check = static_cast<KeyModifier>(mod & ~mask);
if (cit->code == key && cit->mod.first == check) {
// match found
if (!code.isOK())
return;
- key_modifier::state const mod1 = seq->modifiers[r].first;
- key_modifier::state const mod2 = seq->modifiers[r].second;
+ KeyModifier const mod1 = seq->modifiers[r].first;
+ KeyModifier const mod2 = seq->modifiers[r].second;
// check if key is already there
Table::iterator end = table.end();
docstring const KeyMap::printbindings(FuncRequest const & func) const
{
- odocstringstream res;
Bindings bindings = findbindings(func);
- for (Bindings::const_iterator cit = bindings.begin();
- cit != bindings.end() ; ++cit)
- res << '[' << cit->print(true) << ']';
+ if (bindings.empty())
+ return docstring();
+
+ odocstringstream res;
+ Bindings::const_iterator cit = bindings.begin();
+ Bindings::const_iterator cit_end = bindings.end();
+ // prin the first item
+ res << cit->print(true);
+ // more than one shortcuts?
+ for (++cit; cit != cit_end; ++cit)
+ res << ", " << cit->print(true);
return res.str();
}
}
+KeyMap::BindingList const KeyMap::listBindings(bool unbound) const
+{
+ BindingList list;
+ listBindings(list, KeySequence(0, 0));
+ if (unbound) {
+ LyXAction::const_func_iterator fit = lyxaction.func_begin();
+ LyXAction::const_func_iterator fit_end = lyxaction.func_end();
+ for (; fit != fit_end; ++fit) {
+ kb_action action = fit->second;
+ bool has_action = false;
+ BindingList::const_iterator it = list.begin();
+ BindingList::const_iterator it_end = list.end();
+ for (; it != it_end; ++it)
+ if (it->first.action == action) {
+ has_action = true;
+ break;
+ }
+ if (!has_action)
+ list.push_back(make_pair(action, KeySequence(0, 0)));
+ }
+ }
+ return list;
+}
+
+
+void KeyMap::listBindings(BindingList & list,
+ KeySequence const & prefix) const
+{
+ Table::const_iterator it = table.begin();
+ Table::const_iterator it_end = table.end();
+ for (; it != it_end; ++it) {
+ // a LFUN_COMMAND_PREFIX
+ if (it->table.get()) {
+ KeySequence seq = prefix;
+ seq.addkey(it->code, it->mod.first);
+ it->table->listBindings(list, seq);
+ } else {
+ KeySequence seq = prefix;
+ seq.addkey(it->code, it->mod.first);
+ list.push_back(make_pair(it->func, seq));
+ }
+ }
+}
+
+
} // namespace lyx