GitXplorerGitXplorer
f

pyre-check

public
6897 stars
442 forks
140 issues

Commits

List of commits on branch main.
Unverified
6d4576a9efc5caba6b16971cd321efcf7b76d6f2

Add a helper for parsing string literals

nndmitchell committed 16 hours ago
Unverified
540c3e8ffb6b20fc1f1df371429014d3dfd56366

add bug testcase for generic typeddict

yyangdanny97 committed 17 hours ago
Unverified
f7044fd377e156c2b4b1ad4b4f631f0b9edde3f5

support typed dict NotRequired

yyangdanny97 committed a day ago
Unverified
3abc2d0f8ac737c83bc9c9ae7207e46fda106baf

support typed dict subtyping

yyangdanny97 committed a day ago
Unverified
7ebb5cdf51a0223e0ec11d0936963a45d1b95053

support typed dictionary subscript

yyangdanny97 committed a day ago
Unverified
39204c9b1d594b8b5f153b572115606cd7cf961d

class field and metadata checks for typed dicts

yyangdanny97 committed a day ago

README

The README file for this repository.

tests License: MIT Gitter

Pyre is a performant type checker for Python compliant with PEP 484. 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.

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 to get started with our security analysis.

Pysa is also available on the GitHub Marketplace as a Github Action

Requirements

To get started, you need Python 3.8 or later and watchman working on your system. On MacOS you can get everything with homebrew:

$ brew install python3 watchman

On Ubuntu, Mint, or Debian; use apt-get and homebrew:

$ 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:

$ 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:

(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:

(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 for how to help out.

License

Pyre is licensed under the MIT license.