diff options
| author | TheSiahxyz <164138827+TheSiahxyz@users.noreply.github.com> | 2025-12-07 18:16:05 +0900 |
|---|---|---|
| committer | TheSiahxyz <164138827+TheSiahxyz@users.noreply.github.com> | 2025-12-07 18:16:05 +0900 |
| commit | 5ff02959d3069923bca63cb54c4bb246b86bf20d (patch) | |
| tree | 7ef1b56fb85a48c563bb3af51c26f181741282be /fedora/.local/bin/opensessions | |
| parent | f65fe7591c18d6c8f4ecac5f379407a910aba1bc (diff) | |
deleted .gnupg/gpg-agent.conf, created .gnupg/, created .config/, created .local/, created .gnupg/
Diffstat (limited to 'fedora/.local/bin/opensessions')
| -rwxr-xr-x | fedora/.local/bin/opensessions | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/fedora/.local/bin/opensessions b/fedora/.local/bin/opensessions new file mode 100755 index 0000000..6f9f236 --- /dev/null +++ b/fedora/.local/bin/opensessions @@ -0,0 +1,37 @@ +#!/bin/sh + +# split the selected directories into an array +dirs="$*" + +# filter out any empty selections +dirs=$(echo "$dirs" | tr -s ' ' '\n' | sed '/^$/d') +[ -z "$dirs" ] && exit 0 + +# function to clean and create a valid session name +get_session_name() { + basename "$1" | sed 's/[^a-zA-Z0-9]/_/g' +} + +set -- $dirs + +# handle session creation for multiple selected directories +for dir in $dirs; do + if [ -d "$dir" ]; then + session_name=$(get_session_name "$dir") + if ! tmux has-session -t "$session_name" 2>/dev/null; then + tmux new-session -d -s "$session_name" -c "$dir" + if git -C "$dir" rev-parse --is-inside-work-tree >/dev/null 2>&1 && [ -n "$(git -C "$dir" status --porcelain)" ]; then + tmux send-keys -t "$session_name" "git status --porcelain" C-m + fi + fi + fi +done + +if [ "$#" -gt 0 ]; then + first_session=$(get_session_name "$1") + if [ -n "$TMUX" ]; then + tmux switch-client -t "$first_session" + else + tmux attach-session -t "$first_session" + fi +fi |
