From 83148d9351e2ffe0751151388d431482fd850796 Mon Sep 17 00:00:00 2001 From: 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> Date: Tue, 17 Jun 2025 22:21:12 +1000 Subject: shell: no duplicate + daemon option --- src/caelestia/parser.py | 1 + src/caelestia/subcommands/shell.py | 5 ++++- 2 files changed, 5 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/caelestia/parser.py b/src/caelestia/parser.py index 5b1e924..e39b29c 100644 --- a/src/caelestia/parser.py +++ b/src/caelestia/parser.py @@ -18,6 +18,7 @@ def parse_args() -> (argparse.ArgumentParser, argparse.Namespace): shell_parser = command_parser.add_parser("shell", help="start or message the shell") shell_parser.set_defaults(cls=shell.Command) shell_parser.add_argument("message", nargs="*", help="a message to send to the shell") + shell_parser.add_argument("-d", "--daemon", action="store_true", help="start the shell detached") shell_parser.add_argument("-s", "--show", action="store_true", help="print all shell IPC commands") shell_parser.add_argument( "-l", diff --git a/src/caelestia/subcommands/shell.py b/src/caelestia/subcommands/shell.py index 11c979c..e8017fe 100644 --- a/src/caelestia/subcommands/shell.py +++ b/src/caelestia/subcommands/shell.py @@ -20,7 +20,10 @@ class Command: self.message(*self.args.message) else: # Start the shell - subprocess.Popen(["qs", "-c", "caelestia"]).wait() + args = ["qs", "-n", "-c", "caelestia"] + if self.args.daemon: + args.append("-d") + subprocess.run(args) def shell(self, *args: list[str]) -> str: return subprocess.check_output(["qs", "-c", "caelestia", *args], text=True) -- cgit v1.2.3-freya