You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

419 lines
8.9 KiB

  1. # QMK CLI Commands
  2. # User Commands
  3. ## `qmk compile`
  4. This command allows you to compile firmware from any directory. You can compile JSON exports from <https://config.qmk.fm>, compile keymaps in the repo, or compile the keyboard in the current working directory.
  5. This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
  6. **Usage for Configurator Exports**:
  7. ```
  8. qmk compile [-c] <configuratorExport.json>
  9. ```
  10. **Usage for Keymaps**:
  11. ```
  12. qmk compile [-c] [-e <var>=<value>] -kb <keyboard_name> -km <keymap_name>
  13. ```
  14. **Usage in Keyboard Directory**:
  15. Must be in keyboard directory with a default keymap, or in keymap directory for keyboard, or supply one with `--keymap <keymap_name>`
  16. ```
  17. qmk compile
  18. ```
  19. **Usage for building all keyboards that support a specific keymap**:
  20. ```
  21. qmk compile -kb all -km <keymap_name>
  22. ```
  23. **Example**:
  24. ```
  25. $ qmk config compile.keymap=default
  26. $ cd ~/qmk_firmware/keyboards/planck/rev6
  27. $ qmk compile
  28. Ψ Compiling keymap with make planck/rev6:default
  29. ...
  30. ```
  31. or with optional keymap argument
  32. ```
  33. $ cd ~/qmk_firmware/keyboards/clueboard/66/rev4
  34. $ qmk compile -km 66_iso
  35. Ψ Compiling keymap with make clueboard/66/rev4:66_iso
  36. ...
  37. ```
  38. or in keymap directory
  39. ```
  40. $ cd ~/qmk_firmware/keyboards/gh60/satan/keymaps/colemak
  41. $ qmk compile
  42. Ψ Compiling keymap with make make gh60/satan:colemak
  43. ...
  44. ```
  45. **Usage in Layout Directory**:
  46. Must be under `qmk_firmware/layouts/`, and in a keymap folder.
  47. ```
  48. qmk compile -kb <keyboard_name>
  49. ```
  50. **Example**:
  51. ```
  52. $ cd ~/qmk_firmware/layouts/community/60_ansi/mechmerlin-ansi
  53. $ qmk compile -kb dz60
  54. Ψ Compiling keymap with make dz60:mechmerlin-ansi
  55. ...
  56. ```
  57. ## `qmk flash`
  58. This command is similar to `qmk compile`, but can also target a bootloader. The bootloader is optional, and is set to `:flash` by default. To specify a different bootloader, use `-bl <bootloader>`. Visit the [Flashing Firmware](flashing.md) guide for more details of the available bootloaders.
  59. This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
  60. **Usage for Configurator Exports**:
  61. ```
  62. qmk flash [-bl <bootloader>] [-c] [-e <var>=<value>] <configuratorExport.json>
  63. ```
  64. **Usage for Keymaps**:
  65. ```
  66. qmk flash -kb <keyboard_name> -km <keymap_name> [-bl <bootloader>] [-c] [-e <var>=<value>]
  67. ```
  68. **Listing the Bootloaders**
  69. ```
  70. qmk flash -b
  71. ```
  72. ## `qmk config`
  73. This command lets you configure the behavior of QMK. For the full `qmk config` documentation see [CLI Configuration](cli_configuration.md).
  74. **Usage**:
  75. ```
  76. qmk config [-ro] [config_token1] [config_token2] [...] [config_tokenN]
  77. ```
  78. ## `qmk console`
  79. This command lets you connect to keyboard consoles to get debugging messages. It only works if your keyboard firmware has been compiled with `CONSOLE_ENABLED=yes`.
  80. **Usage**:
  81. ```
  82. qmk console [-d <pid>:<vid>[:<index>]] [-l] [-n] [-t] [-w <seconds>]
  83. ```
  84. **Examples**:
  85. Connect to all available keyboards and show their console messages:
  86. ```
  87. qmk console
  88. ```
  89. List all devices:
  90. ```
  91. qmk console -l
  92. ```
  93. Show only messages from clueboard/66/rev3 keyboards:
  94. ```
  95. qmk console -d C1ED:2370
  96. ```
  97. Show only messages from the second clueboard/66/rev3:
  98. ```
  99. qmk console -d C1ED:2370:2
  100. ```
  101. Show timestamps and VID:PID instead of names:
  102. ```
  103. qmk console -n -t
  104. ```
  105. Disable bootloader messages:
  106. ```
  107. qmk console --no-bootloaders
  108. ```
  109. ## `qmk doctor`
  110. This command examines your environment and alerts you to potential build or flash problems. It can fix many of them if you want it to.
  111. **Usage**:
  112. ```
  113. qmk doctor [-y] [-n]
  114. ```
  115. **Examples**:
  116. Check your environment for problems and prompt to fix them:
  117. qmk doctor
  118. Check your environment and automatically fix any problems found:
  119. qmk doctor -y
  120. Check your environment and report problems only:
  121. qmk doctor -n
  122. ## `qmk format-json`
  123. Formats a JSON file in a (mostly) human-friendly way. Will usually correctly detect the format of the JSON (info.json or keymap.json) but you can override this with `--format` if neccesary.
  124. **Usage**:
  125. ```
  126. qmk format-json [-f FORMAT] <json_file>
  127. ```
  128. ## `qmk info`
  129. Displays information about keyboards and keymaps in QMK. You can use this to get information about a keyboard, show the layouts, display the underlying key matrix, or to pretty-print JSON keymaps.
  130. **Usage**:
  131. ```
  132. qmk info [-f FORMAT] [-m] [-l] [-km KEYMAP] [-kb KEYBOARD]
  133. ```
  134. This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
  135. **Examples**:
  136. Show basic information for a keyboard:
  137. qmk info -kb planck/rev5
  138. Show the matrix for a keyboard:
  139. qmk info -kb ergodox_ez -m
  140. Show a JSON keymap for a keyboard:
  141. qmk info -kb clueboard/california -km default
  142. ## `qmk json2c`
  143. Creates a keymap.c from a QMK Configurator export.
  144. **Usage**:
  145. ```
  146. qmk json2c [-o OUTPUT] filename
  147. ```
  148. ## `qmk c2json`
  149. Creates a keymap.json from a keymap.c.
  150. **Note:** Parsing C source files is not easy, therefore this subcommand may not work with your keymap. In some cases not using the C pre-processor helps.
  151. **Usage**:
  152. ```
  153. qmk c2json -km KEYMAP -kb KEYBOARD [-q] [--no-cpp] [-o OUTPUT] filename
  154. ```
  155. ## `qmk lint`
  156. Checks over a keyboard and/or keymap and highlights common errors, problems, and anti-patterns.
  157. **Usage**:
  158. ```
  159. qmk lint [-km KEYMAP] [-kb KEYBOARD] [--strict]
  160. ```
  161. This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
  162. **Examples**:
  163. Do a basic lint check:
  164. qmk lint -kb rominronin/katana60/rev2
  165. ## `qmk list-keyboards`
  166. This command lists all the keyboards currently defined in `qmk_firmware`
  167. **Usage**:
  168. ```
  169. qmk list-keyboards
  170. ```
  171. ## `qmk list-keymaps`
  172. This command lists all the keymaps for a specified keyboard (and revision).
  173. This command is directory aware. It will automatically fill in KEYBOARD if you are in a keyboard directory.
  174. **Usage**:
  175. ```
  176. qmk list-keymaps -kb planck/ez
  177. ```
  178. ## `qmk new-keyboard`
  179. This command creates a new keyboard based on available templates.
  180. This command will prompt for input to guide you though the generation process.
  181. **Usage**:
  182. ```
  183. qmk new-keyboard
  184. ```
  185. ## `qmk new-keymap`
  186. This command creates a new keymap based on a keyboard's existing default keymap.
  187. This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
  188. **Usage**:
  189. ```
  190. qmk new-keymap [-kb KEYBOARD] [-km KEYMAP]
  191. ```
  192. ## `qmk clean`
  193. This command cleans up the `.build` folder. If `--all` is passed, any .hex or .bin files present in the `qmk_firmware` directory will also be deleted.
  194. **Usage**:
  195. ```
  196. qmk clean [-a]
  197. ```
  198. ---
  199. # Developer Commands
  200. ## `qmk cformat`
  201. This command formats C code using clang-format.
  202. Run it with no arguments to format all core code that has been changed. Default checks `origin/master` with `git diff`, branch can be changed using `-b <branch_name>`
  203. Run it with `-a` to format all core code, or pass filenames on the command line to run it on specific files.
  204. **Usage for specified files**:
  205. ```
  206. qmk cformat [file1] [file2] [...] [fileN]
  207. ```
  208. **Usage for all core files**:
  209. ```
  210. qmk cformat -a
  211. ```
  212. **Usage for only changed files against origin/master**:
  213. ```
  214. qmk cformat
  215. ```
  216. **Usage for only changed files against branch_name**:
  217. ```
  218. qmk cformat -b branch_name
  219. ```
  220. ## `qmk docs`
  221. This command starts a local HTTP server which you can use for browsing or improving the docs. Default port is 8936.
  222. **Usage**:
  223. ```
  224. qmk docs [-p PORT]
  225. ```
  226. ## `qmk generate-docs`
  227. This command allows you to generate QMK documentation locally. It can be uses for general browsing or improving the docs. External tools such as [serve](https://www.npmjs.com/package/serve) can be used to browse the generated files.
  228. **Usage**:
  229. ```
  230. qmk generate-docs
  231. ```
  232. ## `qmk generate-rgb-breathe-table`
  233. This command generates a lookup table (LUT) header file for the [RGB Lighting](feature_rgblight.md) feature's breathing animation. Place this file in your keyboard or keymap directory as `rgblight_breathe_table.h` to override the default LUT in `quantum/`.
  234. **Usage**:
  235. ```
  236. qmk generate-rgb-breathe-table [-q] [-o OUTPUT] [-m MAX] [-c CENTER]
  237. ```
  238. ## `qmk kle2json`
  239. This command allows you to convert from raw KLE data to QMK Configurator JSON. It accepts either an absolute file path, or a file name in the current directory. By default it will not overwrite `info.json` if it is already present. Use the `-f` or `--force` flag to overwrite.
  240. **Usage**:
  241. ```
  242. qmk kle2json [-f] <filename>
  243. ```
  244. **Examples**:
  245. ```
  246. $ qmk kle2json kle.txt
  247. ☒ File info.json already exists, use -f or --force to overwrite.
  248. ```
  249. ```
  250. $ qmk kle2json -f kle.txt -f
  251. Ψ Wrote out to info.json
  252. ```
  253. ## `qmk pyformat`
  254. This command formats python code in `qmk_firmware`.
  255. **Usage**:
  256. ```
  257. qmk pyformat
  258. ```
  259. ## `qmk pytest`
  260. This command runs the python test suite. If you make changes to python code you should ensure this runs successfully.
  261. **Usage**:
  262. ```
  263. qmk pytest
  264. ```