Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@xxxxxxxxx> --- builtin/list-files.c | 24 ++++++++++++++++++++---- 1 file changed, 20 insertions(+), 4 deletions(-) diff --git a/builtin/list-files.c b/builtin/list-files.c index dc865a1..316f59c 100644 --- a/builtin/list-files.c +++ b/builtin/list-files.c @@ -5,6 +5,7 @@ #include "dir.h" #include "quote.h" #include "column.h" +#include "color.h" static struct pathspec pathspec; static struct pathspec recursive_pathspec; @@ -13,6 +14,7 @@ static int prefix_length; static unsigned int colopts; static int max_depth; static int show_dirs; +static int use_color = -1; static const char * const ls_usage[] = { N_("git list-files [options] [<pathspec>...]"), @@ -28,16 +30,23 @@ struct option ls_options[] = { NULL, 1 }, OPT_SET_INT('R', "recursive", &max_depth, N_("shortcut for --max-depth=-1"), -1), + OPT__COLOR(&use_color, N_("show color")), OPT_END() }; -static void add_one(struct string_list *result, const char *name, +static void add_one(struct string_list *result, const char *name, int mode, const char *tag) { struct strbuf sb = STRBUF_INIT; struct string_list_item *item; quote_path_relative(name, prefix_length ? prefix : NULL, &sb); + if (want_color(use_color)) { + struct strbuf quoted = STRBUF_INIT; + strbuf_swap(&sb, "ed); + color_filename(&sb, name, quoted.buf, mode, 1); + strbuf_release("ed); + } strbuf_insert(&sb, 0, " ", 3); sb.buf[0] = tag[0]; sb.buf[1] = tag[1]; @@ -56,7 +65,7 @@ static int add_directory(struct string_list *result, strbuf_setlen(&sb, p - sb.buf); if (!match_pathspec(&pathspec, sb.buf, sb.len, 0, NULL, 1)) continue; - add_one(result, sb.buf, " "); + add_one(result, sb.buf, S_IFDIR, " "); /* * sb.buf is leaked, but because this command is * short-lived anyway so it does not matter much @@ -101,7 +110,7 @@ static void populate_cached_entries(struct string_list *result, if (!matched(result, ce->name, ce->ce_mode)) continue; - add_one(result, ce->name, " "); + add_one(result, ce->name, ce->ce_mode, " "); } if (!show_dirs) @@ -164,7 +173,11 @@ static int ls_config(const char *var, const char *value, void *cb) { if (starts_with(var, "column.")) return git_column_config(var, value, "listfiles", &colopts); - return git_default_config(var, value, cb); + if (!strcmp(var, "color.listfiles")) { + use_color = git_config_colorbool(var, value); + return 0; + } + return git_color_default_config(var, value, cb); } int cmd_list_files(int argc, const char **argv, const char *cmd_prefix) @@ -187,6 +200,9 @@ int cmd_list_files(int argc, const char **argv, const char *cmd_prefix) argc = parse_options(argc, argv, prefix, ls_options, ls_usage, 0); + if (want_color(use_color)) + parse_ls_color(); + parse_pathspec(&pathspec, 0, PATHSPEC_PREFER_CWD | (max_depth != -1 ? PATHSPEC_MAXDEPTH_VALID : 0) | -- 2.3.0.rc1.137.g477eb31 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html