summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHerbert Valerio Riedel <hvr@gnu.org>2016-03-08 17:26:00 +0100
committerHerbert Valerio Riedel <hvr@gnu.org>2016-03-08 17:26:26 +0100
commit1c76e1686bd4291556ae9357151f256c805b4b5d (patch)
tree2ebf12bf489a715b8b1cbb61d5d44beda1273483
parent941b8f5fa1ffbf404fde1f59a7866b937efd173a (diff)
downloadhaskell-1c76e1686bd4291556ae9357151f256c805b4b5d.tar.gz
template-haskell: define `MonadFail Q` instance
When `MonadFail`is available, this patch makes `MonadFail` a superclass of `Quasi`, and `Q` an instance of `MonadFail`. NB: Since f16ddcee0c64a92ab911a7841a8cf64e3ac671fd, we need to be able to compile `template-haskell` with stage0 compilers that don't provide a `MonadFail` class yet. Once we reach GHC 8.3 development we can drop the CPP conditionals again. Addresses #11661 Reviewed By: bgamari, goldfire Differential Revision: https://phabricator.haskell.org/D1982
-rw-r--r--libraries/ghci/GHCi/TH.hs4
-rw-r--r--libraries/template-haskell/Language/Haskell/TH/Syntax.hs19
-rw-r--r--libraries/template-haskell/changelog.md2
-rw-r--r--testsuite/tests/stranal/should_compile/T9208.hs8
4 files changed, 33 insertions, 0 deletions
diff --git a/libraries/ghci/GHCi/TH.hs b/libraries/ghci/GHCi/TH.hs
index 00601ba933..152522166c 100644
--- a/libraries/ghci/GHCi/TH.hs
+++ b/libraries/ghci/GHCi/TH.hs
@@ -12,6 +12,7 @@ import GHCi.RemoteTypes
import GHC.Serialized
import Control.Exception
+import qualified Control.Monad.Fail as Fail
import Data.Binary
import Data.Binary.Put
import Data.ByteString (ByteString)
@@ -60,6 +61,9 @@ instance Monad GHCiQ where
do (m', s') <- runGHCiQ m s
(a, s'') <- runGHCiQ (f m') s'
return (a, s'')
+ fail = Fail.fail
+
+instance Fail.MonadFail GHCiQ where
fail err = GHCiQ $ \s -> throwIO (GHCiQException s err)
getState :: GHCiQ QState
diff --git a/libraries/template-haskell/Language/Haskell/TH/Syntax.hs b/libraries/template-haskell/Language/Haskell/TH/Syntax.hs
index f26f37e2d1..ce3c9083b2 100644
--- a/libraries/template-haskell/Language/Haskell/TH/Syntax.hs
+++ b/libraries/template-haskell/Language/Haskell/TH/Syntax.hs
@@ -4,6 +4,10 @@
{-# OPTIONS_GHC -fno-warn-inline-rule-shadowing #-}
+#if MIN_VERSION_base(4,9,0)
+# define HAS_MONADFAIL 1
+#endif
+
-----------------------------------------------------------------------------
-- |
-- Module : Language.Haskell.Syntax
@@ -38,13 +42,21 @@ import GHC.Lexeme ( startsVarSym, startsVarId )
import Language.Haskell.TH.LanguageExtensions
import Numeric.Natural
+#if HAS_MONADFAIL
+import qualified Control.Monad.Fail as Fail
+#endif
+
-----------------------------------------------------
--
-- The Quasi class
--
-----------------------------------------------------
+#if HAS_MONADFAIL
+class Fail.MonadFail m => Quasi m where
+#else
class Monad m => Quasi m where
+#endif
qNewName :: String -> m Name
-- ^ Fresh names
@@ -162,7 +174,14 @@ runQ (Q m) = m
instance Monad Q where
Q m >>= k = Q (m >>= \x -> unQ (k x))
(>>) = (*>)
+#if !HAS_MONADFAIL
fail s = report True s >> Q (fail "Q monad failure")
+#else
+ fail = Fail.fail
+
+instance Fail.MonadFail Q where
+ fail s = report True s >> Q (Fail.fail "Q monad failure")
+#endif
instance Functor Q where
fmap f (Q x) = Q (fmap f x)
diff --git a/libraries/template-haskell/changelog.md b/libraries/template-haskell/changelog.md
index 1c0919a8a2..c313c62d14 100644
--- a/libraries/template-haskell/changelog.md
+++ b/libraries/template-haskell/changelog.md
@@ -43,6 +43,8 @@
fixity if there is an explicit fixity declaration for that `Name`, and
`Nothing` otherwise (#10704 and #11345)
+ * Add `MonadFail Q` instance for GHC 8.0 and later (#11661)
+
* TODO: document API changes and important bugfixes
diff --git a/testsuite/tests/stranal/should_compile/T9208.hs b/testsuite/tests/stranal/should_compile/T9208.hs
index f587da7640..bf98fba9f6 100644
--- a/testsuite/tests/stranal/should_compile/T9208.hs
+++ b/testsuite/tests/stranal/should_compile/T9208.hs
@@ -22,6 +22,9 @@ module Eval (
import Control.Applicative
import Control.Monad
+#if __GLASGOW_HASKELL__ >= 800
+import Control.Monad.Fail (MonadFail(fail))
+#endif
import Data.Binary
import Data.Binary.Get
@@ -73,6 +76,11 @@ instance Monad GHCJSQ where
return (a, s'')
return = pure
+#if __GLASGOW_HASKELL__ >= 800
+instance MonadFail GHCJSQ where
+ fail = undefined
+#endif
+
instance TH.Quasi GHCJSQ where qRunIO m = GHCJSQ $ \s -> fmap (,s) m
-- | the Template Haskell server