Skip to content
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

docs: add %checks and T is x #51

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Conversation

Bjeaurn
Copy link

@Bjeaurn Bjeaurn commented Jan 18, 2019

No description provided.

@niieani
Copy link
Owner

niieani commented Jan 19, 2019

Hi @Bjeaurn. This feature is not unique to Flow, as TypeScript has an equivalent (and even more advanced/useful): T is SomeType return type.

I'd happily accept a description/comparison of both features into the readme.

@niieani niieani changed the title docs: Adds a missing unique feature from Flow to the list. docs: add %checks and T is x Jan 19, 2019
@FezVrasta
Copy link
Contributor

(and even more advanced/useful)

This kind of comments make this project lose all its credibility, just FYI

@slikts
Copy link

slikts commented Jun 18, 2019

Is the comment inaccurate? If so, you could elaborate

@FezVrasta
Copy link
Contributor

They do the same thing

@niieani
Copy link
Owner

niieani commented Jun 20, 2019

They don't do the same thing @FezVrasta. You can't use %checks in declarations in all the cases where you can use x is T, making its usefulness limited.

Below is one really useful example taken from the TypeScript's library definition (Array.filter):

interface Array<T> {
  filter<S extends T>(callbackfn: (value: T, index: number) => value is S): S[];
}

This makes is possible refine the type of an Array by filtering it.

You can't model this with %checks (or with Flow altogether). If you could, Flow's official library would do it (it doesn't).

Additionally, %checks doesn't work in class methods.

I apologize for not being clear in my first comment, but my intention is completeness, not bias against any of the two technologies.

@FezVrasta
Copy link
Contributor

How can you say the Array#filter TypeScript's type definition is correct? It expects the callbackFn to return a type extended from T while it should accept any value and cast it to boolean 🤔

The Flow definition seems way more accurate, since it allows to return any from the callback.

@niieani
Copy link
Owner

niieani commented Jun 20, 2019

That's not the meaning of value is T. The return value still has to be a boolean (just like with %checks).

The difference is in the fact that such defined boolean has extra meaning attached to it, in that it ensures the mapping between: true and value is T, versus in the case of Flow, it ensures the value is "checked" against the logic within the body of the function.

Here's an example comparing the two in respective playgrounds: TypeScript vs Flow

All in all, %checks is similar to TypeScript's param is T, with these exceptions:

  • %checks cannot appear in class methods (that's why it cannot be defined in the Array case)
  • you cannot mark a check with an arbitrary type in Flow - it only works based on the logic defined in the body of the function: i.e. things like typeof, instanceof will work, but not complex cases where you reuse logic from a different function, or in cases where there is no body at all (e.g. library definitions))

The two reasons above make TypeScript's param is T more powerful and useful.

niieani added a commit that referenced this pull request Jun 20, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants