{-# LANGUAGE CPP #-}
module GHC.Types.TyThing.Ppr (
        pprTyThing,
        pprTyThingInContext,
        pprTyThingLoc,
        pprTyThingInContextLoc,
        pprTyThingHdr,
        pprTypeForUser,
        pprFamInst
  ) where
#include "HsVersions.h"
import GHC.Prelude
import GHC.Driver.Ppr (warnPprTrace)
import GHC.Types.TyThing ( TyThing(..), tyThingParent_maybe )
import GHC.Types.Name
import GHC.Types.Var.Env( emptyTidyEnv )
import GHC.Core.Type    ( Type, ArgFlag(..), mkTyVarBinders, tidyOpenType )
import GHC.Core.Coercion.Axiom ( coAxiomTyCon )
import GHC.Core.FamInstEnv( FamInst(..), FamFlavor(..) )
import GHC.Core.TyCo.Ppr ( pprUserForAll, pprTypeApp, pprSigmaType )
import GHC.Iface.Syntax ( ShowSub(..), ShowHowMuch(..), AltPpr(..)
  , showToHeader, pprIfaceDecl )
import GHC.Iface.Make ( tyThingToIfaceDecl )
import GHC.Utils.Outputable
pprFamInst :: FamInst -> SDoc
pprFamInst :: FamInst -> SDoc
pprFamInst (FamInst { fi_flavor :: FamInst -> FamFlavor
fi_flavor = DataFamilyInst TyCon
rep_tc })
  = TyThing -> SDoc
pprTyThingInContextLoc (TyCon -> TyThing
ATyCon TyCon
rep_tc)
pprFamInst (FamInst { fi_flavor :: FamInst -> FamFlavor
fi_flavor = FamFlavor
SynFamilyInst, fi_axiom :: FamInst -> CoAxiom Unbranched
fi_axiom = CoAxiom Unbranched
axiom
                    , fi_tvs :: FamInst -> [TyVar]
fi_tvs = [TyVar]
tvs, fi_tys :: FamInst -> [Type]
fi_tys = [Type]
lhs_tys, fi_rhs :: FamInst -> Type
fi_rhs = Type
rhs })
  = SDoc -> SDoc -> SDoc
showWithLoc (Name -> SDoc
pprDefinedAt (forall a. NamedThing a => a -> Name
getName CoAxiom Unbranched
axiom)) forall a b. (a -> b) -> a -> b
$
    SDoc -> Int -> SDoc -> SDoc
hang (String -> SDoc
text String
"type instance"
            SDoc -> SDoc -> SDoc
<+> [TyCoVarBinder] -> SDoc
pprUserForAll (forall vis. vis -> [TyVar] -> [VarBndr TyVar vis]
mkTyVarBinders ArgFlag
Specified [TyVar]
tvs)
                
                
            SDoc -> SDoc -> SDoc
<+> TyCon -> [Type] -> SDoc
pprTypeApp (forall (br :: BranchFlag). CoAxiom br -> TyCon
coAxiomTyCon CoAxiom Unbranched
axiom) [Type]
lhs_tys)
       Int
2 (SDoc
equals SDoc -> SDoc -> SDoc
<+> forall a. Outputable a => a -> SDoc
ppr Type
rhs)
pprTyThingLoc :: TyThing -> SDoc
pprTyThingLoc :: TyThing -> SDoc
pprTyThingLoc TyThing
tyThing
  = SDoc -> SDoc -> SDoc
showWithLoc (Name -> SDoc
pprDefinedAt (forall a. NamedThing a => a -> Name
getName TyThing
tyThing))
                (ShowSub -> TyThing -> SDoc
pprTyThing ShowSub
showToHeader TyThing
tyThing)
pprTyThingHdr :: TyThing -> SDoc
pprTyThingHdr :: TyThing -> SDoc
pprTyThingHdr = ShowSub -> TyThing -> SDoc
pprTyThing ShowSub
showToHeader
pprTyThingInContext :: ShowSub -> TyThing -> SDoc
pprTyThingInContext :: ShowSub -> TyThing -> SDoc
pprTyThingInContext ShowSub
show_sub TyThing
thing
  = [OccName] -> TyThing -> SDoc
go [] TyThing
thing
  where
    go :: [OccName] -> TyThing -> SDoc
go [OccName]
ss TyThing
thing
      = case TyThing -> Maybe TyThing
tyThingParent_maybe TyThing
thing of
          Just TyThing
parent ->
            [OccName] -> TyThing -> SDoc
go (forall a. NamedThing a => a -> OccName
getOccName TyThing
thing forall a. a -> [a] -> [a]
: [OccName]
ss) TyThing
parent
          Maybe TyThing
Nothing ->
            ShowSub -> TyThing -> SDoc
pprTyThing
              (ShowSub
show_sub { ss_how_much :: ShowHowMuch
ss_how_much = [OccName] -> AltPpr -> ShowHowMuch
ShowSome [OccName]
ss (Maybe (OccName -> SDoc) -> AltPpr
AltPpr forall a. Maybe a
Nothing) })
              TyThing
thing
pprTyThingInContextLoc :: TyThing -> SDoc
pprTyThingInContextLoc :: TyThing -> SDoc
pprTyThingInContextLoc TyThing
tyThing
  = SDoc -> SDoc -> SDoc
showWithLoc (Name -> SDoc
pprDefinedAt (forall a. NamedThing a => a -> Name
getName TyThing
tyThing))
                (ShowSub -> TyThing -> SDoc
pprTyThingInContext ShowSub
showToHeader TyThing
tyThing)
pprTyThing :: ShowSub -> TyThing -> SDoc
pprTyThing :: ShowSub -> TyThing -> SDoc
pprTyThing ShowSub
ss TyThing
ty_thing
  = forall a. (SDocContext -> a) -> (a -> SDoc) -> SDoc
sdocOption SDocContext -> Bool
sdocLinearTypes forall a b. (a -> b) -> a -> b
$ \Bool
show_linear_types ->
      ShowSub -> IfaceDecl -> SDoc
pprIfaceDecl ShowSub
ss' (Bool -> TyThing -> IfaceDecl
tyThingToIfaceDecl Bool
show_linear_types TyThing
ty_thing)
  where
    ss' :: ShowSub
ss' = case ShowSub -> ShowHowMuch
ss_how_much ShowSub
ss of
      ShowHeader (AltPpr Maybe (OccName -> SDoc)
Nothing)  -> ShowSub
ss { ss_how_much :: ShowHowMuch
ss_how_much = AltPpr -> ShowHowMuch
ShowHeader AltPpr
ppr' }
      ShowSome [OccName]
xs (AltPpr Maybe (OccName -> SDoc)
Nothing) -> ShowSub
ss { ss_how_much :: ShowHowMuch
ss_how_much = [OccName] -> AltPpr -> ShowHowMuch
ShowSome [OccName]
xs AltPpr
ppr' }
      ShowHowMuch
_                   -> ShowSub
ss
    ppr' :: AltPpr
ppr' = Maybe (OccName -> SDoc) -> AltPpr
AltPpr forall a b. (a -> b) -> a -> b
$ Name -> Maybe (OccName -> SDoc)
ppr_bndr forall a b. (a -> b) -> a -> b
$ forall a. NamedThing a => a -> Name
getName TyThing
ty_thing
    ppr_bndr :: Name -> Maybe (OccName -> SDoc)
    ppr_bndr :: Name -> Maybe (OccName -> SDoc)
ppr_bndr Name
name
      | Name -> Bool
isBuiltInSyntax Name
name
         = forall a. Maybe a
Nothing
      | Bool
otherwise
         = case Name -> Maybe Module
nameModule_maybe Name
name of
             Just Module
mod -> forall a. a -> Maybe a
Just forall a b. (a -> b) -> a -> b
$ \OccName
occ -> (PprStyle -> SDoc) -> SDoc
getPprStyle forall a b. (a -> b) -> a -> b
$ \PprStyle
sty ->
               PprStyle -> Module -> OccName -> SDoc
pprModulePrefix PprStyle
sty Module
mod OccName
occ SDoc -> SDoc -> SDoc
<> forall a. Outputable a => a -> SDoc
ppr OccName
occ
             Maybe Module
Nothing  -> WARN( True, ppr name ) Nothing
             
pprTypeForUser :: Type -> SDoc
pprTypeForUser :: Type -> SDoc
pprTypeForUser Type
ty
  = Type -> SDoc
pprSigmaType Type
tidy_ty
  where
    (TidyEnv
_, Type
tidy_ty)     = TidyEnv -> Type -> (TidyEnv, Type)
tidyOpenType TidyEnv
emptyTidyEnv Type
ty
     
     
     
     
showWithLoc :: SDoc -> SDoc -> SDoc
showWithLoc :: SDoc -> SDoc -> SDoc
showWithLoc SDoc
loc SDoc
doc
    = SDoc -> Int -> SDoc -> SDoc
hang SDoc
doc Int
2 (Char -> SDoc
char Char
'\t' SDoc -> SDoc -> SDoc
<> SDoc
comment SDoc -> SDoc -> SDoc
<+> SDoc
loc)
                
  where
    comment :: SDoc
comment = String -> SDoc
text String
"--"