mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-11-09 00:12:40 +01:00
2ad15c499a
Summary: Fixes T11744. Because intraline diffs are expensive to generate, we already bail out and decline to generate them for very long lines. However, we currently split the inputs into lists of characters first, then check how long they are and make a decision to bail. For //huge// inputs (e.g., 1MB+), this is too late: just splitting them has a large CPU/RAM cost. (These inputs are rare in normal source, but can appear in, e.g., JSON files written without newlines.) Instead, add an extra "are the inputs really huge?" check first, and bail early if they are. Test Plan: - Generated a 1MB "change a file full of Q to a file full of R" diff. - Before change: purged changeset cache; took about 7 seconds to load. - After change: purged changeset cache; took about 1 second to load. - Viewed some normal diffs to make sure intraline edits still displayed correctly. Reviewers: chad Reviewed By: chad Maniphest Tasks: T11744 Differential Revision: https://secure.phabricator.com/D16683 |
||
---|---|---|
.. | ||
__tests__ | ||
configuration | ||
difference | ||
differential | ||
docs/book | ||
events/constant | ||
exception | ||
extensions | ||
hgdaemon | ||
internationalization | ||
land | ||
lint | ||
parser | ||
repository | ||
unit | ||
upload | ||
workflow | ||
workingcopyidentity | ||
__phutil_library_init__.php | ||
__phutil_library_map__.php |