This will make "git status" show core.defaultsparse and list of orphaned files if present. Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@xxxxxxxxx> --- wt-status.c | 44 ++++++++++++++++++++++++++++++++++++++++++++ wt-status.h | 1 + 2 files changed, 45 insertions(+), 0 deletions(-) diff --git a/wt-status.c b/wt-status.c index 3edae43..71cf809 100644 --- a/wt-status.c +++ b/wt-status.c @@ -20,6 +20,7 @@ static char wt_status_colors[][COLOR_MAXLEN] = { "\033[31m", /* WT_STATUS_CHANGED: red */ "\033[31m", /* WT_STATUS_UNTRACKED: red */ "\033[31m", /* WT_STATUS_NOBRANCH: red */ + "\033[31m", /* WT_STATUS_ORPHANED: red */ }; enum untracked_status_type show_untracked_files = SHOW_NORMAL_UNTRACKED_FILES; @@ -83,6 +84,16 @@ static void wt_status_print_dirty_header(struct wt_status *s, color_fprintf_ln(s->fp, c, "#"); } +static void wt_status_print_orphaned_header(struct wt_status *s) +{ + const char *c = color(WT_STATUS_HEADER); + color_fprintf_ln(s->fp, c, "# Orphaned files:"); + color_fprintf_ln(s->fp, c, "# (these are tracked, but marked no-checkout and should not be present)"); + color_fprintf_ln(s->fp, c, "# (use \"git update-index --checkout\" to remove no-checkout status)"); + color_fprintf_ln(s->fp, c, "# (otherwise remove them to avoid confusion because git will ignore them)"); + color_fprintf_ln(s->fp, c, "#"); +} + static void wt_status_print_untracked_header(struct wt_status *s) { const char *c = color(WT_STATUS_HEADER); @@ -211,6 +222,33 @@ static void wt_status_print_changed(struct wt_status *s) run_diff_files(&rev, 0); } +static void wt_status_print_orphaned(struct wt_status *s) +{ + int i, show_header = 0; + struct stat st; + struct strbuf buf; + + strbuf_init(&buf, 0); + for (i = 0; i < the_index.cache_nr; i++) { + struct cache_entry *ce = the_index.cache[i]; + + if (ce_checkout(ce) || lstat(ce->name, &st)) + continue; + + if (!show_header) { + wt_status_print_orphaned_header(s); + show_header = 1; + } + + color_fprintf(s->fp, color(WT_STATUS_HEADER), "#\t"); + color_fprintf_ln(s->fp, color(WT_STATUS_ORPHANED), "%s", + quote_path(ce->name, -1, &buf, s->prefix)); + } + + if (show_header) + color_fprintf_ln(s->fp, color(WT_STATUS_HEADER),"#"); +} + static void wt_status_print_submodule_summary(struct wt_status *s) { struct child_process sm_summary; @@ -344,8 +382,14 @@ void wt_status_print(struct wt_status *s) color_fprintf_ln(s->fp, color(WT_STATUS_HEADER), "#"); } + if (core_default_sparse) { + color_fprintf_ln(s->fp, color(WT_STATUS_HEADER), "# Sparse patterns: %s", core_default_sparse); + color_fprintf_ln(s->fp, color(WT_STATUS_HEADER), "#"); + } + wt_status_print_updated(s); wt_status_print_changed(s); + wt_status_print_orphaned(s); if (wt_status_submodule_summary) wt_status_print_submodule_summary(s); if (show_untracked_files) diff --git a/wt-status.h b/wt-status.h index 78add09..52f1eb5 100644 --- a/wt-status.h +++ b/wt-status.h @@ -9,6 +9,7 @@ enum color_wt_status { WT_STATUS_CHANGED, WT_STATUS_UNTRACKED, WT_STATUS_NOBRANCH, + WT_STATUS_ORPHANED, }; enum untracked_status_type { -- 1.6.0.3.890.g95457 -- 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