1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-21 14:47:03 +01:00

gpg: Simplify default_recipient().

* g10/pkclist.c (default_recipient): Use hexfingerprint.
--

Note that on malloc failure this function now returns NULL instead of
terminating the process.  However, under memory pressure any function
called latter will very likely fail as well.

Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2017-12-13 11:00:24 +01:00
parent cd26c5482b
commit 9f641430dc
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B

View File

@ -730,40 +730,35 @@ key_present_in_pk_list(PK_LIST pk_list, PKT_public_key *pk)
} }
/**************** /*
* Return a malloced string with a default recipient if there is any * Return a malloced string with a default recipient if there is any
* Fixme: We don't distinguish between malloc failure and no-default-recipient.
*/ */
static char * static char *
default_recipient(ctrl_t ctrl) default_recipient (ctrl_t ctrl)
{ {
PKT_public_key *pk; PKT_public_key *pk;
byte fpr[MAX_FINGERPRINT_LEN+1]; char *result;
size_t n;
char *p;
int i;
if( opt.def_recipient ) if (opt.def_recipient)
return xstrdup( opt.def_recipient ); return xtrystrdup (opt.def_recipient);
if( !opt.def_recipient_self )
return NULL; if (!opt.def_recipient_self)
pk = xmalloc_clear( sizeof *pk ); return NULL;
i = get_seckey_default (ctrl, pk); pk = xtrycalloc (1, sizeof *pk );
if( i ) { if (!pk)
free_public_key( pk ); return NULL;
return NULL; if (get_seckey_default (ctrl, pk))
{
free_public_key (pk);
return NULL;
} }
n = MAX_FINGERPRINT_LEN; result = hexfingerprint (pk, NULL, 0);
fingerprint_from_pk( pk, fpr, &n ); free_public_key (pk);
free_public_key( pk ); return result;
p = xmalloc( 2*n+3 );
*p++ = '0';
*p++ = 'x';
for(i=0; i < n; i++ )
sprintf( p+2*i, "%02X", fpr[i] );
p -= 2;
return p;
} }
static int static int
expand_id(const char *id,strlist_t *into,unsigned int flags) expand_id(const char *id,strlist_t *into,unsigned int flags)
{ {