Page MenuHomePhabricator

Add a linter rule to detect implict method visibility
ClosedPublic

Authored by joshuaspence on Oct 12 2014, 12:29 PM.
Tags
None
Referenced Files
F14776245: D10687.id27043.diff
Fri, Jan 24, 3:55 AM
Unknown Object (File)
Thu, Jan 23, 5:33 PM
Unknown Object (File)
Thu, Jan 23, 5:32 PM
Unknown Object (File)
Thu, Jan 23, 5:32 PM
Unknown Object (File)
Thu, Jan 23, 5:32 PM
Unknown Object (File)
Thu, Jan 23, 5:32 PM
Unknown Object (File)
Thu, Jan 23, 5:32 PM
Unknown Object (File)
Thu, Jan 23, 5:12 AM

Details

Summary

I'm not sure whether this is in any coding standards, but it seems to be an unspoken rule that methods should have a visiblity modifier (public, protected or private) explicitly specified. According to the PHP documentation, methods declared without any explicit visibility keyword are defined as public.

Test Plan

Added a test case.

Diff Detail

Repository
rARC Arcanist
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

joshuaspence retitled this revision from to Add a linter rule to detect implict method visibility.
joshuaspence updated this object.
joshuaspence edited the test plan for this revision. (Show Details)
joshuaspence added a reviewer: epriestley.

I think the unit test is not working as expected because of a bug in XHPAST. See https://secure.phabricator.com/xhpast/view/621/ for an example. It seems that in public function bar() {}, T_FUNCTION belongs to n_METHOD_DECLARATION but in function baz() {} this is not the case.

joshuaspence edited edge metadata.

Handle properties as well

epriestley edited edge metadata.
This revision is now accepted and ready to land.Jan 4 2015, 11:27 PM

This doesn't actually work yet :P

I need to make some changes to XHPAST I think :(

joshuaspence edited edge metadata.

Working now (after D11215)

This revision was automatically updated to reflect the committed changes.
richardvanvelzen added inline comments.
src/lint/linter/ArcanistXHPASTLinter.php
3014

Shouldn't abstract or static methods have an explicit visibility?