How do I assign the right type signature to this curried function in typescript?
up vote
-1
down vote
favorite
I am new to typescript & generics and working with a Maybe monad. I have created this small utility function using Ramda:
const fromEmpty = R.ifElse(hasLength, Just, Maybe.zero);
The closest signature I can infer from this is:
type EmptyFunc<T> = (val: T) => Maybe<T>;
It's a function takes in an array and returns a function that returns a Maybe of that array.
I tried doing
const fromEmpty(<U extends EmptyFunc<U>) = R.ifElse(hasLength, Just, Maybe.zero);
But that doesn't work. It returns error TS1005: ',' expected.
What is the right way to work with curried functions in typescript?
typescript functional-programming currying ramda.js
add a comment |
up vote
-1
down vote
favorite
I am new to typescript & generics and working with a Maybe monad. I have created this small utility function using Ramda:
const fromEmpty = R.ifElse(hasLength, Just, Maybe.zero);
The closest signature I can infer from this is:
type EmptyFunc<T> = (val: T) => Maybe<T>;
It's a function takes in an array and returns a function that returns a Maybe of that array.
I tried doing
const fromEmpty(<U extends EmptyFunc<U>) = R.ifElse(hasLength, Just, Maybe.zero);
But that doesn't work. It returns error TS1005: ',' expected.
What is the right way to work with curried functions in typescript?
typescript functional-programming currying ramda.js
add a comment |
up vote
-1
down vote
favorite
up vote
-1
down vote
favorite
I am new to typescript & generics and working with a Maybe monad. I have created this small utility function using Ramda:
const fromEmpty = R.ifElse(hasLength, Just, Maybe.zero);
The closest signature I can infer from this is:
type EmptyFunc<T> = (val: T) => Maybe<T>;
It's a function takes in an array and returns a function that returns a Maybe of that array.
I tried doing
const fromEmpty(<U extends EmptyFunc<U>) = R.ifElse(hasLength, Just, Maybe.zero);
But that doesn't work. It returns error TS1005: ',' expected.
What is the right way to work with curried functions in typescript?
typescript functional-programming currying ramda.js
I am new to typescript & generics and working with a Maybe monad. I have created this small utility function using Ramda:
const fromEmpty = R.ifElse(hasLength, Just, Maybe.zero);
The closest signature I can infer from this is:
type EmptyFunc<T> = (val: T) => Maybe<T>;
It's a function takes in an array and returns a function that returns a Maybe of that array.
I tried doing
const fromEmpty(<U extends EmptyFunc<U>) = R.ifElse(hasLength, Just, Maybe.zero);
But that doesn't work. It returns error TS1005: ',' expected.
What is the right way to work with curried functions in typescript?
typescript functional-programming currying ramda.js
typescript functional-programming currying ramda.js
asked Nov 11 at 8:46
Amit Erandole
3,915154882
3,915154882
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
up vote
1
down vote
The declaration
type EmptyFunc<T> = (val: T) => Maybe<T>;
declares a family of different function types EmptyFunc<number>
, EmptyFunc<string>
, etc., each of which works for only the specified type T
. You probably meant
type EmptyFunc = <T>(val: T) => Maybe<T>;
which declares the type EmptyFunc
of a single generic function that works for all types T
. Then to apply this type to fromEmpty
, just write:
const fromEmpty: EmptyFunc = R.ifElse(hasLength, Just, Maybe.zero);
(I'm unable to test this myself since you didn't give the definitions of hasLength
, Just
, and Maybe
.) If that wasn't what you were asking, please clarify the question.
add a comment |
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
1
down vote
The declaration
type EmptyFunc<T> = (val: T) => Maybe<T>;
declares a family of different function types EmptyFunc<number>
, EmptyFunc<string>
, etc., each of which works for only the specified type T
. You probably meant
type EmptyFunc = <T>(val: T) => Maybe<T>;
which declares the type EmptyFunc
of a single generic function that works for all types T
. Then to apply this type to fromEmpty
, just write:
const fromEmpty: EmptyFunc = R.ifElse(hasLength, Just, Maybe.zero);
(I'm unable to test this myself since you didn't give the definitions of hasLength
, Just
, and Maybe
.) If that wasn't what you were asking, please clarify the question.
add a comment |
up vote
1
down vote
The declaration
type EmptyFunc<T> = (val: T) => Maybe<T>;
declares a family of different function types EmptyFunc<number>
, EmptyFunc<string>
, etc., each of which works for only the specified type T
. You probably meant
type EmptyFunc = <T>(val: T) => Maybe<T>;
which declares the type EmptyFunc
of a single generic function that works for all types T
. Then to apply this type to fromEmpty
, just write:
const fromEmpty: EmptyFunc = R.ifElse(hasLength, Just, Maybe.zero);
(I'm unable to test this myself since you didn't give the definitions of hasLength
, Just
, and Maybe
.) If that wasn't what you were asking, please clarify the question.
add a comment |
up vote
1
down vote
up vote
1
down vote
The declaration
type EmptyFunc<T> = (val: T) => Maybe<T>;
declares a family of different function types EmptyFunc<number>
, EmptyFunc<string>
, etc., each of which works for only the specified type T
. You probably meant
type EmptyFunc = <T>(val: T) => Maybe<T>;
which declares the type EmptyFunc
of a single generic function that works for all types T
. Then to apply this type to fromEmpty
, just write:
const fromEmpty: EmptyFunc = R.ifElse(hasLength, Just, Maybe.zero);
(I'm unable to test this myself since you didn't give the definitions of hasLength
, Just
, and Maybe
.) If that wasn't what you were asking, please clarify the question.
The declaration
type EmptyFunc<T> = (val: T) => Maybe<T>;
declares a family of different function types EmptyFunc<number>
, EmptyFunc<string>
, etc., each of which works for only the specified type T
. You probably meant
type EmptyFunc = <T>(val: T) => Maybe<T>;
which declares the type EmptyFunc
of a single generic function that works for all types T
. Then to apply this type to fromEmpty
, just write:
const fromEmpty: EmptyFunc = R.ifElse(hasLength, Just, Maybe.zero);
(I'm unable to test this myself since you didn't give the definitions of hasLength
, Just
, and Maybe
.) If that wasn't what you were asking, please clarify the question.
answered Nov 11 at 14:03
Matt McCutchen
13k719
13k719
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53247124%2fhow-do-i-assign-the-right-type-signature-to-this-curried-function-in-typescript%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown