Commit 36e13399 by Boris Egorov

describe example: fix memory allocation size

We need to allocate memory for sizeof(char *) * ncommits, not just for
ncommits.

Issue detected by GCC's AddressSanitizer.
parent 73c5db76
...@@ -96,7 +96,8 @@ static void parse_options(describe_options *opts, int argc, char **argv) ...@@ -96,7 +96,8 @@ static void parse_options(describe_options *opts, int argc, char **argv)
const char *curr = argv[args.pos]; const char *curr = argv[args.pos];
if (curr[0] != '-') { if (curr[0] != '-') {
opts->commits = (const char **)realloc((void *)opts->commits, ++opts->commit_count); size_t newsz = ++opts->commit_count * sizeof(opts->commits[0]);
opts->commits = (const char **)realloc((void *)opts->commits, newsz);
opts->commits[opts->commit_count - 1] = curr; opts->commits[opts->commit_count - 1] = curr;
} else if (!strcmp(curr, "--all")) { } else if (!strcmp(curr, "--all")) {
opts->describe_options.describe_strategy = GIT_DESCRIBE_ALL; opts->describe_options.describe_strategy = GIT_DESCRIBE_ALL;
...@@ -123,7 +124,8 @@ static void parse_options(describe_options *opts, int argc, char **argv) ...@@ -123,7 +124,8 @@ static void parse_options(describe_options *opts, int argc, char **argv)
} }
else { else {
if (!opts->format_options.dirty_suffix || !opts->format_options.dirty_suffix[0]) { if (!opts->format_options.dirty_suffix || !opts->format_options.dirty_suffix[0]) {
opts->commits = (const char **)malloc(++opts->commit_count); size_t sz = ++opts->commit_count * sizeof(opts->commits[0]);
opts->commits = (const char **)malloc(sz);
opts->commits[0] = "HEAD"; opts->commits[0] = "HEAD";
} }
} }
......
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