mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
common: In private key mode write "Key:" always last in name-value.
* common/name-value.c (nvc_write): Take care of Key. Factor some code out to ... (write_one_entry): new. -- The key item is in general not manual editable thus we put it at the end of a file. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
bd6ecbb8f8
commit
c9fa28bfad
@ -778,16 +778,13 @@ nvc_parse_private_key (nvc_t *result, int *errlinep, estream_t stream)
|
||||
}
|
||||
|
||||
|
||||
/* Write a representation of PK to STREAM. */
|
||||
gpg_error_t
|
||||
nvc_write (nvc_t pk, estream_t stream)
|
||||
/* Helper fpr nvc_write. */
|
||||
static gpg_error_t
|
||||
write_one_entry (nve_t entry, estream_t stream)
|
||||
{
|
||||
gpg_error_t err;
|
||||
nve_t entry;
|
||||
strlist_t s;
|
||||
strlist_t sl;
|
||||
|
||||
for (entry = pk->first; entry; entry = entry->next)
|
||||
{
|
||||
if (entry->name)
|
||||
es_fputs (entry->name, stream);
|
||||
|
||||
@ -795,12 +792,42 @@ nvc_write (nvc_t pk, estream_t stream)
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
for (s = entry->raw_value; s; s = s->next)
|
||||
es_fputs (s->d, stream);
|
||||
for (sl = entry->raw_value; sl; sl = sl->next)
|
||||
es_fputs (sl->d, stream);
|
||||
|
||||
if (es_ferror (stream))
|
||||
return my_error_from_syserror ();
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
/* Write a representation of PK to STREAM. */
|
||||
gpg_error_t
|
||||
nvc_write (nvc_t pk, estream_t stream)
|
||||
{
|
||||
gpg_error_t err = 0;
|
||||
nve_t entry;
|
||||
nve_t keyentry = NULL;
|
||||
|
||||
for (entry = pk->first; entry; entry = entry->next)
|
||||
{
|
||||
if (pk->private_key_mode
|
||||
&& entry->name && !ascii_strcasecmp (entry->name, "Key:"))
|
||||
{
|
||||
if (!keyentry)
|
||||
keyentry = entry;
|
||||
continue;
|
||||
}
|
||||
|
||||
err = write_one_entry (entry, stream);
|
||||
if (err)
|
||||
return err;
|
||||
}
|
||||
|
||||
/* In private key mode we write the Key always last. */
|
||||
if (keyentry)
|
||||
err = write_one_entry (keyentry, stream);
|
||||
|
||||
return err;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user