path: root/tag.c
diff options
authorStefan Beller <>2018-05-15 21:48:42 (GMT)
committerJunio C Hamano <>2018-05-16 02:16:50 (GMT)
commit14ba97f81c7b94e10d591b363688a073023f332d (patch)
treeed3672cff9cc1e0df22baa6c689db4deb06805f3 /tag.c
parent341e45e46bba094ef1274957ef5891f43e91b344 (diff)
alloc: allow arbitrary repositories for alloc functions
We have to convert all of the alloc functions at once, because alloc_report uses a funky macro for reporting. It is better for the sake of mechanical conversion to convert multiple functions at once rather than changing the structure of the reporting function. We record all memory allocation in alloc.c, and free them in clear_alloc_state, which is called for all repositories except the_repository. Signed-off-by: Stefan Beller <> Signed-off-by: Junio C Hamano <>
Diffstat (limited to 'tag.c')
1 files changed, 9 insertions, 0 deletions
diff --git a/tag.c b/tag.c
index 02ef4ea..7c12426 100644
--- a/tag.c
+++ b/tag.c
@@ -3,6 +3,7 @@
#include "commit.h"
#include "tree.h"
#include "blob.h"
+#include "alloc.h"
#include "gpg-interface.h"
const char *tag_type = "tag";
@@ -115,6 +116,14 @@ static timestamp_t parse_tag_date(const char *buf, const char *tail)
return parse_timestamp(dateptr, NULL, 10);
+void release_tag_memory(struct tag *t)
+ free(t->tag);
+ t->tagged = NULL;
+ t->object.parsed = 0;
+ t->date = 0;
int parse_tag_buffer(struct tag *item, const void *data, unsigned long size)
struct object_id oid;