Php Inspections (EA Extended)

Compatible with: IntelliJ IDEA PhpStorm
May 06, 2018
294 192
For support and donations please visit Github | Issues | PayPal | Patreon.

Please follow me at twitter for status updates.

This plugin is a Static Code Analysis tool for PHP (aka inspections in JetBrains products).

It covers:
- architecture related issues
- weak types control and possible code construct simplifications
- performance issues
- non-optimal, duplicate and suspicious "if" conditions
- validation of magic methods usage
- regular expressions
- validation of exception handling workflow
- compatibility issues
- variety of time-consuming bugs
- PhpUnit API usage
- security issues

Some of inspections are expecting conditional statements (e.g. "if") to use group statement for wrapping body expressions. If this requirement is met then additional inspections are applied to the source code.

For Mac shortcuts, see this reference card. Windows/Linux ones are:
Alt + Shift + I to inspect current file with current profile
Ctrl + Alt + Shift + I to run inspection by name
Ctrl + Shift + F4 to close results of inspection.

On some projects CPU and therefore battery usage could be intensive, so it should be taken into account when traveling with a laptop.

Note: we are sending anonymous crash-reports and installation statistics to Google Analytics. You are welcome to review the implementation.

Download plugin

Recent change notes

Features release. Supporters via Patreon are wanted.

- Worked out crash-reports for April
- Introduced privacy settings (File -> Settings -> Other Settings -> Php Inspections (EA Extended))

- Strings normalization: resolved a false-positive (trim characters provided)
- Suspicious assignments: resolved a false-positive (.=)
- Traits properties conflicts resolution: resolved a false-positive (phpdoc)
- Unnecessary parentheses: resolved false-positives (yield)

- PhpUnit: methods mocking issues: implemented
- Unnecessary closures: implemented
- Unsupported string offset operations: new cases
- 'isset(...)' constructs can be merged: implemented