Format code using shfmt
This commit is contained in:
parent
8935c2c131
commit
5c3781ceb6
143
snippy
143
snippy
@ -85,7 +85,7 @@ snippet=
|
|||||||
# @param string - string with bash(down) syntax (usually surrounded by ' quotes instead of ")
|
# @param string - string with bash(down) syntax (usually surrounded by ' quotes instead of ")
|
||||||
bashdown() {
|
bashdown() {
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
line="$(eval "printf -- \"$( printf "%s" "$line" | sed 's/"/\\"/g' )\"")";
|
line="$(eval "printf -- \"$(printf "%s" "$line" | sed 's/"/\\"/g')\"")"
|
||||||
echo -e "$line"
|
echo -e "$line"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
@ -93,10 +93,10 @@ bashdown() {
|
|||||||
# Simplified version of bashdown, use echo and bash var search and replace
|
# Simplified version of bashdown, use echo and bash var search and replace
|
||||||
# Better handling of symbol char
|
# Better handling of symbol char
|
||||||
bashdown_simple() {
|
bashdown_simple() {
|
||||||
while IFS= read -r line || [[ -n "$line" ]]; do
|
while IFS= read -r line || [[ -n "$line" ]]; do
|
||||||
line="$(eval "echo \"${line//\"/\\\"}\"")"
|
line="$(eval "echo \"${line//\"/\\\"}\"")"
|
||||||
echo "$line"
|
echo "$line"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
# Detect if focused app is a terminal or a gui
|
# Detect if focused app is a terminal or a gui
|
||||||
@ -147,9 +147,9 @@ move_cursor() {
|
|||||||
local count=$2
|
local count=$2
|
||||||
local keys="End "
|
local keys="End "
|
||||||
if [[ $count -gt 0 ]]; then
|
if [[ $count -gt 0 ]]; then
|
||||||
until [ "$count" -eq 0 ]; do
|
until [ "$count" -eq 0 ]; do
|
||||||
keys+="${key} "
|
keys+="${key} "
|
||||||
((count-=1)) || true
|
((count -= 1)) || true
|
||||||
done
|
done
|
||||||
# shellcheck disable=SC2086
|
# shellcheck disable=SC2086
|
||||||
if [[ $is_wayland ]]; then
|
if [[ $is_wayland ]]; then
|
||||||
@ -164,9 +164,9 @@ init() {
|
|||||||
# Check basic dependency
|
# Check basic dependency
|
||||||
local all_needed_programs_installed=true
|
local all_needed_programs_installed=true
|
||||||
if [[ $is_wayland ]]; then
|
if [[ $is_wayland ]]; then
|
||||||
local needed_programs=( wofi fzf wtype wl-copy wl-paste jq )
|
local needed_programs=(wofi fzf wtype wl-copy wl-paste jq)
|
||||||
else
|
else
|
||||||
local needed_programs=( rofi fzf xsel xclip jq xdotool )
|
local needed_programs=(rofi fzf xsel xclip jq xdotool)
|
||||||
fi
|
fi
|
||||||
for program in "${needed_programs[@]}"; do
|
for program in "${needed_programs[@]}"; do
|
||||||
if ! command -v "$program" >/dev/null 2>&1; then
|
if ! command -v "$program" >/dev/null 2>&1; then
|
||||||
@ -175,7 +175,7 @@ init() {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "$all_needed_programs_installed" = false ] ; then
|
if [ "$all_needed_programs_installed" = false ]; then
|
||||||
echo -e "\nPlease install the previous dependancies"
|
echo -e "\nPlease install the previous dependancies"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@ -184,7 +184,7 @@ init() {
|
|||||||
if [[ ! -d "$snippets_directory" ]]; then
|
if [[ ! -d "$snippets_directory" ]]; then
|
||||||
mkdir -p "$snippets_directory"
|
mkdir -p "$snippets_directory"
|
||||||
echo "$snippets_directory created"
|
echo "$snippets_directory created"
|
||||||
echo "hi it is \$(date)" > "$snippets_directory/test"
|
echo "hi it is \$(date)" >"$snippets_directory/test"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -223,41 +223,41 @@ usage() {
|
|||||||
|
|
||||||
parse_options() {
|
parse_options() {
|
||||||
|
|
||||||
while (( "$#" )); do
|
while (("$#")); do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-h|--help)
|
-h | --help)
|
||||||
usage
|
usage
|
||||||
;;
|
;;
|
||||||
--) # end argument parsing
|
--) # end argument parsing
|
||||||
shift
|
shift
|
||||||
break
|
break
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
action="$1"
|
action="$1"
|
||||||
shift
|
shift
|
||||||
return
|
return
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
error() {
|
error() {
|
||||||
local message="$1"
|
local message="$1"
|
||||||
echo "$message" >&2
|
echo "$message" >&2
|
||||||
}
|
}
|
||||||
|
|
||||||
cli() {
|
cli() {
|
||||||
snippet=$( list | fzf "${fzf_args[@]}")
|
snippet=$(list | fzf "${fzf_args[@]}")
|
||||||
}
|
}
|
||||||
|
|
||||||
list() {
|
list() {
|
||||||
local type="${1:-f}"
|
local type="${1:-f}"
|
||||||
|
|
||||||
find -L . -type "$type" \
|
find -L . -type "$type" |
|
||||||
| grep -vE '^\.$|\.git|\.gitconfig|\.gitkeep|\.gitignore' \
|
grep -vE '^\.$|\.git|\.gitconfig|\.gitkeep|\.gitignore' |
|
||||||
| sed -e 's!\.\/!!' \
|
sed -e 's!\.\/!!' |
|
||||||
| sort
|
sort
|
||||||
}
|
}
|
||||||
|
|
||||||
add() {
|
add() {
|
||||||
@ -290,7 +290,7 @@ gui() {
|
|||||||
# shellcheck disable=SC2086
|
# shellcheck disable=SC2086
|
||||||
set +o errexit
|
set +o errexit
|
||||||
|
|
||||||
snippet=$( list | sed -re 's_^([^/]*)/(.*)_&\x0icon\x1f\1_' | rofi "${rofi_args[@]}" -p '❯ ')
|
snippet=$(list | sed -re 's_^([^/]*)/(.*)_&\x0icon\x1f\1_' | rofi "${rofi_args[@]}" -p '❯ ')
|
||||||
|
|
||||||
if [ $? -eq 10 ]; then
|
if [ $? -eq 10 ]; then
|
||||||
script_content=true
|
script_content=true
|
||||||
@ -315,31 +315,32 @@ run() {
|
|||||||
|
|
||||||
# Custom selection, copy the script content without parsing
|
# Custom selection, copy the script content without parsing
|
||||||
elif [ "$script_content" = true ]; then
|
elif [ "$script_content" = true ]; then
|
||||||
content="$( cat "${snippets_directory}/${snippet}" )"
|
content="$(cat "${snippets_directory}/${snippet}")"
|
||||||
|
|
||||||
# don't parse file with the ##noparse header
|
# don't parse file with the ##noparse header
|
||||||
elif grep -qE "^##noparse" "${snippets_directory}/${snippet}"; then
|
elif grep -qE "^##noparse" "${snippets_directory}/${snippet}"; then
|
||||||
content="$( tail -n +2 "${snippets_directory}/${snippet}" )"
|
content="$(tail -n +2 "${snippets_directory}/${snippet}")"
|
||||||
|
|
||||||
# replace tmpfile for snippets with ##tmpfile header
|
# replace tmpfile for snippets with ##tmpfile header
|
||||||
elif grep -qE "^##tmpfile" "${snippets_directory}/${snippet}"; then
|
elif grep -qE "^##tmpfile" "${snippets_directory}/${snippet}"; then
|
||||||
content="$( bashdown_simple <<< "$(tail -n +2 "${snippets_directory}/${snippet}" | sed "s%\$tmpfile%$tmpfile%g" )" )"
|
content="$(bashdown_simple <<<"$(tail -n +2 "${snippets_directory}/${snippet}" | sed "s%\$tmpfile%$tmpfile%g")")"
|
||||||
|
|
||||||
# execute bash script in scripts dir
|
# execute bash script in scripts dir
|
||||||
elif [[ $(dirname "${snippet}") == 'scripts' ]] && grep -qE "^#!/bin/bash" "${snippets_directory}/${snippet}"; then
|
elif [[ $(dirname "${snippet}") == 'scripts' ]] && grep -qE "^#!/bin/bash" "${snippets_directory}/${snippet}"; then
|
||||||
content="$( bash "${snippets_directory}/${snippet}" )"
|
content="$(bash "${snippets_directory}/${snippet}")"
|
||||||
|
|
||||||
# default action
|
# default action
|
||||||
else
|
else
|
||||||
content="$( bashdown_simple < "${snippets_directory}/${snippet}" )"
|
content="$(bashdown_simple <"${snippets_directory}/${snippet}")"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$content" ]; then
|
if [ -n "$content" ]; then
|
||||||
printf "%s" "$content" > "$tmpfile"
|
printf "%s" "$content" >"$tmpfile"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
else [[ ${snippet} =~ ^$ ]]
|
else
|
||||||
${snippet##*$} 2>/dev/null > "$tmpfile" # execute as bashcommand
|
[[ ${snippet} =~ ^$ ]]
|
||||||
|
${snippet##*$} 2>/dev/null >"$tmpfile" # execute as bashcommand
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# if tmpfile is empty at this step, nothing to do.
|
# if tmpfile is empty at this step, nothing to do.
|
||||||
@ -379,7 +380,7 @@ run() {
|
|||||||
|
|
||||||
if grep -q "$placeholder_clipboard_urlencode" "$tmpfile"; then
|
if grep -q "$placeholder_clipboard_urlencode" "$tmpfile"; then
|
||||||
awk -i inplace \
|
awk -i inplace \
|
||||||
-v clipboard="$( echo "$current_clipboard" | jq -sRr @uri)" \
|
-v clipboard="$(echo "$current_clipboard" | jq -sRr @uri)" \
|
||||||
-v placeholder="$placeholder_clipboard_urlencode" \
|
-v placeholder="$placeholder_clipboard_urlencode" \
|
||||||
'{ gsub(placeholder, clipboard); print }' "$tmpfile"
|
'{ gsub(placeholder, clipboard); print }' "$tmpfile"
|
||||||
|
|
||||||
@ -398,15 +399,15 @@ run() {
|
|||||||
# retrieve the line
|
# retrieve the line
|
||||||
cursor_line=$(grep $placeholder_cursor "$tmpfile")
|
cursor_line=$(grep $placeholder_cursor "$tmpfile")
|
||||||
# calculate snippet total lines
|
# calculate snippet total lines
|
||||||
file_lines=$(wc -l < "$tmpfile")
|
file_lines=$(wc -l <"$tmpfile")
|
||||||
# determine the number of line to go up
|
# determine the number of line to go up
|
||||||
cursor_line_position=$(( file_lines - cursor_line_position + 1 ))
|
cursor_line_position=$((file_lines - cursor_line_position + 1))
|
||||||
# Extract cursor position
|
# Extract cursor position
|
||||||
cursor_position=$(strindex "$cursor_line" $placeholder_cursor)
|
cursor_position=$(strindex "$cursor_line" $placeholder_cursor)
|
||||||
# total cursor line lenght
|
# total cursor line lenght
|
||||||
cursor_line_lenght=${#cursor_line}
|
cursor_line_lenght=${#cursor_line}
|
||||||
# Compute the final cursor position ( 8 is the lenght of the placeholder {cursor} )
|
# Compute the final cursor position ( 8 is the lenght of the placeholder {cursor} )
|
||||||
cursor_position=$(( cursor_line_lenght - cursor_position - 8 ))
|
cursor_position=$((cursor_line_lenght - cursor_position - 8))
|
||||||
# remove the placeholder
|
# remove the placeholder
|
||||||
sed -i -e "s/$placeholder_cursor//g" "$tmpfile"
|
sed -i -e "s/$placeholder_cursor//g" "$tmpfile"
|
||||||
fi
|
fi
|
||||||
@ -414,19 +415,19 @@ run() {
|
|||||||
# Copy snippet in clipboard
|
# Copy snippet in clipboard
|
||||||
if is_rich_snippet "${snippets_directory}/${snippet}"; then
|
if is_rich_snippet "${snippets_directory}/${snippet}"; then
|
||||||
if [[ $is_wayland ]]; then
|
if [[ $is_wayland ]]; then
|
||||||
wl-copy --type text/html -o < "$tmpfile"
|
wl-copy --type text/html -o <"$tmpfile"
|
||||||
else
|
else
|
||||||
xclip -target text/html -selection clipboard -in -loops 1 < "$tmpfile"
|
xclip -target text/html -selection clipboard -in -loops 1 <"$tmpfile"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
if [[ $is_wayland ]]; then
|
if [[ $is_wayland ]]; then
|
||||||
wl-copy < "$tmpfile"
|
wl-copy <"$tmpfile"
|
||||||
else
|
else
|
||||||
xsel --clipboard --input < "$tmpfile"
|
xsel --clipboard --input <"$tmpfile"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$paste" = true ] ; then
|
if [ "$paste" = true ]; then
|
||||||
# Paste into the current application.
|
# Paste into the current application.
|
||||||
if is_gui; then
|
if is_gui; then
|
||||||
# We need a little pause to handle the time to focus on the window
|
# We need a little pause to handle the time to focus on the window
|
||||||
@ -469,31 +470,31 @@ main() {
|
|||||||
cd "${snippets_directory}" || exit
|
cd "${snippets_directory}" || exit
|
||||||
|
|
||||||
case "$action" in
|
case "$action" in
|
||||||
'gui' )
|
'gui')
|
||||||
gui
|
gui
|
||||||
run
|
run
|
||||||
;;
|
;;
|
||||||
'cli' )
|
'cli')
|
||||||
cli
|
cli
|
||||||
run false
|
run false
|
||||||
;;
|
;;
|
||||||
'list' )
|
'list')
|
||||||
list
|
list
|
||||||
;;
|
;;
|
||||||
'cat' )
|
'cat')
|
||||||
list d
|
list d
|
||||||
;;
|
;;
|
||||||
'add' )
|
'add')
|
||||||
shift
|
shift
|
||||||
add "$@"
|
add "$@"
|
||||||
;;
|
;;
|
||||||
'edit' )
|
'edit')
|
||||||
cli
|
cli
|
||||||
edit
|
edit
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
error "Action $action does not exists"
|
error "Action $action does not exists"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user