config_file: check result of git_array_alloc

git_array_alloc can return NULL if no memory is available, causing
a segmentation fault in memset. This adds GIT_ERROR_CHECK_ALLOC
similar to how other parts of the code base deal with the return
value of git_array_alloc.
parent ed959ca2
...@@ -678,6 +678,7 @@ static int parse_include(git_config_parser *reader, ...@@ -678,6 +678,7 @@ static int parse_include(git_config_parser *reader,
return result; return result;
include = git_array_alloc(reader->file->includes); include = git_array_alloc(reader->file->includes);
GIT_ERROR_CHECK_ALLOC(include);
memset(include, 0, sizeof(*include)); memset(include, 0, sizeof(*include));
git_array_init(include->includes); git_array_init(include->includes);
include->path = git_buf_detach(&path); include->path = git_buf_detach(&path);
......
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