From 4dd8bef8752d4e432668f711d2ef666784cf8e78 Mon Sep 17 00:00:00 2001 From: skullY Date: Tue, 10 Mar 2020 07:24:08 -0700 Subject: [PATCH 1/3] Rename qmk json-keymap to qmk json2c --- build_json.mk | 2 +- docs/cli.md | 4 +-- docs/ja/cli.md | 4 +-- lib/python/qmk/cli/__init__.py | 1 + lib/python/qmk/cli/json/keymap.py | 38 ++------------------- lib/python/qmk/cli/json2c.py | 56 +++++++++++++++++++++++++++++++ 6 files changed, 64 insertions(+), 41 deletions(-) create mode 100755 lib/python/qmk/cli/json2c.py diff --git a/build_json.mk b/build_json.mk index e04786144cae..087944cc418f 100644 --- a/build_json.mk +++ b/build_json.mk @@ -23,4 +23,4 @@ endif # Generate the keymap.c $(KEYBOARD_OUTPUT)/src/keymap.c: $(KEYMAP_JSON) - bin/qmk json-keymap --quiet --output $(KEYMAP_C) $(KEYMAP_JSON) + bin/qmk json2c --quiet --output $(KEYMAP_C) $(KEYMAP_JSON) diff --git a/docs/cli.md b/docs/cli.md index eda365d87b29..61f838536eb2 100644 --- a/docs/cli.md +++ b/docs/cli.md @@ -231,14 +231,14 @@ Check your environment and report problems only: qmk doctor -n -## `qmk json-keymap` +## `qmk json2c` Creates a keymap.c from a QMK Configurator export. **Usage**: ``` -qmk json-keymap [-o OUTPUT] filename +qmk json2c [-o OUTPUT] filename ``` ## `qmk kle2json` diff --git a/docs/ja/cli.md b/docs/ja/cli.md index 4b1f5da365ce..e0bee35a6f54 100644 --- a/docs/ja/cli.md +++ b/docs/ja/cli.md @@ -215,14 +215,14 @@ qmk doctor [-y] [-n] qmk doctor -n -## `qmk json-keymap` +## `qmk json2c` QMK Configurator からエクスポートしたものから keymap.c を生成します。 **使用法**: ``` -qmk json-keymap [-o OUTPUT] filename +qmk json2c [-o OUTPUT] filename ``` ## `qmk kle2json` diff --git a/lib/python/qmk/cli/__init__.py b/lib/python/qmk/cli/__init__.py index 72ee38f5620f..5149a6215af6 100644 --- a/lib/python/qmk/cli/__init__.py +++ b/lib/python/qmk/cli/__init__.py @@ -10,6 +10,7 @@ from . import flash from . import hello from . import json +from . import json2c from . import list from . import kle2json from . import new diff --git a/lib/python/qmk/cli/json/keymap.py b/lib/python/qmk/cli/json/keymap.py index c2b7dde7ab43..233c0792c0e1 100755 --- a/lib/python/qmk/cli/json/keymap.py +++ b/lib/python/qmk/cli/json/keymap.py @@ -18,39 +18,5 @@ def json_keymap(cli): This command uses the `qmk.keymap` module to generate a keymap.c from a configurator export. The generated keymap is written to stdout, or to a file if -o is provided. """ - cli.args.filename = qmk.path.normpath(cli.args.filename) - - # Error checking - if not cli.args.filename.exists(): - cli.log.error('JSON file does not exist!') - cli.print_usage() - exit(1) - - if str(cli.args.filename) == '-': - # TODO(skullydazed/anyone): Read file contents from STDIN - cli.log.error('Reading from STDIN is not (yet) supported.') - cli.print_usage() - exit(1) - - # Environment processing - if cli.args.output == ('-'): - cli.args.output = None - - # Parse the configurator json - with cli.args.filename.open('r') as fd: - user_keymap = json.load(fd) - - # Generate the keymap - keymap_c = qmk.keymap.generate(user_keymap['keyboard'], user_keymap['layout'], user_keymap['layers']) - - if cli.args.output: - cli.args.output.parent.mkdir(parents=True, exist_ok=True) - if cli.args.output.exists(): - cli.args.output.replace(cli.args.output.name + '.bak') - cli.args.output.write_text(keymap_c) - - if not cli.args.quiet: - cli.log.info('Wrote keymap to %s.', cli.args.output) - - else: - print(keymap_c) + cli.log.error('This command has been renamed to `qmk json2c`.') + exit(1) diff --git a/lib/python/qmk/cli/json2c.py b/lib/python/qmk/cli/json2c.py new file mode 100755 index 000000000000..9abf03d8a14e --- /dev/null +++ b/lib/python/qmk/cli/json2c.py @@ -0,0 +1,56 @@ +"""Generate a keymap.c from a configurator export. +""" +import json +from pathlib import Path + +from milc import cli + +import qmk.keymap +import qmk.path + + +@cli.argument('-o', '--output', arg_only=True, type=Path, help='File to write to') +@cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") +@cli.argument('filename', arg_only=True, help='Configurator JSON file') +@cli.subcommand('Creates a keymap.c from a QMK Configurator export.') +def json2c(cli): + """Generate a keymap.c from a configurator export. + + This command uses the `qmk.keymap` module to generate a keymap.c from a configurator export. The generated keymap is written to stdout, or to a file if -o is provided. + """ + cli.args.filename = qmk.path.normpath(cli.args.filename) + + # Error checking + if not cli.args.filename.exists(): + cli.log.error('JSON file does not exist!') + cli.print_usage() + exit(1) + + if str(cli.args.filename) == '-': + # TODO(skullydazed/anyone): Read file contents from STDIN + cli.log.error('Reading from STDIN is not (yet) supported.') + cli.print_usage() + exit(1) + + # Environment processing + if cli.args.output == ('-'): + cli.args.output = None + + # Parse the configurator json + with cli.args.filename.open('r') as fd: + user_keymap = json.load(fd) + + # Generate the keymap + keymap_c = qmk.keymap.generate(user_keymap['keyboard'], user_keymap['layout'], user_keymap['layers']) + + if cli.args.output: + cli.args.output.parent.mkdir(parents=True, exist_ok=True) + if cli.args.output.exists(): + cli.args.output.replace(cli.args.output.name + '.bak') + cli.args.output.write_text(keymap_c) + + if not cli.args.quiet: + cli.log.info('Wrote keymap to %s.', cli.args.output) + + else: + print(keymap_c) From 9b309b352931101f4ba9fc9745015aea0025fc5b Mon Sep 17 00:00:00 2001 From: skullY Date: Tue, 10 Mar 2020 07:42:00 -0700 Subject: [PATCH 2/3] fix test errors --- lib/python/qmk/cli/json/keymap.py | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/lib/python/qmk/cli/json/keymap.py b/lib/python/qmk/cli/json/keymap.py index 233c0792c0e1..9a79570fdeb4 100755 --- a/lib/python/qmk/cli/json/keymap.py +++ b/lib/python/qmk/cli/json/keymap.py @@ -1,22 +1,15 @@ """Generate a keymap.c from a configurator export. """ -import json from pathlib import Path from milc import cli -import qmk.keymap -import qmk.path - - @cli.argument('-o', '--output', arg_only=True, type=Path, help='File to write to') @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") @cli.argument('filename', arg_only=True, help='Configurator JSON file') @cli.subcommand('Creates a keymap.c from a QMK Configurator export.') def json_keymap(cli): - """Generate a keymap.c from a configurator export. - - This command uses the `qmk.keymap` module to generate a keymap.c from a configurator export. The generated keymap is written to stdout, or to a file if -o is provided. + """Renamed to `qmk json2c`. """ cli.log.error('This command has been renamed to `qmk json2c`.') exit(1) From 520e1ebd297af8ea89b99a9a0d1825e3e5f0ef5b Mon Sep 17 00:00:00 2001 From: skullY Date: Tue, 10 Mar 2020 07:44:30 -0700 Subject: [PATCH 3/3] add missing blank line --- lib/python/qmk/cli/json/keymap.py | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/python/qmk/cli/json/keymap.py b/lib/python/qmk/cli/json/keymap.py index 9a79570fdeb4..6e25b7862bbb 100755 --- a/lib/python/qmk/cli/json/keymap.py +++ b/lib/python/qmk/cli/json/keymap.py @@ -4,6 +4,7 @@ from milc import cli + @cli.argument('-o', '--output', arg_only=True, type=Path, help='File to write to') @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages") @cli.argument('filename', arg_only=True, help='Configurator JSON file')