diff options
author | Junio C Hamano <gitster@pobox.com> | 2017-03-10 22:24:22 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-03-10 22:24:22 +0100 |
commit | 963792ed277bde985ea9ff4953529d656b186571 (patch) | |
tree | ce457fde106f33c0cd9c75b1c15a5169752431cb /config.c | |
parent | Merge branch 'sb/parse-hide-refs-config-cleanup' (diff) | |
parent | parse_hide_refs_config: tell parse_config_key we don't want a subsection (diff) | |
download | git-963792ed277bde985ea9ff4953529d656b186571.tar.xz git-963792ed277bde985ea9ff4953529d656b186571.zip |
Merge branch 'jk/parse-config-key-cleanup'
The "parse_config_key()" API function has been cleaned up.
* jk/parse-config-key-cleanup:
parse_hide_refs_config: tell parse_config_key we don't want a subsection
parse_config_key: allow matching single-level config
parse_config_key: use skip_prefix instead of starts_with
Diffstat (limited to 'config.c')
-rw-r--r-- | config.c | 15 |
1 files changed, 9 insertions, 6 deletions
@@ -2540,11 +2540,10 @@ int parse_config_key(const char *var, const char **subsection, int *subsection_len, const char **key) { - int section_len = strlen(section); const char *dot; /* Does it start with "section." ? */ - if (!starts_with(var, section) || var[section_len] != '.') + if (!skip_prefix(var, section, &var) || *var != '.') return -1; /* @@ -2556,12 +2555,16 @@ int parse_config_key(const char *var, *key = dot + 1; /* Did we have a subsection at all? */ - if (dot == var + section_len) { - *subsection = NULL; - *subsection_len = 0; + if (dot == var) { + if (subsection) { + *subsection = NULL; + *subsection_len = 0; + } } else { - *subsection = var + section_len + 1; + if (!subsection) + return -1; + *subsection = var + 1; *subsection_len = dot - *subsection; } |