-
Notifications
You must be signed in to change notification settings - Fork 79
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Write about Flow not accepting more strict Arrays #9
Comments
Just to clarify: Flow is being more strict here, not TS |
@vkurchatkin I know it's being more strict, I just can't think of a reason why would you want this behavior. Can you give a reason as to why this is better? |
This is better because it's safe. Typescript's behavior is unsafe: function test(param: Array<number | string>) {
param.push('foo')
}
const compatibleVar : Array<number> = []
compatibleVar[0].toFixed(); // Runtime error |
@vkurchatkin ok, this makes sense (I'll add it to the README), but only if you're mutating data. It would be nice to be able to opt-in or opt-out of this, since with modern programming / immutability / functional dogma one really shouldn't be doing what I also think what you gave as an example is an edge case, so personally, I believe TypeScript's trade-off for a bit of unsoundness goes a long way in making it easier to develop in general. (btw. you missed one line: |
Well, in Flow you can just do: function test(param: $ReadOnlyArray<number | string>) {
} And it's going to work |
That's great to know, however this is an undocumented feature. :( |
Maybe this blog post can be helpful regarding this particular Flow behavior? https://medium.com/@forbeslindesay/covariance-and-contravariance-c3b43d805611#.6oemuj9gn Unless you're already familiar with it, in any case maybe it helps for posterity. |
@leoasis I was aware of variance and how to use it (it's documented), it's only the |
Probably good to talk about Flow's treatment of mutated arrays in the same section: const arr = ['1', 0];
arr.sort();
// Error in TS, not in Flow, throws at runtime
arr[0].substr(0); |
Interesting example, I've already filed this issue here: facebook/flow#3735 The thing is, Typescript's behaviour seems to be not that different. In your example TS only catches the error because it doesn't try to infer precise type of const arr: [string, number] = ['1', 0];
arr.sort();
arr[0].substr(0) Flow, on the other hand, will show an error in this case. |
Only because tuples are read-only. The equivalent TS code would be: const arr: ReadonlyArray<number | string> = ['1', 0];
arr.sort(); or const arr: { 0: string, 1: number } = ['1', 0];
arr.sort(); which both show the same error. Probably TS tuples should inherit from some other Array type that allows mutation but doesn't allow reordering operations. Allowing |
No, they are not really read-only, they just have methods of
That's basically what Flow does |
This works properly in TypeScript, but fails in Flow with the error:
The text was updated successfully, but these errors were encountered: