Commit de9a76b9 by Edward Thomson

config: properly handle multiline quotes

Pass a pointer to the quote counts so that we can increment it.
parent b882e9e7
...@@ -279,8 +279,7 @@ static int skip_bom(git_parse_ctx *parser) ...@@ -279,8 +279,7 @@ static int skip_bom(git_parse_ctx *parser)
*/ */
/* '\"' -> '"' etc */ /* '\"' -> '"' etc */
static int unescape_line( static int unescape_line(char **out, bool *is_multi, const char *ptr, int *quote_count)
char **out, bool *is_multi, const char *ptr, int quote_count)
{ {
char *str, *fixed, *esc; char *str, *fixed, *esc;
size_t ptr_len = strlen(ptr), alloc_len; size_t ptr_len = strlen(ptr), alloc_len;
...@@ -296,7 +295,8 @@ static int unescape_line( ...@@ -296,7 +295,8 @@ static int unescape_line(
while (*ptr != '\0') { while (*ptr != '\0') {
if (*ptr == '"') { if (*ptr == '"') {
quote_count++; if (quote_count)
(*quote_count)++;
} else if (*ptr != '\\') { } else if (*ptr != '\\') {
*fixed++ = *ptr; *fixed++ = *ptr;
} else { } else {
...@@ -358,7 +358,7 @@ static int parse_multiline_variable(git_config_parser *reader, git_str *value, i ...@@ -358,7 +358,7 @@ static int parse_multiline_variable(git_config_parser *reader, git_str *value, i
goto next; goto next;
if ((error = unescape_line(&proc_line, &multiline, if ((error = unescape_line(&proc_line, &multiline,
line, in_quotes)) < 0) line, &in_quotes)) < 0)
goto out; goto out;
/* Add this line to the multiline var */ /* Add this line to the multiline var */
...@@ -445,7 +445,7 @@ static int parse_variable(git_config_parser *reader, char **var_name, char **var ...@@ -445,7 +445,7 @@ static int parse_variable(git_config_parser *reader, char **var_name, char **var
while (git__isspace(value_start[0])) while (git__isspace(value_start[0]))
value_start++; value_start++;
if ((error = unescape_line(&value, &multiline, value_start, 0)) < 0) if ((error = unescape_line(&value, &multiline, value_start, NULL)) < 0)
goto out; goto out;
if (multiline) { if (multiline) {
......
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