module Language.HERMIT.GHC
(
ppIdInfo
, var2String
, thRdrNameGuesses
, name2THName
, id2THName
, cmpTHName2Name
, cmpTHName2Id
, unqualifiedIdName
, findNameFromTH
, alphaTyVars
, Type(..)
, GhcException(..)
, throwGhcException
, exprArity
) where
import GhcPlugins
import Convert (thRdrNameGuesses)
import TysPrim (alphaTyVars)
import TypeRep (Type(..))
import Panic (GhcException(ProgramError), throwGhcException)
import CoreArity
import Data.Maybe (isJust)
import qualified Language.Haskell.TH as TH
var2String :: Var -> String
var2String = occNameString . nameOccName . varName
name2THName :: Name -> TH.Name
name2THName = TH.mkName . getOccString
id2THName :: Id -> TH.Name
id2THName = name2THName . idName
unqualifiedIdName :: Id -> String
unqualifiedIdName = TH.nameBase . id2THName
cmpTHName2Name :: TH.Name -> Name -> Bool
cmpTHName2Name th_nm ghc_nm = TH.nameBase th_nm == getOccString ghc_nm
cmpTHName2Id :: TH.Name -> Id -> Bool
cmpTHName2Id nm = cmpTHName2Name nm . idName
findNameFromTH :: GlobalRdrEnv -> TH.Name -> [Name]
findNameFromTH rdrEnv nm =
[ gre_name elt
| elt <- concat $ occEnvElts rdrEnv
, cmpTHName2Name nm (gre_name elt)
]
ppIdInfo :: Id -> IdInfo -> SDoc
ppIdInfo v info
= showAttributes
[ (True, pp_scope <> ppr (idDetails v))
, (has_arity, ptext (sLit "Arity=") <> int arity)
, (has_caf_info, ptext (sLit "Caf=") <> ppr caf_info)
, (has_strictness, ptext (sLit "Str=") <> pprStrictness str_info)
, (has_unf, ptext (sLit "Unf=") <> ppr unf_info)
, (not (null rules), ptext (sLit "RULES:") <+> vcat (map ppr rules))
]
where
pp_scope | isGlobalId v = ptext (sLit "GblId")
| isExportedId v = ptext (sLit "LclIdX")
| otherwise = ptext (sLit "LclId")
arity = arityInfo info
has_arity = arity /= 0
caf_info = cafInfo info
has_caf_info = not (mayHaveCafRefs caf_info)
str_info = strictnessInfo info
has_strictness = isJust str_info
unf_info = unfoldingInfo info
has_unf = hasSomeUnfolding unf_info
rules = specInfoRules (specInfo info)
showAttributes :: [(Bool,SDoc)] -> SDoc
showAttributes stuff
| null docs = empty
| otherwise = brackets (sep (punctuate comma docs))
where
docs = [d | (True,d) <- stuff]