summaryrefslogtreecommitdiff
path: root/scripts/Scripts/open_rel
diff options
context:
space:
mode:
authorJulian T <julian@jtle.dk>2022-03-18 15:36:53 +0100
committerJulian T <julian@jtle.dk>2022-03-18 15:36:53 +0100
commit2d8f41149631f6c68564975c6c6b0b2006ed4763 (patch)
tree5122e50c51d0e772b177655313c7e1bfeab95246 /scripts/Scripts/open_rel
parent69db449e55e10df6f18789b28012522ad5bb0825 (diff)
Add nixshell to open_rel
Diffstat (limited to 'scripts/Scripts/open_rel')
-rwxr-xr-xscripts/Scripts/open_rel24
1 files changed, 21 insertions, 3 deletions
diff --git a/scripts/Scripts/open_rel b/scripts/Scripts/open_rel
index 06f246d..6d68c41 100755
--- a/scripts/Scripts/open_rel
+++ b/scripts/Scripts/open_rel
@@ -3,6 +3,8 @@
import re
import subprocess as sp
+import argparse
+
def get_window_title() -> str:
command = ["xdotool", "getactivewindow", "getwindowname"]
@@ -22,15 +24,31 @@ def launch_term(command=None, directory=None):
sp.run(run)
-def decide_and_run(title: str):
- print(title)
+def decide_and_run(title: str, do_shell=True):
if title.startswith("fish "):
launch_term(directory=title[5:])
elif (m := re.search(".*client\d*@\[(\d*)\] - Kakoune", title)):
id = m.group(1)
launch_term(command=f"kak -c {id}")
+ elif (m := re.search("nix-shell ([^ ]*)( +([^ ]*))?", title)):
+ shell_file = m.group(1)
+ folder = m.group(3)
+ if folder is None:
+ folder = shell_file
+ shell_file = None
+ if do_shell:
+ command = "nix-shell" + (f" {shell_file}" if shell_file else "")
+ else:
+ command = None
+
+ launch_term(command=command,
+ directory=folder)
if __name__ == "__main__":
+ parser = argparse.ArgumentParser()
+ parser.add_argument("--shell", "-s", action="store_true")
+ args = parser.parse_args()
title = get_window_title()
- decide_and_run(title)
+
+ decide_and_run(title, args.shell)