{-# LANGUAGE AllowAmbiguousTypes #-}
{-# LANGUAGE ScopedTypeVariables #-}
module Witch.Utility where
import qualified Control.Exception as Exception
import qualified Data.Coerce as Coerce
import qualified Data.Typeable as Typeable
import qualified GHC.Stack as Stack
import qualified Witch.From as From
import qualified Witch.TryFrom as TryFrom
import qualified Witch.TryFromException as TryFromException
as :: forall source. source -> source
as :: forall source. source -> source
as = forall source. source -> source
id
into :: forall target source. From.From source target => source -> target
into :: forall target source. From source target => source -> target
into = forall source target. From source target => source -> target
From.from
over ::
forall target source.
(From.From source target, From.From target source) =>
(target -> target) ->
source ->
source
over :: forall target source.
(From source target, From target source) =>
(target -> target) -> source -> source
over target -> target
f = forall source target. From source target => source -> target
From.from forall b c a. (b -> c) -> (a -> b) -> a -> c
. target -> target
f forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall source target. From source target => source -> target
From.from
via ::
forall through source target.
(From.From source through, From.From through target) =>
source ->
target
via :: forall through source target.
(From source through, From through target) =>
source -> target
via = forall source target. From source target => source -> target
From.from forall b c a. (b -> c) -> (a -> b) -> a -> c
. (\through
x -> through
x :: through) forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall source target. From source target => source -> target
From.from
tryInto ::
forall target source.
TryFrom.TryFrom source target =>
source ->
Either (TryFromException.TryFromException source target) target
tryInto :: forall target source.
TryFrom source target =>
source -> Either (TryFromException source target) target
tryInto = forall source target.
TryFrom source target =>
source -> Either (TryFromException source target) target
TryFrom.tryFrom
tryVia ::
forall through source target.
(TryFrom.TryFrom source through, TryFrom.TryFrom through target) =>
source ->
Either (TryFromException.TryFromException source target) target
tryVia :: forall through source target.
(TryFrom source through, TryFrom through target) =>
source -> Either (TryFromException source target) target
tryVia source
s = case forall source target.
TryFrom source target =>
source -> Either (TryFromException source target) target
TryFrom.tryFrom source
s of
Left TryFromException source through
e -> forall a b. a -> Either a b
Left forall a b. (a -> b) -> a -> b
$ forall newTarget source oldTarget.
TryFromException source oldTarget
-> TryFromException source newTarget
withTarget TryFromException source through
e
Right through
u -> case forall source target.
TryFrom source target =>
source -> Either (TryFromException source target) target
TryFrom.tryFrom (through
u :: through) of
Left TryFromException through target
e -> forall a b. a -> Either a b
Left forall a b. (a -> b) -> a -> b
$ forall newSource oldSource target.
newSource
-> TryFromException oldSource target
-> TryFromException newSource target
withSource source
s TryFromException through target
e
Right target
t -> forall a b. b -> Either a b
Right target
t
maybeTryFrom ::
(source -> Maybe target) ->
source ->
Either (TryFromException.TryFromException source target) target
maybeTryFrom :: forall source target.
(source -> Maybe target)
-> source -> Either (TryFromException source target) target
maybeTryFrom source -> Maybe target
f source
s = case source -> Maybe target
f source
s of
Maybe target
Nothing -> forall a b. a -> Either a b
Left forall a b. (a -> b) -> a -> b
$ forall source target.
source -> Maybe SomeException -> TryFromException source target
TryFromException.TryFromException source
s forall a. Maybe a
Nothing
Just target
t -> forall a b. b -> Either a b
Right target
t
eitherTryFrom ::
Exception.Exception exception =>
(source -> Either exception target) ->
source ->
Either (TryFromException.TryFromException source target) target
eitherTryFrom :: forall exception source target.
Exception exception =>
(source -> Either exception target)
-> source -> Either (TryFromException source target) target
eitherTryFrom source -> Either exception target
f source
s = case source -> Either exception target
f source
s of
Left exception
e ->
forall a b. a -> Either a b
Left forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall source target.
source -> Maybe SomeException -> TryFromException source target
TryFromException.TryFromException source
s forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. a -> Maybe a
Just forall a b. (a -> b) -> a -> b
$ forall e. Exception e => e -> SomeException
Exception.toException exception
e
Right target
t -> forall a b. b -> Either a b
Right target
t
unsafeFrom ::
forall source target.
( Stack.HasCallStack,
TryFrom.TryFrom source target,
Show source,
Typeable.Typeable source,
Typeable.Typeable target
) =>
source ->
target
unsafeFrom :: forall source target.
(HasCallStack, TryFrom source target, Show source, Typeable source,
Typeable target) =>
source -> target
unsafeFrom = forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either forall a e. Exception e => e -> a
Exception.throw forall source. source -> source
id forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall source target.
TryFrom source target =>
source -> Either (TryFromException source target) target
TryFrom.tryFrom
unsafeInto ::
forall target source.
( Stack.HasCallStack,
TryFrom.TryFrom source target,
Show source,
Typeable.Typeable source,
Typeable.Typeable target
) =>
source ->
target
unsafeInto :: forall target source.
(HasCallStack, TryFrom source target, Show source, Typeable source,
Typeable target) =>
source -> target
unsafeInto = forall source target.
(HasCallStack, TryFrom source target, Show source, Typeable source,
Typeable target) =>
source -> target
unsafeFrom
withSource ::
newSource ->
TryFromException.TryFromException oldSource target ->
TryFromException.TryFromException newSource target
withSource :: forall newSource oldSource target.
newSource
-> TryFromException oldSource target
-> TryFromException newSource target
withSource newSource
x (TryFromException.TryFromException oldSource
_ Maybe SomeException
e) =
forall source target.
source -> Maybe SomeException -> TryFromException source target
TryFromException.TryFromException newSource
x Maybe SomeException
e
withTarget ::
forall newTarget source oldTarget.
TryFromException.TryFromException source oldTarget ->
TryFromException.TryFromException source newTarget
withTarget :: forall newTarget source oldTarget.
TryFromException source oldTarget
-> TryFromException source newTarget
withTarget = coerce :: forall a b. Coercible a b => a -> b
Coerce.coerce