-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathkeyboard.cpp
More file actions
97 lines (80 loc) · 2.02 KB
/
keyboard.cpp
File metadata and controls
97 lines (80 loc) · 2.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include "mastrix.hpp"
Keyboard keyboard;
ClientConsoleVar<bool> show_keys("show_keys", false);
CLIENT_CONSOLE_COMMAND(bind)
{
if(argc != 2) {
console.printf("Usage: bind [key] [command]");
return;
}
keyboard.bind(argv[0], argv[1]);
}
CLIENT_CONSOLE_COMMAND(unbind)
{
if(argc != 1) {
console.printf("Usage: unbind [key]");
return;
}
keyboard.unbind(argv[0]);
}
CLIENT_CONSOLE_COMMAND(unbindall)
{
keyboard.unbindall();
}
Keyboard::Keyboard()
{
}
void Keyboard::bind(const char *key, const char *action)
{
std::string keyname(key);
// Convert to all-uppercase
for(unsigned ii=0; ii<keyname.length(); ii++)
keyname[ii] = toupper(keyname[ii]);
bindings[keyname] = std::string(action);
}
void Keyboard::unbind(const char *key)
{
std::string keyname(key);
// Convert to all-uppercase
for(unsigned ii=0; ii<keyname.length(); ii++)
keyname[ii] = toupper(keyname[ii]);
bindings.erase(keyname);
}
void Keyboard::unbindall(void)
{
bindings.clear();
}
void Keyboard::keydown(const char *key, int mod)
{
std::string cmd = getCommand(key, mod);
if(cmd != "")
clientScripting.command( cmd.c_str() );
}
void Keyboard::keyup(const char *key, int mod)
{
std::string cmd = getCommand(key, mod);
if(cmd != "")
clientScripting.invertCommand( cmd.c_str() );
}
std::string Keyboard::getCommand(const char *key, int mod)
{
std::string keyname(key);
// Convert to all-uppercase
for(unsigned ii=0; ii<keyname.length(); ii++)
keyname[ii] = toupper(keyname[ii]);
std::string mod_keyname = keyname;
if(mod & KMOD_SHIFT)
mod_keyname = "SHIFT-"+mod_keyname;
if(mod & KMOD_CTRL)
mod_keyname = "CTRL-"+mod_keyname;
if(mod & KMOD_ALT)
mod_keyname = "ALT-"+mod_keyname;
if(bindings.find(mod_keyname) != bindings.end())
return bindings[mod_keyname];
else if(bindings.find(keyname) != bindings.end())
return bindings[keyname];
else if(show_keys) {
console.printf("Unrecognized key: '%s'", mod_keyname.c_str());
}
return "";
}