diff options
author | Nick Brassel <nick@tzarc.org> | 2021-11-05 08:55:55 +1100 |
---|---|---|
committer | Nick Brassel <nick@tzarc.org> | 2021-11-05 08:55:55 +1100 |
commit | 92e9bbd9b9c83553f5c9060cbcdb5c44e9eddb79 (patch) | |
tree | 2ccfc6ff2317d94d02e2a3f25db0ec383de32032 /lib/python/qmk/cli/cd.py | |
parent | 84ea77ead663624a6d8ae451ca3d4318008d9d41 (diff) | |
parent | c8da63382c7d2cc0de13559c10b5fde0f436f9e3 (diff) | |
download | qmk_firmware-92e9bbd9b9c83553f5c9060cbcdb5c44e9eddb79.tar.gz qmk_firmware-92e9bbd9b9c83553f5c9060cbcdb5c44e9eddb79.zip |
Merge remote-tracking branch 'upstream/master' into develop
Diffstat (limited to 'lib/python/qmk/cli/cd.py')
-rwxr-xr-x | lib/python/qmk/cli/cd.py | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/lib/python/qmk/cli/cd.py b/lib/python/qmk/cli/cd.py new file mode 100755 index 000000000..c62c3f56c --- /dev/null +++ b/lib/python/qmk/cli/cd.py | |||
@@ -0,0 +1,46 @@ | |||
1 | """Open a shell in the QMK Home directory | ||
2 | """ | ||
3 | import sys | ||
4 | import os | ||
5 | |||
6 | from milc import cli | ||
7 | |||
8 | from qmk.path import under_qmk_firmware | ||
9 | |||
10 | |||
11 | @cli.subcommand('Go to QMK Home') | ||
12 | def cd(cli): | ||
13 | """Go to QMK Home | ||
14 | """ | ||
15 | if not sys.stdout.isatty(): | ||
16 | cli.log.error("This command is for interactive usage only. For non-interactive usage, 'cd $(qmk env QMK_HOME)' is more robust.") | ||
17 | sys.exit(1) | ||
18 | |||
19 | if not under_qmk_firmware(): | ||
20 | # Only do anything if the user is not under qmk_firmware already | ||
21 | # in order to reduce the possibility of starting multiple shells | ||
22 | cli.log.info("Spawning a subshell in your QMK_HOME directory.") | ||
23 | cli.log.info("Type 'exit' to get back to the parent shell.") | ||
24 | if not cli.platform.lower().startswith('windows'): | ||
25 | # For Linux/Mac/etc | ||
26 | # Check the user's login shell from 'passwd' | ||
27 | # alternatively fall back to $SHELL env var | ||
28 | # and finally to '/bin/bash'. | ||
29 | import getpass | ||
30 | import pwd | ||
31 | shell = pwd.getpwnam(getpass.getuser()).pw_shell | ||
32 | if not shell: | ||
33 | shell = os.environ.get('SHELL', '/bin/bash') | ||
34 | # Start the new subshell | ||
35 | os.execl(shell, shell) | ||
36 | else: | ||
37 | # For Windows | ||
38 | # Check the $SHELL env var | ||
39 | # and fall back to '/usr/bin/bash'. | ||
40 | qmk_env = os.environ.copy() | ||
41 | # Set the prompt for the new shell | ||
42 | qmk_env['MSYS2_PS1'] = qmk_env['PS1'] | ||
43 | # Start the new subshell | ||
44 | cli.run([os.environ.get('SHELL', '/usr/bin/bash')], env=qmk_env) | ||
45 | else: | ||
46 | cli.log.info("Already within qmk_firmware directory.") | ||