|
|
@ -2,9 +2,11 @@ |
|
|
|
|
|
|
|
|
|
|
|
Check up for QMK environment. |
|
|
|
Check up for QMK environment. |
|
|
|
""" |
|
|
|
""" |
|
|
|
import shutil |
|
|
|
|
|
|
|
import platform |
|
|
|
|
|
|
|
import os |
|
|
|
import os |
|
|
|
|
|
|
|
import platform |
|
|
|
|
|
|
|
import shutil |
|
|
|
|
|
|
|
import subprocess |
|
|
|
|
|
|
|
from glob import glob |
|
|
|
|
|
|
|
|
|
|
|
from milc import cli |
|
|
|
from milc import cli |
|
|
|
|
|
|
|
|
|
|
@ -16,32 +18,44 @@ def main(cli): |
|
|
|
This is currently very simple, it just checks that all the expected binaries are on your system. |
|
|
|
This is currently very simple, it just checks that all the expected binaries are on your system. |
|
|
|
|
|
|
|
|
|
|
|
TODO(unclaimed): |
|
|
|
TODO(unclaimed): |
|
|
|
* [ ] Run the binaries to make sure they work |
|
|
|
|
|
|
|
* [ ] Compile a trivial program with each compiler |
|
|
|
* [ ] Compile a trivial program with each compiler |
|
|
|
* [ ] Check for udev entries on linux |
|
|
|
* [ ] Check for udev entries on linux |
|
|
|
""" |
|
|
|
""" |
|
|
|
|
|
|
|
|
|
|
|
binaries = ['dfu-programmer', 'avrdude', 'dfu-util', 'avr-gcc', 'arm-none-eabi-gcc'] |
|
|
|
binaries = ['dfu-programmer', 'avrdude', 'dfu-util', 'avr-gcc', 'arm-none-eabi-gcc'] |
|
|
|
|
|
|
|
binaries += glob('bin/qmk-*') |
|
|
|
|
|
|
|
|
|
|
|
cli.log.info('QMK Doctor is Checking your environment') |
|
|
|
cli.log.info('QMK Doctor is checking your environment') |
|
|
|
|
|
|
|
|
|
|
|
ok = True |
|
|
|
ok = True |
|
|
|
for binary in binaries: |
|
|
|
for binary in binaries: |
|
|
|
res = shutil.which(binary) |
|
|
|
res = shutil.which(binary) |
|
|
|
if res is None: |
|
|
|
if res is None: |
|
|
|
cli.log.error('{fg_red}QMK can\'t find ' + binary + ' in your path') |
|
|
|
cli.log.error("{fg_red}QMK can't find %s in your path", binary) |
|
|
|
ok = False |
|
|
|
ok = False |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
try: |
|
|
|
|
|
|
|
subprocess.run([binary, '--version'], stdout=subprocess.PIPE, stderr=subprocess.PIPE, timeout=5, check=True) |
|
|
|
|
|
|
|
except subprocess.CalledProcessError: |
|
|
|
|
|
|
|
cli.log.error("{fg_red}Can't run `%s --version`", binary) |
|
|
|
|
|
|
|
ok = False |
|
|
|
|
|
|
|
|
|
|
|
OS = platform.system() |
|
|
|
OS = platform.system() |
|
|
|
if OS == "Darwin": |
|
|
|
if OS == "Darwin": |
|
|
|
cli.log.info("Detected {fg_cyan}macOS") |
|
|
|
cli.log.info("Detected {fg_cyan}macOS") |
|
|
|
elif OS == "Linux": |
|
|
|
elif OS == "Linux": |
|
|
|
cli.log.info("Detected {fg_cyan}linux") |
|
|
|
cli.log.info("Detected {fg_cyan}linux") |
|
|
|
test = 'systemctl list-unit-files | grep enabled | grep -i ModemManager' |
|
|
|
if shutil.which('systemctl'): |
|
|
|
if os.system(test) == 0: |
|
|
|
test = 'systemctl list-unit-files | grep enabled | grep -i ModemManager' |
|
|
|
cli.log.warn("{bg_yellow}Detected modem manager. Please disable it if you are using Pro Micros") |
|
|
|
if os.system(test) == 0: |
|
|
|
|
|
|
|
cli.log.warn("{bg_yellow}Detected modem manager. Please disable it if you are using Pro Micros") |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
cli.log.warn("Can't find systemctl to check for ModemManager.") |
|
|
|
else: |
|
|
|
else: |
|
|
|
cli.log.info("Assuming {fg_cyan}Windows") |
|
|
|
cli.log.info("Assuming {fg_cyan}Windows") |
|
|
|
|
|
|
|
|
|
|
|
if ok: |
|
|
|
if ok: |
|
|
|
cli.log.info('{fg_green}QMK is ready to go') |
|
|
|
cli.log.info('{fg_green}QMK is ready to go') |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
cli.log.info('{fg_yellow}Problems detected, please fix these problems before proceeding.') |
|
|
|
|
|
|
|
# FIXME(skullydazed): Link to a document about troubleshooting, or discord or something |
|
|
|