[pass] [PATCH 2/2] works now with gpg4win converting cygwin paths to windows paths. had to change an "exec $GPG" to "$GPG" as exec will not execute a function. please check if this impacts any behaviour
Lenz Weber
mail at lenzw.de
Sun Sep 21 23:38:24 CEST 2014
---
src/password-store.sh | 2 +-
src/platform/cygwin.sh | 27 +++++++++++++++++++++++++++
2 files changed, 28 insertions(+), 1 deletion(-)
diff --git a/src/password-store.sh b/src/password-store.sh
index 851b371..3dea599 100755
--- a/src/password-store.sh
+++ b/src/password-store.sh
@@ -320,7 +320,7 @@ cmd_show() {
check_sneaky_paths "$path"
if [[ -f $passfile ]]; then
if [[ $clip -eq 0 ]]; then
- exec $GPG -d "${GPG_OPTS[@]}" "$passfile"
+ $GPG -d "${GPG_OPTS[@]}" "$passfile"
else
local pass="$($GPG -d "${GPG_OPTS[@]}" "$passfile" | head -n 1)"
[[ -n $pass ]] || exit 1
diff --git a/src/platform/cygwin.sh b/src/platform/cygwin.sh
index 05c51e0..c7ff524 100644
--- a/src/platform/cygwin.sh
+++ b/src/platform/cygwin.sh
@@ -14,3 +14,30 @@ clip() {
) 2>/dev/null & disown
echo "Copied $2 to clipboard. Will clear in $CLIP_TIME seconds."
}
+
+#replaces Cygwin-style filenames with their Windows counterparts
+gpg_winpath(){
+ args=("$@")
+ #as soon as an argument (from back to front) is no file, it can only be a filename argument if it is preceeded by '-o'
+ could_be_filenames="true"
+
+ for ((i=${#args[@]}-1; i>=0; i--)); do
+ if ( [ $i -gt 0 ] && [ "${args[$i-1]}" = "-o" ] ) || [ $could_be_filenames = "true" ]; then
+ if [ -e ${args[$i]} ]; then
+ args[$i]=$(cygpath -am ${args[$i]})
+ else
+ could_be_filenames="false"
+ fi
+ fi
+
+ done
+
+ $GPG_ORIG "${args[@]}"
+}
+
+if $GPG --help | grep -q Gpg4win; then
+ GPG_ORIG=$GPG
+ GPG=gpg_winpath
+fi
+
+
--
2.1.0
More information about the Password-Store
mailing list