Page MenuHomePhabricator

In Git, only use "--find-copies-harder" on small diffs
ClosedPublic

Authored by epriestley on Jul 10 2016, 2:29 PM.
Tags
None
Referenced Files
F14763146: D16266.diff
Thu, Jan 23, 9:38 AM
Unknown Object (File)
Tue, Jan 21, 9:22 AM
Unknown Object (File)
Fri, Jan 17, 7:25 PM
Unknown Object (File)
Wed, Jan 1, 8:40 PM
Unknown Object (File)
Tue, Dec 31, 10:10 PM
Unknown Object (File)
Dec 15 2024, 5:55 PM
Unknown Object (File)
Dec 15 2024, 5:24 AM
Unknown Object (File)
Dec 10 2024, 4:51 PM
Subscribers
None

Details

Summary

Ref T10423. This flag can cause git diff to take an enormously long time (the problem case was a 5M line, 20K file commit).

Instead:

  • Run without the flag first.
  • If that shows that the diff is definitely small, try again with the flag.
  • If that works, return the slower, better output.
  • If the fast diff affects too many paths or generating the slow diff takes too long, return the faster, slightly worse output.

The quality of the output differs in how well Git is able to detect "M" and "C" (moves and copies of files).

For example, if you copy src/ to srcpro/, the fast output may not show that you copied files. The slow output will.

I think this is rarely useful for large copies anyway: it's interesting if a 1-2 file diff is a copy, but usually obvious/uninteresting if a 500-file diff is a copy.

Test Plan
  • Ran bin/repository reparse --change rXnnn on Git changes.
  • Saw fast and slow commands execute normally.
  • Tried on a large diff, saw only the fast command execute.

Diff Detail

Repository
rP Phabricator
Branch
fastcopies
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 13008
Build 16619: Run Core Tests
Build 16618: arc lint + arc unit

Event Timeline

epriestley retitled this revision from to In Git, only use "--find-copies-harder" on small diffs.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: chad.
chad edited edge metadata.
This revision is now accepted and ready to land.Jul 10 2016, 2:40 PM
This revision was automatically updated to reflect the committed changes.