summaryrefslogtreecommitdiffstats
path: root/g10/kbnode.c
diff options
context:
space:
mode:
authorWerner Koch <wk@gnupg.org>2017-03-29 11:57:40 +0200
committerWerner Koch <wk@gnupg.org>2017-03-29 12:08:31 +0200
commitafa86809087909a8ba2f9356588bf90cc923529c (patch)
treeff0941a7831c23a47f9dafa522b375b7cc00daa4 /g10/kbnode.c
parentindent: Re-indent function free-packet. (diff)
downloadgnupg2-afa86809087909a8ba2f9356588bf90cc923529c.tar.xz
gnupg2-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 <wk@gnupg.org>
Diffstat (limited to 'g10/kbnode.c')
-rw-r--r--g10/kbnode.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/g10/kbnode.c b/g10/kbnode.c
index b8c31b7a3..c2aaacd76 100644
--- a/g10/kbnode.c
+++ b/g10/kbnode.c
@@ -117,8 +117,8 @@ release_kbnode( KBNODE n )
while( n ) {
n2 = n->next;
if( !is_cloned_kbnode(n) ) {
- free_packet( n->pkt );
- xfree( n->pkt );
+ free_packet (n->pkt, NULL);
+ xfree( n->pkt );
}
free_node( n );
n = n2;
@@ -288,7 +288,7 @@ commit_kbnode( KBNODE *root )
else
nl->next = n->next;
if( !is_cloned_kbnode(n) ) {
- free_packet( n->pkt );
+ free_packet (n->pkt, NULL);
xfree( n->pkt );
}
free_node( n );
@@ -312,7 +312,7 @@ remove_kbnode( KBNODE *root, KBNODE node )
else
nl->next = n->next;
if( !is_cloned_kbnode(n) ) {
- free_packet( n->pkt );
+ free_packet (n->pkt, NULL);
xfree( n->pkt );
}
free_node( n );