ts-pattern
ts-pattern copied to clipboard
Wrong type with Pattern#when
Describe the bug I try to use ts-pattern with fp-ts when I use P.when(some_type_guard_function) is has not expected type
Code Sandbox with a minimal reproduction case the ts version of codesandbox editor is not support 4.7 yet
here is some case, I don't know what happen
data:image/s3,"s3://crabby-images/f6305/f63054b2d8481f1b791457e2fa5835701ed405b6" alt="image"
data:image/s3,"s3://crabby-images/5819d/5819d1a79c62532b395d70ac5947bdda1a9a22a6" alt="image"
but when I change the guard function signature to (fa: any) => fa is Some<number>
or (fa: unknown) => fa is Some<number>
, it will work!!
data:image/s3,"s3://crabby-images/08631/086319db2ce0ce2d58bcf2260c56aadae166b1d0" alt="image"
data:image/s3,"s3://crabby-images/d7e62/d7e6219c0682ae93208ec7413374e3845cedcf9c" alt="image"
It has same problem when input type is string | number
data:image/s3,"s3://crabby-images/59eea/59eea650f5c195580acb7e327470600150d69c5c" alt="image"
data:image/s3,"s3://crabby-images/bf2b8/bf2b8885ba606fe5fddcd1b04569012fe64e9c87" alt="image"
data:image/s3,"s3://crabby-images/82d26/82d26fb4d4bc8adf68b84da7353a9312ae7945f2" alt="image"
but Tuple or Object can work
data:image/s3,"s3://crabby-images/b8de9/b8de94ae77d6c2e2828a9296335c60031f0d4cc8" alt="image"
and I known match().when()
always correct.
Versions
- TypeScript version: 4.7.2
- ts-pattern version: 4.0.2
- environment: chrome
there is another case
data:image/s3,"s3://crabby-images/67b15/67b15246734c9816d76d2f0c6a15c0a60d568a55" alt="image"
It does not work.
but, look at the type Data
, when I delete value
property or make it to optional, work again !!
data:image/s3,"s3://crabby-images/fc4e4/fc4e426a5788896781392a1abfa1487b97585935" alt="image"
data:image/s3,"s3://crabby-images/0676e/0676e9fd56ecde45456aefc93e89cb9829901971" alt="image"
here is my tsconfig.json
{
"compilerOptions": {
/* Projects */
"incremental": true,
/* Language and Environment */
"target": "es6",
"lib": ["dom", "esnext"],
"jsx": "react-jsx",
/* Modules */
"module": "commonjs",
"baseUrl": "./src",
"paths": {
"@/*": ["./*"]
},
"rootDirs": ["./src", "./package.json"],
"types": ["node", "jest"],
"resolveJsonModule": true,
/* Emit */
"noEmit": true,
"sourceMap": true,
"importsNotUsedAsValues": "error",
/* Interop Constraints */
"allowSyntheticDefaultImports": true,
"forceConsistentCasingInFileNames": true,
/* Type Checking */
"strictNullChecks": true,
"strictBindCallApply": true,
"strictFunctionTypes": true,
"strictPropertyInitialization": true,
"noImplicitAny": false,
"noImplicitThis": true,
"useUnknownInCatchVariables": true,
"noUncheckedIndexedAccess": true,
/* Completeness */
"skipLibCheck": true
},
"exclude": ["node_modules", "src/libs"],
"include": ["src"]
}
Hey! Thanks for the report, do you mind creating a TypeScript playground example demonstrating the issue you are facing so I can investigate later? it seems like you can import ts-pattern and fp-ts in there: Playground Example
Hey! Thanks for the report, do you mind creating a TypeScript playground example demonstrating the issue you are facing so I can investigate later? it seems like you can import ts-pattern and fp-ts in there: Playground Example
Wowww I didn't known I can import npm package in TypeScript Playground.
this is first comment show case: Comment One Case
second comment show case: Comment Two Case
Thanks for the playgrounds. Sorry I didn't have the time to look into it yet, I'll try to find some time this weekend
never mind. I tried another way to write my code