diff options
author | NIIBE Yutaka <[email protected]> | 2019-10-09 00:45:11 +0000 |
---|---|---|
committer | NIIBE Yutaka <[email protected]> | 2019-10-09 00:45:11 +0000 |
commit | 7535f1d47a35e30f736f0e842844555f7a4a9841 (patch) | |
tree | 6e88c169bb5b5f0e4c56e8e4b8852773262c15a1 | |
parent | doc: Clarify that code assignments for g10 code and me terminated. (diff) | |
download | gnupg-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.c | 9 |
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); |