1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-26 20:34:47 +01:00
Go to file
2019-11-06 13:13:02 -05:00
.circleci Add PHPUnit back 2019-09-14 15:49:01 -04:00
assets
bin Bump release 2019-09-14 15:50:21 -04:00
build/phpunit
docs Add support for Iterator<X> type (#2285) 2019-10-30 18:00:27 +00:00
examples
src Fix #2309 - prevent closure-inferred generic template params overwriting parent ones 2019-11-06 13:13:02 -05:00
tests Fix #2309 - prevent closure-inferred generic template params overwriting parent ones 2019-11-06 13:13:02 -05:00
vendor-bin/box
.appveyor.yml Ignore PHP 7.1 & PHP 7.2 on Windows 2019-08-21 14:04:59 -04:00
.editorconfig
.gitattributes
.gitignore
.php_cs.dist
.scrutinizer.yml
.travis.yml symfony/process:^4.3 requires php:^7.1.3, adjust dependency constraint to prevent install on < 7.1.3 (#2141) 2019-09-18 15:03:12 -04:00
box.json.dist
CHANGELOG.md
CODE_OF_CONDUCT.md
composer.json symfony/process:^4.3 requires php:^7.1.3, adjust dependency constraint to prevent install on < 7.1.3 (#2141) 2019-09-18 15:03:12 -04:00
config.xsd docs: change boolean flags to be xs:boolean (instead of xs:string) (#2274) 2019-10-25 16:07:52 +02:00
CONTRIBUTING.md
infection.json.dist
keys.asc.gpg
LICENSE
NEWS.md
phpcs.xml Refactor template calculation out from Psalm\Type\Union 2019-11-03 21:27:40 -05:00
phpunit.xml.dist
psalm
psalm-language-server
psalm-plugin
psalm-refactor
psalm.xml.dist Ignore offset errors again 2019-10-21 07:15:46 -04:00
PsalmLogo.png New and improved logo 2017-01-16 17:24:26 -05:00
psalter
README.md
scoper.inc.php

logo

Packagist Packagist Travis CI Coverage Status Psalm coverage

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.