keyboard_h.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. """Used by the make system to generate keyboard.h from info.json.
  2. """
  3. from milc import cli
  4. from qmk.info import info_json
  5. from qmk.commands import dump_lines
  6. from qmk.keyboard import keyboard_completer, keyboard_folder
  7. from qmk.path import normpath
  8. from qmk.constants import GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE
  9. def would_populate_layout_h(keyboard):
  10. """Detect if a given keyboard is doing data driven layouts
  11. """
  12. # Build the info.json file
  13. kb_info_json = info_json(keyboard)
  14. for layout_name in kb_info_json['layouts']:
  15. if kb_info_json['layouts'][layout_name]['c_macro']:
  16. continue
  17. if 'matrix' not in kb_info_json['layouts'][layout_name]['layout'][0]:
  18. cli.log.debug('%s/%s: No matrix data!', keyboard, layout_name)
  19. continue
  20. return True
  21. return False
  22. @cli.argument('-o', '--output', arg_only=True, type=normpath, help='File to write to')
  23. @cli.argument('-q', '--quiet', arg_only=True, action='store_true', help="Quiet mode, only output error messages")
  24. @cli.argument('-kb', '--keyboard', arg_only=True, type=keyboard_folder, completer=keyboard_completer, required=True, help='Keyboard to generate keyboard.h for.')
  25. @cli.subcommand('Used by the make system to generate keyboard.h from info.json', hidden=True)
  26. def generate_keyboard_h(cli):
  27. """Generates the keyboard.h file.
  28. """
  29. has_layout_h = would_populate_layout_h(cli.args.keyboard)
  30. # Build the layouts.h file.
  31. keyboard_h_lines = [GPL2_HEADER_C_LIKE, GENERATED_HEADER_C_LIKE, '#pragma once', '#include "quantum.h"']
  32. if not has_layout_h:
  33. keyboard_h_lines.append('#error("<keyboard>.h is only optional for data driven keyboards - kb.h == bad times")')
  34. # Show the results
  35. dump_lines(cli.args.output, keyboard_h_lines, cli.args.quiet)