diff options
author | Werner Koch <[email protected]> | 2017-03-29 09:57:40 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2017-03-29 10:08:31 +0000 |
commit | afa86809087909a8ba2f9356588bf90cc923529c (patch) | |
tree | ff0941a7831c23a47f9dafa522b375b7cc00daa4 /g10/free-packet.c | |
parent | indent: Re-indent function free-packet. (diff) | |
download | gnupg-afa86809087909a8ba2f9356588bf90cc923529c.tar.gz gnupg-afa86809087909a8ba2f9356588bf90cc923529c.zip |
gpg: Extend free_packet to handle a packet parser context.
* g10/packet.h (struct parse_packet_ctx_s): Add fields LAST_PKT and
FREE_LAST_PKT.
(init_parse_packet): Clear them.
(deinit_parse_packet): New macro. Change all users if
init_parse_packet to also call this macro.
* g10/free-packet.c (free_packet): Add arg PARSECTX and handle shallow
packet copies in the context. Change all callers.
* g10/parse-packet.c (parse): Store certain packets in the parse
context.
--
Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'g10/free-packet.c')
-rw-r--r-- | g10/free-packet.c | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/g10/free-packet.c b/g10/free-packet.c index 4cf80a4a1..535a17fb8 100644 --- a/g10/free-packet.c +++ b/g10/free-packet.c @@ -394,18 +394,40 @@ free_plaintext( PKT_plaintext *pt ) xfree (pt); } + /**************** * Free the packet in PKT. */ void -free_packet (PACKET *pkt) +free_packet (PACKET *pkt, parse_packet_ctx_t parsectx) { if (!pkt || !pkt->pkt.generic) - return; + { + if (parsectx && parsectx->last_pkt) + { + if (parsectx->free_last_pkt) + { + free_packet (parsectx->last_pkt, NULL); + parsectx->free_last_pkt = 0; + } + parsectx->last_pkt = NULL; + } + return; + } if (DBG_MEMORY) log_debug ("free_packet() type=%d\n", pkt->pkttype); + /* If we have a parser context holding PKT then do not free the + * packet but set a flag that the packet in the parser context is + * now a deep copy. */ + if (parsectx && parsectx->last_pkt == pkt && !parsectx->free_last_pkt) + { + parsectx->free_last_pkt = 1; + pkt->pkt.generic = NULL; + return; + } + switch (pkt->pkttype) { case PKT_SIGNATURE: |