Option
monads support either an A
(success) value, or a None
(no-value) option. You can think of this as an alternative to using
null
to represent a lack of a value. null
unfortunately still allows you to .
into the interface of the decalred type, which means
there's a ticking time-bomb in every reference type.
C# does now have the nullable references feature, which goes some way to removing the need for an optional type, however there's still edge
cases that mean the reference types are problematic. It's also useful to build generic types and say this is an Option<A>
- I don't care
if it's a value-type or reference-type, it's optional.
And finally, there's the automatic checking of None
values when using Option<A>
in LINQ expressions, or if you call Map
. This makes
working with optional values, and the implications for all of the code that works with it, fully declarative.
Here we have two flavours of Option
:
Option<A>
the default optional monad. It does not allownull
in itsSome
case.OptionUnsafe<A>
as above, but it does allownull
in itsSome
case.
You can construct a Some
using the constructor functions in the Prelude
:
Option<int> ma = Some(123);
Option<int> mb = None;
- Option <A>
- None = default
- Some (A value)
- Option (IEnumerable<A> option)
- GetObjectData (SerializationInfo info, StreamingContext context)
- Case
- Equals (Option<A> other)
- Equals <EqA> (Option<A> other)
- CompareTo (Option<A> other)
- CompareTo <OrdA> (Option<A> other)
- < (Option<A> lhs, Option<A> rhs)
- <= (Option<A> lhs, Option<A> rhs)
- > (Option<A> lhs, Option<A> rhs)
- >= (Option<A> lhs, Option<A> rhs)
- == (Option<A> lhs, Option<A> rhs)
- != (Option<A> lhs, Option<A> rhs)
- | (Option<A> lhs, Option<A> rhs)
- | (K<Option, A> lhs, Option<A> rhs)
- | (Option<A> lhs, K<Option, A> rhs)
- | (Option<A> ma, Pure<A> mb)
- | (Option<A> ma, Fail<Unit> mb)
- | (Option<A> ma, CatchM<Unit, Option, A> mb)
- true (Option<A> value)
- false (Option<A> value)
- Equals (object? obj)
- GetHashCode ()
- CompareTo (object? obj)
- ToString ()
- IsSome
- IsNone
- Do (Action<A> f)
- Select <B> (Func<A, B> f)
- Map <B> (Func<A, B> f)
- Traverse <F, B> (Func<A, K<F, B>> f)
- TraverseM <M, B> (Func<A, K<M, B>> f)
- Bind <B> (Func<A, Option<B>> f)
- Bind <B> (Func<A, K<Option, B>> f)
- BiBind <B> (Func<A, Option<B>> Some, Func<Option<B>> None)
- SelectMany <B, C> ( Func<A, Option<B>> bind, Func<A, B, C> project)
- SelectMany <C> ( Func<A, Fail<Unit>> bind, Func<A, Unit, C> project)
- MatchUntyped <R> (Func<object?, R> Some, Func<R> None)
- GetUnderlyingType ()
- ToArray ()
- ToList ()
- ToSeq ()
- AsIterable ()
- ToEff ()
- ToIO ()
- ToStream <M> ()
- ToEff (Error Fail)
- ToFin ()
- ToFin (Error Fail)
- ToEither <L> (L defaultLeftValue)
- ToEither <L> ()
- ToEither <L> (Func<L> Left)
- ToValidation <L> (Func<L> Fail)
- ToValidation <L> (L Fail)
- ToValidation <L> ()
- Some (Action<A> f)
- Some <B> (Func<A, B> f)
- Match <B> (Func<A, B> Some, Func<B> None)
- Match <B> (Func<A, B> Some, B None)
- Match (Action<A> Some, Action None)
- IfSome (Action<A> f)
- IfSome (Func<A, Unit> f)
- IfNone (Func<A> None)
- IfNone (Action None)
- IfNone (A noneValue)
- Fold <S> (S state, Func<S, A, S> folder)
- FoldBack <S> (S state, Func<S, A, S> folder)
- BiFold <S> (S state, Func<S, A, S> Some, Func<S, Unit, S> None)
- BiFold <S> (S state, Func<S, A, S> Some, Func<S, S> None)
- BiMap <B> (Func<A, B> Some, Func<Unit, B> None)
- BiMap <B> (Func<A, B> Some, Func<B> None)
- Count ()
- ForAll (Func<A, bool> pred)
- BiForAll (Func<A, bool> Some, Func<Unit, bool> None)
- BiForAll (Func<A, bool> Some, Func<bool> None)
- Exists (Func<A, bool> pred)
- BiExists (Func<A, bool> Some, Func<Unit, bool> None)
- BiExists (Func<A, bool> Some, Func<bool> None)
- Iter (Action<A> Some)
- BiIter (Action<A> Some, Action<Unit> None)
- BiIter (Action<A> Some, Action None)
- Filter (Func<A, bool> pred)
- Where (Func<A, bool> pred)
- ParMap <B, C> (Func<A, B, C> func)
- ParMap <B, C, D> (Func<A, B, C, D> func)
- GetEnumerator ()
- Bind <B> (Func<A, Pure<B>> f)
- Bind <B> (Func<A, Fail<Unit>> f)
- SelectMany <B, C> (Func<A, Pure<B>> bind, Func<A, B, C> project)
- Combine (Option<A> rhs)
- Empty
- OptionExtensions
- As <A> (this K<Option, A> ma)
- ToValidation <F, A> (Option<A> ma, F defaultFailureValue)
- Flatten <A> (this Option<Option<A>> ma)
- Somes <A> (this IEnumerable<Option<A>> self)
- Somes <A> (this Seq<Option<A>> self)
- Add <ARITH, A> (this Option<A> x, Option<A> y)
- Subtract <ARITH, A> (this Option<A> x, Option<A> y)
- Product <ARITH, A> (this Option<A> x, Option<A> y)
- Divide <NUM, A> (this Option<A> x, Option<A> y)
- ToNullable <A> (this Option<A> ma)
- Match <R> (this Option<bool> ma, Func<R> True, Func<R> False, Func<R> None)
- Match <T, R> (this IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, Func<IEnumerable<R>> None)
- Match <T, R> (this IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, IEnumerable<R> None)
- OptionExtensions
- Map <A, B> (this Func<A, B> f, K<Option, A> ma)
- Map <A, B> (this Func<A, B> f, Option<A> ma)
- Action <A, B> (this Option<A> ma, K<Option, B> mb)
- Action <A, B> (this K<Option, A> ma, K<Option, B> mb)
- Apply <A, B> (this Option<Func<A, B>> mf, K<Option, A> ma)
- Apply <A, B> (this K<Option, Func<A, B>> mf, K<Option, A> ma)
- Option
- Prelude
- flatten <A> (Option<Option<A>> ma)
- subtract <NUM, T> (Option<T> lhs, Option<T> rhs)
- product <NUM, T> (Option<T> lhs, Option<T> rhs)
- divide <NUM, T> (Option<T> lhs, Option<T> rhs)
- add <NUM, T> (Option<T> lhs, Option<T> rhs)
- isSome <T> (Option<T> value)
- isNone <T> (Option<T> value)
- None
- Some <A> (A value)
- Some <A> (A? value)
- Optional <A> (A? value)
- Optional <A> (A? value)
- ifSome <T> (Option<T> option, Action<T> Some)
- ifNone <T> (Option<T> option, Func<T> None)
- ifNone <T> (Option<T> option, T noneValue)
- match <T, R> (Option<T> option, Func<T, R> Some, Func<R> None)
- match <T> (Option<T> option, Action<T> Some, Action None)
- bifold <S, A> (Option<A> option, S state, Func<S, A, S> Some, Func<S, S> None)
- bifold <S, A> (Option<A> option, S state, Func<S, A, S> Some, Func<S, Unit, S> None)
- forall <A> (Option<A> option, Func<A, bool> pred)
- biforall <A> (Option<A> option, Func<A, bool> Some, Func<Unit, bool> None)
- biforall <A> (Option<A> option, Func<A, bool> Some, Func<bool> None)
- count <A> (Option<A> option)
- exists <A> (Option<A> option, Func<A, bool> pred)
- biexists <A> (Option<A> option, Func<A, bool> Some, Func<Unit, bool> None)
- biexists <A> (Option<A> option, Func<A, bool> Some, Func<bool> None)
- map <A, B> (Option<A> option, Func<A, B> f)
- bimap <A, B> (Option<A> option, Func<A, B> Some, Func<B> None)
- bimap <A, B> (Option<A> option, Func<A, B> Some, Func<Unit, B> None)
- filter <T> (Option<T> option, Func<T, bool> pred)
- bind <T, R> (Option<T> option, Func<T, Option<R>> binder)
- match <T, R> ( IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, Func<IEnumerable<R>> None)
- match <T, R> (IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, IEnumerable<R> None)
- somes <T> (IEnumerable<Option<T>> list)
- toList <T> (Option<T> option)
- toArray <T> (Option<T> option)
- Prelude
Sub modules
Option-Shared |
Discriminated union type. Can be in one of two states:
Some(a)
None
Trait instances available for this type:
BiFoldable : MOption
Eq : EqOpt
Foldable : MOption
Functor : FOption
MonadPlus : MOption
Optional : MOption
Ord : OrdOpt
type | A | Bound value |
field Option<A> None = default Source #
None
method Option<A> Some (A value) Source #
Construct an Option of A in a Some state
param | value | Value to bind, must be non-null |
returns | Option of A |
method void GetObjectData (SerializationInfo info, StreamingContext context) Source #
method bool Equals (Option<A> other) Source #
Uses the EqDefault
instance to do an equality check on the bound value.
To use anything other than the default call oa.Equals〈EqA〉(ob)
where EqA
is an instance derived from Eq〈A〉
This uses the EqDefault
instance for comparison of the bound A
values.
The EqDefault
instance wraps up the .NET EqualityComparer.Default
behaviour.
param | other | The |
returns |
|
method bool Equals <EqA> (Option<A> other) Source #
Uses the EqA
instance to do an equality check on the bound value.
param | other | The |
returns |
|
method int CompareTo (Option<A> other) Source #
Uses the OrdDefault
instance to do an ordering comparison on the bound
value. To use anything other than the default call this.Compare〈OrdA〉(this, other)
,
where OrdA
is an instance derived from Ord〈A〉
param | other | The |
method int CompareTo <OrdA> (Option<A> other) Source #
Uses the Ord
instance provided to do an ordering comparison on the bound
value.
param | other | The |
method bool Equals (object? obj) Source #
DO NOT USE - Use the Structural equality variant of this method Equals〈EQ, A〉(y)
method int GetHashCode () Source #
Calculate the hash-code from the bound value, unless the Option is in a None state, in which case the hash-code will be 0
returns | Hash-code from the bound value, unless the Option is in a None state, in which case the hash-code will be 0 |
method string ToString () Source #
Get a string representation of the Option
returns | String representation of the Option |
method Option<A> Do (Action<A> f) Source #
Impure iteration of the bound value in the structure
returns | Returns the original unmodified structure |
method Option<B> Select <B> (Func<A, B> f) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | f | Projection function |
returns | Mapped functor |
method Option<B> Map <B> (Func<A, B> f) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | f | Projection function |
returns | Mapped functor |
method K<F, Option<B>> Traverse <F, B> (Func<A, K<F, B>> f) Source #
Map each element of a structure to an action, evaluate these actions from left to right, and collect the results.
type | F | Applicative functor trait |
type | B | Bound value (output) |
param | f | |
param | ta | Traversable structure |
method K<M, Option<B>> TraverseM <M, B> (Func<A, K<M, B>> f) Source #
Map each element of a structure to an action, evaluate these actions from left to right, and collect the results.
type | M | Monad trait |
type | B | Bound value (output) |
param | f | |
param | ta | Traversable structure |
method Option<B> BiBind <B> (Func<A, Option<B>> Some, Func<Option<B>> None) Source #
Bi-bind. Allows mapping of both monad states
method Option<C> SelectMany <B, C> ( Func<A, Option<B>> bind, Func<A, B, C> project) Source #
Monad bind operation
method Option<C> SelectMany <C> ( Func<A, Fail<Unit>> bind, Func<A, Unit, C> project) Source #
Monad bind operation
method R MatchUntyped <R> (Func<object?, R> Some, Func<R> None) Source #
Match operation with an untyped value for Some. This can be useful for serialisation and dealing with the IOptional interface
type | R | The return type |
param | Some | Operation to perform if the option is in a Some state |
param | None | Operation to perform if the option is in a None state |
returns | The result of the match operation |
method Type GetUnderlyingType () Source #
Get the Type of the bound value
returns | Type of the bound value |
method Arr<A> ToArray () Source #
Convert the Option to an enumerable of zero or one items
returns | An enumerable of zero or one items |
method Lst<A> ToList () Source #
Convert the Option to an immutable list of zero or one items
returns | An immutable list of zero or one items |
method Seq<A> ToSeq () Source #
Convert the Option to an enumerable sequence of zero or one items
returns | An enumerable sequence of zero or one items |
method Iterable<A> AsIterable () Source #
Convert the Option to an enumerable of zero or one items
returns | An enumerable of zero or one items |
method Eff<A> ToEff () Source #
Convert the structure to an Eff
returns | An Eff representation of the structure |
method Eff<A> ToEff (Error Fail) Source #
Convert the structure to an Eff
param | Fail | Default value if the structure is in a None state |
returns | An Eff representation of the structure |
method Fin<A> ToFin () Source #
Convert the structure to a Fin
returns | A Fin representation of the structure |
method Fin<A> ToFin (Error Fail) Source #
Convert the structure to a Fin
param | Fail | Default value if the structure is in a None state |
returns | A Fin representation of the structure |
method Either<L, A> ToEither <L> (L defaultLeftValue) Source #
Convert the structure to an Either
param | defaultLeftValue | Default value if the structure is in a None state |
returns | An Either representation of the structure |
method Either<L, A> ToEither <L> (Func<L> Left) Source #
Convert the structure to an Either
param | Left | Function to invoke to get a default value if the structure is in a None state |
returns | An Either representation of the structure |
method Validation<L, A> ToValidation <L> (Func<L> Fail) Source #
Convert the structure to a Validation
param | Fail | Function to invoke to get a default value if the structure is in a None state |
returns | An Validation representation of the structure |
method Validation<L, A> ToValidation <L> (L Fail) Source #
Convert the structure to a Validation
param | Fail | Default value if the structure is in a None state |
returns | An Validation representation of the structure |
method Validation<L, A> ToValidation <L> () Source #
Convert the structure to a Validation
returns | An Validation representation of the structure |
method SomeUnitContext<A> Some (Action<A> f) Source #
Fluent pattern matching. Provide a Some handler and then follow on fluently with .None(...) to complete the matching operation. This is for dispatching actions, use Some〈A, B〉(...) to return a value from the match operation.
param | f | The |
method SomeContext<A, B> Some <B> (Func<A, B> f) Source #
Fluent pattern matching. Provide a Some handler and then follow on fluently with .None(...) to complete the matching operation. This is for returning a value from the match operation, to dispatch an action instead, use Some〈A〉(...)
type | B | Match operation return value type |
param | f | The |
returns | The result of the match operation |
method B Match <B> (Func<A, B> Some, Func<B> None) Source #
Match the two states of the Option and return a non-null R.
type | B | Return type |
param | Some | Some match operation. Must not return null. |
param | None | None match operation. Must not return null. |
returns | A non-null B |
method B Match <B> (Func<A, B> Some, B None) Source #
Match the two states of the Option and return a non-null R.
type | B | Return type |
param | Some | Some match operation. Must not return null. |
param | None | None match operation. Must not return null. |
returns | A non-null B |
method Unit Match (Action<A> Some, Action None) Source #
Match the two states of the Option
param | Some | Some match operation |
param | None | None match operation |
method Unit IfSome (Action<A> f) Source #
Invokes the action if Option is in the Some state, otherwise nothing happens.
param | f | Action to invoke if Option is in the Some state |
method Unit IfSome (Func<A, Unit> f) Source #
Invokes the f function if Option is in the Some state, otherwise nothing happens.
param | f | Function to invoke if Option is in the Some state |
method A IfNone (Func<A> None) Source #
Returns the result of invoking the None() operation if the optional is in a None state, otherwise the bound Some(x) value is returned.
Will not accept a null return value from the None operation
param | None | Operation to invoke if the structure is in a None state |
returns | Result of invoking the None() operation if the optional is in a None state, otherwise the bound Some(x) value is returned. |
method Unit IfNone (Action None) Source #
Invokes the action if Option is in the None state, otherwise nothing happens.
param | f | Action to invoke if Option is in the None state |
method A IfNone (A noneValue) Source #
Returns the noneValue if the optional is in a None state, otherwise the bound Some(x) value is returned.
Will not accept a null noneValue
param | noneValue | Value to return if in a None state |
returns | noneValue if the optional is in a None state, otherwise the bound Some(x) value is returned |
method S Fold <S> (S state, Func<S, A, S> folder) Source #
Option types are like lists of 0 or 1 items, and therefore follow the same rules when folding.
In the case of lists, 'Fold', when applied to a binary operator, a starting value(typically the left-identity of the operator), and a list, reduces the list using the binary operator, from left to right:
Note that, since the head of the resulting expression is produced by an application of the operator to the first element of the list, 'Fold' can produce a terminating expression from an infinite list.
type | S | Aggregate state type |
param | state | Initial state |
param | folder | Folder function, applied if Option is in a Some state |
returns | The aggregate state |
method S FoldBack <S> (S state, Func<S, A, S> folder) Source #
Option types are like lists of 0 or 1 items, and therefore follow the same rules when folding.
In the case of lists, 'Fold', when applied to a binary operator, a starting value(typically the left-identity of the operator), and a list, reduces the list using the binary operator, from left to right:
Note that, since the head of the resulting expression is produced by an application of the operator to the first element of the list, 'Fold' can produce a terminating expression from an infinite list.
type | S | Aggregate state type |
param | state | Initial state |
param | folder | Folder function, applied if Option is in a Some state |
returns | The aggregate state |
method S BiFold <S> (S state, Func<S, A, S> Some, Func<S, Unit, S> None) Source #
Option types are like lists of 0 or 1 items, and therefore follow the same rules when folding.
In the case of lists, 'Fold', when applied to a binary operator, a starting value(typically the left-identity of the operator), and a list, reduces the list using the binary operator, from left to right:
Note that, since the head of the resulting expression is produced by an application of the operator to the first element of the list, 'Fold' can produce a terminating expression from an infinite list.
type | S | Aggregate state type |
param | state | Initial state |
param | Some | Folder function, applied if Option is in a Some state |
param | None | Folder function, applied if Option is in a None state |
returns | The aggregate state |
method S BiFold <S> (S state, Func<S, A, S> Some, Func<S, S> None) Source #
Option types are like lists of 0 or 1 items, and therefore follow the same rules when folding.
In the case of lists, 'Fold', when applied to a binary operator, a starting value(typically the left-identity of the operator), and a list, reduces the list using the binary operator, from left to right:
Note that, since the head of the resulting expression is produced by an application of the operator to the first element of the list, 'Fold' can produce a terminating expression from an infinite list.
type | S | Aggregate state type |
param | state | Initial state |
param | Some | Folder function, applied if Option is in a Some state |
param | None | Folder function, applied if Option is in a None state |
returns | The aggregate state |
method Option<B> BiMap <B> (Func<A, B> Some, Func<Unit, B> None) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | Some | Projection function |
param | None | Projection function |
returns | Mapped functor |
method Option<B> BiMap <B> (Func<A, B> Some, Func<B> None) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | Some | Projection function |
param | None | Projection function |
returns | Mapped functor |
Return the number of bound values in this structure:
None = 0
Some = 1
returns |
method bool ForAll (Func<A, bool> pred) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned (because the predicate applies for-all values). If the Option is in a Some state the value is the result of running applying the bound value to the predicate supplied.
param | pred | |
returns | If the Option is in a None state then True is returned (because the predicate applies for-all values). If the Option is in a Some state the value is the result of running applying the bound value to the predicate supplied. |
method bool BiForAll (Func<A, bool> Some, Func<Unit, bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | Some | Predicate to apply if in a Some state |
param | None | Predicate to apply if in a None state |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method bool BiForAll (Func<A, bool> Some, Func<bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | Some | Predicate to apply if in a Some state |
param | None | Predicate to apply if in a None state |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method bool Exists (Func<A, bool> pred) Source #
Apply a predicate to the bound value. If the Option is in a None state then False is returned. If the Option is in a Some state the value is the result of running applying the bound value to the predicate supplied.
param | pred | |
returns | If the Option is in a None state then False is returned. If the Option is in a Some state the value is the result of running applying the bound value to the predicate supplied. |
method bool BiExists (Func<A, bool> Some, Func<Unit, bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | pred | |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method bool BiExists (Func<A, bool> Some, Func<bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | pred | |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method Unit Iter (Action<A> Some) Source #
Invoke an action for the bound value (if in a Some state)
param | Some | Action to invoke |
method Unit BiIter (Action<A> Some, Action<Unit> None) Source #
Invoke an action depending on the state of the Option
param | Some | Action to invoke if in a Some state |
param | None | Action to invoke if in a None state |
method Unit BiIter (Action<A> Some, Action None) Source #
Invoke an action depending on the state of the Option
param | Some | Action to invoke if in a Some state |
param | None | Action to invoke if in a None state |
method Option<A> Filter (Func<A, bool> pred) Source #
Apply a predicate to the bound value (if in a Some state)
param | pred | Predicate to apply |
returns | Some(x) if the Option is in a Some state and the predicate returns True. None otherwise. |
method Option<A> Where (Func<A, bool> pred) Source #
Apply a predicate to the bound value (if in a Some state)
param | pred | Predicate to apply |
returns | Some(x) if the Option is in a Some state and the predicate returns True. None otherwise. |
method Option<Func<B, Func<C, D>>> ParMap <B, C, D> (Func<A, B, C, D> func) Source #
Partial application map
method IEnumerator<A> GetEnumerator () Source #
Get an enumerator for the Option
method Option<C> SelectMany <B, C> (Func<A, Pure<B>> bind, Func<A, B, C> project) Source #
Monadic bind and project
param | bind | Bind function |
param | project | Project function |
operator < (Option<A> lhs, Option<A> rhs) Source #
Comparison operator
param | lhs | The left hand side of the operation |
param | rhs | The right hand side of the operation |
returns | True if lhs〈 rhs |
operator <= (Option<A> lhs, Option<A> rhs) Source #
Comparison operator
param | lhs | The left hand side of the operation |
param | rhs | The right hand side of the operation |
returns | True if lhs〈= rhs |
operator > (Option<A> lhs, Option<A> rhs) Source #
Comparison operator
param | lhs | The left hand side of the operation |
param | rhs | The right hand side of the operation |
returns | True if lhs 〉rhs |
operator >= (Option<A> lhs, Option<A> rhs) Source #
Comparison operator
param | lhs | The left hand side of the operation |
param | rhs | The right hand side of the operation |
returns | True if lhs 〉= rhs |
operator == (Option<A> lhs, Option<A> rhs) Source #
Equality operator
This uses the EqDefault instance for comparison of the bound A values. The EqDefault instance wraps up the .NET EqualityComparer.Default behaviour. For more control over equality you can call:
equals〈EQ, A〉(lhs, rhs);
Where EQ is a struct derived from Eq〈A〉. For example:
equals〈EqString, string〉(lhs, rhs);
equals〈EqArray〈int〉, int[]〉(lhs, rhs);
param | lhs | Left hand side of the operation |
param | rhs | Right hand side of the operation |
returns | True if the values are equal |
operator != (Option<A> lhs, Option<A> rhs) Source #
Non-equality operator
This uses the EqDefault instance for comparison of the A value. The EqDefault trait wraps up the .NET EqualityComparer.Default behaviour. For more control over equality you can call:
!equals〈EQ, A〉(lhs, rhs);
Where EQ is a struct derived from Eq〈A〉. For example:
!equals〈EqString, string〉(lhs, rhs);
!equals〈EqArray〈int〉, int[]〉(lhs, rhs);
param | lhs | Left hand side of the operation |
param | rhs | Right hand side of the operation |
returns | True if the values are equal |
class OptionExtensions Source #
Extension methods for Option
method Validation<F, A> ToValidation <F, A> (Option<A> ma, F defaultFailureValue) Source #
method IEnumerable<A> Somes <A> (this IEnumerable<Option<A>> self) Source #
Extracts from a list of Option
all the Some
elements.
All the Some
elements are extracted in order.
method Seq<A> Somes <A> (this Seq<Option<A>> self) Source #
Extracts from a list of Option
all the Some
elements.
All the Some
elements are extracted in order.
method Option<A> Add <ARITH, A> (this Option<A> x, Option<A> y) Source #
Add the bound values of x and y, uses an Add trait to provide the add operation for type A. For example x.Add〈TInteger, int〉(y)
type | ADD | Add of A |
type | A | Bound value type |
param | x | Left hand side of the operation |
param | y | Right hand side of the operation |
returns | An option with y added to x |
method Option<A> Subtract <ARITH, A> (this Option<A> x, Option<A> y) Source #
Find the difference between the two bound values of x and y, uses a Subtract trait to provide the subtract operation for type A. For example x.Subtract〈TInteger, int〉(y)
type | DIFF | Subtract of A |
type | A | Bound value type |
param | x | Left hand side of the operation |
param | y | Right hand side of the operation |
returns | An option with the difference between x and y |
method Option<A> Product <ARITH, A> (this Option<A> x, Option<A> y) Source #
Find the product between the two bound values of x and y, uses a Product trait to provide the product operation for type A. For example x.Product〈TInteger, int〉(y)
type | PROD | Product of A |
type | A | Bound value type |
param | x | Left hand side of the operation |
param | y | Right hand side of the operation |
returns | An option with the product of x and y |
method Option<A> Divide <NUM, A> (this Option<A> x, Option<A> y) Source #
Divide the two bound values of x and y, uses a Divide trait to provide the divide operation for type A. For example x.Divide〈TDouble, double〉(y)
type | DIV | Divide of A |
type | A | Bound value type |
param | x | Left hand side of the operation |
param | y | Right hand side of the operation |
returns | An option x / y |
method A? ToNullable <A> (this Option<A> ma) Source #
Convert the Option type to a Nullable of A
type | A | Type of the bound value |
param | ma | Option to convert |
returns | Nullable of A |
method R Match <R> (this Option<bool> ma, Func<R> True, Func<R> False, Func<R> None) Source #
Match for an optional boolean
type | R | |
param | ma | Optional boolean |
param | True | Match for Some(true) |
param | False | Match for Some(false) |
param | None | Match for None |
returns |
method IEnumerable<R> Match <T, R> (this IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, Func<IEnumerable<R>> None) Source #
Match over a list of options
type | T | Type of the bound values |
type | R | Result type |
param | list | List of options to match against |
param | Some | Operation to perform when an Option is in the Some state |
param | None | Operation to perform when an Option is in the None state |
returns | An enumerable of results of the match operations |
method IEnumerable<R> Match <T, R> (this IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, IEnumerable<R> None) Source #
Match over a list of options
type | T | Type of the bound values |
type | R | Result type |
param | list | List of options to match against |
param | Some | Operation to perform when an Option is in the Some state |
param | None | Default if the list is empty |
returns | An enumerable of results of the match operations |
class OptionExtensions Source #
method Option<B> Map <A, B> (this Func<A, B> f, K<Option, A> ma) Source #
Functor map operation
Unwraps the value within the functor, passes it to the map function f
provided, and
then takes the mapped value and wraps it back up into a new functor.
param | ma | Functor to map |
param | f | Mapping function |
returns | Mapped functor |
method Option<B> Map <A, B> (this Func<A, B> f, Option<A> ma) Source #
Functor map operation
Unwraps the value within the functor, passes it to the map function f
provided, and
then takes the mapped value and wraps it back up into a new functor.
param | ma | Functor to map |
param | f | Mapping function |
returns | Mapped functor |
method Option<B> Action <A, B> (this Option<A> ma, K<Option, B> mb) Source #
Applicative action: runs the first applicative, ignores the result, and returns the second applicative
method Option<B> Action <A, B> (this K<Option, A> ma, K<Option, B> mb) Source #
Applicative action: runs the first applicative, ignores the result, and returns the second applicative
method Option<B> Apply <A, B> (this Option<Func<A, B>> mf, K<Option, A> ma) Source #
Applicative functor apply operation
Unwraps the value within the ma
applicative-functor, passes it to the unwrapped function(s) within mf
, and
then takes the resulting value and wraps it back up into a new applicative-functor.
param | ma | Value(s) applicative functor |
param | mf | Mapping function(s) |
returns | Mapped applicative functor |
method Option<B> Apply <A, B> (this K<Option, Func<A, B>> mf, K<Option, A> ma) Source #
Applicative functor apply operation
Unwraps the value within the ma
applicative-functor, passes it to the unwrapped function(s) within mf
, and
then takes the resulting value and wraps it back up into a new applicative-functor.
param | ma | Value(s) applicative functor |
param | mf | Mapping function(s) |
returns | Mapped applicative functor |
method Option<T> subtract <NUM, T> (Option<T> lhs, Option<T> rhs) Source #
Subtract the Ts
param | lhs | Left-hand side of the operation |
param | rhs | Right-hand side of the operation |
returns | lhs - rhs |
method Option<T> product <NUM, T> (Option<T> lhs, Option<T> rhs) Source #
Find the product of the Ts
method Option<T> divide <NUM, T> (Option<T> lhs, Option<T> rhs) Source #
Divide the Ts
param | lhs | Left-hand side of the operation |
param | rhs | Right-hand side of the operation |
returns | lhs / rhs |
method Option<T> add <NUM, T> (Option<T> lhs, Option<T> rhs) Source #
Add the Ts
param | lhs | Left-hand side of the operation |
param | rhs | Right-hand side of the operation |
returns | lhs / rhs |
method bool isSome <T> (Option<T> value) Source #
Check if Option is in a Some state
type | T | T |
param | value | Option |
returns | True if value is in a Some state |
method bool isNone <T> (Option<T> value) Source #
Check if Option is in a None state
type | T | T |
param | value | Option |
returns | True if value is in a None state |
method Option<A> Some <A> (A value) Source #
Create a Some
of A
type | A | Bound value type |
param | value | Non-null value to be made optional |
returns |
|
method Option<A> Some <A> (A? value) Source #
Create a Some
of A
from a Nullable〈A〉
type | A | Bound value type |
param | value | Non-null value to be made optional |
returns |
|
method Option<A> Optional <A> (A? value) Source #
Create an Option
of A
type | A | Bound value type |
param | value | Value to be made optional, or |
returns | If the value is |
method Option<A> Optional <A> (A? value) Source #
Create an Option
of A
type | A | Bound value type |
param | value | Value to be made optional, or null |
returns | If the value is |
method Unit ifSome <T> (Option<T> option, Action<T> Some) Source #
Invokes the action if Option is in the Some state, otherwise nothing happens.
param | f | Action to invoke if Option is in the Some state |
method T ifNone <T> (Option<T> option, Func<T> None) Source #
Returns the result of invoking the None() operation if the optional is in a None state, otherwise the bound Some(x) value is returned.
Will not accept a null return value from the None operation
param | None | Operation to invoke if the structure is in a None state |
returns | Result of invoking the None() operation if the optional is in a None state, otherwise the bound Some(x) value is returned. |
method T ifNone <T> (Option<T> option, T noneValue) Source #
Returns the noneValue if the optional is in a None state, otherwise the bound Some(x) value is returned.
Will not accept a null noneValue
param | noneValue | Value to return if in a None state |
returns | noneValue if the optional is in a None state, otherwise the bound Some(x) value is returned |
method R match <T, R> (Option<T> option, Func<T, R> Some, Func<R> None) Source #
Match the two states of the Option and return a non-null R.
type | B | Return type |
param | Some | Some match operation. Must not return null. |
param | None | None match operation. Must not return null. |
returns | A non-null B |
method Unit match <T> (Option<T> option, Action<T> Some, Action None) Source #
Match the two states of the Option
param | Some | Some match operation |
param | None | None match operation |
method S bifold <S, A> (Option<A> option, S state, Func<S, A, S> Some, Func<S, S> None) Source #
Option types are like lists of 0 or 1 items, and therefore follow the same rules when folding.
In the case of lists, 'Fold', when applied to a binary operator, a starting value(typically the left-identity of the operator), and a list, reduces the list using the binary operator, from left to right:
Note that, since the head of the resulting expression is produced by an application of the operator to the first element of the list, 'Fold' can produce a terminating expression from an infinite list.
type | S | Aggregate state type |
param | state | Initial state |
param | Some | Folder function, applied if Option is in a Some state |
param | None | Folder function, applied if Option is in a None state |
returns | The aggregate state |
method S bifold <S, A> (Option<A> option, S state, Func<S, A, S> Some, Func<S, Unit, S> None) Source #
Option types are like lists of 0 or 1 items, and therefore follow the same rules when folding.
In the case of lists, 'Fold', when applied to a binary operator, a starting value(typically the left-identity of the operator), and a list, reduces the list using the binary operator, from left to right:
Note that, since the head of the resulting expression is produced by an application of the operator to the first element of the list, 'Fold' can produce a terminating expression from an infinite list.
type | S | Aggregate state type |
param | state | Initial state |
param | Some | Folder function, applied if Option is in a Some state |
param | None | Folder function, applied if Option is in a None state |
returns | The aggregate state |
method bool forall <A> (Option<A> option, Func<A, bool> pred) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned (because the predicate applies for-all values). If the Option is in a Some state the value is the result of running applying the bound value to the predicate supplied.
param | pred | Predicate to apply |
returns | If the Option is in a None state then True is returned (because the predicate applies for-all values). If the Option is in a Some state the value is the result of running applying the bound value to the predicate supplied. |
method bool biforall <A> (Option<A> option, Func<A, bool> Some, Func<Unit, bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | Some | Predicate to apply if in a Some state |
param | None | Predicate to apply if in a None state |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method bool biforall <A> (Option<A> option, Func<A, bool> Some, Func<bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | Some | Predicate to apply if in a Some state |
param | None | Predicate to apply if in a None state |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method int count <A> (Option<A> option) Source #
Return the number of bound values in this structure:
None = 0
Some = 1
returns |
method bool exists <A> (Option<A> option, Func<A, bool> pred) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | pred | Predicate to apply |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method bool biexists <A> (Option<A> option, Func<A, bool> Some, Func<Unit, bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | Some | Predicate to apply if in a Some state |
param | None | Predicate to apply if in a None state |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method bool biexists <A> (Option<A> option, Func<A, bool> Some, Func<bool> None) Source #
Apply a predicate to the bound value. If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied.
param | Some | Predicate to apply if in a Some state |
param | None | Predicate to apply if in a None state |
returns | If the Option is in a None state then True is returned if invoking None returns True. If the Option is in a Some state the value is the result of running applying the bound value to the Some predicate supplied. |
method Option<B> map <A, B> (Option<A> option, Func<A, B> f) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | f | Projection function |
returns | Mapped functor |
method Option<B> bimap <A, B> (Option<A> option, Func<A, B> Some, Func<B> None) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | Some | Projection function |
param | None | Projection function |
returns | Mapped functor |
method Option<B> bimap <A, B> (Option<A> option, Func<A, B> Some, Func<Unit, B> None) Source #
Projection from one value to another
type | B | Resulting functor value type |
param | Some | Projection function |
param | None | Projection function |
returns | Mapped functor |
method Option<T> filter <T> (Option<T> option, Func<T, bool> pred) Source #
Apply a predicate to the bound value (if in a Some state)
param | pred | Predicate to apply |
returns | Some(x) if the Option is in a Some state and the predicate returns True. None otherwise. |
method Option<R> bind <T, R> (Option<T> option, Func<T, Option<R>> binder) Source #
Monadic bind operation
method IEnumerable<R> match <T, R> ( IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, Func<IEnumerable<R>> None) Source #
Match the two states of the list of Options
param | Some | Some match operation |
param | None | None match operation |
method IEnumerable<R> match <T, R> (IEnumerable<Option<T>> list, Func<T, IEnumerable<R>> Some, IEnumerable<R> None) Source #
Match the two states of the list of Options
param | Some | Some match operation |
param | None | None match operation |
method IEnumerable<T> somes <T> (IEnumerable<Option<T>> list) Source #
Extracts from a list of 'Option' all the 'Some' elements. All the 'Some' elements are extracted in order.
method Option<B> map <A, B> (Func<A, B> f, K<Option, A> ma) Source #
Functor map operation
Unwraps the value within the functor, passes it to the map function f
provided, and
then takes the mapped value and wraps it back up into a new functor.
param | ma | Functor to map |
param | f | Mapping function |
returns | Mapped functor |
method Option<B> action <A, B> (K<Option, A> ma, K<Option, B> mb) Source #
Applicative action: runs the first applicative, ignores the result, and returns the second applicative
method Option<B> apply <A, B> (K<Option, Func<A, B>> mf, K<Option, A> ma) Source #
Applicative functor apply operation
Unwraps the value within the ma
applicative-functor, passes it to the unwrapped function(s) within mf
, and
then takes the resulting value and wraps it back up into a new applicative-functor.
param | ma | Value(s) applicative functor |
param | mf | Mapping function(s) |
returns | Mapped applicative functor |