Commit 81765cc9 authored by Thomas Schilling's avatar Thomas Schilling
Browse files

Provide accessors for 'ImportDecl'.

parent 4feaaf7e
...@@ -33,13 +33,16 @@ One per \tr{import} declaration in a module. ...@@ -33,13 +33,16 @@ One per \tr{import} declaration in a module.
\begin{code} \begin{code}
type LImportDecl name = Located (ImportDecl name) type LImportDecl name = Located (ImportDecl name)
-- | A single Haskell @import@ declaration.
data ImportDecl name data ImportDecl name
= ImportDecl (Located ModuleName) -- module name = ImportDecl {
(Maybe FastString) -- package qualifier ideclName :: Located ModuleName, -- ^ Module name.
Bool -- True <=> {-# SOURCE #-} import ideclPkgQual :: Maybe FastString, -- ^ Package qualifier.
Bool -- True => qualified ideclSource :: Bool, -- ^ True <=> {-# SOURCE #-} import
(Maybe ModuleName) -- as Module ideclQualified :: Bool, -- ^ True => qualified
(Maybe (Bool, [LIE name])) -- (True => hiding, names) ideclAs :: Maybe ModuleName, -- ^ as Module
ideclHiding :: Maybe (Bool, [LIE name]) -- ^ (True => hiding, names)
}
\end{code} \end{code}
\begin{code} \begin{code}
...@@ -66,9 +69,6 @@ instance (Outputable name) => Outputable (ImportDecl name) where ...@@ -66,9 +69,6 @@ instance (Outputable name) => Outputable (ImportDecl name) where
= parens (interpp'SP spec) = parens (interpp'SP spec)
pp_spec (Just (True, spec)) pp_spec (Just (True, spec))
= ptext (sLit "hiding") <+> parens (interpp'SP spec) = ptext (sLit "hiding") <+> parens (interpp'SP spec)
ideclName :: ImportDecl name -> Located ModuleName
ideclName (ImportDecl mod_nm _ _ _ _ _) = mod_nm
\end{code} \end{code}
%************************************************************************ %************************************************************************
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment