Fix leak in git_tag_create_from_buffer

If the tag already exists and we are not forcing overwrite we need to free ref_name buffer before return the "tag already exists" error.
parent a3841af5
...@@ -397,6 +397,7 @@ int git_tag_create_from_buffer(git_oid *oid, git_repository *repo, const char *b ...@@ -397,6 +397,7 @@ int git_tag_create_from_buffer(git_oid *oid, git_repository *repo, const char *b
/** Ensure the tag name doesn't conflict with an already existing /** Ensure the tag name doesn't conflict with an already existing
* reference unless overwriting has explicitly been requested **/ * reference unless overwriting has explicitly been requested **/
if (error == 0 && !allow_ref_overwrite) { if (error == 0 && !allow_ref_overwrite) {
git_str_dispose(&ref_name);
git_error_set(GIT_ERROR_TAG, "tag already exists"); git_error_set(GIT_ERROR_TAG, "tag already exists");
return GIT_EEXISTS; return GIT_EEXISTS;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment