# About Psalm Psalm is a static analysis tool that attempts to dig into your program and find as many type-related bugs as possible. It has a few features that go further than other similar tools: - **Mixed type warnings**
If Psalm cannot infer a type for an expression then it uses a `mixed` placeholder. Any `mixed` type is a sign of an insufficiently-documented codebase. You can configure Psalm warn when encountering `mixed` types by adding *`totallyTyped="true"`* attribute to your XML config file. - **Logic checks**
Psalm keeps track of logical assertions made about your code, so `if ($a && $a) {}` and `if ($a && !$a) {}` are both treated as issues. Psalm also keeps track of logical assertions made in prior code paths, preventing issues like `if ($a) {} elseif ($a) {}`. - **Property initialisation checks**
Psalm checks that all properties of a given object have values after the constructor is called. - **Support for complicated array shapes**
Psalm has support for [object-like arrays](annotating_code/docblock_type_syntax.md#object-like-arrays), allowing you to specify types for all keys of an array if you so wish. Psalm also has a few features to make it perform as well as possible on large codebases: - **Multi-threaded mode**
Using the `--threads=[X]` command line option will run Psalm's analysis stage on [X] threads. Useful for large codebases, it has a massive impact on performance. - **Incremental checks**
When using the `--diff` command line option, Psalm will only analyse files that have changed *and* files that reference them. ## Example output ```php // somefile.php ./vendor/bin/psalm somefile.php ERROR: InvalidArgument - somefile.php:3:14 - Argument 1 of implode expects `string`, `array` provided ``` ## Inspirations There are two main inspirations for Psalm: - Etsy's [Phan](https://github.com/etsy/phan), which uses nikic's [php-ast](https://github.com/nikic/php-ast) extension to create an abstract syntax tree - Facebook's [Hack](http://hacklang.org/), a PHP-like language that supports many advanced typing features natively, so docblocks aren't necessary. ## Index - Running Psalm: - [Installation](running_psalm/installation.md) - [Configuration](running_psalm/configuration.md) - Plugins - [Using plugins](running_psalm/plugins/using_plugins.md) - [Authoring plugins](running_psalm/plugins/authoring_plugins.md) - [How Psalm represents types](running_psalm/plugins/plugins_type_system.md) - [Command line usage](running_psalm/command_line_usage.md) - [IDE support](running_psalm/language_server.md) - Handling errors: - [Dealing with code issues](running_psalm/dealing_with_code_issues.md) - [Issue Types](running_psalm/issues.md) - [Checking non-PHP files](running_psalm/checking_non_php_files.md) - Annotating code: - [Typing in Psalm](annotating_code/typing_in_psalm.md) - [Docblock Type Syntax](annotating_code/docblock_type_syntax.md) - [Supported Annotations](annotating_code/supported_annotations.md) - [Template Annotations](annotating_code/templated_annotations.md) - Manipulating code: - [Fixing code](manipulating_code/fixing.md) - [Refactoring code](manipulating_code/refactoring.md)