f04e58dad6
`list_keyboards` replicates the `make list-keyboards` by globbing for all paths that include `rules.mk` and then removing the paths that include `keymaps`. This basis of this cli command could be reused in the future as a util, but is not done so here since this would be the only place that would use it currently Resolves #6911
27 lines
921 B
Python
27 lines
921 B
Python
"""List the keyboards currently defined within QMK
|
|
"""
|
|
import os
|
|
import re
|
|
import glob
|
|
|
|
from milc import cli
|
|
|
|
@cli.subcommand("List the keyboards currently defined within QMK")
|
|
def list_keyboards(cli):
|
|
"""List the keyboards currently defined within QMK
|
|
"""
|
|
|
|
base_path = os.path.join(os.getcwd(), "keyboards") + os.path.sep
|
|
kb_path_wildcard = os.path.join(base_path, "**", "rules.mk")
|
|
|
|
# find everywhere we have rules.mk where keymaps isn't in the path
|
|
paths = [path for path in glob.iglob(kb_path_wildcard, recursive=True) if 'keymaps' not in path]
|
|
|
|
# strip the keyboard directory path prefix and rules.mk suffix and alphabetize
|
|
find_name = lambda path: path.replace(base_path, "").replace(os.path.sep + "rules.mk", "")
|
|
names = sorted(map(find_name, paths))
|
|
|
|
for name in names:
|
|
# We echo instead of cli.log.info to allow easier piping of this output
|
|
cli.echo(name)
|