29 lines
682 B
Haskell
29 lines
682 B
Haskell
{-# LANGUAGE ScopedTypeVariables #-}
|
|
|
|
module Language.Haskell.GhcMod.GHCChoice where
|
|
|
|
import Control.Exception
|
|
import CoreMonad
|
|
import Exception
|
|
import GHC
|
|
|
|
----------------------------------------------------------------
|
|
|
|
(||>) :: Ghc a -> Ghc a -> Ghc a
|
|
x ||> y = x `gcatch` (\(_ :: IOException) -> y)
|
|
|
|
(|||>) :: GhcMonad m => m a -> m a -> m a
|
|
x |||> y = x `gcatch` (\(_ :: IOException) -> y)
|
|
|
|
----------------------------------------------------------------
|
|
|
|
{-| Go to the next 'Ghc' monad by throwing 'AltGhcgoNext'.
|
|
-}
|
|
goNext :: Ghc a
|
|
goNext = liftIO . throwIO $ userError "goNext"
|
|
|
|
{-| Run any one 'Ghc' monad.
|
|
-}
|
|
runAnyOne :: [Ghc a] -> Ghc a
|
|
runAnyOne = foldr (||>) goNext
|