1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-26 20:34:47 +01:00
Go to file
2019-05-26 14:22:28 -04:00
assets/config_levels Add ImplementedParamTypeMismatch issue 2019-05-14 15:44:46 -04:00
bin Set better permissions on Travis deploy script 2019-03-25 16:32:36 -04:00
docs Add a word 2019-05-21 23:06:50 -04:00
examples Split apart TypeCoercion issues, allowing more granular issue filtering 2019-04-25 18:02:19 -04:00
src class_esists check with false arg shouldn’t count 2019-05-26 13:16:44 -04:00
tests Skip broken test 2019-05-26 14:22:28 -04:00
vendor-bin/box Add --language-server support 2019-03-27 11:55:10 -04:00
.appveyor.yml loading in cacert.pem-related changes from 4b5b8208a3 as recommended by @muglug 2019-04-01 16:34:44 -04:00
.editorconfig
.gitattributes Add .gitattributes 2019-03-17 13:30:33 -04:00
.gitignore Remove ignored symlink 2019-05-23 22:31:54 -04:00
.php_cs.dist
.scrutinizer.yml
.travis.yml Bump to PHP 7.1 2019-05-16 18:36:36 -04:00
box.json.dist Revert "Reduce size of generated Phar" 2019-04-29 19:14:37 -04:00
CHANGELOG.md
CODE_OF_CONDUCT.md
composer.json Remove TSqlSelectString and related dependency 2019-05-20 23:14:41 -04:00
config.xsd Add separate issue for undefined classes in docblocks 2019-05-15 18:41:26 -04:00
CONTRIBUTING.md Add autodiscovery of --init folders based on composer.json 2019-05-09 19:19:33 -04:00
keys.asc.gpg
LICENSE
NEWS.md
phpcs.xml Add autodiscovery of --init folders based on composer.json 2019-05-09 19:19:33 -04:00
phpunit.xml.dist Bump to PHP 7.1 2019-05-16 18:36:36 -04:00
psalm
psalm-language-server
psalm-plugin
psalm.xml.dist Move test fixtures to a single directory 2019-05-09 18:23:14 -04:00
PsalmLogo.png
psalter
README.md spirit => shepherd 2019-03-31 14:02:30 -04:00
scoper.inc.php Fix #1452 - fix phar when analysing sql queries 2019-03-12 08:55:38 -04:00

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.