1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-30 04:39:00 +01:00
Go to file
2018-10-15 17:41:10 -04:00
assets/config_levels Add support for checking DeprecatedTrait and DeprecatedConstant 2018-08-10 13:25:25 -04:00
bin Multi-stage builds (#928) 2018-08-02 00:44:15 -04:00
docs ADD extra documentation about psalm-assert 2018-10-11 15:54:37 -04:00
examples Treat required files the same as the files that require them, reporting-wise 2018-05-30 16:19:18 -04:00
src Add alarms for recalcitrant processes 2018-10-15 17:41:10 -04:00
tests Skip test broken by new scanning system 2018-10-15 09:16:11 -04:00
vendor-bin/box Bump Box 2018-10-08 10:18:54 -04:00
.editorconfig
.gitignore Ignore .ds_store 2018-05-19 18:57:14 -04:00
.php_cs.dist Fix formatting in examples 2018-01-18 17:41:14 -05:00
.scrutinizer.yml Attempt to fix builds on scrutinizer-ci (#788) 2018-06-01 09:38:10 -04:00
.travis.yml Add secure github token 2018-08-07 13:54:02 -04:00
box.json.dist Bump Box 2018-10-08 10:18:54 -04:00
CHANGELOG.md Solidify changes to V2 2018-05-11 18:45:19 -04:00
CODE_OF_CONDUCT.md Add code of conduct 2017-12-31 16:53:56 -05:00
composer.json Bump XDebugHandler version 2018-07-17 15:24:20 -04:00
config.xsd Improve file hash reloading 2018-10-15 11:34:51 -04:00
CONTRIBUTING.md Add reference to how Psalm works overview 2018-01-14 15:35:52 -05:00
LICENSE
NEWS.md Prepare v2 dev release 2018-04-19 17:29:07 -04:00
phpcs.xml Resolve as many names as possible in the parsing stage 2018-07-12 21:25:06 -04:00
phpunit.xml.dist Test issue position adjustment 2018-09-30 11:34:51 -04:00
psalm Move Psalm execution code into PHP file that Psalm can analyse 2017-12-29 17:02:56 -05:00
psalm.xml.dist Add way of getting changes in a given file 2018-09-30 11:34:51 -04:00
PsalmLogo.png
psalter Break file manipulation out into Psalter 2018-01-07 17:25:23 -05:00
README.md README Typo: missing word (#956) 2018-08-25 11:30:31 -04:00
scoper.inc.php Fix #748 - correct paths that stopped working 2018-05-30 07:21:34 -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 of 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

Documentation is available on Psalms website, generated from the docs folder.

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.