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
Unknown Object (File)
Oct 20 2024, 4:02 PM
Unknown Object (File)
Oct 19 2024, 3:26 PM
Unknown Object (File)
Oct 15 2024, 2:50 AM
Unknown Object (File)
Oct 12 2024, 12:21 AM
Unknown Object (File)
Oct 5 2024, 8:22 AM
Unknown Object (File)
Oct 4 2024, 1:48 PM
Unknown Object (File)
Oct 2 2024, 4:02 AM
Unknown Object (File)
Sep 30 2024, 11:58 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
Lint
Lint Not Applicable
Unit
Tests Not Applicable