aboutsummaryrefslogtreecommitdiff
path: root/lib/python/qmk/cli/compile.py
diff options
context:
space:
mode:
Diffstat (limited to 'lib/python/qmk/cli/compile.py')
-rwxr-xr-xlib/python/qmk/cli/compile.py27
1 files changed, 22 insertions, 5 deletions
diff --git a/lib/python/qmk/cli/compile.py b/lib/python/qmk/cli/compile.py
index daee597d8..322ce6a25 100755
--- a/lib/python/qmk/cli/compile.py
+++ b/lib/python/qmk/cli/compile.py
@@ -2,7 +2,6 @@
2 2
3You can compile a keymap already in the repo or using a QMK Configurator export. 3You can compile a keymap already in the repo or using a QMK Configurator export.
4""" 4"""
5import subprocess
6from argparse import FileType 5from argparse import FileType
7 6
8from milc import cli 7from milc import cli
@@ -15,6 +14,9 @@ from qmk.commands import compile_configurator_json, create_make_command, parse_c
15@cli.argument('-kb', '--keyboard', help='The keyboard to build a firmware for. Ignored when a configurator export is supplied.') 14@cli.argument('-kb', '--keyboard', help='The keyboard to build a firmware for. Ignored when a configurator export is supplied.')
16@cli.argument('-km', '--keymap', help='The keymap to build a firmware for. Ignored when a configurator export is supplied.') 15@cli.argument('-km', '--keymap', help='The keymap to build a firmware for. Ignored when a configurator export is supplied.')
17@cli.argument('-n', '--dry-run', arg_only=True, action='store_true', help="Don't actually build, just show the make command to be run.") 16@cli.argument('-n', '--dry-run', arg_only=True, action='store_true', help="Don't actually build, just show the make command to be run.")
17@cli.argument('-j', '--parallel', type=int, default=1, help="Set the number of parallel make jobs to run.")
18@cli.argument('-e', '--env', arg_only=True, action='append', default=[], help="Set a variable to be passed to make. May be passed multiple times.")
19@cli.argument('-c', '--clean', arg_only=True, action='store_true', help="Remove object files before compiling.")
18@cli.subcommand('Compile a QMK Firmware.') 20@cli.subcommand('Compile a QMK Firmware.')
19@automagic_keyboard 21@automagic_keyboard
20@automagic_keymap 22@automagic_keymap
@@ -25,18 +27,32 @@ def compile(cli):
25 27
26 If a keyboard and keymap are provided this command will build a firmware based on that. 28 If a keyboard and keymap are provided this command will build a firmware based on that.
27 """ 29 """
30 if cli.args.clean and not cli.args.filename and not cli.args.dry_run:
31 command = create_make_command(cli.config.compile.keyboard, cli.config.compile.keymap, 'clean')
32 # FIXME(skullydazed/anyone): Remove text=False once milc 1.0.11 has had enough time to be installed everywhere.
33 cli.run(command, capture_output=False, text=False)
34
35 # Build the environment vars
36 envs = {}
37 for env in cli.args.env:
38 if '=' in env:
39 key, value = env.split('=', 1)
40 envs[key] = value
41 else:
42 cli.log.warning('Invalid environment variable: %s', env)
43
44 # Determine the compile command
28 command = None 45 command = None
29 46
30 if cli.args.filename: 47 if cli.args.filename:
31 # If a configurator JSON was provided generate a keymap and compile it 48 # If a configurator JSON was provided generate a keymap and compile it
32 # FIXME(skullydazed): add code to check and warn if the keymap already exists when compiling a json keymap.
33 user_keymap = parse_configurator_json(cli.args.filename) 49 user_keymap = parse_configurator_json(cli.args.filename)
34 command = compile_configurator_json(user_keymap) 50 command = compile_configurator_json(user_keymap, parallel=cli.config.compile.parallel, **envs)
35 51
36 else: 52 else:
37 if cli.config.compile.keyboard and cli.config.compile.keymap: 53 if cli.config.compile.keyboard and cli.config.compile.keymap:
38 # Generate the make command for a specific keyboard/keymap. 54 # Generate the make command for a specific keyboard/keymap.
39 command = create_make_command(cli.config.compile.keyboard, cli.config.compile.keymap) 55 command = create_make_command(cli.config.compile.keyboard, cli.config.compile.keymap, parallel=cli.config.compile.parallel, **envs)
40 56
41 elif not cli.config.compile.keyboard: 57 elif not cli.config.compile.keyboard:
42 cli.log.error('Could not determine keyboard!') 58 cli.log.error('Could not determine keyboard!')
@@ -48,7 +64,8 @@ def compile(cli):
48 cli.log.info('Compiling keymap with {fg_cyan}%s', ' '.join(command)) 64 cli.log.info('Compiling keymap with {fg_cyan}%s', ' '.join(command))
49 if not cli.args.dry_run: 65 if not cli.args.dry_run:
50 cli.echo('\n') 66 cli.echo('\n')
51 compile = subprocess.run(command) 67 # FIXME(skullydazed/anyone): Remove text=False once milc 1.0.11 has had enough time to be installed everywhere.
68 compile = cli.run(command, capture_output=False, text=False)
52 return compile.returncode 69 return compile.returncode
53 70
54 else: 71 else: