diff options
author | Werner Koch <[email protected]> | 2017-03-29 08:02:40 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2017-03-29 08:06:29 +0000 |
commit | 0526c99164d3531b5ec763ffc672407eb24b2296 (patch) | |
tree | 0deb94a79a1cb2b916548e5d5cbb58114402dc2e /g10/keyring.c | |
parent | gpg: Export ring trust packets in backup mode. (diff) | |
download | gnupg-0526c99164d3531b5ec763ffc672407eb24b2296.tar.gz gnupg-0526c99164d3531b5ec763ffc672407eb24b2296.zip |
gpg: Change parse_packet to take a context.
* g10/packet.h (struct parse_packet_ctx_s): New.
(parse_packet_ctx_t): New type.
(init_parse_packet): New macro.
* g10/parse-packet.c (parse_packet, dbg_parse_packet): Change to take
a parse context. Change all callers to provide a context instead of
directly supplying the input stream.
(search_packet, dbg_search_packet): Ditto.
(copy_all_packets, dbg_copy_all_packets): Init an use a parse context.
(copy_some_packets, dbg_copy_some_packets): Ditto.
(skip_some_packets, dbg_skip_some_packets): Ditto.
--
We will need this change to handle ring packets inside the parser.
Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'g10/keyring.c')
-rw-r--r-- | g10/keyring.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/g10/keyring.c b/g10/keyring.c index 31f60f9fc..e4fc111ed 100644 --- a/g10/keyring.c +++ b/g10/keyring.c @@ -378,6 +378,7 @@ int keyring_get_keyblock (KEYRING_HANDLE hd, KBNODE *ret_kb) { PACKET *pkt; + struct parse_packet_ctx_s parsectx; int rc; KBNODE keyblock = NULL, node, lastnode; IOBUF a; @@ -407,10 +408,11 @@ keyring_get_keyblock (KEYRING_HANDLE hd, KBNODE *ret_kb) pkt = xmalloc (sizeof *pkt); init_packet (pkt); + init_parse_packet (&parsectx, a); hd->found.n_packets = 0;; lastnode = NULL; save_mode = set_packet_list_mode(0); - while ((rc=parse_packet (a, pkt)) != -1) { + while ((rc=parse_packet (&parsectx, pkt)) != -1) { hd->found.n_packets++; if (gpg_err_code (rc) == GPG_ERR_UNKNOWN_PACKET) { free_packet (pkt); @@ -985,6 +987,7 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc, { int rc; PACKET pkt; + struct parse_packet_ctx_s parsectx; int save_mode; off_t offset, main_offset; size_t n; @@ -1120,12 +1123,13 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc, if (DBG_LOOKUP) log_debug ("%s: %ssearching from start of resource.\n", __func__, scanned_from_start ? "" : "not "); + init_parse_packet (&parsectx, hd->current.iobuf); while (1) { byte afp[MAX_FINGERPRINT_LEN]; size_t an; - rc = search_packet (hd->current.iobuf, &pkt, &offset, need_uid); + rc = search_packet (&parsectx, &pkt, &offset, need_uid); if (ignore_legacy && gpg_err_code (rc) == GPG_ERR_LEGACY_KEY) { free_packet (&pkt); |