Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/facebook/pyre-check
Performant type-checking for python.
https://github.com/facebook/pyre-check
abstract-interpretation code-quality control-flow-analysis ocaml program-analysis python security static-analysis taint-analysis type-check typechecker
Last synced: 5 days ago
JSON representation
Performant type-checking for python.
- Host: GitHub
- URL: https://github.com/facebook/pyre-check
- Owner: facebook
- License: mit
- Created: 2017-11-10T17:31:36.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T03:23:13.000Z (2 months ago)
- Last Synced: 2024-10-29T09:07:24.862Z (2 months ago)
- Topics: abstract-interpretation, code-quality, control-flow-analysis, ocaml, program-analysis, python, security, static-analysis, taint-analysis, type-check, typechecker
- Language: OCaml
- Homepage: https://pyre-check.org/
- Size: 200 MB
- Stars: 6,853
- Watchers: 112
- Forks: 437
- Open Issues: 157
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.es.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Roadmap: ROADMAP.md
Awesome Lists containing this project
- awesome-ccamel - facebook/pyre-check - Performant type-checking for python. (OCaml)
- awesome-repositories - facebook/pyre-check - Performant type-checking for python. (OCaml)
- awesome-starts - facebook/pyre-check - Performant type-checking for python. (OCaml)
- awesome-robotic-tooling - pyre-check - Performant type-checking for python. (Development Environment / Debugging and Tracing)
- awesome-list - Pyre - Performant type-checking for python. (Containers & Language Extentions & Linting / For Python)
- best-of-python-dev - GitHub - 36% open · ⏱️ 29.05.2024): (Type checkers)
- awesome-python-typing - pyre infer - Pyre has a powerful feature for migrating codebases to a typed format. The [infer](https://pyre-check.org/docs/pysa-coverage/) command-line option ingests a file or directory, makes educated guesses about the types used, and applies the annotations to the files. (Tools / Helper tools to add annotations to existing code)
- starred-awesome - pyre-check - Performant type-checking for python. (OCaml)
- jimsghstars - facebook/pyre-check - Performant type-checking for python. (OCaml)
- StarryDivineSky - facebook/pyre-check: Performant type-checking for python.
- awesome-python-resources - GitHub - 28% open · ⏱️ 26.08.2022): (代码分析和 Lint 工具)
README
[![lint](https://github.com/facebook/pyre-check/workflows/lint/badge.svg)](https://github.com/facebook/pyre-check/actions/workflows/lint.yml)
[![tests](https://github.com/facebook/pyre-check/workflows/tests/badge.svg)](https://github.com/facebook/pyre-check/actions/workflows/tests.yml)
[![pyre](https://github.com/facebook/pyre-check/workflows/pyre/badge.svg)](https://github.com/facebook/pyre-check/actions/workflows/pyre.yml)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
[![Gitter](https://badges.gitter.im/pyre-check/community.svg)](https://gitter.im/pyre-check/community?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge)
Pyre is a performant type checker for Python compliant with [PEP 484](https://www.python.org/dev/peps/pep-0484/). Pyre can analyze codebases with millions of lines of code incrementally – providing instantaneous feedback to developers as they write code. You can try it out on examples in [the Pyre Playground](https://pyre-check.org/play).
Pyre ships with **Pysa**, a security focused static analysis tool we've built on top of Pyre that reasons about data flows in Python applications. Please refer to our [documentation](https://pyre-check.org/docs/pysa-quickstart) to get started with our security analysis.
Pysa is also available on the [GitHub Marketplace as a Github Action](https://github.com/marketplace/actions/pysa-action)
## Requirements
To get started, you need [Python 3.8 or later](https://www.python.org/getit/) and [watchman](https://facebook.github.io/watchman/) working on your system. On *MacOS* you can get everything with [homebrew](https://brew.sh/):
```bash
$ brew install python3 watchman
```
On *Ubuntu*, *Mint*, or *Debian*; use `apt-get` and [homebrew](https://brew.sh/):
```bash
$ sudo apt-get install python3 python3-pip python3-venv
$ brew install watchman
```
We tested Pyre on *Ubuntu 18.04.5 LTS*, *CentOS 7*, as well as *OSX 10.11* and later.## Setting up a Project
We start by creating an empty project directory and setting up a virtual environment:```bash
$ mkdir my_project && cd my_project
$ python3 -m venv ~/.venvs/venv
$ source ~/.venvs/venv/bin/activate
(venv) $ pip install pyre-check
```Next, we teach Pyre about our new project:
```bash
(venv) $ pyre init
```
This command will set up a configuration for Pyre (`.pyre_configuration`) as well as watchman (`.watchmanconfig`) in your project's directory. Accept the defaults for now – you can change them later if necessary.## Running Pyre
We are now ready to run Pyre:
```bash
(venv) $ echo "i: int = 'string'" > test.py
(venv) $ pyre
ƛ Found 1 type error!
test.py:1:0 Incompatible variable type [9]: i is declared to have type `int` but is used as type `str`.
```
This first invocation will start a daemon listening for filesystem changes – type checking your project incrementally as you make edits to the code. You will notice that subsequent invocations of `pyre` will be faster than the first one.For more detailed documentation, see https://pyre-check.org.
## Join the Pyre community
See [CONTRIBUTING.md](CONTRIBUTING.md) for how to help out.
## License
Pyre is licensed under the MIT license.