Page MenuHomePhabricator

Allow linters to share resources by shoving them on the Engine
ClosedPublic

Authored by epriestley on May 11 2014, 11:58 PM.
Tags
None
Referenced Files
F14744425: D9059.diff
Tue, Jan 21, 9:03 AM
Unknown Object (File)
Mon, Jan 20, 4:21 PM
Unknown Object (File)
Mon, Jan 20, 3:13 AM
Unknown Object (File)
Sat, Jan 18, 3:49 AM
Unknown Object (File)
Tue, Jan 14, 4:04 PM
Unknown Object (File)
Tue, Jan 14, 1:00 PM
Unknown Object (File)
Wed, Jan 8, 3:43 PM
Unknown Object (File)
Sat, Dec 28, 2:35 AM
Subscribers

Details

Summary

Currently, the Phutil XHPAST Linter and vanilla XHPAST Linter reuse the same parse tree, but do this by having explicit knowledge of one another.

Instead, let them synchronize by writing to a glorified array of globals on the Engine. They no longer require knowledge of one another, so this can work under .arclint.

(This could probably be a little cleaner by putting more logic in the shared base class, but Facebook has some kind of goofy subclass of this thing and this patch won't disrupt it, while a cleaner one might.)

This should unblock D9057.

Test Plan

Ran unit tests and normal lint, got accurate looking results without duplicate invocations showing up in --trace.

Diff Detail

Repository
rARC Arcanist
Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

epriestley retitled this revision from to Allow linters to share resources by shoving them on the Engine.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added reviewers: joshuaspence, btrahan.
  • Explicitly force the Phutil linter to run after the main linter so the parse trees are always reused.
joshuaspence edited edge metadata.

Some minor inlines.

src/lint/linter/ArcanistPhutilXHPASTLinter.php
12–13

It would almost be nice if this method was static, in which case we could do 2 * ArcanistXHPASTLinter::getLinterPriority().

Maybe (just in case) we should add a unit test which checks that ArcanistPhutilXHPASTLinter has a larger (numerically) priority than ArcanistXHPASTLinter.

62

Maybe check that $linter is an instance of ArcanistXHPASTLinter? Just in case...

This revision now requires changes to proceed.May 12 2014, 12:23 AM

I'll see if I can restructure this so the linters are order-independent without affecting hypothetical Facebook subclasses.

src/lint/linter/ArcanistPhutilXHPASTLinter.php
12–13

We can't make this static until late static binding, introduced in PHP 5.3.0.

epriestley edited edge metadata.
  • Allow subclasses to coordinate regardless of order.
joshuaspence edited edge metadata.

This looks much better.

This revision is now accepted and ready to land.May 12 2014, 2:13 AM
epriestley updated this revision to Diff 21517.

Closed by commit rARC86cbcb9f564b (authored by @epriestley).