1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-21 21:31:13 +01:00
Matthew Brown 1a4ddc7cdd
Support value types (#707)
* Add first idea

* Add initial count experiments

* Remove false positives

* Fix getId to support changes in conditionals

* Add better tests

* Strip types when not exists

* Fix array offsets

* More fixes

* Add class constant value types

* Clone constants everywhere

* Don’t complain unnecessarily

* Be more lenient with possibly invalid __sets

* Fix mixed issues

* Fix bug concerning orred string equality

* Remove unnecessary casts
2018-05-03 13:56:30 -04:00
2018-04-25 11:53:10 -04:00
2018-05-03 13:56:30 -04:00
2018-05-03 13:56:30 -04:00
2018-01-18 17:41:14 -05:00
2018-02-03 20:08:14 -05:00
2018-03-21 12:42:22 -04:00
2018-04-19 17:29:07 -04:00
2017-12-31 16:53:56 -05:00
2016-11-21 14:48:17 -05:00
2018-04-19 17:29:07 -04:00
2018-04-12 22:40:47 -04:00
2017-01-16 17:24:26 -05:00
2018-03-18 10:52:54 -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 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.

Description
No description provided
Readme MIT 108 MiB
Languages
PHP 100%