diff options
| -rw-r--r-- | compiler/rename/RnNames.hs | 48 | 
1 files changed, 27 insertions, 21 deletions
| diff --git a/compiler/rename/RnNames.hs b/compiler/rename/RnNames.hs index 6b24d80e9c..8d3f1835ae 100644 --- a/compiler/rename/RnNames.hs +++ b/compiler/rename/RnNames.hs @@ -22,6 +22,8 @@ module RnNames (          dodgyMsg,          dodgyMsgInsert,          findImportUsage, +        getMinimalImports, +        printMinimalImports,          ImportDeclUsage      ) where @@ -1466,28 +1468,9 @@ decls, and simply trim their import lists.  NB that      from it.  Instead we just trim to an empty import list  -} -printMinimalImports :: [ImportDeclUsage] -> RnM () --- See Note [Printing minimal imports] -printMinimalImports imports_w_usage -  = do { imports' <- mapM mk_minimal imports_w_usage -       ; this_mod <- getModule -       ; dflags   <- getDynFlags -       ; liftIO $ -         do { h <- openFile (mkFilename dflags this_mod) WriteMode -            ; printForUser dflags h neverQualify (vcat (map ppr imports')) } -              -- The neverQualify is important.  We are printing Names -              -- but they are in the context of an 'import' decl, and -              -- we never qualify things inside there -              -- E.g.   import Blag( f, b ) -              -- not    import Blag( Blag.f, Blag.g )! -       } +getMinimalImports :: [ImportDeclUsage] -> RnM [LImportDecl GhcRn] +getMinimalImports = mapM mk_minimal    where -    mkFilename dflags this_mod -      | Just d <- dumpDir dflags = d </> basefn -      | otherwise                = basefn -      where -        basefn = moduleNameString (moduleName this_mod) ++ ".imports" -      mk_minimal (L l decl, used, unused)        | null unused        , Just (False, _) <- ideclHiding decl @@ -1538,6 +1521,29 @@ printMinimalImports imports_w_usage            all_non_overloaded = all (not . flIsOverloaded) +printMinimalImports :: [ImportDeclUsage] -> RnM () +-- See Note [Printing minimal imports] +printMinimalImports imports_w_usage +  = do { imports' <- getMinimalImports imports_w_usage +       ; this_mod <- getModule +       ; dflags   <- getDynFlags +       ; liftIO $ +         do { h <- openFile (mkFilename dflags this_mod) WriteMode +            ; printForUser dflags h neverQualify (vcat (map ppr imports')) } +              -- The neverQualify is important.  We are printing Names +              -- but they are in the context of an 'import' decl, and +              -- we never qualify things inside there +              -- E.g.   import Blag( f, b ) +              -- not    import Blag( Blag.f, Blag.g )! +       } +  where +    mkFilename dflags this_mod +      | Just d <- dumpDir dflags = d </> basefn +      | otherwise                = basefn +      where +        basefn = moduleNameString (moduleName this_mod) ++ ".imports" + +  to_ie_post_rn_var :: (HasOccName name) => Located name -> LIEWrappedName name  to_ie_post_rn_var (L l n)    | isDataOcc $ occName n = L l (IEPattern (L l n)) | 
