提交 0911c475 编写于 作者: S Stefan Beller 提交者: Junio C Hamano

diff.c: convert show_stats to use emit_diff_symbol

We call print_stat_summary from builtin/apply, so we still
need the version with a file pointer, so introduce
print_stat_summary_0 that uses emit_string machinery and
keep print_stat_summary with the same arguments around.
Signed-off-by: NStefan Beller <sbeller@google.com>
Signed-off-by: NJunio C Hamano <gitster@pobox.com>
上级 4eed0ebd
...@@ -566,6 +566,10 @@ enum diff_symbol { ...@@ -566,6 +566,10 @@ enum diff_symbol {
DIFF_SYMBOL_BINARY_DIFF_HEADER_LITERAL, DIFF_SYMBOL_BINARY_DIFF_HEADER_LITERAL,
DIFF_SYMBOL_BINARY_DIFF_BODY, DIFF_SYMBOL_BINARY_DIFF_BODY,
DIFF_SYMBOL_BINARY_DIFF_FOOTER, DIFF_SYMBOL_BINARY_DIFF_FOOTER,
DIFF_SYMBOL_STATS_SUMMARY_NO_FILES,
DIFF_SYMBOL_STATS_SUMMARY_ABBREV,
DIFF_SYMBOL_STATS_SUMMARY_INSERTS_DELETES,
DIFF_SYMBOL_STATS_LINE,
DIFF_SYMBOL_SUBMODULE_ADD, DIFF_SYMBOL_SUBMODULE_ADD,
DIFF_SYMBOL_SUBMODULE_DEL, DIFF_SYMBOL_SUBMODULE_DEL,
DIFF_SYMBOL_SUBMODULE_UNTRACKED, DIFF_SYMBOL_SUBMODULE_UNTRACKED,
...@@ -629,6 +633,7 @@ static void emit_diff_symbol(struct diff_options *o, enum diff_symbol s, ...@@ -629,6 +633,7 @@ static void emit_diff_symbol(struct diff_options *o, enum diff_symbol s,
{ {
static const char *nneof = " No newline at end of file\n"; static const char *nneof = " No newline at end of file\n";
const char *context, *reset, *set, *meta, *fraginfo; const char *context, *reset, *set, *meta, *fraginfo;
struct strbuf sb = STRBUF_INIT;
switch (s) { switch (s) {
case DIFF_SYMBOL_NO_LF_EOF: case DIFF_SYMBOL_NO_LF_EOF:
context = diff_get_color_opt(o, DIFF_CONTEXT); context = diff_get_color_opt(o, DIFF_CONTEXT);
...@@ -640,6 +645,8 @@ static void emit_diff_symbol(struct diff_options *o, enum diff_symbol s, ...@@ -640,6 +645,8 @@ static void emit_diff_symbol(struct diff_options *o, enum diff_symbol s,
case DIFF_SYMBOL_SUBMODULE_HEADER: case DIFF_SYMBOL_SUBMODULE_HEADER:
case DIFF_SYMBOL_SUBMODULE_ERROR: case DIFF_SYMBOL_SUBMODULE_ERROR:
case DIFF_SYMBOL_SUBMODULE_PIPETHROUGH: case DIFF_SYMBOL_SUBMODULE_PIPETHROUGH:
case DIFF_SYMBOL_STATS_SUMMARY_INSERTS_DELETES:
case DIFF_SYMBOL_STATS_LINE:
case DIFF_SYMBOL_BINARY_DIFF_BODY: case DIFF_SYMBOL_BINARY_DIFF_BODY:
case DIFF_SYMBOL_CONTEXT_FRAGINFO: case DIFF_SYMBOL_CONTEXT_FRAGINFO:
emit_line(o, "", "", line, len); emit_line(o, "", "", line, len);
...@@ -748,9 +755,17 @@ static void emit_diff_symbol(struct diff_options *o, enum diff_symbol s, ...@@ -748,9 +755,17 @@ static void emit_diff_symbol(struct diff_options *o, enum diff_symbol s,
fprintf(o->file, "%sSubmodule %s contains modified content\n", fprintf(o->file, "%sSubmodule %s contains modified content\n",
diff_line_prefix(o), line); diff_line_prefix(o), line);
break; break;
case DIFF_SYMBOL_STATS_SUMMARY_NO_FILES:
emit_line(o, "", "", " 0 files changed\n",
strlen(" 0 files changed\n"));
break;
case DIFF_SYMBOL_STATS_SUMMARY_ABBREV:
emit_line(o, "", "", " ...\n", strlen(" ...\n"));
break;
default: default:
die("BUG: unknown diff symbol"); die("BUG: unknown diff symbol");
} }
strbuf_release(&sb);
} }
void diff_emit_submodule_del(struct diff_options *o, const char *line) void diff_emit_submodule_del(struct diff_options *o, const char *line)
...@@ -1705,20 +1720,14 @@ static int scale_linear(int it, int width, int max_change) ...@@ -1705,20 +1720,14 @@ static int scale_linear(int it, int width, int max_change)
return 1 + (it * (width - 1) / max_change); return 1 + (it * (width - 1) / max_change);
} }
static void show_name(FILE *file, static void show_graph(struct strbuf *out, char ch, int cnt,
const char *prefix, const char *name, int len) const char *set, const char *reset)
{
fprintf(file, " %s%-*s |", prefix, len, name);
}
static void show_graph(FILE *file, char ch, int cnt, const char *set, const char *reset)
{ {
if (cnt <= 0) if (cnt <= 0)
return; return;
fprintf(file, "%s", set); strbuf_addstr(out, set);
while (cnt--) strbuf_addchars(out, ch, cnt);
putc(ch, file); strbuf_addstr(out, reset);
fprintf(file, "%s", reset);
} }
static void fill_print_name(struct diffstat_file *file) static void fill_print_name(struct diffstat_file *file)
...@@ -1742,14 +1751,16 @@ static void fill_print_name(struct diffstat_file *file) ...@@ -1742,14 +1751,16 @@ static void fill_print_name(struct diffstat_file *file)
file->print_name = pname; file->print_name = pname;
} }
int print_stat_summary(FILE *fp, int files, int insertions, int deletions) static void print_stat_summary_inserts_deletes(struct diff_options *options,
int files, int insertions, int deletions)
{ {
struct strbuf sb = STRBUF_INIT; struct strbuf sb = STRBUF_INIT;
int ret;
if (!files) { if (!files) {
assert(insertions == 0 && deletions == 0); assert(insertions == 0 && deletions == 0);
return fprintf(fp, "%s\n", " 0 files changed"); emit_diff_symbol(options, DIFF_SYMBOL_STATS_SUMMARY_NO_FILES,
NULL, 0, 0);
return;
} }
strbuf_addf(&sb, strbuf_addf(&sb,
...@@ -1776,9 +1787,19 @@ int print_stat_summary(FILE *fp, int files, int insertions, int deletions) ...@@ -1776,9 +1787,19 @@ int print_stat_summary(FILE *fp, int files, int insertions, int deletions)
deletions); deletions);
} }
strbuf_addch(&sb, '\n'); strbuf_addch(&sb, '\n');
ret = fputs(sb.buf, fp); emit_diff_symbol(options, DIFF_SYMBOL_STATS_SUMMARY_INSERTS_DELETES,
sb.buf, sb.len, 0);
strbuf_release(&sb); strbuf_release(&sb);
return ret; }
void print_stat_summary(FILE *fp, int files,
int insertions, int deletions)
{
struct diff_options o;
memset(&o, 0, sizeof(o));
o.file = fp;
print_stat_summary_inserts_deletes(&o, files, insertions, deletions);
} }
static void show_stats(struct diffstat_t *data, struct diff_options *options) static void show_stats(struct diffstat_t *data, struct diff_options *options)
...@@ -1788,13 +1809,13 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options) ...@@ -1788,13 +1809,13 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options)
int total_files = data->nr, count; int total_files = data->nr, count;
int width, name_width, graph_width, number_width = 0, bin_width = 0; int width, name_width, graph_width, number_width = 0, bin_width = 0;
const char *reset, *add_c, *del_c; const char *reset, *add_c, *del_c;
const char *line_prefix = "";
int extra_shown = 0; int extra_shown = 0;
const char *line_prefix = diff_line_prefix(options);
struct strbuf out = STRBUF_INIT;
if (data->nr == 0) if (data->nr == 0)
return; return;
line_prefix = diff_line_prefix(options);
count = options->stat_count ? options->stat_count : data->nr; count = options->stat_count ? options->stat_count : data->nr;
reset = diff_get_color_opt(options, DIFF_RESET); reset = diff_get_color_opt(options, DIFF_RESET);
...@@ -1948,26 +1969,32 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options) ...@@ -1948,26 +1969,32 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options)
} }
if (file->is_binary) { if (file->is_binary) {
fprintf(options->file, "%s", line_prefix); strbuf_addf(&out, " %s%-*s |", prefix, len, name);
show_name(options->file, prefix, name, len); strbuf_addf(&out, " %*s", number_width, "Bin");
fprintf(options->file, " %*s", number_width, "Bin");
if (!added && !deleted) { if (!added && !deleted) {
putc('\n', options->file); strbuf_addch(&out, '\n');
emit_diff_symbol(options, DIFF_SYMBOL_STATS_LINE,
out.buf, out.len, 0);
strbuf_reset(&out);
continue; continue;
} }
fprintf(options->file, " %s%"PRIuMAX"%s", strbuf_addf(&out, " %s%"PRIuMAX"%s",
del_c, deleted, reset); del_c, deleted, reset);
fprintf(options->file, " -> "); strbuf_addstr(&out, " -> ");
fprintf(options->file, "%s%"PRIuMAX"%s", strbuf_addf(&out, "%s%"PRIuMAX"%s",
add_c, added, reset); add_c, added, reset);
fprintf(options->file, " bytes"); strbuf_addstr(&out, " bytes\n");
fprintf(options->file, "\n"); emit_diff_symbol(options, DIFF_SYMBOL_STATS_LINE,
out.buf, out.len, 0);
strbuf_reset(&out);
continue; continue;
} }
else if (file->is_unmerged) { else if (file->is_unmerged) {
fprintf(options->file, "%s", line_prefix); strbuf_addf(&out, " %s%-*s |", prefix, len, name);
show_name(options->file, prefix, name, len); strbuf_addstr(&out, " Unmerged\n");
fprintf(options->file, " Unmerged\n"); emit_diff_symbol(options, DIFF_SYMBOL_STATS_LINE,
out.buf, out.len, 0);
strbuf_reset(&out);
continue; continue;
} }
...@@ -1990,14 +2017,16 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options) ...@@ -1990,14 +2017,16 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options)
add = total - del; add = total - del;
} }
} }
fprintf(options->file, "%s", line_prefix); strbuf_addf(&out, " %s%-*s |", prefix, len, name);
show_name(options->file, prefix, name, len); strbuf_addf(&out, " %*"PRIuMAX"%s",
fprintf(options->file, " %*"PRIuMAX"%s",
number_width, added + deleted, number_width, added + deleted,
added + deleted ? " " : ""); added + deleted ? " " : "");
show_graph(options->file, '+', add, add_c, reset); show_graph(&out, '+', add, add_c, reset);
show_graph(options->file, '-', del, del_c, reset); show_graph(&out, '-', del, del_c, reset);
fprintf(options->file, "\n"); strbuf_addch(&out, '\n');
emit_diff_symbol(options, DIFF_SYMBOL_STATS_LINE,
out.buf, out.len, 0);
strbuf_reset(&out);
} }
for (i = 0; i < data->nr; i++) { for (i = 0; i < data->nr; i++) {
...@@ -2018,11 +2047,13 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options) ...@@ -2018,11 +2047,13 @@ static void show_stats(struct diffstat_t *data, struct diff_options *options)
if (i < count) if (i < count)
continue; continue;
if (!extra_shown) if (!extra_shown)
fprintf(options->file, "%s ...\n", line_prefix); emit_diff_symbol(options,
DIFF_SYMBOL_STATS_SUMMARY_ABBREV,
NULL, 0, 0);
extra_shown = 1; extra_shown = 1;
} }
fprintf(options->file, "%s", line_prefix);
print_stat_summary(options->file, total_files, adds, dels); print_stat_summary_inserts_deletes(options, total_files, adds, dels);
} }
static void show_shortstats(struct diffstat_t *data, struct diff_options *options) static void show_shortstats(struct diffstat_t *data, struct diff_options *options)
...@@ -2034,7 +2065,7 @@ static void show_shortstats(struct diffstat_t *data, struct diff_options *option ...@@ -2034,7 +2065,7 @@ static void show_shortstats(struct diffstat_t *data, struct diff_options *option
for (i = 0; i < data->nr; i++) { for (i = 0; i < data->nr; i++) {
int added = data->files[i]->added; int added = data->files[i]->added;
int deleted= data->files[i]->deleted; int deleted = data->files[i]->deleted;
if (data->files[i]->is_unmerged || if (data->files[i]->is_unmerged ||
(!data->files[i]->is_interesting && (added + deleted == 0))) { (!data->files[i]->is_interesting && (added + deleted == 0))) {
...@@ -2044,8 +2075,7 @@ static void show_shortstats(struct diffstat_t *data, struct diff_options *option ...@@ -2044,8 +2075,7 @@ static void show_shortstats(struct diffstat_t *data, struct diff_options *option
dels += deleted; dels += deleted;
} }
} }
fprintf(options->file, "%s", diff_line_prefix(options)); print_stat_summary_inserts_deletes(options, total_files, adds, dels);
print_stat_summary(options->file, total_files, adds, dels);
} }
static void show_numstat(struct diffstat_t *data, struct diff_options *options) static void show_numstat(struct diffstat_t *data, struct diff_options *options)
......
...@@ -405,8 +405,8 @@ extern int parse_rename_score(const char **cp_p); ...@@ -405,8 +405,8 @@ extern int parse_rename_score(const char **cp_p);
extern long parse_algorithm_value(const char *value); extern long parse_algorithm_value(const char *value);
extern int print_stat_summary(FILE *fp, int files, extern void print_stat_summary(FILE *fp, int files,
int insertions, int deletions); int insertions, int deletions);
extern void setup_diff_pager(struct diff_options *); extern void setup_diff_pager(struct diff_options *);
#endif /* DIFF_H */ #endif /* DIFF_H */
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册