Page MenuHomePhabricator

Add trailing tabs when generating synthetic Git diffs for files with spaces
ClosedPublic

Authored by epriestley on Jan 16 2018, 4:26 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Dec 20, 7:53 PM
Unknown Object (File)
Fri, Dec 13, 9:19 PM
Unknown Object (File)
Tue, Dec 10, 4:09 PM
Unknown Object (File)
Mon, Dec 2, 9:05 AM
Unknown Object (File)
Wed, Nov 27, 10:40 PM
Unknown Object (File)
Tue, Nov 26, 7:12 AM
Unknown Object (File)
Nov 21 2024, 6:29 PM
Unknown Object (File)
Nov 19 2024, 1:44 AM
Subscribers
None

Details

Summary

Fixes T8768. See PHI294. See that task for more details.

Git, Mercurial, diff, and patch have conspired to make things weird. To correctly handle files with spaces in the way everything else does and expects, we need to emit semantic trailing whitespace literals.

Test Plan
  • Created a file with spaces in it in a Mercurial repositroy, committed it, diffed it into a revision.
  • Used arc patch to apply the change to a clean copy of the repository.
  • Before patch: Mercurial incorrectly creates a file named X, not a file named X Y.txt.
  • After patch: arc patch commit is identical to genuine commit.
  • Also added test coverage. The other general behaviors here are fairly well covered already.

Diff Detail

Repository
rARC Arcanist
Lint
Lint Not Applicable
Unit
Tests Not Applicable