]> git.ipfire.org Git - thirdparty/git.git/commitdiff
config: format bools gently
authorDerrick Stolee <stolee@gmail.com>
Mon, 23 Feb 2026 12:26:47 +0000 (12:26 +0000)
committerJunio C Hamano <gitster@pobox.com>
Mon, 23 Feb 2026 21:23:40 +0000 (13:23 -0800)
Move the logic for formatting bool config values into a helper method
and use gentle parsing when needed.

This makes 'git config list --type=bool' not fail when coming across a
non-boolean value. Such unparseable values are filtered out quietly.

Signed-off-by: Derrick Stolee <stolee@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/config.c
t/t1300-config.sh

index 448b1485637c58f89396903b9338f448cb0f3f12..d8b38c51d3ae64ff6a588a323c510cfbdbdc5a47 100644 (file)
@@ -256,6 +256,24 @@ static int format_config_int64(struct strbuf *buf,
        return 0;
 }
 
+static int format_config_bool(struct strbuf *buf,
+                             const char *key_,
+                             const char *value_,
+                             int gently)
+{
+       int v = 0;
+       if (gently) {
+               if ((v = git_parse_maybe_bool(value_)) < 0)
+                       return -1;
+       } else {
+               /* may die() */
+               v = git_config_bool(key_, value_);
+       }
+
+       strbuf_addstr(buf, v ? "true" : "false");
+       return 0;
+}
+
 /*
  * Format the configuration key-value pair (`key_`, `value_`) and
  * append it into strbuf `buf`.  Returns a negative value on failure,
@@ -284,8 +302,7 @@ static int format_config(const struct config_display_options *opts,
                if (opts->type == TYPE_INT)
                        res = format_config_int64(buf, key_, value_, kvi, gently);
                else if (opts->type == TYPE_BOOL)
-                       strbuf_addstr(buf, git_config_bool(key_, value_) ?
-                                     "true" : "false");
+                       res = format_config_bool(buf, key_, value_, gently);
                else if (opts->type == TYPE_BOOL_OR_INT) {
                        int is_bool, v;
                        v = git_config_bool_or_int(key_, value_, kvi,
index 05a812fd6d27e8fe409c46b55b03f5b3aa691f73..568cfaa3c5629548e1d0baf8eb2aff870336b2d6 100755 (executable)
@@ -2527,7 +2527,9 @@ test_expect_success 'list --type=bool shows only canonicalizable bool values' '
        section.big=true
        EOF
 
-       test_must_fail git config ${mode_prefix}list --type=bool
+       git config ${mode_prefix}list --type=bool >actual 2>err &&
+       test_cmp expect actual &&
+       test_must_be_empty err
 '
 
 test_expect_success 'list --type=bool-or-int shows only canonicalizable values' '