2019-07-15 19:14:27 +00:00
#!/usr/bin/env python3
"""CLI wrapper for running QMK commands.
"""
import os
import sys
from importlib.util import find_spec
2019-11-27 20:27:06 +00:00
from time import strftime
from pathlib import Path
2019-07-15 19:14:27 +00:00
# Add the QMK python libs to our path
2019-11-27 20:27:06 +00:00
script_dir = Path(os.path.realpath(__file__)).parent
qmk_dir = script_dir.parent
python_lib_dir = Path(qmk_dir / 'lib' / 'python').resolve()
sys.path.append(str(python_lib_dir))
# QMK CLI user config file
config_file = Path(Path.home() / '.config/qmk/qmk.ini')
2019-07-15 19:14:27 +00:00
2019-11-27 20:27:06 +00:00
def _check_modules(requirements):
""" Check if the modules in the given requirements.txt are available.
"""
with Path(qmk_dir / requirements).open() as fd:
for line in fd.readlines():
line = line.strip().replace('<', '=').replace('>', '=')
2019-07-15 19:14:27 +00:00
2019-11-27 20:27:06 +00:00
if line[0] == '#':
continue
2019-07-15 19:14:27 +00:00
2019-11-27 20:27:06 +00:00
if '#' in line:
line = line.split('#')[0]
module = dict()
module['name'] = module['import'] = line.split('=')[0] if '=' in line else line
2019-11-23 18:42:39 +00:00
# Not every module is importable by its own name.
2019-11-27 20:27:06 +00:00
if module['name'] == "pep8-naming":
module['import'] = "pep8ext_naming"
2019-11-23 18:42:39 +00:00
2019-11-27 20:27:06 +00:00
if not find_spec(module['import']):
print('Could not find module %s!' % module['name'])
if developer:
print('Please run `pip3 install -r requirements-dev.txt` to install the python development dependencies or turn off developer mode with `qmk config user.developer=None`.')
print()
else:
print('Please run `pip3 install -r requirements.txt` to install the python dependencies.')
print()
exit(255)
developer = False
# Make sure our modules have been setup
_check_modules('requirements.txt')
# For developers additional modules are needed
if config_file.exists() and 'developer = True' in config_file.read_text():
developer = True
_check_modules('requirements-dev.txt')
2019-07-15 19:14:27 +00:00
# Setup the CLI
2019-11-20 22:54:18 +00:00
import milc # noqa
2019-07-15 19:14:27 +00:00
2019-09-22 20:25:33 +00:00
milc.EMOJI_LOGLEVELS['INFO'] = '{fg_blue}Ψ{style_reset_all}'
2019-07-15 19:14:27 +00:00
2019-09-22 20:25:33 +00:00
@milc.cli.entrypoint('QMK Helper Script')
def qmk_main(cli):
"""The function that gets run when no subcommand is provided.
"""
cli.print_help()
2019-07-15 19:14:27 +00:00
2019-09-22 20:25:33 +00:00
def main():
"""Setup our environment and then call the CLI entrypoint.
"""
# Change to the root of our checkout
os.environ['ORIG_CWD'] = os.getcwd()
os.chdir(qmk_dir)
2019-07-15 19:14:27 +00:00
2019-09-22 20:25:33 +00:00
# Import the subcommands
2019-11-20 22:54:18 +00:00
import qmk.cli # noqa
2019-07-15 19:14:27 +00:00
2019-09-22 20:25:33 +00:00
# Execute
2019-08-22 06:40:24 +00:00
return_code = milc.cli()
2019-09-22 20:25:33 +00:00
2019-08-22 06:40:24 +00:00
if return_code is False:
exit(1)
2019-09-22 20:25:33 +00:00
elif return_code is not True and isinstance(return_code, int):
if return_code < 0 or return_code > 255:
milc.cli.log.error('Invalid return_code: %d', return_code)
exit(255)
2019-08-22 06:40:24 +00:00
exit(return_code)
2019-09-22 20:25:33 +00:00
exit(0)
if __name__ == '__main__':
main()