Fix older GHCs
This commit is contained in:
parent
daeb5018f3
commit
4f289fc4e4
@ -14,16 +14,16 @@
|
|||||||
-- You should have received a copy of the GNU Affero General Public License
|
-- You should have received a copy of the GNU Affero General Public License
|
||||||
-- along with this program. If not, see <http://www.gnu.org/licenses/>.
|
-- along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
{-# LANGUAGE TemplateHaskell #-}
|
{-# LANGUAGE CPP, TemplateHaskell #-}
|
||||||
module Language.Haskell.GhcMod.DynFlagsTH where
|
module Language.Haskell.GhcMod.DynFlagsTH where
|
||||||
|
|
||||||
import Language.Haskell.TH.Syntax
|
import Language.Haskell.TH.Syntax
|
||||||
|
import Control.Applicative
|
||||||
import Data.Maybe
|
import Data.Maybe
|
||||||
import Data.Generics.Aliases
|
import Data.Generics.Aliases
|
||||||
import Data.Generics.Schemes
|
import Data.Generics.Schemes
|
||||||
import Packages
|
|
||||||
import Hooks
|
|
||||||
import DynFlags
|
import DynFlags
|
||||||
|
import Prelude
|
||||||
|
|
||||||
deriveEqDynFlags :: Q [Dec] -> Q [Dec]
|
deriveEqDynFlags :: Q [Dec] -> Q [Dec]
|
||||||
deriveEqDynFlags qds = do
|
deriveEqDynFlags qds = do
|
||||||
@ -42,24 +42,31 @@ deriveEqDynFlags qds = do
|
|||||||
where
|
where
|
||||||
eq :: Name -> Name -> (Name, Strict, Type) -> Maybe (Q Exp)
|
eq :: Name -> Name -> (Name, Strict, Type) -> Maybe (Q Exp)
|
||||||
eq a b (fn@(Name (OccName fon) _), _, ft)
|
eq a b (fn@(Name (OccName fon) _), _, ft)
|
||||||
| not isUneqable = Just expr
|
| not (isUneqable || isIgnored) = Just expr
|
||||||
| otherwise = Nothing
|
| otherwise = Nothing
|
||||||
where
|
where
|
||||||
isUneqable = everything (||) (mkQ False hasUnEqable) ft
|
isUneqable = everything (||) (mkQ False hasUnEqable) ft
|
||||||
|
|
||||||
hasUnEqable ArrowT = True
|
hasUnEqable ArrowT = True
|
||||||
hasUnEqable (ConT n@(Name (OccName on) _))
|
hasUnEqable (ConT (Name (OccName on) _))
|
||||||
| n == ''LogAction = True
|
| any (==on) ignoredTypeNames = True
|
||||||
| any (==n) ignoredTypeNames = True
|
|
||||||
| any (==on) ignoredTypeOccNames = True
|
| any (==on) ignoredTypeOccNames = True
|
||||||
hasUnEqable _ = False
|
hasUnEqable _ = False
|
||||||
|
|
||||||
|
isIgnored = fon `elem` ignoredNames
|
||||||
|
|
||||||
|
ignoredNames = [ "pkgDatabase" -- 7.8
|
||||||
|
#if __GLASGOW_HASKELL__ <= 706
|
||||||
|
, "ways" -- 'Ways' is not exported :/
|
||||||
|
#endif
|
||||||
|
]
|
||||||
ignoredTypeNames =
|
ignoredTypeNames =
|
||||||
[ ''PackageState
|
[ "LogAction"
|
||||||
, ''Hooks
|
, "PackageState"
|
||||||
, ''FlushOut
|
, "Hooks"
|
||||||
, ''FlushErr
|
, "FlushOut"
|
||||||
, ''Settings -- I think these can't cange at runtime
|
, "FlushErr"
|
||||||
|
, "Settings" -- I think these can't cange at runtime
|
||||||
]
|
]
|
||||||
ignoredTypeOccNames = [ "OnOff" ]
|
ignoredTypeOccNames = [ "OnOff" ]
|
||||||
|
|
||||||
@ -67,13 +74,6 @@ deriveEqDynFlags qds = do
|
|||||||
fb = AppE (VarE fn) (VarE b)
|
fb = AppE (VarE fn) (VarE b)
|
||||||
expr =
|
expr =
|
||||||
case fon of
|
case fon of
|
||||||
"language" -> do
|
|
||||||
eqfn <- [| let eqfn (Just Haskell98) (Just Haskell98) = True
|
|
||||||
eqfn (Just Haskell2010) (Just Haskell2010) = True
|
|
||||||
eqfn _ _ = False
|
|
||||||
in eqfn
|
|
||||||
|]
|
|
||||||
return $ AppE (AppE eqfn fa) fb
|
|
||||||
"rtsOptsEnabled" -> do
|
"rtsOptsEnabled" -> do
|
||||||
eqfn <- [| let eqfn RtsOptsNone RtsOptsNone = True
|
eqfn <- [| let eqfn RtsOptsNone RtsOptsNone = True
|
||||||
eqfn RtsOptsSafeOnly RtsOptsSafeOnly = True
|
eqfn RtsOptsSafeOnly RtsOptsSafeOnly = True
|
||||||
@ -83,6 +83,7 @@ deriveEqDynFlags qds = do
|
|||||||
|]
|
|]
|
||||||
return $ AppE (AppE eqfn fa) fb
|
return $ AppE (AppE eqfn fa) fb
|
||||||
|
|
||||||
|
#if __GLASGOW_HASKELL__ >= 710
|
||||||
"sigOf" -> do
|
"sigOf" -> do
|
||||||
eqfn <- [| let eqfn NotSigOf NotSigOf = True
|
eqfn <- [| let eqfn NotSigOf NotSigOf = True
|
||||||
eqfn (SigOf a') (SigOf b') = a' == b'
|
eqfn (SigOf a') (SigOf b') = a' == b'
|
||||||
@ -91,7 +92,30 @@ deriveEqDynFlags qds = do
|
|||||||
in eqfn
|
in eqfn
|
||||||
|]
|
|]
|
||||||
return $ AppE (AppE eqfn fa) fb
|
return $ AppE (AppE eqfn fa) fb
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __GLASGOW_HASKELL <= 706
|
||||||
|
"profAuto" -> do
|
||||||
|
eqfn <- [| let eqfn NoProfAuto NoProfAuto = True
|
||||||
|
eqfn ProfAutoAll ProfAutoAll = True
|
||||||
|
eqfn ProfAutoTop ProfAutoTop = True
|
||||||
|
eqfn ProfAutoExports ProfAutoExports = True
|
||||||
|
eqfn ProfAutoCalls ProfAutoCalls = True
|
||||||
|
eqfn _ _ = False
|
||||||
|
in eqfn
|
||||||
|
|]
|
||||||
|
return $ AppE (AppE eqfn fa) fb
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __GLASGOW_HASKELL__ >= 706
|
||||||
|
"language" -> do
|
||||||
|
eqfn <- [| let eqfn (Just Haskell98) (Just Haskell98) = True
|
||||||
|
eqfn (Just Haskell2010) (Just Haskell2010) = True
|
||||||
|
eqfn _ _ = False
|
||||||
|
in eqfn
|
||||||
|
|]
|
||||||
|
return $ AppE (AppE eqfn fa) fb
|
||||||
|
#endif
|
||||||
|
|
||||||
_ ->
|
_ ->
|
||||||
return $ InfixE (Just fa) (VarE '(==)) (Just fb)
|
return $ InfixE (Just fa) (VarE '(==)) (Just fb)
|
||||||
|
Loading…
Reference in New Issue
Block a user