gpg-interface: provide clear helper for struct signature_check

The struct has been growing members whose malloced memory needs to be
freed. Do this with one helper function so that no malloced memory shall
be left unfreed.

Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Michael J Gruber 2014-06-23 09:05:47 +02:00 committed by Junio C Hamano
parent 0953113bb5
commit 01e57b5d91
4 changed files with 15 additions and 6 deletions

View File

@ -1282,10 +1282,7 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
printf(_("Commit %s has a good GPG signature by %s\n"), printf(_("Commit %s has a good GPG signature by %s\n"),
hex, signature_check.signer); hex, signature_check.signer);
free(signature_check.gpg_output); signature_check_clear(&signature_check);
free(signature_check.gpg_status);
free(signature_check.signer);
free(signature_check.key);
} }
} }

View File

@ -7,6 +7,18 @@
static char *configured_signing_key; static char *configured_signing_key;
static const char *gpg_program = "gpg"; static const char *gpg_program = "gpg";
void signature_check_clear(struct signature_check *sigc)
{
free(sigc->gpg_output);
free(sigc->gpg_status);
free(sigc->signer);
free(sigc->key);
sigc->gpg_output = NULL;
sigc->gpg_status = NULL;
sigc->signer = NULL;
sigc->key = NULL;
}
void set_signing_key(const char *key) void set_signing_key(const char *key)
{ {
free(configured_signing_key); free(configured_signing_key);

View File

@ -13,6 +13,7 @@ struct signature_check {
char *key; char *key;
}; };
extern void signature_check_clear(struct signature_check *sigc);
extern int sign_buffer(struct strbuf *buffer, struct strbuf *signature, const char *signing_key); extern int sign_buffer(struct strbuf *buffer, struct strbuf *signature, const char *signing_key);
extern int verify_signed_buffer(const char *payload, size_t payload_size, const char *signature, size_t signature_size, struct strbuf *gpg_output, struct strbuf *gpg_status); extern int verify_signed_buffer(const char *payload, size_t payload_size, const char *signature, size_t signature_size, struct strbuf *gpg_output, struct strbuf *gpg_status);
extern int git_gpg_config(const char *, const char *, void *); extern int git_gpg_config(const char *, const char *, void *);

View File

@ -1532,8 +1532,7 @@ void format_commit_message(const struct commit *commit,
free(context.commit_encoding); free(context.commit_encoding);
logmsg_free(context.message, commit); logmsg_free(context.message, commit);
free(context.signature_check.gpg_output); signature_check_clear(&context.signature_check);
free(context.signature_check.signer);
} }
static void pp_header(struct pretty_print_context *pp, static void pp_header(struct pretty_print_context *pp,