{-# LANGUAGE NoImplicitPrelude #-}
module Unsafe
( module Universum.Unsafe
, Unsafe.fromIntegral
, Unsafe.fromInteger
, unsafe
, unsafeM
) where
import Fmt (Buildable, pretty)
import Morley.Prelude.FromIntegral (fromIntegralNoOverflow)
import Universum
import Universum.Unsafe
fromIntegral :: (HasCallStack, Integral a, Integral b) => a -> b
fromIntegral :: a -> b
fromIntegral = (ArithException -> b) -> (b -> b) -> Either ArithException b -> b
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (Text -> b
forall a. HasCallStack => Text -> a
error (Text -> b) -> (ArithException -> Text) -> ArithException -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> Text
forall a. IsString a => String -> a
fromString (String -> Text)
-> (ArithException -> String) -> ArithException -> Text
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ArithException -> String
forall e. Exception e => e -> String
displayException) b -> b
forall a. a -> a
id (Either ArithException b -> b)
-> (a -> Either ArithException b) -> a -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Either ArithException b
forall a b.
(Integral a, Integral b) =>
a -> Either ArithException b
fromIntegralNoOverflow
fromInteger :: (HasCallStack, Integral a) => Integer -> a
fromInteger :: Integer -> a
fromInteger = Integer -> a
forall a b. (HasCallStack, Integral a, Integral b) => a -> b
Unsafe.fromIntegral
unsafe :: (HasCallStack, Buildable a) => Either a b -> b
unsafe :: Either a b -> b
unsafe = (a -> b) -> (b -> b) -> Either a b -> b
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (Text -> b
forall a. HasCallStack => Text -> a
error (Text -> b) -> (a -> Text) -> a -> b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> Text
forall a b. (Buildable a, FromBuilder b) => a -> b
pretty) b -> b
forall a. a -> a
id
{-# INLINE unsafe #-}
unsafeM :: (MonadFail m, Buildable a) => Either a b -> m b
unsafeM :: Either a b -> m b
unsafeM = (a -> m b) -> (b -> m b) -> Either a b -> m b
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (String -> m b
forall (m :: * -> *) a. MonadFail m => String -> m a
fail (String -> m b) -> (a -> String) -> a -> m b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> String
forall a b. (Buildable a, FromBuilder b) => a -> b
pretty) b -> m b
forall (f :: * -> *) a. Applicative f => a -> f a
pure
{-# INLINE unsafeM #-}