Extract clipper choice to function

This commit is contained in:
Marty Oehme 2021-12-18 16:59:25 +01:00
parent 96728de273
commit 87f20b7e05
Signed by: Marty
GPG key ID: B7538B8F50A1C800

View file

@ -71,6 +71,19 @@ _picker() {
exit 1 exit 1
fi fi
} }
# copies to clipboard, removes any trailing newlines,
# and only keeps it in for 1 paste (1 loop to read in script, 1 to output)
_clipper() {
if command -v wl-copy 1>/dev/null 2>/dev/null; then
wl-copy -o -n
elif command -v xclip 1>/dev/null 2>/dev/null; then
xclip -i -selection 'clipboard' -loops 2 -rmlastnl
elif command -v xsel 1>/dev/null 2>/dev/null; then
xsel -b
else
notify-send "No clipboard utility" "Install wl-copy, xclip or xsel."
fi
}
# parse, see https://unix.stackexchange.com/a/331965/8541 # parse, see https://unix.stackexchange.com/a/331965/8541
_parse_config() { _parse_config() {
@ -164,7 +177,6 @@ clip_password() {
_p_get_field() { _p_get_field() {
local gp_entry="$1" local gp_entry="$1"
local gp_field="$2" local gp_field="$2"
local clip="$3"
# return on first successfully returned key # return on first successfully returned key
for key in $gp_field; do for key in $gp_field; do
@ -173,23 +185,7 @@ _p_get_field() {
# found entry # found entry
if [ -n "$value" ]; then if [ -n "$value" ]; then
echo "$value" && break
if [ -n "$clip" ]; then
# copies to clipboard, removes any trailing newlines,
# and only keeps it in for 1 paste (1 loop to read in script, 1 to output)
if command -v wl-copy; then
echo "$value" | wl-copy -o && break
elif command -v xclip; then
echo "$value" | xclip -i -selection 'clipboard' -loops 2 -rmlastnl && break
elif command -v xsel; then
echo "$value" | xsel -b && break
else
notify-send "No clipboard utility" "Install wl-copy, xclip or xsel."
fi
else
echo "$value" && break
fi
fi fi
done done
} }
@ -212,7 +208,7 @@ show_username() {
} }
clip_username() { clip_username() {
_p_get_field "$1" "${PASS_USERNAME_FIELD}" "-c" _p_get_field "$1" "${PASS_USERNAME_FIELD}" | _clipper
} }
show_field() { show_field() {
@ -220,7 +216,7 @@ show_field() {
} }
clip_field() { clip_field() {
_p_get_field "$1" "$2" "-c" _p_get_field "$1" "$2" | _clipper
} }
list_fields() { list_fields() {