diff options
author | Johannes Schindelin <Johannes.Schindelin@gmx.de> | 2006-05-03 14:41:03 +0200 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-05-03 16:26:29 -0700 |
commit | 8f5ff31f8e74ac2f72c3c415beb2639bc36f7cb7 (patch) | |
tree | 95d4ef7a4998ba6d1e6af3611b0ce6b3f7147e02 /repo-config.c | |
parent | e098c6f82a28efe1488c7eb1bed4e92f76dd2afd (diff) | |
download | git-8f5ff31f8e74ac2f72c3c415beb2639bc36f7cb7.tar.gz git-8f5ff31f8e74ac2f72c3c415beb2639bc36f7cb7.tar.xz |
repo-config: deconvolute logics
It was rightly noticed that the logic is quite convoluted. Fix that.
Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'repo-config.c')
-rw-r--r-- | repo-config.c | 50 |
1 files changed, 26 insertions, 24 deletions
diff --git a/repo-config.c b/repo-config.c index 7e06d1a04..63eda1bb7 100644 --- a/repo-config.c +++ b/repo-config.c @@ -27,36 +27,38 @@ static int show_config(const char* key_, const char* value_) { char value[256]; const char *vptr = value; + int dup_error = 0; if (value_ == NULL) value_ = ""; - if ((use_key_regexp || !strcmp(key_, key)) && - (!use_key_regexp || - !regexec(key_regexp, key_, 0, NULL, 0)) && - (regexp == NULL || + if (!use_key_regexp && strcmp(key_, key)) + return 0; + if (use_key_regexp && regexec(key_regexp, key_, 0, NULL, 0)) + return 0; + if (regexp != NULL && (do_not_match ^ - !regexec(regexp, value_, 0, NULL, 0)))) { - int dup_error = 0; - if (show_keys) - printf("%s ", key_); - if (seen && !do_all) - dup_error = 1; - if (type == T_INT) - sprintf(value, "%d", git_config_int(key_, value_)); - else if (type == T_BOOL) - sprintf(value, "%s", git_config_bool(key_, value_) - ? "true" : "false"); - else - vptr = value_; - seen++; - if (dup_error) { - error("More than one value for the key %s: %s", - key_, vptr); - } - else - printf("%s\n", vptr); + regexec(regexp, value_, 0, NULL, 0))) + return 0; + + if (show_keys) + printf("%s ", key_); + if (seen && !do_all) + dup_error = 1; + if (type == T_INT) + sprintf(value, "%d", git_config_int(key_, value_)); + else if (type == T_BOOL) + vptr = git_config_bool(key_, value_) ? "true" : "false"; + else + vptr = value_; + seen++; + if (dup_error) { + error("More than one value for the key %s: %s", + key_, vptr); } + else + printf("%s\n", vptr); + return 0; } |