Page MenuHomePhabricator

Improve the performance of tab replacement in common cases
ClosedPublic

Authored by epriestley on Apr 25 2019, 9:38 PM.
Tags
None
Referenced Files
F15472898: D20477.diff
Sat, Apr 5, 5:24 PM
F15457257: D20477.diff
Sun, Mar 30, 3:17 PM
F15427707: D20477.diff
Sun, Mar 23, 3:43 PM
F15415488: D20477.id48849.diff
Thu, Mar 20, 6:13 AM
F15385022: D20477.id.diff
Fri, Mar 14, 9:28 PM
Unknown Object (File)
Feb 27 2025, 3:01 PM
Unknown Object (File)
Feb 16 2025, 2:13 AM
Unknown Object (File)
Feb 14 2025, 10:53 PM
Subscribers
None

Details

Summary

See PHI1210. For certain large inputs, we spend more time than we need to replacing tabs with spaces. Add some fast paths:

  • When a line only has tabs at the beginning of the line, we don't need to do as much work parsing the rest of the line.
  • When a line has no unicode characters, we don't need to vectorize it to get the right result.
Test Plan
  • Added test coverage.
  • Profiled this, got a ~60x performance increase on a 36,000 line 3MB text file.

Diff Detail

Repository
rP Phabricator
Branch
tabs1
Lint
Lint Passed
SeverityLocationCodeMessage
Advicesrc/applications/differential/parser/DifferentialChangesetParser.php:1459XHP16TODO Comment
Unit
Tests Passed
Build Status
Buildable 22724
Build 31150: Run Core Tests
Build 31149: arc lint + arc unit