From a useless Git Diff to a useful one
Imagine you have a file with 500 lines of code and you changed the indentation from tabs to spaces in more than 200 lines and besides that you changed the feature. Doing a normal git diff it will be useless because you will get a lot of diffs from the indentation changes.
But there is a way to make it useful, you just need to add some options to the git diff command and you are done:
Git version <= 1.8.3.4:
git diff --ignore-space-at-eol -b -w [commit] ...
Git version >= 1.8.4:
git diff --ignore-space-at-eol -b -w --ignore-blank-lines [commit] ...
See the options definition below:
--ignore-space-at-eol
Ignore changes in whitespace at EOL.
-b
--ignore-space-change
Ignore changes in amount of whitespace. This ignores whitespace at line end, and considers all other sequences of one or more whitespace characters to be equivalent.
-w
--ignore-all-space
Ignore whitespace when comparing lines. This ignores differences even if one line has whitespace where the other line has none.
[git version 1.8.4+]--ignore-blank-lines
Ignore changes whose lines are all blank.
Written by Daniel Gomes
Related protips
11 Responses
data:image/s3,"s3://crabby-images/32c2c/32c2cbae6e1e79b51b93c19a6138b84eb579ac92" alt=""
Great tip! Although --ignore-blank-lines
throws an error and I can't find it in the git spec?
error: invalid option: --ignore-blank-lines
Edit: It appears my git version is not up to date! (also just seen @danielcsgomes reply!)
data:image/s3,"s3://crabby-images/fd55c/fd55c81c0a9f9e5157c56e988c896e996fbdf045" alt=""
The --ignore-blank-lines option is only available on Git version 1.8.4.
data:image/s3,"s3://crabby-images/71afd/71afd735ae6ef6f361a9f3e71865fdfccfa9c7c8" alt=""
Every time you commit trailing spaces a panda dies. =(
data:image/s3,"s3://crabby-images/02121/02121e0c85251f2ad631867f54258bd434dad8e3" alt=""
Is -w
a particularly good idea? Wouldn't it silently treat doSomething(withThis)
and do Something(with This)
as equivalent?
data:image/s3,"s3://crabby-images/7469d/7469daa7a0b48a7d5e842a2de97f21e15c379983" alt=""
I don't think I'd use this approach with python code...
data:image/s3,"s3://crabby-images/3f436/3f436d0ec8d2801901ab59223577c2e977bf5539" alt=""
This is wrong! if you ever, EVER, change indentation or trim a file, it should be ALWAYS on a separate commit.
- change ONLY white space. (stash anything else)
- run a diff with -b (or add all those fancy options) and see if it shows no changes.
- commit with comment "whitespace"
- push.
- continue with your work.
(edit: this was a numbered list, but the site changed it to bullet points.... )
data:image/s3,"s3://crabby-images/fd55c/fd55c81c0a9f9e5157c56e988c896e996fbdf045" alt=""
@gcb this pro-tip is just about the git diff, not a strategy on how to commit/push this kind of situation. If that was the case the best approach IMO is the one you mentioned ;)
data:image/s3,"s3://crabby-images/fd55c/fd55c81c0a9f9e5157c56e988c896e996fbdf045" alt=""
@alecb I guess it will depend on your purpose and situation and of course this is not a straight command, you should mix the options depending on your needs!
data:image/s3,"s3://crabby-images/d6061/d60615e6f01596c5b680e02a3484697b0d375e6d" alt=""
data:image/s3,"s3://crabby-images/02121/02121e0c85251f2ad631867f54258bd434dad8e3" alt=""
@joshribakoff Tested it, and it seems to do just that:
$ git diff
diff --git a/file b/file
index 5271a52..f5ac887 100644
--- a/file
+++ b/file
@@ -1 +1 @@
-test123
+test 123
(END)
$ git diff -w
(END)
data:image/s3,"s3://crabby-images/ecd11/ecd1147fd5604342f2953ed91c0ef12e55157c0f" alt=""
The options do not make sense to me:
- -b is synonymous to --ignore-space-change
- -w is synonymous to --ignore-all-space
If I understand the official documentation at http://git-scm.com/docs/git-diff correctly, -b should be a superset of --ignore-space-at-eol and -w in turn is a superset of -b. In that case, the command git diff --ignore-space-at-eol -b -w [commit] ...
would be equivalent to simply git diff -w [commit] ...
. And I agree with @alecb that -w is a bad idea. Also untested, but I do understand the documentation such that it would regard "test123" and "test 123" as equivalent.
Have a fresh tip? Share with Coderwall community!
data:image/s3,"s3://crabby-images/fd55c/fd55c81c0a9f9e5157c56e988c896e996fbdf045" alt=""