From: Soukaina NAIT HMID <[email protected]>

Signed-off-by: Soukaina NAIT HMID <[email protected]>
---
 builtin/config.c | 14 +++++++++++++-
 1 file changed, 13 insertions(+), 1 deletion(-)

diff --git a/builtin/config.c b/builtin/config.c
index 124a682d50fa8..9df2d9c43bcad 100644
--- a/builtin/config.c
+++ b/builtin/config.c
@@ -30,6 +30,7 @@ static int end_null;
 static int respect_includes_opt = -1;
 static struct config_options config_options;
 static int show_origin;
+static const char *default_value;
 
 #define ACTION_GET (1<<0)
 #define ACTION_GET_ALL (1<<1)
@@ -47,6 +48,7 @@ static int show_origin;
 #define ACTION_GET_COLOR (1<<13)
 #define ACTION_GET_COLORBOOL (1<<14)
 #define ACTION_GET_URLMATCH (1<<15)
+#define ACTION_GET_COLORORDEFAULT (1<<16)
 
 #define TYPE_BOOL (1<<0)
 #define TYPE_INT (1<<1)
@@ -80,12 +82,13 @@ static struct option builtin_config_options[] = {
        OPT_BIT(0, "int", &types, N_("value is decimal number"), TYPE_INT),
        OPT_BIT(0, "bool-or-int", &types, N_("value is --bool or --int"), 
TYPE_BOOL_OR_INT),
        OPT_BIT(0, "path", &types, N_("value is a path (file or directory 
name)"), TYPE_PATH),
-       OPT_BIT(0, "color", &actions, N_("find the color configured"), 
ACTION_GET_COLOR),
+       OPT_BIT(0, "color", &actions, N_("find the color configured"), 
ACTION_GET_COLORORDEFAULT),
        OPT_GROUP(N_("Other")),
        OPT_BOOL('z', "null", &end_null, N_("terminate values with NUL byte")),
        OPT_BOOL(0, "name-only", &omit_values, N_("show variable names only")),
        OPT_BOOL(0, "includes", &respect_includes_opt, N_("respect include 
directives on lookup")),
        OPT_BOOL(0, "show-origin", &show_origin, N_("show origin of config 
(file, standard input, blob, command line)")),
+       OPT_STRING(0, "default", &default_value, N_("default-value"), N_("sets 
default for bool/int/path/color when no value is returned from config")),
        OPT_END(),
 };
 
@@ -331,6 +334,11 @@ static void get_color(const char *var, const char 
*def_color)
        fputs(parsed_color, stdout);
 }
 
+static void get_color_default(const char *var)
+{
+       get_color(var, default_value);
+}
+
 static int get_colorbool_found;
 static int get_diff_color_found;
 static int get_color_ui_found;
@@ -726,6 +734,10 @@ int cmd_config(int argc, const char **argv, const char 
*prefix)
                check_argc(argc, 1, 2);
                get_color(argv[0], argv[1]);
        }
+       else if (actions == ACTION_GET_COLORORDEFAULT) {
+               check_argc(argc, 1, 1);
+               get_color_default(argv[0]);
+       }
        else if (actions == ACTION_GET_COLORBOOL) {
                check_argc(argc, 1, 2);
                if (argc == 2)

--
https://github.com/git/git/pull/431

Reply via email to