Page MenuHomePhabricator

When generating diffs in "arc diff", disable Git config option "diff.suppressBlankEmpty"
ClosedPublic

Authored by epriestley on Oct 29 2019, 5:12 PM.
Tags
None
Referenced Files
F18752260: D20877.id.diff
Sat, Oct 4, 2:40 PM
F18734090: D20877.id.diff
Tue, Sep 30, 10:48 PM
F18705654: D20877.diff
Sun, Sep 28, 12:23 PM
F18678949: D20877.diff
Thu, Sep 25, 11:56 PM
F18571028: D20877.id49772.diff
Sep 10 2025, 4:18 AM
F18571026: D20877.id49771.diff
Sep 10 2025, 4:18 AM
F18567499: D20877.id.diff
Sep 9 2025, 3:50 PM
F18100779: D20877.diff
Aug 9 2025, 12:04 PM
Subscribers
None

Details

Summary

Ref T13432. Git has a "diff.suppressBlankEmpty" config option which makes it emit nonstandard diffs with trimmed trailing whitespace on unchanged blank lines.

Currently, we don't parse these diffs correctly. Even if we do in the future, emitting a more standard diff is desirable.

Explicitly disable this option when executing "git diff" so we build more standard diffs.

Test Plan
  • Configured this option.
  • Modified a file with a blank line in it without changing the blank line, got this goofy display diff:

Screen Shot 2019-10-29 at 10.09.14 AM.png (150×1 px, 21 KB)

  • Applied patch, rediffed the same change, saw "-c diff.suppressBlankEmpty" in "--trace" output and got this sensible diff:

Screen Shot 2019-10-29 at 10.09.28 AM.png (107×1 px, 17 KB)

Diff Detail

Repository
rARC Arcanist
Lint
Lint Not Applicable
Unit
Tests Not Applicable