aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNIIBE Yutaka <[email protected]>2019-10-09 00:45:11 +0000
committerNIIBE Yutaka <[email protected]>2019-10-09 00:45:11 +0000
commit7535f1d47a35e30f736f0e842844555f7a4a9841 (patch)
tree6e88c169bb5b5f0e4c56e8e4b8852773262c15a1
parentdoc: Clarify that code assignments for g10 code and me terminated. (diff)
downloadgnupg-7535f1d47a35e30f736f0e842844555f7a4a9841.tar.gz
gnupg-7535f1d47a35e30f736f0e842844555f7a4a9841.zip
gpg: The first key should be in candidates.
* g10/getkey.c (get_best_pubkey_byname): Handle the first key as the initial candidate for the selection. -- GnuPG-bug-id: 4713 Signed-off-by: NIIBE Yutaka <[email protected]>
-rw-r--r--g10/getkey.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/g10/getkey.c b/g10/getkey.c
index 6802026f6..27bbd354c 100644
--- a/g10/getkey.c
+++ b/g10/getkey.c
@@ -1354,6 +1354,8 @@ get_best_pubkey_byname (ctrl_t ctrl, enum get_pubkey_modes mode,
int is_mbox = is_valid_mailbox (name);
int wkd_tried = 0;
+ log_assert (ret_keyblock != NULL);
+
if (retctx)
*retctx = NULL;
@@ -1416,7 +1418,10 @@ get_best_pubkey_byname (ctrl_t ctrl, enum get_pubkey_modes mode,
struct pubkey_cmp_cookie new = { 0 };
kbnode_t new_keyblock;
- while (getkey_next (ctrl, ctx, &new.key, &new_keyblock) == 0)
+ copy_public_key (&new.key, (*ret_keyblock)->pkt->pkt.public_key);
+ new_keyblock = clone_kbnode (*ret_keyblock);
+
+ do
{
int diff = pubkey_cmp (ctrl, name, &best, &new, new_keyblock);
release_kbnode (new_keyblock);
@@ -1441,6 +1446,8 @@ get_best_pubkey_byname (ctrl_t ctrl, enum get_pubkey_modes mode,
}
new.uid = NULL;
}
+ while (getkey_next (ctrl, ctx, &new.key, &new_keyblock) == 0);
+
getkey_end (ctrl, ctx);
ctx = NULL;
free_user_id (best.uid);