Add bookmark finder scripts, fix a few incorrect uses of IFS and read
This commit is contained in:
@@ -27,6 +27,7 @@
|
|||||||
- config for mpd, and client(s), (mpd clients to consider: mpc, ncmpcpp, ncmpc, inori)
|
- config for mpd, and client(s), (mpd clients to consider: mpc, ncmpcpp, ncmpc, inori)
|
||||||
- get find, xargs, and awk (use nawk) as unified as i can across system types
|
- get find, xargs, and awk (use nawk) as unified as i can across system types
|
||||||
- seems mpv install (maybe others?) bring in wayland, see if i can remove it
|
- seems mpv install (maybe others?) bring in wayland, see if i can remove it
|
||||||
|
- switched to macports (replace homebrew) before september 2026
|
||||||
- adjusted tmux so that n goes next/down and N goes prev/up in search results
|
- adjusted tmux so that n goes next/down and N goes prev/up in search results
|
||||||
- figured out nvim debug options for linux and macos, then update nvim's dap.lua
|
- figured out nvim debug options for linux and macos, then update nvim's dap.lua
|
||||||
- picked and configured rss reader
|
- picked and configured rss reader
|
||||||
|
|||||||
@@ -33,10 +33,10 @@ echo "---- installing programs ---------------"
|
|||||||
|
|
||||||
echo "$system_types_list" |
|
echo "$system_types_list" |
|
||||||
sed -E "s/,/\n/g" |
|
sed -E "s/,/\n/g" |
|
||||||
while IFS="\n" read -r system_type; do
|
while IFS= read -r system_type; do
|
||||||
echo "-------- install for system type: $system_type"
|
echo "-------- install for system type: $system_type"
|
||||||
cat "installs_and_builds/programs_$system_type.txt" |
|
cat "installs_and_builds/programs_$system_type.txt" |
|
||||||
while IFS="\n" read -r program_name; do
|
while IFS= read -r program_name; do
|
||||||
build_install "$program_name"
|
build_install "$program_name"
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -0,0 +1,2 @@
|
|||||||
|
# this file is just here to easily allow committing this directory to git
|
||||||
|
# the imported themes are copied here when ./copy_dotfiles.sh is run
|
||||||
|
|||||||
@@ -5,9 +5,10 @@ cmd - h : $(which skhd) -k "ctrl + shift - tab"
|
|||||||
cmd - l : $(which skhd) -k "ctrl - tab"
|
cmd - l : $(which skhd) -k "ctrl - tab"
|
||||||
|
|
||||||
# shortcuts to open programs
|
# shortcuts to open programs
|
||||||
cmd - return : open -a kitty.app -n
|
cmd - return : open -n -a kitty.app
|
||||||
cmd - b : open -a Brave\ Browser.app -n
|
cmd + shift - b : open -n -a Brave\ Browser.app
|
||||||
cmd - s : open -a kitty.app -n --args htop
|
cmd - s : open -n -a kitty.app --args --override macos_quit_when_last_window_closed=yes htop
|
||||||
|
cmd - b : open -n -a kitty.app --args --override macos_quit_when_last_window_closed=yes bookmark-find
|
||||||
|
|
||||||
# shortcuts to scripts/procs
|
# shortcuts to scripts/procs
|
||||||
# cmd - zxcv : path/to/script.sh
|
# cmd - zxcv : path/to/script.sh
|
||||||
|
|||||||
51
src_files/.local/scripts/bookmark-find
Executable file
51
src_files/.local/scripts/bookmark-find
Executable file
@@ -0,0 +1,51 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
BKMRK_FIND_TMP_PATH="/tmp/bookmark-find-selected-url"
|
||||||
|
|
||||||
|
[ -z "$1" ] && bkmrk_find_search_root="$DIR_HOME_BOX" || bkmrk_find_search_root="$1"
|
||||||
|
|
||||||
|
# search for boookmark
|
||||||
|
bm_selected_bookmark_url=$(
|
||||||
|
find "$bkmrk_find_search_root" \
|
||||||
|
\( -type d -name "*archive" -prune \) \
|
||||||
|
-o \( -type d -name "*z-sort" -prune \) \
|
||||||
|
-o -name "*.bkmrk" -print |
|
||||||
|
while IFS= read -r bookmark_file; do tail -n +2 "$bookmark_file"; done |
|
||||||
|
fzf \
|
||||||
|
--style full \
|
||||||
|
--border --padding 0,1 \
|
||||||
|
--border-label '|bookmarks|' \
|
||||||
|
--preview='bookmark-preview-info {}' |
|
||||||
|
sed -E "s/^[^^]+\^([^^]+)\^.*$/\1/g" ||
|
||||||
|
printf "%s" "BKMRK_FIND_ERROR"
|
||||||
|
)
|
||||||
|
|
||||||
|
# notify if lookup failed
|
||||||
|
[ "$bm_selected_bookmark_url" = "BKMRK_FIND_ERROR" ] &&
|
||||||
|
printf "%s\n" "error while selecting bookmark" &&
|
||||||
|
printf "%s" "error while selecting bookmark" > "$BKMRK_FIND_TMP_PATH" &&
|
||||||
|
read && # read command to force a pause for input (hit return) before shell is closed
|
||||||
|
exit 0 # exit 0 so (in macOS) skhd's invocation returns success and terminal can quit
|
||||||
|
|
||||||
|
# write selection to tmp path
|
||||||
|
printf "%s" "$bm_selected_bookmark_url" > "$BKMRK_FIND_TMP_PATH"
|
||||||
|
|
||||||
|
# copy selection to clipboard
|
||||||
|
[ "$XDG_SESSION_TYPE" = "wayland" ] && command -v wl-copy > /dev/null 2>&1 && {
|
||||||
|
printf "%s" "$bm_selected_bookmark_url" | wl-copy
|
||||||
|
} || {
|
||||||
|
command -v xclip > /dev/null 2>&1 && {
|
||||||
|
printf "%s" "$bm_selected_bookmark_url" | xclip -selection clipboard
|
||||||
|
}
|
||||||
|
} || {
|
||||||
|
command -v pbcopy > /dev/null 2>&1 && {
|
||||||
|
printf "%s" "$bm_selected_bookmark_url" | pbcopy
|
||||||
|
}
|
||||||
|
} || {
|
||||||
|
printf "error finding tool for copy/paste, selected bookmark (%s) written to %s\n" \
|
||||||
|
"$bm_selected_bookmark_url" \
|
||||||
|
"$BKMRK_FIND_TMP_PATH"
|
||||||
|
read # read command to force a pause for input (hit return) before shell is closed
|
||||||
|
}
|
||||||
|
exit 0 # exit 0 so (in macOS) skhd's invocation returns success and terminal can quit
|
||||||
|
|
||||||
26
src_files/.local/scripts/bookmark-preview-info
Executable file
26
src_files/.local/scripts/bookmark-preview-info
Executable file
@@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
IFS="^" read -r bm_name bm_url bm_date_added bm_type bm_comments <<BM_LINE_BLOCK
|
||||||
|
$(printf "%s" "$@")
|
||||||
|
BM_LINE_BLOCK
|
||||||
|
|
||||||
|
bm_preview_format_block=$(cat <<'BM_PREVIEW_FORMAT_BLOCK'
|
||||||
|
name:
|
||||||
|
%s
|
||||||
|
|
||||||
|
url:
|
||||||
|
%s
|
||||||
|
|
||||||
|
date_added:
|
||||||
|
%s
|
||||||
|
|
||||||
|
type:
|
||||||
|
%s
|
||||||
|
|
||||||
|
comments:
|
||||||
|
%s
|
||||||
|
|
||||||
|
BM_PREVIEW_FORMAT_BLOCK)
|
||||||
|
|
||||||
|
printf "$bm_preview_format_block" \
|
||||||
|
"$bm_name" "$bm_url" "$bm_date_added" "$bm_type" "$bm_comments"
|
||||||
@@ -9,7 +9,7 @@ non_primary_monitors_off() {
|
|||||||
grep -v "^Screen" |
|
grep -v "^Screen" |
|
||||||
grep -v "^\s" |
|
grep -v "^\s" |
|
||||||
grep -v "primary" |
|
grep -v "primary" |
|
||||||
while IFS="\n " read -r target_mon_id remaining_text; do
|
while read -r target_mon_id remaining_text; do
|
||||||
xrandr --output "$target_mon_id" --off
|
xrandr --output "$target_mon_id" --off
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user