1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-27 04:45:20 +01:00
Go to file
2018-11-18 16:53:46 -05:00
assets/config_levels Default allowStringToStandInForClass to true and fix errors found 2018-11-12 12:03:55 -05:00
bin Plugin interface segregation (#1076) 2018-11-12 11:20:59 -05:00
docs Fix typos noticed in docs 2018-11-15 21:54:25 -05:00
examples Migrate Codebase-namespaced and FileManipulation-namespaced classes to internals 2018-11-12 11:20:59 -05:00
src Fix #1071 - improve resolution of include paths 2018-11-18 16:53:46 -05:00
tests Move more classes into Internal namespace 2018-11-18 12:41:47 -05: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
.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 Add v3 changes 2018-11-18 12:10:00 -05:00
CODE_OF_CONDUCT.md
composer.json Add phpunit psalm plugin 2018-11-14 13:19:38 -05:00
config.xsd Plugin loading (#855) 2018-11-10 23:23:36 -05:00
CONTRIBUTING.md
LICENSE
NEWS.md
phpcs.xml Move internal classes to own namespace 2018-11-12 11:20:59 -05:00
phpunit.xml.dist Fix codecoverage refs 2018-11-12 11:20:59 -05:00
psalm
psalm-language-server Change permissions on the language server executable 2018-10-19 14:04:22 -04:00
psalm-plugin Plugin loading (#855) 2018-11-10 23:23:36 -05:00
psalm.xml.dist Fix memory leak issues and disable garbage collection 2018-11-18 11:39:14 -05:00
PsalmLogo.png
psalter
README.md Fix wording nits in documentation 2018-10-27 13:05:49 -04:00
scoper.inc.php Plugin interface segregation (#1076) 2018-11-12 11:20:59 -05: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.