mirror of
https://github.com/git/git.git
synced 2026-01-10 01:56:42 +00:00
builtin/submodule--helper: fix leak when remote_submodule_branch() failed
In builtin/submodule--helper.c:update_submodule(), the variable remote_name is allocated in get_default_remote_submodule() but may be leaked if remote_submodule_branch() fails. Although it is unlikely that remote_submodule_branch() would fail after successfully obtaining a remote ref name from get_default_remote_submodule(), it is still possible. To prevent a potential memory leak, add a call to free(remote_name) at the early exit point. Signed-off-by: Lidong Yan <502024330056@smail.nju.edu.cn> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
d50a5e8939
commit
bfc9f9cc64
@@ -2660,8 +2660,10 @@ static int update_submodule(struct update_data *update_data)
|
||||
if (code)
|
||||
return code;
|
||||
code = remote_submodule_branch(update_data->sm_path, &branch);
|
||||
if (code)
|
||||
if (code) {
|
||||
free(remote_name);
|
||||
return code;
|
||||
}
|
||||
remote_ref = xstrfmt("refs/remotes/%s/%s", remote_name, branch);
|
||||
|
||||
free(remote_name);
|
||||
|
||||
Reference in New Issue
Block a user