1
0
mirror of https://github.com/danog/psalm.git synced 2024-11-26 20:34:47 +01:00
Go to file
lhchavez 216f991b0c Normalize stringified type names (#2239)
This change makes stringified types more normalized. Concretely it sorts
all union types, reconciled types, and sorts the keys within object-like
types.
2019-10-17 01:14:33 -04:00
.circleci Add PHPUnit back 2019-09-14 15:49:01 -04:00
assets Add a PossibleRawObjectIteration issue 2019-08-20 12:06:02 -04:00
bin Bump release 2019-09-14 15:50:21 -04:00
build/phpunit Add circleci config file 2019-06-16 09:04:56 -04:00
docs add link to lists 2019-10-11 09:58:34 -04:00
examples Remove redundant @psalm-suppress in Psalm’s codebsae 2019-08-18 16:10:12 -04:00
src Normalize stringified type names (#2239) 2019-10-17 01:14:33 -04:00
tests Normalize stringified type names (#2239) 2019-10-17 01:14:33 -04:00
vendor-bin/box Bump box version 2019-06-08 19:59:23 -04:00
.appveyor.yml Ignore PHP 7.1 & PHP 7.2 on Windows 2019-08-21 14:04:59 -04:00
.editorconfig adding editorconfig that seems to match the php files (#163) 2017-06-26 00:22:05 -04:00
.gitattributes Add .gitattributes 2019-03-17 13:30:33 -04:00
.gitignore Issue 1926 unused variable (#1967) 2019-07-24 16:48:54 -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 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 Fix reference to psalm_plugin in box.json.dist 2019-06-07 06:52:07 -04:00
CHANGELOG.md Add v3 changes 2018-11-18 12:10:00 -05:00
CODE_OF_CONDUCT.md Add code of conduct 2017-12-31 16:53:56 -05:00
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 Add support for checking integer array offsets 2019-10-04 11:08:08 -04:00
CONTRIBUTING.md Add autodiscovery of --init folders based on composer.json 2019-05-09 19:19:33 -04:00
infection.json.dist Add circleci config file 2019-06-16 09:04:56 -04:00
keys.asc.gpg Fix signing (I hope) of releases 2018-12-14 11:20:31 -05:00
LICENSE Add license 2016-11-21 14:48:17 -05:00
NEWS.md Prepare v2 dev release 2018-04-19 17:29:07 -04:00
phpcs.xml Fully qualify constants and function calls (#1849) 2019-06-26 16:52:29 -04:00
phpunit.xml.dist Use local xsd file for PHPunit xml 2019-06-16 09:04:56 -04:00
psalm Move Psalm execution code into PHP file that Psalm can analyse 2017-12-29 17:02:56 -05:00
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-refactor Change psalm-refactor perms 2019-06-05 10:43:51 -04:00
psalm.xml.dist Ignore deprecated methods in tests 2019-10-04 11:23:35 -04:00
PsalmLogo.png New and improved logo 2017-01-16 17:24:26 -05:00
psalter Break file manipulation out into Psalter 2018-01-07 17:25:23 -05:00
README.md Fix link to issues 2019-06-20 10:57:45 -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.