keycode.h 12 KB

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