ovr / phpsa
PHPSA aims to bring complex static analysis for PHP applications and libraries.
Installs: 16 170
Dependents: 4
Suggesters: 0
Security: 0
Stars: 651
Watchers: 33
Forks: 46
Open Issues: 62
Type:util
Requires
- php: >=5.5
- nikic/php-parser: ^2.1
- ovr/phpreflection: ^0.3.1
- phpdocumentor/reflection-docblock: ^3.0
- phpdocumentor/type-resolver: ^0.2
- regex-guard/regex-guard: ^1.1
- symfony/config: ^3.0.5
- symfony/console: ^3.0.5
- symfony/event-dispatcher: ^3.0.5
- symfony/yaml: ^3.0.5
- webiny/event-manager: ^1.4.1
Requires (Dev)
- phpunit/phpunit: ^4.8.26
- squizlabs/php_codesniffer: ^2.6
- symfony/var-dumper: ^3.1
This package is auto-updated.
Last update: 2020-09-28 21:59:03 UTC
README
PHPSA - Smart Analyzer for PHP
PHPSA is a development tool aimed at bringing complex analysis for PHP applications and libraries.
P.S This software is currently in early alpha state, any contributions/stars will be awesome.
Components
- Core - Component containing definitions and other core files
- Compiler - Component to compile expression(s) and statement(s) from an abstract syntax tree
- Analyzer - Component doing various checks on your files
- ControlFlow - Component for ControlFlow (WIP)
Installation (more)
The recommended way to install phpsa is via Composer.
Run php composer.phar require ovr/phpsa
or add a new requirement in your composer.json.
{ "require": { "ovr/phpsa": "*" } }
How to use (more)
$ ./bin/phpsa check fixtures/ Syntax error: Syntax error, unexpected T_RETURN on line 11 in fixtures/simple/syntax/Error2.php $b = $a + 1; 123123 Notice: Constant BBBB does not exist in self scope in fixtures/simple/undefined/Const.php on 29 [undefined-const] return self::BBBB; Notice: You are trying to cast 'string' to 'string' in fixtures/simple/code-smell/StandardFunctionCall.php on 16 [stupid.cast] return (string) json_encode(array( Notice: Missing docblock for callStaticMethodBySelf() method in fixtures/Compiling/Expression/StaticCall.php on 18 [missing-docblock] public static function callStaticMethodBySelf()
Requirements
PHP >= 7.0, but you can check files that use PHP >= 5.2 with this.
Documentation
See our documentation in case you need more information on some topic.
Contributing
Check our Contributing Guide to see how you can help.
Sponsors
Thanks to our sponsors and supporters:
JetBrains |
---|
LICENSE
This project is open-sourced software licensed under the MIT License.
See the LICENSE file for more information.