Releases: facebook/flow
Releases · facebook/flow
v0.280.0
Likely to cause new Flow errors:
- Accessing missing exports on namespaced import will now trigger
missing-export
error instead ofprop-missing
error. (example) - The only supported
suppress_type
$FlowFixMe
is now just a type alias ofany
. For most of the code, there will be no functional differences. However, you might see new errors if you have any local definitions of$FlowFixMe
, or you used the undocumented$FlowFixMe<arbitrary type arguments>
. - Support for
suppress_type
config has been removed. The only supportedsupress_type
now is$FlowFixMe
. If you want other variants, you can add
type MySuppressType = any
in your global library definitions.
- Many subtyping type errors' error codes have been standardized into
incompatible-type
, so some previously suppressed errors will reappear until you change the suppression error code intoincompatible-type
. The change was announced in the previous version, with option to enable it viaexperimental.error_code_migration=new
. Now the only valid option toexperimental.error_code_migration
isnew
. You can runflow codemod error-code-migration --write .
with the previous version of Flow to help migrate, since the codemod is removed in this version.
v0.279.0
New Features:
- In the next release (0.280.0) of Flow, we intend to standardize the error code for various subtyping errors into
incompatible-type
. You can addexperimental.error_code_migration=new
in your flowconfig to enable the new behavior now. We also provide a codemodflow codemod error-code-migration --write .
that you can run over your codebase to automatically change the error code. Both the flowconfig option and the codemod will be removed in the next version.
Notable bug fixes:
- Improved precision of error messages when inferred primitive types are checked against other incompatible primitive types (e.g. try-Flow)
Misc:
- Thanks @JamBalaya56562 for fixing various typos across the codebase!
v0.278.0
Likely to cause new Flow errors:
- Hooks calls inside normal functions in component or hooks as conditional calls. They will get
react-rule-hook-conditional
error instead ofreact-rule-hook
error. - Array literals that cannot be contextually typed will be inferred as an actual array type. It might cause additional errors. example
v0.277.1
Notable bug fixes:
- Fixed windows builds.
v0.277.0
v0.276.0
Likely to cause new Flow errors:
- Hook calls inside anonynous functions bound to a variable will get
react-rule-hook-definitely-not-in-component-or-hook
error, if the variable name doesn't conform to hook naming convention. example
IDE:
- Added support for workspace symbol feature
Misc:
- Thanks @jbroma for improving
as
casts withfunction
generics andcomponent
generics!
v0.275.0
Likely to cause new Flow errors:
- For all object literals in positions that cannot be contextually typed, we will infer a stricter type for them. It will cause new errors in code like
const foo = {baz: new Dog()};
type Foo = {bar?: string, baz: Animal};
declare function acceptFoo(foo: Foo): void;
acceptFoo(foo); // error
To fix the error, you can either annotate the object
const foo: Foo = {baz: new Dog()};
type Foo = {bar?: string, baz: Animal};
declare function acceptFoo(foo: Foo): void;
acceptFoo(foo);
or make the call site accepts readonly objects:
const foo = {baz: new Dog()};
type Foo = $ReadOnly<{bar?: string, baz: Animal}>;
declare function acceptFoo(foo: Foo): void;
acceptFoo(foo);
We provide a codemod to automate the annotation process. flow codemod annotate-literal-declaration --write --max-type-size 5
. (You can adjust the max type size based on your needs).
IDE:
- Support rename on private properties and methods.
Library Definitions:
React$MixedElement
is removed from builtin libdef. It will causeinternal-type
error sincev0.258.0
. You should useReact.MixedElement
instead.
v0.274.2
- Bug fixes for
match
v0.274.1
New Features:
- Support for experimental
match
feature using optionexperimental.pattern_matching=true
v0.274.0
Likely to cause new Flow errors:
- Unannotated object literals reachable from exports will now be inferred to have all mutable fields when being imported. Previously, it has unsound types, so new errors might appear.
- When comparing two object types whose properties have variance incompatibilities, Flow will raise a single error that will summarize the properties with incompatible variances, instead of a single error for each property. (e.g. try-Flow)
- When an object with extra properties is passed to a place that expect an exact object, we will now generate a single error with all extra properties. The error message will list the extra properties, and state that "Exact objects do not accept extra props". In rare cases, the error locations might be moved.
- Flow will error more consistently with sketchy-bool on nullable boolean types (e.g. try-Flow)
Library Definitions:
- All properties in the builtin
PropertyDescriptor
type are marked as readonly. If you need a mutable version, you can introduce something liketype MutablePropertyDescriptor<T> = {...$Exact<PropertyDescriptor<T>>, ...}