mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-18 14:17:03 +01:00
g10: Fix iteration over getkey results.
* g10/getkey.c (getkey_next): Return the public key in PK even if RET_KEYBLOCK is NULL. Signed-off-by: Justus Winter <justus@g10code.com>
This commit is contained in:
parent
445f0c13d7
commit
8ea72a776a
@ -1930,7 +1930,7 @@ getkey_byname (ctrl_t ctrl, getkey_ctx_t *retctx, PKT_public_key *pk,
|
|||||||
* If PK is not NULL, the public key of the next result is returned in
|
* If PK is not NULL, the public key of the next result is returned in
|
||||||
* *PK. Note: The self-signed data has already been merged into the
|
* *PK. Note: The self-signed data has already been merged into the
|
||||||
* public key using merge_selfsigs. Free *PK by calling
|
* public key using merge_selfsigs. Free *PK by calling
|
||||||
* release_public_key_parts (or, if PK was allocated using xfree, you
|
* release_public_key_parts (or, if PK was allocated using xmalloc, you
|
||||||
* can use free_public_key, which calls release_public_key_parts(PK)
|
* can use free_public_key, which calls release_public_key_parts(PK)
|
||||||
* and then xfree(PK)).
|
* and then xfree(PK)).
|
||||||
*
|
*
|
||||||
@ -1954,8 +1954,11 @@ getkey_next (getkey_ctx_t ctx, PKT_public_key *pk, kbnode_t *ret_keyblock)
|
|||||||
keydb_disable_caching (ctx->kr_handle);
|
keydb_disable_caching (ctx->kr_handle);
|
||||||
|
|
||||||
rc = lookup (ctx, ret_keyblock, &found_key, ctx->want_secret);
|
rc = lookup (ctx, ret_keyblock, &found_key, ctx->want_secret);
|
||||||
if (!rc && pk && ret_keyblock)
|
if (!rc && pk)
|
||||||
pk_from_block (pk, *ret_keyblock, found_key);
|
{
|
||||||
|
log_assert (found_key);
|
||||||
|
pk_from_block (pk, NULL, found_key);
|
||||||
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user