Home GnuPG

Improve UTF8StringTruncator behavior for huge inputs
fe7d8c21a808Unpublished

Unpublished Commit ยท Learn More

Repository Importing: This repository is still importing.

Description

Improve UTF8StringTruncator behavior for huge inputs

Summary:
Fixes T9632. Currently, when you truncate a very big input (like a huge paste) into a very small output (like a snippet of that paste), it can take a long time. The amount of work we do is proportional to the size of the input.

Reorganize some of the UTF8 code so we can do less work, and only examine about as much of the input as we can possibly need to look at in order to generate the desired output.

Test Plan:

  • This code is well-covered by unit tests.
  • Added a new unit test which ran in ~4s before the change and runs in ~2ms afterward on my machine (2000x).
  • Created a huge paste, viewed from web UI.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T9632

Differential Revision: https://secure.phabricator.com/D14339

Details

Provenance
epriestley <git@epriestley.com>Authored on Oct 26 2015, 5:49 PM
Parents
rPHUTILdb3667a62f66: Add an upstream JSON fragment lexer
Branches
Unknown
Tags
Unknown

Event Timeline

epriestley <git@epriestley.com> committed rPHUTILfe7d8c21a808: Improve UTF8StringTruncator behavior for huge inputs (authored by epriestley <git@epriestley.com>).Oct 26 2015, 5:49 PM