From c03fd1bd3a84a1923ef130f20ab0c01ec3d8c742 Mon Sep 17 00:00:00 2001 From: Josef Kufner Date: Sat, 12 Sep 2015 01:25:11 +0200 Subject: pretty: pass graph width to pretty formatting for use in '%>|(N)' Pass graph width to pretty formatting, to make N in '%>|(N)' include columns consumed by graph rendered when --graph option is in use. For example, in the output of git log --all --graph --pretty='format: [%>|(20)%h] %ar%d' this change will make all commit hashes align at 20th column from the edge of the terminal, not from the edge of the graph. Signed-off-by: Josef Kufner Signed-off-by: Junio C Hamano --- commit.h | 1 + graph.c | 7 +++++++ graph.h | 5 +++++ log-tree.c | 2 ++ pretty.c | 1 + t/t4205-log-pretty-formats.sh | 24 ++++++++++++++++++++++++ 6 files changed, 40 insertions(+) diff --git a/commit.h b/commit.h index bc68ccbe69..ec6ecf8fff 100644 --- a/commit.h +++ b/commit.h @@ -156,6 +156,7 @@ struct pretty_print_context { * should not be counted on by callers. */ struct string_list in_body_headers; + int graph_width; }; struct userformat_want { diff --git a/graph.c b/graph.c index c25a09a8fd..48024113a6 100644 --- a/graph.c +++ b/graph.c @@ -671,6 +671,13 @@ static void graph_output_padding_line(struct git_graph *graph, graph_pad_horizontally(graph, sb, graph->num_new_columns * 2); } + +int graph_width(struct git_graph *graph) +{ + return graph->width; +} + + static void graph_output_skip_line(struct git_graph *graph, struct strbuf *sb) { /* diff --git a/graph.h b/graph.h index 0be62bd8b1..3f48c19b62 100644 --- a/graph.h +++ b/graph.h @@ -67,6 +67,11 @@ int graph_is_commit_finished(struct git_graph const *graph); int graph_next_line(struct git_graph *graph, struct strbuf *sb); +/* + * Return current width of the graph in on-screen characters. + */ +int graph_width(struct git_graph *graph); + /* * graph_show_*: helper functions for printing to stdout */ diff --git a/log-tree.c b/log-tree.c index 7f0890e4ac..a456ed015b 100644 --- a/log-tree.c +++ b/log-tree.c @@ -612,6 +612,8 @@ void show_log(struct rev_info *opt) ctx.output_encoding = get_log_output_encoding(); if (opt->from_ident.mail_begin && opt->from_ident.name_begin) ctx.from_ident = &opt->from_ident; + if (opt->graph) + ctx.graph_width = graph_width(opt->graph); pretty_print_commit(&ctx, commit, &msgbuf); if (opt->add_signoff) diff --git a/pretty.c b/pretty.c index 9d34d02db1..bf8a0a9a80 100644 --- a/pretty.c +++ b/pretty.c @@ -1296,6 +1296,7 @@ static size_t format_and_pad_commit(struct strbuf *sb, /* in UTF-8 */ if (!start) start = sb->buf; occupied = utf8_strnwidth(start, -1, 1); + occupied += c->pretty_ctx->graph_width; padding = (-padding) - occupied; } while (1) { diff --git a/t/t4205-log-pretty-formats.sh b/t/t4205-log-pretty-formats.sh index 7398605e7b..d75cdbbf9c 100755 --- a/t/t4205-log-pretty-formats.sh +++ b/t/t4205-log-pretty-formats.sh @@ -319,6 +319,19 @@ EOF test_cmp expected actual ' +# Note: Space between 'message' and 'two' should be in the same column +# as in previous test. +test_expect_success 'right alignment formatting at the nth column with --graph. i18n.logOutputEncoding' ' + git -c i18n.logOutputEncoding=$test_encoding log --graph --pretty="tformat:%h %>|(40)%s" >actual && + iconv -f utf-8 -t $test_encoding >expected <actual && cat <expected && @@ -330,6 +343,17 @@ EOF test_cmp expected actual ' +test_expect_success 'right alignment formatting with no padding and with --graph' ' + git log --graph --pretty="tformat:%>(1)%s" >actual && + cat <expected && +* message two +* message one +* add bar +* $(commit_msg) +EOF + test_cmp expected actual +' + test_expect_success 'right alignment formatting with no padding. i18n.logOutputEncoding' ' git -c i18n.logOutputEncoding=$test_encoding log --pretty="tformat:%>(1)%s" >actual && cat <expected && -- cgit v1.2.1