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.

41 lines
1.6 KiB

  1. """Generate a keymap.c from a configurator export.
  2. """
  3. from argcomplete.completers import FilesCompleter
  4. from milc import cli
  5. import qmk.keymap
  6. import qmk.path
  7. from qmk.commands import parse_configurator_json
  8. @cli.argument('-o', '--output', arg_only=True, type=qmk.path.normpath, help='File to write to')
  9. @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages")
  10. @cli.argument('filename', type=qmk.path.FileType('r'), arg_only=True, completer=FilesCompleter('.json'), help='Configurator JSON file')
  11. @cli.subcommand('Creates a keymap.c from a QMK Configurator export.')
  12. def json2c(cli):
  13. """Generate a keymap.c from a configurator export.
  14. 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.
  15. """
  16. # Parse the configurator from json file (or stdin)
  17. user_keymap = parse_configurator_json(cli.args.filename)
  18. # Environment processing
  19. if cli.args.output and cli.args.output.name == '-':
  20. cli.args.output = None
  21. # Generate the keymap
  22. keymap_c = qmk.keymap.generate_c(user_keymap)
  23. if cli.args.output:
  24. cli.args.output.parent.mkdir(parents=True, exist_ok=True)
  25. if cli.args.output.exists():
  26. cli.args.output.replace(cli.args.output.parent / (cli.args.output.name + '.bak'))
  27. cli.args.output.write_text(keymap_c)
  28. if not cli.args.quiet:
  29. cli.log.info('Wrote keymap to %s.', cli.args.output)
  30. else:
  31. print(keymap_c)