flow

向JavaScript添加静态类型以提高开发人员的工作效率和代码质量。(Adds static typing to JavaScript to improve developer productivity and code quality.)

  • Owner: facebook/flow
  • Platform: Linux, Mac, Windows
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Flow Build Status Windows Build Status Join the chat at https://discordapp.com/invite/8ezwRUK

Flow is a static typechecker for JavaScript. To find out more about Flow, check out flow.org.

For a background on the project, please read this overview.

Contents

Requirements

Flow works with:

  • macOS
  • Linux (64-bit)
  • Windows (64-bit, Windows 10 recommended)

There are binary distributions for each of these platforms and you can also build it from source on any of them as well.

Using Flow

Check out the installation instructions, and then how to get started.

Using Flow's parser from JavaScript

While Flow is written in OCaml, its parser is available as a compiled-to-JavaScript module published to npm, named flow-parser. Most end users of Flow
will not need to use this parser directly
, but JavaScript packages which make use of parsing
Flow-typed JavaScript can use this to generate Flow's syntax tree with annotated types attached.

Building Flow from source

Flow is written in OCaml (OCaml 4.07.1 is required).

  1. Install opam:
  1. Initialize opam:
opam init
  1. Install OCaml and Flow's dependencies:
# from within this git checkout
opam switch create . --deps-only -y
  1. Build the flow binary:
eval $(opam env)
make

This produces the bin/flow binary.

  1. Build flow.js (optional):
opam install -y js_of_ocaml.3.4.0
make js

This produces bin/flow.js.

The Flow parser can also be compiled to JavaScript. Read how here.

Running the tests

To run the tests, first compile flow using make. Then run bash ./runtests.sh bin/flow

There is a make test target that compiles and runs tests.

To run a subset of the tests you can pass a second argument to the runtests.sh file.

For example: bash runtests.sh bin/flow class, grep -v 'SKIP'

Join the Flow community

License

Flow is MIT-licensed (LICENSE). The website and documentation are licensed under the Creative Commons Attribution 4.0 license (website/LICENSE-DOCUMENTATION).

Main metrics

Overview
Name With Ownerfacebook/flow
Primary LanguageOCaml
Program languageShell (Language Count: 13)
PlatformLinux, Mac, Windows
License:MIT License
所有者活动
Created At2014-10-28 17:17:45
Pushed At2025-06-30 14:19:09
Last Commit At
Release Count414
Last Release Namev0.274.2 (Posted on )
First Release Namev0.1.0 (Posted on 2014-11-18 10:34:57)
用户参与
Stargazers Count22.2k
Watchers Count383
Fork Count1.9k
Commits Count19.4k
Has Issues Enabled
Issues Count6699
Issue Open Count660
Pull Requests Count160
Pull Requests Open Count17
Pull Requests Close Count2293
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private