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
This commit is contained in:
commit
963792ed27
5
cache.h
5
cache.h
@ -1863,8 +1863,11 @@ extern int git_config_include(const char *name, const char *value, void *data);
|
||||
*
|
||||
* (i.e., what gets handed to a config_fn_t). The caller provides the section;
|
||||
* we return -1 if it does not match, 0 otherwise. The subsection and key
|
||||
* out-parameters are filled by the function (and subsection is NULL if it is
|
||||
* out-parameters are filled by the function (and *subsection is NULL if it is
|
||||
* missing).
|
||||
*
|
||||
* If the subsection pointer-to-pointer passed in is NULL, returns 0 only if
|
||||
* there is no subsection at all.
|
||||
*/
|
||||
extern int parse_config_key(const char *var,
|
||||
const char *section,
|
||||
|
15
config.c
15
config.c
@ -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;
|
||||
}
|
||||
|
||||
|
7
refs.c
7
refs.c
@ -1035,11 +1035,10 @@ static struct string_list *hide_refs;
|
||||
|
||||
int parse_hide_refs_config(const char *var, const char *value, const char *section)
|
||||
{
|
||||
const char *subsection, *key;
|
||||
int subsection_len;
|
||||
const char *key;
|
||||
if (!strcmp("transfer.hiderefs", var) ||
|
||||
(!parse_config_key(var, section, &subsection, &subsection_len, &key)
|
||||
&& !subsection && !strcmp(key, "hiderefs"))) {
|
||||
(!parse_config_key(var, section, NULL, NULL, &key) &&
|
||||
!strcmp(key, "hiderefs"))) {
|
||||
char *ref;
|
||||
int len;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user