]> git.ipfire.org Git - thirdparty/git.git/commit - diff.c
diff: add -I<regex> that ignores matching changes
authorMichał Kępień <michal@isc.org>
Tue, 20 Oct 2020 06:48:09 +0000 (08:48 +0200)
committerJunio C Hamano <gitster@pobox.com>
Tue, 20 Oct 2020 19:53:26 +0000 (12:53 -0700)
commit296d4a94e7231a1d57356889f51bff57a1a3c5a1
tree85fa1fa7d7ed82a83298e1c5a26071015e175684
parentec7967cfafd5844e33afbc1e6fb8ba1b9e5b111b
diff: add -I<regex> that ignores matching changes

Add a new diff option that enables ignoring changes whose all lines
(changed, removed, and added) match a given regular expression.  This is
similar to the -I/--ignore-matching-lines option in standalone diff
utilities and can be used e.g. to ignore changes which only affect code
comments or to look for unrelated changes in commits containing a large
number of automatically applied modifications (e.g. a tree-wide string
replacement).  The difference between -G/-S and the new -I option is
that the latter filters output on a per-change basis.

Use the 'ignore' field of xdchange_t for marking a change as ignored or
not.  Since the same field is used by --ignore-blank-lines, identical
hunk emitting rules apply for --ignore-blank-lines and -I.  These two
options can also be used together in the same git invocation (they are
complementary to each other).

Rename xdl_mark_ignorable() to xdl_mark_ignorable_lines(), to indicate
that it is logically a "sibling" of xdl_mark_ignorable_regex() rather
than its "parent".

Signed-off-by: Michał Kępień <michal@isc.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Documentation/diff-options.txt
diff.c
diff.h
t/t4013-diff-various.sh
t/t4013/diff.log_-IA_-IB_-I1_-I2_-p_master [new file with mode: 0644]
xdiff/xdiff.h
xdiff/xdiffi.c