mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
gpg: Improve speed of secret key listing.
* agent/command.c (cmd_keyinfo): Factor some code out to ... (get_keyinfo_on_cards): ... new. (cmd_havekey): Add --list mode. * g10/gpg.h (struct server_control_s): Add new caching vars. * g10/gpg.c (gpg_deinit_default_ctrl): Release cache. * g10/call-agent.c (agent_probe_any_secret_key): Init and try to use the keygrip cache. (agent_genkey): Clear the cache. (agent_import_key): Ditto. * g10/keylist.c (list_all, list_one): Pass ctrl to agent_probe_any_secret_key. * g10/getkey.c (lookup): Ditto. -- With this change we first ask the agent for a list of all secret keygrips and use that list instead of asking the agent for each public key. Speeds up my "gpg -K" with a lot of secret and public keys by more than 25%. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
b8e6e485ee
commit
40da61b89b
6 changed files with 246 additions and 55 deletions
|
@ -3916,7 +3916,7 @@ lookup (ctrl_t ctrl, getkey_ctx_t ctx, int want_secret,
|
|||
|
||||
if (want_secret)
|
||||
{
|
||||
rc = agent_probe_any_secret_key (NULL, keyblock);
|
||||
rc = agent_probe_any_secret_key (ctrl, keyblock);
|
||||
if (gpg_err_code(rc) == GPG_ERR_NO_SECKEY)
|
||||
goto skip; /* No secret key available. */
|
||||
if (rc)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue