Page MenuHomePhabricator

Add a linter rule for `parent` references
ClosedPublic

Authored by joshuaspence on Nov 9 2015, 12:59 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Dec 19, 2:24 AM
Unknown Object (File)
Tue, Dec 17, 8:13 AM
Unknown Object (File)
Sat, Dec 14, 4:09 AM
Unknown Object (File)
Dec 8 2024, 10:20 AM
Unknown Object (File)
Dec 5 2024, 3:24 AM
Unknown Object (File)
Nov 25 2024, 8:24 PM
Unknown Object (File)
Nov 25 2024, 4:47 AM
Unknown Object (File)
Nov 21 2024, 5:52 AM
Subscribers

Details

Summary

Add a linter rule to detect static method calls which should reference the parent class instead of a hardcoded class reference. For example, consider the following:

class SomeClass extends AnotherClass {
  public function someMethod() {
    AnotherClass::someOtherMethod();
  }
}

This should instead be written as:

class SomeClass extends AnotherClass {
  public function someMethod() {
    parent::someOtherMethod();
  }
}
Test Plan

Added unit tests.

Diff Detail

Repository
rARC Arcanist
Branch
master
Lint
Lint Passed
Unit
Test Failures
Build Status
Buildable 8863
Build 10363: Run Core Tests
Build 10362: arc lint + arc unit

Event Timeline

joshuaspence retitled this revision from to Add a linter rule for `parent` references.
joshuaspence updated this object.
joshuaspence edited the test plan for this revision. (Show Details)
joshuaspence edited the test plan for this revision. (Show Details)
epriestley added a reviewer: epriestley.
epriestley added inline comments.
src/lint/linter/xhpast/rules/ArcanistParentMemberReferenceXHPASTLinterRule.php
63

Extra period in human-readable message.

This revision is now accepted and ready to land.Nov 15 2015, 4:52 PM
joshuaspence edited edge metadata.

Fix lint message

This revision was automatically updated to reflect the committed changes.