2018-02-17 19:53:17 -05:00
|
|
|
|
# Running Psalm
|
|
|
|
|
|
|
|
|
|
Once you've set up your config file, you can run Psalm from your project's root directory with
|
|
|
|
|
```bash
|
|
|
|
|
./vendor/bin/psalm
|
|
|
|
|
```
|
|
|
|
|
|
2019-02-12 23:35:28 +01:00
|
|
|
|
and Psalm will scan all files in the project referenced by `<projectFiles>`.
|
2018-02-17 19:53:17 -05:00
|
|
|
|
|
|
|
|
|
If you want to run on specific files, use
|
|
|
|
|
```bash
|
|
|
|
|
./vendor/bin/psalm file1.php [file2.php...]
|
|
|
|
|
```
|
|
|
|
|
|
2018-09-30 11:13:12 -04:00
|
|
|
|
## Command-line options
|
2018-02-17 19:53:17 -05:00
|
|
|
|
|
|
|
|
|
Run with `--help` to see a list of options that Psalm supports.
|
2018-09-30 11:13:12 -04:00
|
|
|
|
|
2019-12-03 09:53:37 -05:00
|
|
|
|
## Shepherd
|
|
|
|
|
|
|
|
|
|
Psalm currently offers some GitHub integration with public projects.
|
|
|
|
|
|
|
|
|
|
Add `--shepherd` to send information about your build to https://shepherd.dev.
|
|
|
|
|
|
|
|
|
|
Currently, Shepherd tracks type coverage (the percentage of types Psalm can infer) on `master` branches.
|
|
|
|
|
|
2020-03-22 18:42:19 -04:00
|
|
|
|
## Running Psalm faster
|
2018-09-30 11:13:12 -04:00
|
|
|
|
|
|
|
|
|
Psalm has a couple of command-line options that will result in faster builds:
|
|
|
|
|
|
2018-09-30 16:05:42 -04:00
|
|
|
|
- `--threads=[n]` to run Psalm’s analysis in a number of threads
|
2020-01-25 15:50:11 +00:00
|
|
|
|
- `--diff` which only checks files you’ve updated since the last run (and their dependents).
|
|
|
|
|
- `--diff-methods` which only checks methods you’ve updated since the last run (and their dependents).
|
|
|
|
|
|
|
|
|
|
Data from the last run is stored in the *cache directory*, which may be set in [configuration](./configuration.md).
|
|
|
|
|
If you are running Psalm on a build server, you may want to configure the server to ensure that the cache directory
|
|
|
|
|
is preserved between runs.
|
2018-09-30 16:05:42 -04:00
|
|
|
|
|
2018-10-07 00:42:25 -04:00
|
|
|
|
Running them together (e.g. `--threads=8 --diff --diff-methods`) will result in the fastest possible Psalm run.
|