]> git.gir.st - tmk_keyboard.git/blob - common/keycode.h
f34027120093530c1f9b274a5374e5ad68cec7e8
[tmk_keyboard.git] / common / keycode.h
1 /*
2 Copyright 2011,2012 Jun Wako <wakojun@gmail.com>
3
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 2 of the License, or
7 (at your option) any later version.
8
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
13
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>.
16 */
17
18 /*
19 * Keycodes based on HID Usage Keyboard/Keypad Page(0x07) plus special codes
20 * http://www.usb.org/developers/devclass_docs/Hut1_12.pdf
21 */
22 #ifndef KEYCODE_H
23 #define KEYCODE_H
24
25
26 #define IS_ERROR(code) (KC_ROLL_OVER <= (code) && (code) <= KC_UNDEFINED)
27 #define IS_ANY(code) (KC_A <= (code) && (code) <= 0xFF)
28 #define IS_KEY(code) (KC_A <= (code) && (code) <= KC_EXSEL)
29 #define IS_MOD(code) (KC_LCTRL <= (code) && (code) <= KC_RGUI)
30
31
32 #define IS_SPECIAL(code) ((0xA5 <= (code) && (code) <= 0xDF) || (0xE8 <= (code) && (code) <= 0xFF))
33 #define IS_SYSTEM(code) (KC_PWR <= (code) && (code) <= KC_WAKE)
34 #define IS_CONSUMER(code) (KC_MUTE <= (code) && (code) <= KC_WFAV)
35 #define IS_FN(code) (KC_FN0 <= (code) && (code) <= KC_FN31)
36 #define IS_MOUSEKEY(code) (KC_MS_UP <= (code) && (code) <= KC_MS_ACCEL2)
37 #define IS_MOUSEKEY_MOVE(code) (KC_MS_UP <= (code) && (code) <= KC_MS_RIGHT)
38 #define IS_MOUSEKEY_BUTTON(code) (KC_MS_BTN1 <= (code) && (code) <= KC_MS_BTN5)
39 #define IS_MOUSEKEY_WHEEL(code) (KC_MS_WH_UP <= (code) && (code) <= KC_MS_WH_RIGHT)
40 #define IS_MOUSEKEY_ACCEL(code) (KC_MS_ACCEL0 <= (code) && (code) <= KC_MS_ACCEL2)
41
42 #define MOD_BIT(code) (1<<MOD_INDEX(code))
43 #define MOD_INDEX(code) ((code) & 0x07)
44 #define FN_BIT(code) (1<<FN_INDEX(code))
45 #define FN_INDEX(code) ((code) - KC_FN0)
46 #define FN_MIN KC_FN0
47 #define FN_MAX KC_FN31
48
49
50 /*
51 * Short names for ease of definition of keymap
52 */
53 #define KC_LCTL KC_LCTRL
54 #define KC_RCTL KC_RCTRL
55 #define KC_LSFT KC_LSHIFT
56 #define KC_RSFT KC_RSHIFT
57 #define KC_ESC KC_ESCAPE
58 #define KC_BSPC KC_BSPACE
59 #define KC_ENT KC_ENTER
60 #define KC_DEL KC_DELETE
61 #define KC_INS KC_INSERT
62 #define KC_CAPS KC_CAPSLOCK
63 #define KC_CLCK KC_CAPSLOCK
64 #define KC_RGHT KC_RIGHT
65 #define KC_PGDN KC_PGDOWN
66 #define KC_PSCR KC_PSCREEN
67 #define KC_SLCK KC_SCROLLLOCK
68 #define KC_PAUS KC_PAUSE
69 #define KC_BRK KC_PAUSE
70 #define KC_NLCK KC_NUMLOCK
71 #define KC_SPC KC_SPACE
72 #define KC_MINS KC_MINUS
73 #define KC_EQL KC_EQUAL
74 #define KC_GRV KC_GRAVE
75 #define KC_RBRC KC_RBRACKET
76 #define KC_LBRC KC_LBRACKET
77 #define KC_COMM KC_COMMA
78 #define KC_BSLS KC_BSLASH
79 #define KC_SLSH KC_SLASH
80 #define KC_SCLN KC_SCOLON
81 #define KC_QUOT KC_QUOTE
82 #define KC_APP KC_APPLICATION
83 #define KC_NUHS KC_NONUS_HASH
84 #define KC_NUBS KC_NONUS_BSLASH
85 #define KC_LCAP KC_LOCKING_CAPS
86 #define KC_LNUM KC_LOCKING_NUM
87 #define KC_LSCR KC_LOCKING_SCROLL
88 #define KC_ERAS KC_ALT_ERASE
89 #define KC_CLR KC_CLEAR
90 /* Japanese specific */
91 #define KC_ZKHK KC_GRAVE
92 #define KC_RO KC_INT1
93 #define KC_KANA KC_INT2
94 #define KC_JYEN KC_INT3
95 #define KC_JPY KC_INT3
96 #define KC_HENK KC_INT4
97 #define KC_MHEN KC_INT5
98 /* Korean specific */
99 #define KC_HAEN KC_LANG1
100 #define KC_HANJ KC_LANG2
101 /* Keypad */
102 #define KC_P1 KC_KP_1
103 #define KC_P2 KC_KP_2
104 #define KC_P3 KC_KP_3
105 #define KC_P4 KC_KP_4
106 #define KC_P5 KC_KP_5
107 #define KC_P6 KC_KP_6
108 #define KC_P7 KC_KP_7
109 #define KC_P8 KC_KP_8
110 #define KC_P9 KC_KP_9
111 #define KC_P0 KC_KP_0
112 #define KC_PDOT KC_KP_DOT
113 #define KC_PCMM KC_KP_COMMA
114 #define KC_PSLS KC_KP_SLASH
115 #define KC_PAST KC_KP_ASTERISK
116 #define KC_PMNS KC_KP_MINUS
117 #define KC_PPLS KC_KP_PLUS
118 #define KC_PEQL KC_KP_EQUAL
119 #define KC_PENT KC_KP_ENTER
120 /* Unix function key */
121 #define KC_EXEC KC_EXECUTE
122 #define KC_SLCT KC_SELECT
123 #define KC_AGIN KC_AGAIN
124 #define KC_PSTE KC_PASTE
125 /* Mousekey */
126 #define KC_MS_U KC_MS_UP
127 #define KC_MS_D KC_MS_DOWN
128 #define KC_MS_L KC_MS_LEFT
129 #define KC_MS_R KC_MS_RIGHT
130 #define KC_BTN1 KC_MS_BTN1
131 #define KC_BTN2 KC_MS_BTN2
132 #define KC_BTN3 KC_MS_BTN3
133 #define KC_BTN4 KC_MS_BTN4
134 #define KC_BTN5 KC_MS_BTN5
135 #define KC_WH_U KC_MS_WH_UP
136 #define KC_WH_D KC_MS_WH_DOWN
137 #define KC_WH_L KC_MS_WH_LEFT
138 #define KC_WH_R KC_MS_WH_RIGHT
139 #define KC_ACL0 KC_MS_ACCEL0
140 #define KC_ACL1 KC_MS_ACCEL1
141 #define KC_ACL2 KC_MS_ACCEL2
142 /* Sytem Control */
143 #define KC_PWR KC_SYSTEM_POWER
144 #define KC_SLEP KC_SYSTEM_SLEEP
145 #define KC_WAKE KC_SYSTEM_WAKE
146 /* Consumer Page */
147 #define KC_MUTE KC_AUDIO_MUTE
148 #define KC_VOLU KC_AUDIO_VOL_UP
149 #define KC_VOLD KC_AUDIO_VOL_DOWN
150 #define KC_MNXT KC_MEDIA_NEXT_TRACK
151 #define KC_MPRV KC_MEDIA_PREV_TRACK
152 #define KC_MFFD KC_MEDIA_FAST_FORWARD
153 #define KC_MRWD KC_MEDIA_REWIND
154 #define KC_MSTP KC_MEDIA_STOP
155 #define KC_MPLY KC_MEDIA_PLAY_PAUSE
156 #define KC_MSEL KC_MEDIA_SELECT
157 #define KC_EJCT KC_MEDIA_EJECT
158 #define KC_MAIL KC_MAIL
159 #define KC_CALC KC_CALCULATOR
160 #define KC_MYCM KC_MY_COMPUTER
161 #define KC_WSCH KC_WWW_SEARCH
162 #define KC_WHOM KC_WWW_HOME
163 #define KC_WBAK KC_WWW_BACK
164 #define KC_WFWD KC_WWW_FORWARD
165 #define KC_WSTP KC_WWW_STOP
166 #define KC_WREF KC_WWW_REFRESH
167 #define KC_WFAV KC_WWW_FAVORITES
168 /* Jump to bootloader */
169 #define KC_BTLD KC_BOOTLOADER
170 /* Transparent */
171 #define KC_TRANSPARENT 1
172 #define KC_TRNS KC_TRANSPARENT
173
174
175
176 /* USB HID Keyboard/Keypad Usage(0x07) */
177 enum hid_keyboard_keypad_usage {
178 KC_NO = 0x00,
179 KC_ROLL_OVER,
180 KC_POST_FAIL,
181 KC_UNDEFINED,
182 KC_A,
183 KC_B,
184 KC_C,
185 KC_D,
186 KC_E,
187 KC_F,
188 KC_G,
189 KC_H,
190 KC_I,
191 KC_J,
192 KC_K,
193 KC_L,
194 KC_M, /* 0x10 */
195 KC_N,
196 KC_O,
197 KC_P,
198 KC_Q,
199 KC_R,
200 KC_S,
201 KC_T,
202 KC_U,
203 KC_V,
204 KC_W,
205 KC_X,
206 KC_Y,
207 KC_Z,
208 KC_1,
209 KC_2,
210 KC_3, /* 0x20 */
211 KC_4,
212 KC_5,
213 KC_6,
214 KC_7,
215 KC_8,
216 KC_9,
217 KC_0,
218 KC_ENTER,
219 KC_ESCAPE,
220 KC_BSPACE,
221 KC_TAB,
222 KC_SPACE,
223 KC_MINUS,
224 KC_EQUAL,
225 KC_LBRACKET,
226 KC_RBRACKET, /* 0x30 */
227 KC_BSLASH, /* \ (and |) */
228 KC_NONUS_HASH, /* Non-US # and ~ (Typically near the Enter key) */
229 KC_SCOLON, /* ; (and :) */
230 KC_QUOTE, /* ' and " */
231 KC_GRAVE, /* Grave accent and tilde */
232 KC_COMMA, /* , and < */
233 KC_DOT, /* . and > */
234 KC_SLASH, /* / and ? */
235 KC_CAPSLOCK,
236 KC_F1,
237 KC_F2,
238 KC_F3,
239 KC_F4,
240 KC_F5,
241 KC_F6,
242 KC_F7, /* 0x40 */
243 KC_F8,
244 KC_F9,
245 KC_F10,
246 KC_F11,
247 KC_F12,
248 KC_PSCREEN,
249 KC_SCROLLLOCK,
250 KC_PAUSE,
251 KC_INSERT,
252 KC_HOME,
253 KC_PGUP,
254 KC_DELETE,
255 KC_END,
256 KC_PGDOWN,
257 KC_RIGHT,
258 KC_LEFT, /* 0x50 */
259 KC_DOWN,
260 KC_UP,
261 KC_NUMLOCK,
262 KC_KP_SLASH,
263 KC_KP_ASTERISK,
264 KC_KP_MINUS,
265 KC_KP_PLUS,
266 KC_KP_ENTER,
267 KC_KP_1,
268 KC_KP_2,
269 KC_KP_3,
270 KC_KP_4,
271 KC_KP_5,
272 KC_KP_6,
273 KC_KP_7,
274 KC_KP_8, /* 0x60 */
275 KC_KP_9,
276 KC_KP_0,
277 KC_KP_DOT,
278 KC_NONUS_BSLASH, /* Non-US \ and | (Typically near the Left-Shift key) */
279 KC_APPLICATION,
280 KC_POWER,
281 KC_KP_EQUAL,
282 KC_F13,
283 KC_F14,
284 KC_F15,
285 KC_F16,
286 KC_F17,
287 KC_F18,
288 KC_F19,
289 KC_F20,
290 KC_F21, /* 0x70 */
291 KC_F22,
292 KC_F23,
293 KC_F24,
294 KC_EXECUTE,
295 KC_HELP,
296 KC_MENU,
297 KC_SELECT,
298 KC_STOP,
299 KC_AGAIN,
300 KC_UNDO,
301 KC_CUT,
302 KC_COPY,
303 KC_PASTE,
304 KC_FIND,
305 KC__MUTE,
306 KC__VOLUP, /* 0x80 */
307 KC__VOLDOWN,
308 KC_LOCKING_CAPS, /* locking Caps Lock */
309 KC_LOCKING_NUM, /* locking Num Lock */
310 KC_LOCKING_SCROLL, /* locking Scroll Lock */
311 KC_KP_COMMA,
312 KC_KP_EQUAL_AS400, /* equal sign on AS/400 */
313 KC_INT1,
314 KC_INT2,
315 KC_INT3,
316 KC_INT4,
317 KC_INT5,
318 KC_INT6,
319 KC_INT7,
320 KC_INT8,
321 KC_INT9,
322 KC_LANG1, /* 0x90 */
323 KC_LANG2,
324 KC_LANG3,
325 KC_LANG4,
326 KC_LANG5,
327 KC_LANG6,
328 KC_LANG7,
329 KC_LANG8,
330 KC_LANG9,
331 KC_ALT_ERASE,
332 KC_SYSREQ,
333 KC_CANCEL,
334 KC_CLEAR,
335 KC_PRIOR,
336 KC_RETURN,
337 KC_SEPARATOR,
338 KC_OUT, /* 0xA0 */
339 KC_OPER,
340 KC_CLEAR_AGAIN,
341 KC_CRSEL,
342 KC_EXSEL, /* 0xA4 */
343
344 /* NOTE: 0xA5-DF are used for internal special purpose */
345
346 #if 0
347 /* NOTE: Following codes(0xB0-DD) are not used. Leave them for reference. */
348 KC_KP_00 = 0xB0,
349 KC_KP_000,
350 KC_THOUSANDS_SEPARATOR,
351 KC_DECIMAL_SEPARATOR,
352 KC_CURRENCY_UNIT,
353 KC_CURRENCY_SUB_UNIT,
354 KC_KP_LPAREN,
355 KC_KP_RPAREN,
356 KC_KP_LCBRACKET, /* { */
357 KC_KP_RCBRACKET, /* } */
358 KC_KP_TAB,
359 KC_KP_BSPACE,
360 KC_KP_A,
361 KC_KP_B,
362 KC_KP_C,
363 KC_KP_D,
364 KC_KP_E, /* 0xC0 */
365 KC_KP_F,
366 KC_KP_XOR,
367 KC_KP_HAT,
368 KC_KP_PERC,
369 KC_KP_LT,
370 KC_KP_GT,
371 KC_KP_AND,
372 KC_KP_LAZYAND,
373 KC_KP_OR,
374 KC_KP_LAZYOR,
375 KC_KP_COLON,
376 KC_KP_HASH,
377 KC_KP_SPACE,
378 KC_KP_ATMARK,
379 KC_KP_EXCLAMATION,
380 KC_KP_MEM_STORE, /* 0xD0 */
381 KC_KP_MEM_RECALL,
382 KC_KP_MEM_CLEAR,
383 KC_KP_MEM_ADD,
384 KC_KP_MEM_SUB,
385 KC_KP_MEM_MUL,
386 KC_KP_MEM_DIV,
387 KC_KP_PLUS_MINUS,
388 KC_KP_CLEAR,
389 KC_KP_CLEAR_ENTRY,
390 KC_KP_BINARY,
391 KC_KP_OCTAL,
392 KC_KP_DECIMAL,
393 KC_KP_HEXADECIMAL, /* 0xDD */
394 #endif
395
396 /* Modifiers */
397 KC_LCTRL = 0xE0,
398 KC_LSHIFT,
399 KC_LALT,
400 KC_LGUI,
401 KC_RCTRL,
402 KC_RSHIFT,
403 KC_RALT,
404 KC_RGUI,
405
406 /* NOTE: 0xE8-FF are used for internal special purpose */
407 };
408
409 /* Special keycodes */
410 /* NOTE: 0xA5-DF and 0xE8-FF are used for internal special purpose */
411 enum internal_special_keycodes {
412 /* System Control */
413 KC_SYSTEM_POWER = 0xA5,
414 KC_SYSTEM_SLEEP,
415 KC_SYSTEM_WAKE,
416
417 /* Media Control */
418 KC_AUDIO_MUTE,
419 KC_AUDIO_VOL_UP,
420 KC_AUDIO_VOL_DOWN,
421 KC_MEDIA_NEXT_TRACK,
422 KC_MEDIA_PREV_TRACK,
423 KC_MEDIA_STOP,
424 KC_MEDIA_PLAY_PAUSE,
425 KC_MEDIA_SELECT,
426 KC_MEDIA_EJECT,
427 KC_MAIL,
428 KC_CALCULATOR,
429 KC_MY_COMPUTER,
430 KC_WWW_SEARCH,
431 KC_WWW_HOME,
432 KC_WWW_BACK,
433 KC_WWW_FORWARD,
434 KC_WWW_STOP,
435 KC_WWW_REFRESH,
436 KC_WWW_FAVORITES,
437 KC_MEDIA_FAST_FORWARD,
438 KC_MEDIA_REWIND, /* 0xBC */
439
440 /* Jump to bootloader */
441 KC_BOOTLOADER = 0xBF,
442
443 /* Fn key */
444 KC_FN0 = 0xC0,
445 KC_FN1,
446 KC_FN2,
447 KC_FN3,
448 KC_FN4,
449 KC_FN5,
450 KC_FN6,
451 KC_FN7,
452 KC_FN8,
453 KC_FN9,
454 KC_FN10,
455 KC_FN11,
456 KC_FN12,
457 KC_FN13,
458 KC_FN14,
459 KC_FN15,
460
461 KC_FN16 = 0xD0,
462 KC_FN17,
463 KC_FN18,
464 KC_FN19,
465 KC_FN20,
466 KC_FN21,
467 KC_FN22,
468 KC_FN23,
469 KC_FN24,
470 KC_FN25,
471 KC_FN26,
472 KC_FN27,
473 KC_FN28,
474 KC_FN29,
475 KC_FN30,
476 KC_FN31, /* 0xDF */
477
478 /**************************************/
479 /* 0xE0-E7 for Modifiers. DO NOT USE. */
480 /**************************************/
481
482 /* Mousekey */
483 KC_MS_UP = 0xF0,
484 KC_MS_DOWN,
485 KC_MS_LEFT,
486 KC_MS_RIGHT,
487 KC_MS_BTN1,
488 KC_MS_BTN2,
489 KC_MS_BTN3,
490 KC_MS_BTN4,
491 KC_MS_BTN5, /* 0xF8 */
492 /* Mousekey wheel */
493 KC_MS_WH_UP,
494 KC_MS_WH_DOWN,
495 KC_MS_WH_LEFT,
496 KC_MS_WH_RIGHT, /* 0xFC */
497 /* Mousekey accel */
498 KC_MS_ACCEL0,
499 KC_MS_ACCEL1,
500 KC_MS_ACCEL2 /* 0xFF */
501 };
502
503 #endif /* KEYCODE_H */
Imprint / Impressum