{-# LANGUAGE CPP #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE ImplicitParams #-}
{-# LANGUAGE ExistentialQuantification #-}
#if ( __GLASGOW_HASKELL__ >= 800 )
{-# LANGUAGE TypeInType #-}
#endif
#if MIN_VERSION_base(4,9,0)
{-# OPTIONS_GHC -fno-warn-redundant-constraints #-}
#endif
module Protolude.Error
( error
) where
import Data.Text (Text, unpack)
#if MIN_VERSION_base(4,9,0)
import GHC.Prim (TYPE, raise#)
import GHC.Types (RuntimeRep)
import Protolude.CallStack (HasCallStack)
import GHC.Exception (errorCallWithCallStackException)
{-# WARNING error "'error' remains in code" #-}
error :: forall (r :: RuntimeRep) . forall (a :: TYPE r) . HasCallStack => Text -> a
error :: forall a. HasCallStack => Text -> a
error Text
s = forall b a. b -> a
raise# (String -> CallStack -> SomeException
errorCallWithCallStackException (Text -> String
unpack Text
s) HasCallStack
?callStack)
#elif MIN_VERSION_base(4,7,0)
import GHC.Prim (raise#)
import GHC.Exception (errorCallException)
{-# WARNING error "'error' remains in code" #-}
error :: Text -> a
error s = raise# (errorCallException (unpack s))
#else
import GHC.Types
import GHC.Exception
{-# WARNING error "'error' remains in code" #-}
error :: Text -> a
error s = throw (ErrorCall (unpack s))
#endif