Page MenuHomePhabricator

Lift class map construction into a new class map query
ClosedPublic

Authored by epriestley on Jun 22 2015, 4:44 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 15, 5:31 AM
Unknown Object (File)
Fri, Jan 3, 8:26 PM
Unknown Object (File)
Tue, Dec 31, 9:40 PM
Unknown Object (File)
Mon, Dec 30, 12:20 AM
Unknown Object (File)
Sun, Dec 22, 5:58 PM
Unknown Object (File)
Dec 8 2024, 11:47 AM
Unknown Object (File)
Dec 3 2024, 12:31 PM
Unknown Object (File)
Nov 27 2024, 10:39 PM
Subscribers

Details

Summary

Ref T8637. The "load concrete subclasses" pattern has enjoyed wide success, but we're starting to collect a lot of instances of "loop over this list of things and make sure they all really have unique keys".

We can better support this, caching, subclass expansion, and sorting in a thin layer on top of PhutilSymbolLoader.

Test Plan

See next diff.

Diff Detail

Repository
rPHU libphutil
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Lift class map construction into a new class map query.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added reviewers: btrahan, joshuaspence.
btrahan edited edge metadata.
This revision is now accepted and ready to land.Jun 22 2015, 9:11 PM
joshuaspence edited edge metadata.

This should maybe have some unit tests?

src/symbols/PhutilClassMapQuery.php
5

There's no technical reason that the parent class needs to be abstract, although that is the normal use case.

96–98

Add ```lang=php?

103–109

As above

I think we should definitely get code blocks inside source code documentation defaulting to their source file language per T5323 as a solution for the lang=php thing.

This revision was automatically updated to reflect the committed changes.

I also don't see an easy way to unit test this without building two (three? four?) separate class trees for each major case. I figure failures should be pretty obvious from usage and other getAll() tests.