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:
parent
cd26c5482b
commit
9f641430dc
@ -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)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user