Page MenuHomePhabricator

Remove expensive, pointless typeachecking in custom fields
ClosedPublic

Authored by epriestley on Jul 31 2016, 4:33 PM.
Tags
None
Referenced Files
F14495267: D16354.diff
Fri, Jan 3, 8:16 AM
F14494234: D16354.diff
Fri, Jan 3, 4:56 AM
Unknown Object (File)
Sat, Dec 21, 1:30 AM
Unknown Object (File)
Tue, Dec 17, 12:14 PM
Unknown Object (File)
Tue, Dec 17, 11:07 AM
Unknown Object (File)
Sat, Dec 14, 8:43 AM
Unknown Object (File)
Tue, Dec 10, 7:09 AM
Unknown Object (File)
Sun, Dec 8, 12:25 PM
Subscribers
None

Details

Summary

Ref T11404. On my system, this improves performance by 10-15% for differential.revision.search.

PhutilTypeSpec provides high quality typechecking and is great for user-facing things that need good error messages.

However, it's also a bit slow, and pointless here (the API is internal and it only has one possible option).

I think I added this after writing checkMap just because I wanted to use it more often. My desire is sated after finding many reasonable ways to use it to give users high-quality error messages about things like configuration files.

Test Plan

Profiled differential.revision.search before and after change, saw wall time drop from ~220ms to ~195ms.

Diff Detail

Repository
rP Phabricator
Branch
cfield4
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 13204
Build 16914: Run Core Tests
Build 16913: arc lint + arc unit

Event Timeline

epriestley retitled this revision from to Remove expensive, pointless typeachecking in custom fields.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added reviewers: chad, yelirekim.
chad edited edge metadata.
This revision is now accepted and ready to land.Jul 31 2016, 4:34 PM
This revision was automatically updated to reflect the committed changes.