parse_treeish_arg() uses dwim_ref() to set refname to a strdup'd string. Release it after use. Also remove the const qualifier from the refname member to signify that ownership of the string is handed to the struct, leaving cleanup duty with the caller of parse_treeish_arg(), thus avoiding a cast. Signed-off-by: René Scharfe <l.s.r@xxxxxx> --- archive.c | 1 + archive.h | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/archive.c b/archive.c index 3c1541af9e..da89d292c2 100644 --- a/archive.c +++ b/archive.c @@ -662,6 +662,7 @@ int write_archive(int argc, const char **argv, const char *prefix, rc = ar->write_archive(ar, &args); string_list_clear_func(&args.extra_files, extra_file_info_clear); + free(args.refname); return rc; } diff --git a/archive.h b/archive.h index 82b226011a..43028ffbf3 100644 --- a/archive.h +++ b/archive.h @@ -8,7 +8,7 @@ struct repository; struct archiver_args { struct repository *repo; - const char *refname; + char *refname; const char *prefix; const char *base; size_t baselen; -- 2.29.2