diff options
| author | Mike Frysinger <vapier@google.com> | 2020-02-14 16:28:13 -0500 | 
|---|---|---|
| committer | Mike Frysinger <vapier@google.com> | 2020-02-15 03:55:45 +0000 | 
| commit | 19a1f22cd0a06eeb1cdea8e81ce7871bd5d6d6a2 (patch) | |
| tree | 1c4ba8a749c017bd28ada2821defe8cd4b1128f4 /platform_utils_win32.py | |
| parent | 076512aafaa96563cfb1ca1d43bbd515091d0e5e (diff) | |
| download | git-repo-19a1f22cd0a06eeb1cdea8e81ce7871bd5d6d6a2.tar.gz | |
repo: rework gpg import for Windows
Some versions of gpg on Windows mishandle native paths with homedir.
It manifests itself like:
gpg: keybox 'C:\Users\.../.repoconfig\gnupg/pubring.kbx' created
gpg: C:\Users\.../.repoconfig\gnupg/trustdb.gpg: trustdb created
gpg: key 16530D5E920F5C65: public key "Repo Maintainer <repo@android.kernel.org>" imported
gpg: can't connect to the agent: Invalid value passed to IPC
gpg: Total number processed: 1
gpg:               imported: 1
fatal: registering repo maintainer keys failed
It seems gpg (at least version 2.2.17) needs paths to be specified
in cygwin form (e.g. "/c/Users/.../.repoconfig/gnupg") otherwise
it fails to talk to its own processes.  We can work around this
with a minor trick: we cd to the right path and then invoke gpg
with --homedir . and let gpg itself resolve . to whatever form it
really wants.
This is a bit hacky, but we don't control gpg, and this allows us
to avoid having to muck with the environment.  Since --homedir has
been around since at least gpg-1.4.x from 2004, backwards compat
shouldn't be an issue.
While we're here, touch up the output a bit: there's no need to
dump all the chatty gpg output if things don't fail, so always
swallow the output.  If things do fail, our exception handler
takes care of dumping the full stdout & stderr.
Change-Id: I74ab98e1e61e95318fda6faf57c6a8699f775935
Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/255120
Reviewed-by: David Pursehouse <dpursehouse@collab.net>
Tested-by: Mike Frysinger <vapier@google.com>
Diffstat (limited to 'platform_utils_win32.py')
0 files changed, 0 insertions, 0 deletions
