glurp : ré-écriture
This commit is contained in:
parent
03e49268f1
commit
cb3fc72d2b
1 changed files with 62 additions and 64 deletions
116
bin/glurp
116
bin/glurp
|
@ -1,83 +1,81 @@
|
||||||
#!/bin/bash
|
#!/usr/bin/env sh
|
||||||
|
# Function to print an error in stderr
|
||||||
declare -A temp_files
|
perror() {
|
||||||
temp_files[command_to_source]=$(mktemp)
|
>&2 printf '\033[1;31mERROR:\033[0m \033[1m%s\033[0m\n' "$*"
|
||||||
|
|
||||||
clean() {
|
|
||||||
rm -- "${temp_files[@]}"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
usage() {
|
usage() {
|
||||||
cat << EOF
|
name=$(basename "$0")
|
||||||
Usage:
|
|
||||||
glurp full|area clip|file
|
printf %s "${name}: usage
|
||||||
EOF
|
${name} f[ull]|a[rea] c[lip]|f[ile]
|
||||||
}
|
${name} -h
|
||||||
|
"
|
||||||
error() {
|
|
||||||
>&2 printf '\033[0m\033[1;31mERROR:\033[0m \033[1m%s\033[0m\n' "$*"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Function to throw an error usage
|
||||||
error_usage() {
|
error_usage() {
|
||||||
error "Invalid usage"
|
perror "invalid usage"
|
||||||
>&2 usage
|
>&2 usage
|
||||||
}
|
|
||||||
|
|
||||||
error_usage_clean() {
|
exit 1
|
||||||
error_usage
|
|
||||||
clean
|
|
||||||
}
|
}
|
||||||
|
|
||||||
screenshot_path() {
|
screenshot_path() {
|
||||||
local path
|
if [ -d "$XDG_RUNTIME_DIR" ]; then
|
||||||
if [ -n "$1" ]; then
|
base=${XDG_RUNTIME_DIR}/screenshots
|
||||||
path="$1"
|
|
||||||
else
|
else
|
||||||
path=.
|
base=/tmp/${USER}-screenshots
|
||||||
fi
|
fi
|
||||||
mkdir -p "$path"
|
|
||||||
printf '%sscreenshot-%s.png' "${path}/" "$(date +%Y_%m_%d_%H_%M_%S_%N)"
|
# I literally know, shellcheck
|
||||||
|
# shellcheck disable=2174
|
||||||
|
mkdir -p -m 700 -- "$base"
|
||||||
|
|
||||||
|
printf %s "${base}/screenshot-$(date +%Y%m%d_%H%M%S%N).png"
|
||||||
}
|
}
|
||||||
|
|
||||||
trap error_usage_clean EXIT
|
while getopts :h opt; do
|
||||||
set -e
|
case "$opt" in
|
||||||
|
h)
|
||||||
slurp=()
|
usage
|
||||||
grim_args=()
|
exit 0
|
||||||
wl_copy=()
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
full)
|
|
||||||
:
|
|
||||||
;;
|
;;
|
||||||
area)
|
?)
|
||||||
slurp+=(slurp \|)
|
error_usage
|
||||||
grim_args+=(-g -)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
false
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
shift
|
done
|
||||||
|
|
||||||
|
# Initial variables
|
||||||
|
slurp=
|
||||||
|
grim="grim -t png"
|
||||||
|
clipboard=
|
||||||
|
|
||||||
|
# f* = full, a* = area
|
||||||
case "$1" in
|
case "$1" in
|
||||||
clip)
|
f*) : ;;
|
||||||
wl_copy+=(\| wl-copy -t image/png)
|
a*)
|
||||||
grim_args+=(-)
|
slurp="slurp |"
|
||||||
;;
|
grim="${grim} -g -"
|
||||||
file)
|
|
||||||
grim_args+=("$(screenshot_path "${XDG_RUNTIME_DIR:-/tmp/$(whoami)}/screenshots")")
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
false
|
|
||||||
;;
|
;;
|
||||||
|
*) error_usage ;;
|
||||||
esac
|
esac
|
||||||
shift
|
|
||||||
|
|
||||||
cat > "${temp_files[command_to_source]}" << EOF
|
# c* = clip, f* = file
|
||||||
${slurp[@]} grim ${grim_args[@]} ${@} ${wl_copy[@]}
|
case "$2" in
|
||||||
EOF
|
c*)
|
||||||
|
grim="${grim} -o -"
|
||||||
|
clipboard="| wl-copy -t image/png"
|
||||||
|
;;
|
||||||
|
f*)
|
||||||
|
grim="${grim} -o '$(screenshot_path)'"
|
||||||
|
;;
|
||||||
|
*) error_usage ;;
|
||||||
|
esac
|
||||||
|
|
||||||
trap clean EXIT
|
set -- sh -c "${slurp} ${grim} ${clipboard}"
|
||||||
|
set -x
|
||||||
sh -s < "${temp_files[command_to_source]}"
|
#: "$@"
|
||||||
|
#exit
|
||||||
|
exec "$@"
|
||||||
|
|
Loading…
Reference in a new issue