daemon: Strictly parse the "extra arg" part of the command
[gitweb.git] / builtin-grep.c
index 9e7e766a496e44d3f5f266f24eb3430ae046235a..f88a912ace9195c387566770432a904e2d7adcb7 100644 (file)
@@ -26,16 +26,13 @@ static int grep_config(const char *var, const char *value, void *cb)
 {
        struct grep_opt *opt = cb;
 
-       if (!strcmp(var, "grep.color") || !strcmp(var, "color.grep")) {
+       if (!strcmp(var, "color.grep")) {
                opt->color = git_config_colorbool(var, value, -1);
                return 0;
        }
-       if (!strcmp(var, "grep.color.external") ||
-           !strcmp(var, "color.grep.external")) {
+       if (!strcmp(var, "color.grep.external"))
                return git_config_string(&(opt->color_external), var, value);
-       }
-       if (!strcmp(var, "grep.color.match") ||
-           !strcmp(var, "color.grep.match")) {
+       if (!strcmp(var, "color.grep.match")) {
                if (!value)
                        return config_error_nonbool(var);
                color_parse(value, var, opt->color_match);
@@ -825,6 +822,8 @@ int cmd_grep(int argc, const char **argv, const char *prefix)
                }
        }
 
+       if (opt.color && !opt.color_external)
+               builtin_grep = 1;
        if (!opt.pattern_list)
                die("no pattern given.");
        if ((opt.regflags != REG_NEWLINE) && opt.fixed)