From: Junio C Hamano <gitster@pobox.com>
To: Jeff Muizelaar <jmuizelaar@mozilla.com>
Cc: git@vger.kernel.org
Subject: Re: [PATCH] diff: diff.context configuration gives default to -U
Date: Thu, 27 Sep 2012 10:40:26 -0700 [thread overview]
Message-ID: <7vr4pnqs8l.fsf@alter.siamese.dyndns.org> (raw)
In-Reply-To: <C4993A4E-E443-4DB4-9DCA-20128CADDC6E@mozilla.com> (Jeff Muizelaar's message of "Thu, 27 Sep 2012 11:04:44 -0400")
Jeff Muizelaar <jmuizelaar@mozilla.com> writes:
> Introduce a configuration variable diff.context that tells
> Porcelain commands to use a non-default number of context
> lines instead of 3 (the default). With this variable, users
> do not have to keep repeating "git log -U8" from the command
> line; instead, it becomes sufficient to say "git config
> diff.context 8" just once.
>
> Signed-off-by: Jeff Muizelaar <jmuizelaar@mozilla.com>
> ---
> Documentation/diff-config.txt | 4 +
> diff.c | 9 +++-
> t/t4060-diff-context.sh | 127 +++++++++++++++++++++++++++++++++++++++++
> 3 files changed, 139 insertions(+), 1 deletions(-)
> create mode 100755 t/t4060-diff-context.sh
Sigh, we don't have existing tests to check the number of context
lines given with -U option and we need to allocate a new test number
for it. What is the gap between 4054 (the last one in the tests for
the diff family) and 4060 for?
> diff --git a/Documentation/diff-config.txt b/Documentation/diff-config.txt
> index 67a90a8..75ab8a5 100644
> --- a/Documentation/diff-config.txt
> +++ b/Documentation/diff-config.txt
> @@ -56,6 +56,10 @@ diff.statGraphWidth::
> Limit the width of the graph part in --stat output. If set, applies
> to all commands generating --stat output except format-patch.
>
> +diff.context::
> + Generate diffs with <n> lines of context instead of the default of
> + 3. This value is overridden by the -U option.
> +
> diff.external::
> If this config variable is set, diff generation is not
> performed using the internal diff machinery, but using the
> diff --git a/diff.c b/diff.c
> index 35d3f07..86e5f2a 100644
> --- a/diff.c
> +++ b/diff.c
> @@ -26,6 +26,7 @@ static int diff_detect_rename_default;
> static int diff_rename_limit_default = 400;
> static int diff_suppress_blank_empty;
> static int diff_use_color_default = -1;
> +static int diff_context_default = 3;
> static const char *diff_word_regex_cfg;
> static const char *external_diff_cmd_cfg;
> int diff_auto_refresh_index = 1;
> @@ -141,6 +142,12 @@ int git_diff_ui_config(const char *var, const char *value, void *cb)
> diff_use_color_default = git_config_colorbool(var, value);
> return 0;
> }
> + if (!strcmp(var, "diff.context")) {
> + diff_context_default = git_config_int(var, value);
> + if (diff_context_default < 0)
> + return -1;
> + return 0;
> + }
> if (!strcmp(var, "diff.renames")) {
> diff_detect_rename_default = git_config_rename(var, value);
> return 0;
> @@ -3170,7 +3177,7 @@ void diff_setup(struct diff_options *options)
> options->break_opt = -1;
> options->rename_limit = -1;
> options->dirstat_permille = diff_dirstat_permille_default;
> - options->context = 3;
> + options->context = diff_context_default;
> DIFF_OPT_SET(options, RENAME_EMPTY);
>
> options->change = diff_change;
Thanks; looks sensible.
> diff --git a/t/t4060-diff-context.sh b/t/t4060-diff-context.sh
> new file mode 100755
> index 0000000..76fa3c3
> --- /dev/null
> +++ b/t/t4060-diff-context.sh
> @@ -0,0 +1,127 @@
> +#!/bin/sh
> +#
> +# Copyright (c) 2012 Mozilla Foundation
> +#
> +
> +test_description='diff.context configuration'
> +
> +. ./test-lib.sh
> +
> +cat << EOF > x
> +firstline
> +b
> +c
> +d
> +e
> +f
> +preline
> +postline
> +i
> +j
> +k
> +l
> +m
> +n
> +EOF
I know ancient tests are written like this, but we are slowly trying
to migrate them to have these test-vector preparation inside
test_expect_success block, e.g.
test_expect_success setup '
cat >x <<-\EOF &&
firstline
b
...
n
EOF
git add x &&
git commit -m initial
'
> +test_expect_success 'diff.context affects log' '
> + git log -1 -p | grep -q -v firstline
> + git config diff.context 8 &&
> + git log -1 -p | grep -q firstline
> +'
Three points:
- Please avoid "grep -q", which does not help people who ran tests
(the output is hidden by default) and hurts people who want to
debug tests.
- Your test will ignore breakage from the first "log 1" output and
goes on running "git config". Make sure you got your && cascades
right.
- Because an error from the command on the upstream side of the
pipe is ignored, we tend to prefer writing things like this:
git log -n 1 -p >output &&
grep -v firstline output &&
...
> +cat > .git/config << EOF
> +[diff]
> + context = no
> +EOF
> +test_expect_success 'config parsing' '
> + git diff 2>&1 | grep -q "bad config value"
> +'
How does the "git diff" command exit? That is far more important
than the actual error message, but being on the left side of the
pipe, the exit status from the command is not being tested.
next prev parent reply other threads:[~2012-09-27 17:40 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-09-14 18:16 [PATCH] Add diff.context option to specify default context Jeff Muizelaar
2012-09-14 21:06 ` Junio C Hamano
2012-09-27 15:04 ` [PATCH] diff: diff.context configuration gives default to -U Jeff Muizelaar
2012-09-27 17:40 ` Junio C Hamano [this message]
2012-09-27 18:43 ` Jeff King
2012-09-27 19:12 ` Jeff Muizelaar
2012-09-27 22:18 ` Junio C Hamano
2012-10-19 20:54 ` Jeff Muizelaar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=7vr4pnqs8l.fsf@alter.siamese.dyndns.org \
--to=gitster@pobox.com \
--cc=git@vger.kernel.org \
--cc=jmuizelaar@mozilla.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).