2020-03-15 07:48:44 -07:00
# QMK CLI Commands
2020-03-22 22:10:30 +01:00
# User Commands
2020-03-15 07:48:44 -07:00
## `qmk compile`
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.
2020-05-26 13:05:41 -07:00
This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
2020-03-15 07:48:44 -07:00
**Usage for Configurator Exports**:
```
2021-01-16 15:13:04 -08:00
qmk compile [-c] < configuratorExport.json >
2020-03-15 07:48:44 -07:00
```
**Usage for Keymaps**:
```
2021-01-16 15:13:04 -08:00
qmk compile [-c] [-e < var > =< value > ] -kb < keyboard_name > -km < keymap_name >
2020-03-15 07:48:44 -07:00
```
**Usage in Keyboard Directory**:
Must be in keyboard directory with a default keymap, or in keymap directory for keyboard, or supply one with `--keymap <keymap_name>`
```
qmk compile
```
2020-03-16 14:27:19 +00:00
**Usage for building all keyboards that support a specific keymap**:
```
qmk compile -kb all -km < keymap_name >
```
2020-03-15 07:48:44 -07:00
**Example**:
```
$ qmk config compile.keymap=default
$ cd ~/qmk_firmware/keyboards/planck/rev6
$ qmk compile
Ψ Compiling keymap with make planck/rev6:default
...
```
or with optional keymap argument
```
$ cd ~/qmk_firmware/keyboards/clueboard/66/rev4
$ qmk compile -km 66_iso
Ψ Compiling keymap with make clueboard/66/rev4:66_iso
...
```
or in keymap directory
```
$ cd ~/qmk_firmware/keyboards/gh60/satan/keymaps/colemak
$ qmk compile
Ψ Compiling keymap with make make gh60/satan:colemak
...
```
**Usage in Layout Directory**:
Must be under `qmk_firmware/layouts/` , and in a keymap folder.
```
qmk compile -kb < keyboard_name >
```
**Example**:
```
$ cd ~/qmk_firmware/layouts/community/60_ansi/mechmerlin-ansi
$ qmk compile -kb dz60
Ψ Compiling keymap with make dz60:mechmerlin-ansi
...
```
## `qmk flash`
2020-05-26 13:05:41 -07:00
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.
This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
2020-03-15 07:48:44 -07:00
**Usage for Configurator Exports**:
```
2021-01-16 15:13:04 -08:00
qmk flash [-bl < bootloader > ] [-c] [-e < var > =< value > ] < configuratorExport.json >
2020-03-15 07:48:44 -07:00
```
**Usage for Keymaps**:
```
2021-01-16 15:13:04 -08:00
qmk flash -kb < keyboard_name > -km < keymap_name > [-bl < bootloader > ] [-c] [-e < var > =< value > ]
2020-03-15 07:48:44 -07:00
```
**Listing the Bootloaders**
```
qmk flash -b
```
## `qmk config`
This command lets you configure the behavior of QMK. For the full `qmk config` documentation see [CLI Configuration ](cli_configuration.md ).
**Usage**:
```
qmk config [-ro] [config_token1] [config_token2] [...] [config_tokenN]
```
2021-05-08 20:56:07 -07:00
## `qmk console`
2021-07-24 20:51:40 -07:00
This command lets you connect to keyboard consoles to get debugging messages. It only works if your keyboard firmware has been compiled with `CONSOLE_ENABLE=yes` .
2021-05-08 20:56:07 -07:00
**Usage**:
```
qmk console [-d < pid > :< vid > [:< index > ]] [-l] [-n] [-t] [-w < seconds > ]
```
**Examples**:
Connect to all available keyboards and show their console messages:
```
qmk console
```
List all devices:
```
qmk console -l
```
Show only messages from clueboard/66/rev3 keyboards:
```
qmk console -d C1ED:2370
```
Show only messages from the second clueboard/66/rev3:
```
qmk console -d C1ED:2370:2
```
Show timestamps and VID:PID instead of names:
```
qmk console -n -t
```
Disable bootloader messages:
```
qmk console --no-bootloaders
```
2020-03-15 07:48:44 -07:00
## `qmk doctor`
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.
**Usage**:
```
qmk doctor [-y] [-n]
```
**Examples**:
Check your environment for problems and prompt to fix them:
qmk doctor
Check your environment and automatically fix any problems found:
qmk doctor -y
Check your environment and report problems only:
qmk doctor -n
2021-03-25 04:38:10 -07:00
## `qmk format-json`
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.
**Usage**:
```
qmk format-json [-f FORMAT] < json_file >
```
2020-05-26 13:05:41 -07:00
## `qmk info`
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.
**Usage**:
```
qmk info [-f FORMAT] [-m] [-l] [-km KEYMAP] [-kb KEYBOARD]
```
This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
**Examples**:
Show basic information for a keyboard:
qmk info -kb planck/rev5
Show the matrix for a keyboard:
qmk info -kb ergodox_ez -m
Show a JSON keymap for a keyboard:
qmk info -kb clueboard/california -km default
2020-03-15 07:48:44 -07:00
## `qmk json2c`
Creates a keymap.c from a QMK Configurator export.
**Usage**:
```
qmk json2c [-o OUTPUT] filename
```
2020-10-07 01:10:19 +01:00
## `qmk c2json`
Creates a keymap.json from a keymap.c.
2021-03-25 07:31:05 -04:00
**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.
2020-10-07 01:10:19 +01:00
**Usage**:
```
2020-12-18 21:56:23 +01:00
qmk c2json -km KEYMAP -kb KEYBOARD [-q] [--no-cpp] [-o OUTPUT] filename
2020-10-07 01:10:19 +01:00
```
2020-11-07 09:56:08 -08:00
## `qmk lint`
Checks over a keyboard and/or keymap and highlights common errors, problems, and anti-patterns.
**Usage**:
```
qmk lint [-km KEYMAP] [-kb KEYBOARD] [--strict]
```
This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
**Examples**:
Do a basic lint check:
qmk lint -kb rominronin/katana60/rev2
2020-03-22 22:10:30 +01:00
## `qmk list-keyboards`
2020-03-15 07:48:44 -07:00
2020-03-22 22:10:30 +01:00
This command lists all the keyboards currently defined in `qmk_firmware`
2020-03-22 19:48:30 +01:00
2020-03-22 22:10:30 +01:00
**Usage**:
```
qmk list-keyboards
```
## `qmk list-keymaps`
This command lists all the keymaps for a specified keyboard (and revision).
2020-03-15 07:48:44 -07:00
2020-05-26 13:05:41 -07:00
This command is directory aware. It will automatically fill in KEYBOARD if you are in a keyboard directory.
2020-03-15 07:48:44 -07:00
**Usage**:
```
2020-03-22 22:10:30 +01:00
qmk list-keymaps -kb planck/ez
2020-03-15 07:48:44 -07:00
```
2021-05-02 16:59:10 +01:00
## `qmk new-keyboard`
This command creates a new keyboard based on available templates.
2021-07-31 06:57:40 +10:00
Any arguments that are not provided will prompt for input. If `-u` is not passed and `user.name` is set in .gitconfig, it will be used as the default username in the prompt.
2021-05-02 16:59:10 +01:00
**Usage**:
```
2021-07-31 06:57:40 +10:00
qmk new-keyboard [-kb KEYBOARD] [-t {avr,ps2avrgb}] -u USERNAME
2021-05-02 16:59:10 +01:00
```
2020-03-22 22:10:30 +01:00
## `qmk new-keymap`
This command creates a new keymap based on a keyboard's existing default keymap.
2020-05-26 13:05:41 -07:00
This command is directory aware. It will automatically fill in KEYBOARD and/or KEYMAP if you are in a keyboard or keymap directory.
2020-03-22 22:10:30 +01:00
**Usage**:
2020-03-15 07:48:44 -07:00
```
2020-03-22 22:10:30 +01:00
qmk new-keymap [-kb KEYBOARD] [-km KEYMAP]
2020-03-15 07:48:44 -07:00
```
2020-11-05 06:18:47 +11:00
## `qmk clean`
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.
**Usage**:
```
qmk clean [-a]
```
2020-03-22 22:10:30 +01:00
---
# Developer Commands
2021-07-23 21:41:33 +01:00
## `qmk format-text`
This command formats text files to have proper line endings.
Every text file in the repository needs to have Unix (LF) line ending.
If you are working on **Windows** , you must ensure that line endings are corrected in order to get your PRs merged.
```
qmk format-text
```
## `qmk format-c`
2020-03-22 22:10:30 +01:00
This command formats C code using clang-format.
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>`
Run it with `-a` to format all core code, or pass filenames on the command line to run it on specific files.
**Usage for specified files**:
2020-03-15 07:48:44 -07:00
```
2021-07-23 21:41:33 +01:00
qmk format-c [file1] [file2] [...] [fileN]
2020-03-15 07:48:44 -07:00
```
2020-03-22 22:10:30 +01:00
**Usage for all core files**:
2020-03-15 07:48:44 -07:00
2020-03-22 22:10:30 +01:00
```
2021-07-23 21:41:33 +01:00
qmk format-c -a
2020-03-22 22:10:30 +01:00
```
2020-03-15 07:48:44 -07:00
2020-03-22 22:10:30 +01:00
**Usage for only changed files against origin/master**:
2020-03-15 07:48:44 -07:00
```
2021-07-23 21:41:33 +01:00
qmk format-c
2020-03-15 07:48:44 -07:00
```
2020-03-22 22:10:30 +01:00
**Usage for only changed files against branch_name**:
2020-03-15 07:48:44 -07:00
2020-03-22 22:10:30 +01:00
```
2021-07-23 21:41:33 +01:00
qmk format-c -b branch_name
2020-03-22 22:10:30 +01:00
```
## `qmk docs`
This command starts a local HTTP server which you can use for browsing or improving the docs. Default port is 8936.
2021-07-30 23:47:34 +10:00
Use the `-b` /`--browser` flag to automatically open the local webserver in your default browser.
2020-03-15 07:48:44 -07:00
**Usage**:
```
2021-07-30 23:47:34 +10:00
qmk docs [-b] [-p PORT]
2020-03-15 07:48:44 -07:00
```
2020-11-10 15:00:40 +00:00
## `qmk generate-docs`
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.
**Usage**:
```
qmk generate-docs
```
2020-12-16 14:24:42 +11:00
## `qmk generate-rgb-breathe-table`
2021-06-28 15:15:24 +10:00
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/rgblight/` .
2020-12-16 14:24:42 +11:00
**Usage**:
```
qmk generate-rgb-breathe-table [-q] [-o OUTPUT] [-m MAX] [-c CENTER]
```
2020-03-22 22:10:30 +01:00
## `qmk kle2json`
2020-03-15 07:48:44 -07:00
2020-03-22 22:10:30 +01:00
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.
2020-03-15 07:48:44 -07:00
**Usage**:
```
2020-03-22 22:10:30 +01:00
qmk kle2json [-f] < filename >
2020-03-15 07:48:44 -07:00
```
2020-03-22 22:10:30 +01:00
**Examples**:
2020-03-15 07:48:44 -07:00
2020-03-22 22:10:30 +01:00
```
$ qmk kle2json kle.txt
☒ File info.json already exists, use -f or --force to overwrite.
```
```
$ qmk kle2json -f kle.txt -f
Ψ Wrote out to info.json
```
2021-07-23 21:41:33 +01:00
## `qmk format-python`
2020-03-22 19:48:30 +01:00
2020-03-15 07:48:44 -07:00
This command formats python code in `qmk_firmware` .
**Usage**:
```
2021-07-23 21:41:33 +01:00
qmk format-python
2020-03-15 07:48:44 -07:00
```
## `qmk pytest`
This command runs the python test suite. If you make changes to python code you should ensure this runs successfully.
**Usage**:
```
qmk pytest
```