Add build_varname to make a full var name Signed-off-by: Carlos Martín Nieto <cmn@elego.de>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
diff --git a/src/config.c b/src/config.c
index 8d01d7b..5f0c34a 100644
--- a/src/config.c
+++ b/src/config.c
@@ -463,10 +463,25 @@ static int config_parse(git_config *cfg_file)
return error;
}
+static const char *build_varname(const char *section, const char *name, int len)
+{
+ static char varname[1024]; /* TODO: What's the longest we should allow? */
+
+ if(strlen(section) + len + 2 > sizeof(varname))
+ return NULL;
+
+ strcpy(varname, section);
+ strcat(varname, ".");
+ strncat(varname, name, len);
+
+ return varname;
+}
+
static int parse_variable(git_config *cfg, const char *section_name, const char *line)
{
int error;
int has_value = 1;
+ const char *varname;
const char *var_end = NULL;
const char *value_start = NULL;
@@ -492,6 +507,8 @@ static int parse_variable(git_config *cfg, const char *section_name, const char
goto error;
}
+ varname = build_varname(section_name, line, var_end - line + 1);
+
return GIT_SUCCESS;
error: