Clean up the hotkey code a bit

This commit is contained in:
Thomas Goyne 2013-06-08 18:24:50 -07:00
parent 6c08f53d1b
commit e693fa97ba
3 changed files with 11 additions and 16 deletions

View file

@ -47,15 +47,14 @@ namespace {
void migrate_hotkeys(const char *removed[], const char *added[][4]) { void migrate_hotkeys(const char *removed[], const char *added[][4]) {
agi::hotkey::Hotkey::HotkeyMap hk_map = hotkey::inst->GetHotkeyMap(); agi::hotkey::Hotkey::HotkeyMap hk_map = hotkey::inst->GetHotkeyMap();
for (size_t i = 0; removed[i]; ++i) { for (size_t i = 0; removed[i]; ++i)
hk_map.erase(removed[i]); hk_map.erase(removed[i]);
}
for (size_t i = 0; added[i] && added[i][0]; ++i) { for (size_t i = 0; added[i] && added[i][0]; ++i) {
std::vector<std::string> keys; std::vector<std::string> keys;
keys.push_back(added[i][2]); keys.emplace_back(added[i][2]);
if (added[i][3]) if (added[i][3])
keys.push_back(added[i][3]); keys.emplace_back(added[i][3]);
hk_map.insert(make_pair( hk_map.insert(make_pair(
std::string(added[i][0]), std::string(added[i][0]),
agi::hotkey::Combo(added[i][1], added[i][0], keys))); agi::hotkey::Combo(added[i][1], added[i][0], keys)));
@ -100,7 +99,7 @@ static std::string const& keycode_name(int code) {
return keycode_names[code]; return keycode_names[code];
} }
std::string keypress_to_str(int key_code, wchar_t key_char, int modifier) { std::string keypress_to_str(int key_code, int modifier) {
std::string combo; std::string combo;
if ((modifier != wxMOD_NONE)) { if ((modifier != wxMOD_NONE)) {
if ((modifier & wxMOD_CMD) != 0) combo.append("Ctrl-"); if ((modifier & wxMOD_CMD) != 0) combo.append("Ctrl-");
@ -113,24 +112,20 @@ std::string keypress_to_str(int key_code, wchar_t key_char, int modifier) {
return combo; return combo;
} }
bool check(std::string const& context, agi::Context *c, int key_code, wchar_t key_char, int modifier) { bool check(std::string const& context, agi::Context *c, int key_code, int modifier) {
std::string combo = keypress_to_str(key_code, key_char, modifier); std::string combo = keypress_to_str(key_code, modifier);
if (combo.empty()) return false; if (combo.empty()) return false;
std::string command = inst->Scan(context, combo, OPT_GET("Audio/Medusa Timing Hotkeys")->GetBool()); std::string command = inst->Scan(context, combo, OPT_GET("Audio/Medusa Timing Hotkeys")->GetBool());
if (!command.empty()) { if (!command.empty()) {
/// The bottom line should be removed after all the hotkey commands are fixed.
/// This is to avoid pointless exceptions.
if (command.find("/") != std::string::npos) {
cmd::call(command, c); cmd::call(command, c);
return true; return true;
} }
}
return false; return false;
} }
bool check(std::string const& context, agi::Context *c, wxKeyEvent &evt) { bool check(std::string const& context, agi::Context *c, wxKeyEvent &evt) {
if (!hotkey::check(context, c, evt.GetKeyCode(), evt.GetUnicodeKey(), evt.GetModifiers())) { if (!hotkey::check(context, c, evt.GetKeyCode(), evt.GetModifiers())) {
evt.Skip(); evt.Skip();
return false; return false;
} }

View file

@ -35,7 +35,7 @@ void clear();
bool check(std::string const& context, agi::Context *c, wxKeyEvent &evt); bool check(std::string const& context, agi::Context *c, wxKeyEvent &evt);
bool check(std::string const& context, agi::Context *c, int key_code, wchar_t key_char, int modifier); bool check(std::string const& context, agi::Context *c, int key_code, wchar_t key_char, int modifier);
std::string keypress_to_str(int key_code, wchar_t key_char, int modifier); std::string keypress_to_str(int key_code, int modifier);
std::string get_hotkey_str_first(std::string const& context, std::string const& command); std::string get_hotkey_str_first(std::string const& context, std::string const& command);
std::vector<std::string> get_hotkey_strs(std::string const& context, std::string const& command); std::vector<std::string> get_hotkey_strs(std::string const& context, std::string const& command);

View file

@ -342,7 +342,7 @@ public:
} }
void OnKeyDown(wxKeyEvent &evt) { void OnKeyDown(wxKeyEvent &evt) {
ctrl->ChangeValue(to_wx(hotkey::keypress_to_str(evt.GetKeyCode(), evt.GetUnicodeKey(), evt.GetModifiers()))); ctrl->ChangeValue(to_wx(hotkey::keypress_to_str(evt.GetKeyCode(), evt.GetModifiers())));
} }
bool SetValue(wxVariant const& var) { bool SetValue(wxVariant const& var) {