X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=compiler%2FhsSyn%2FHsImpExp.lhs;h=ebd18eacf82351ed53807978304c965f325a90af;hp=f63d86aec2af50e52ad8f6c22f86be6066b5ebe0;hb=17b297d97d327620ed6bfab942f8992b2446f1bf;hpb=61d2625ae2e6a4cdae2ffc92df828905e81c24cc diff --git a/compiler/hsSyn/HsImpExp.lhs b/compiler/hsSyn/HsImpExp.lhs index f63d86a..ebd18ea 100644 --- a/compiler/hsSyn/HsImpExp.lhs +++ b/compiler/hsSyn/HsImpExp.lhs @@ -1,14 +1,25 @@ % +% (c) The University of Glasgow 2006 % (c) The GRASP/AQUA Project, Glasgow University, 1992-1998 % -\section[HsImpExp]{Abstract syntax: imports, exports, interfaces} + +HsImpExp: Abstract syntax: imports, exports, interfaces \begin{code} +{-# OPTIONS_GHC -w #-} +-- The above warning supression flag is a temporary kludge. +-- While working on this module you are encouraged to remove it and fix +-- any warnings in the module. See +-- http://hackage.haskell.org/trac/ghc/wiki/WorkingConventions#Warnings +-- for details + module HsImpExp where #include "HsVersions.h" import Module ( ModuleName ) +import HsDoc ( HsDoc ) + import Outputable import FastString import SrcLoc ( Located(..) ) @@ -68,11 +79,14 @@ ideclName (ImportDecl mod_nm _ _ _ _) = mod_nm type LIE name = Located (IE name) data IE name - = IEVar name - | IEThingAbs name -- Class/Type (can't tell) - | IEThingAll name -- Class/Type plus all methods/constructors - | IEThingWith name [name] -- Class/Type plus some methods/constructors - | IEModuleContents ModuleName -- (Export Only) + = IEVar name + | IEThingAbs name -- Class/Type (can't tell) + | IEThingAll name -- Class/Type plus all methods/constructors + | IEThingWith name [name] -- Class/Type plus some methods/constructors + | IEModuleContents ModuleName -- (Export Only) + | IEGroup Int (HsDoc name) -- Doc section heading + | IEDoc (HsDoc name) -- Some documentation + | IEDocNamed String -- Reference to named doc \end{code} \begin{code} @@ -88,6 +102,9 @@ ieNames (IEThingAbs n ) = [n] ieNames (IEThingAll n ) = [n] ieNames (IEThingWith n ns) = n:ns ieNames (IEModuleContents _ ) = [] +ieNames (IEGroup _ _ ) = [] +ieNames (IEDoc _ ) = [] +ieNames (IEDocNamed _ ) = [] \end{code} \begin{code} @@ -99,6 +116,9 @@ instance (Outputable name) => Outputable (IE name) where = ppr thing <> parens (fsep (punctuate comma (map pprHsVar withs))) ppr (IEModuleContents mod) = ptext SLIT("module") <+> ppr mod + ppr (IEGroup n doc) = text ("") + ppr (IEDoc doc) = ppr doc + ppr (IEDocNamed string) = text ("") \end{code} \begin{code}