1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-30 04:39:00 +01:00
Go to file
2018-04-09 16:45:54 -04:00
assets/config_levels Refine 4,5 and 6 defaults 2018-03-20 23:06:17 -04:00
bin Analyse scoped build with Psalm 2018-03-18 10:52:54 -04:00
docs Fix #654 - warn about MixedArgument when inferredType property does not exist 2018-04-07 15:16:46 -04:00
examples Don’t get statements from cache if file hasn’t changed 2018-02-19 11:53:30 -05:00
src Fix display of closure objects 2018-04-09 16:45:54 -04:00
tests Fix display of closure objects 2018-04-09 16:45:54 -04:00
.editorconfig
.gitignore Remove lockfile because it’s wholly unnecessary 2018-01-02 20:44:10 -05:00
.php_cs.dist Fix formatting in examples 2018-01-18 17:41:14 -05:00
.scrutinizer.yml Ignore useless dirs 2018-02-03 20:08:14 -05:00
.travis.yml Disable coveralls on all but the PHP 7.2 build 2018-01-29 01:09:09 -05:00
box.json.dist Remove compression 2018-03-21 12:42:22 -04:00
CODE_OF_CONDUCT.md Add code of conduct 2017-12-31 16:53:56 -05:00
composer.json Bump composer version of package-versions 2018-03-26 23:43:54 -04:00
config.xsd Add more refined treatment of InvalidIterator 2018-03-20 22:59:22 -04:00
CONTRIBUTING.md Add reference to how Psalm works overview 2018-01-14 15:35:52 -05:00
LICENSE
NEWS.md Add news.md 2018-02-22 13:46:26 -05:00
phpcs.xml Fix formatting in examples 2018-01-18 17:41:14 -05:00
phpunit.xml.dist Allow tests to not test anything 2018-01-22 00:27:22 -05:00
psalm Move Psalm execution code into PHP file that Psalm can analyse 2017-12-29 17:02:56 -05:00
psalm.xml Add support for callable(...) syntax 2018-03-26 22:13:10 -04:00
PsalmLogo.png
psalter Break file manipulation out into Psalter 2018-01-07 17:25:23 -05:00
README.md Fix singular noun 2018-03-18 09:08:32 -04:00
scoper.inc.php Analyse scoped build with Psalm 2018-03-18 10:52:54 -04:00

logo

Packagist Packagist Travis CI Coverage Status

Psalm is a static analysis tool for finding errors in PHP applications, built on top of PHP Parser.

It's able to find a large number issues, but it can also be configured to only care about a small subset of those.

Try a live demo, or install it in your project by following the Quickstart Guide below.

Psalm documentation

All the documentation for Psalm is found in the docs folder - the index is located here,

Quickstart Guide

Install via Composer:

composer require --dev vimeo/psalm

Add a config:

./vendor/bin/psalm --init

Then run Psalm:

./vendor/bin/psalm

The config created above will show you all issues in your code, but will emit INFO issues (as opposed to ERROR) for certain common trivial code problems. If you want a more lenient config you can specify the level with

./vendor/bin/psalm --init [source_dir] [level]

You can also learn how to suppress certain issues.

How Psalm Works

A basic rundown of Psalms internals can be found in docs/how_psalm_works.md.

Acknowledgements

The engineering team @vimeo for encouragement and patience, especially @nbeliard, @erunion and @nickyr.