diff options
| author | simonmar <unknown> | 2004-11-26 16:22:13 +0000 |
|---|---|---|
| committer | simonmar <unknown> | 2004-11-26 16:22:13 +0000 |
| commit | ef5b4b146aa172d8ac10f39b5eb3d7a0f948d8f1 (patch) | |
| tree | ccf398dd86fd64e8034098b39f47e610885d88cd /ghc/compiler/iface/TcIface.lhs | |
| parent | 1f8b341a88b6b60935b0ce80b59ed6e356b8cfbf (diff) | |
| download | haskell-ef5b4b146aa172d8ac10f39b5eb3d7a0f948d8f1.tar.gz | |
[project @ 2004-11-26 16:19:45 by simonmar]
Further integration with the new package story. GHC now supports
pretty much everything in the package proposal.
- GHC now works in terms of PackageIds (<pkg>-<version>) rather than
just package names. You can still specify package names without
versions on the command line, as long as the name is unambiguous.
- GHC understands hidden/exposed modules in a package, and will refuse
to import a hidden module. Also, the hidden/eposed status of packages
is taken into account.
- I had to remove the old package syntax from ghc-pkg, backwards
compatibility isn't really practical.
- All the package.conf.in files have been rewritten in the new syntax,
and contain a complete list of modules in the package. I've set all
the versions to 1.0 for now - please check your package(s) and fix the
version number & other info appropriately.
- New options:
-hide-package P sets the expose flag on package P to False
-ignore-package P unregisters P for this compilation
For comparison, -package P sets the expose flag on package P
to True, and also causes P to be linked in eagerly.
-package-name is no longer officially supported. Unofficially, it's
a synonym for -ignore-package, which has more or less the same effect
as -package-name used to.
Note that a package may be hidden and yet still be linked into
the program, by virtue of being a dependency of some other package.
To completely remove a package from the compiler's internal database,
use -ignore-package.
The compiler will complain if any two packages in the
transitive closure of exposed packages contain the same
module.
You *must* use -ignore-package P when compiling modules for
package P, if package P (or an older version of P) is already
registered. The compiler will helpfully complain if you don't.
The fptools build system does this.
- Note: the Cabal library won't work yet. It still thinks GHC uses
the old package config syntax.
Internal changes/cleanups:
- The ModuleName type has gone away. Modules are now just (a
newtype of) FastStrings, and don't contain any package information.
All the package-related knowledge is in DynFlags, which is passed
down to where it is needed.
- DynFlags manipulation has been cleaned up somewhat: there are no
global variables holding DynFlags any more, instead the DynFlags
are passed around properly.
- There are a few less global variables in GHC. Lots more are
scheduled for removal.
- -i is now a dynamic flag, as are all the package-related flags (but
using them in {-# OPTIONS #-} is Officially Not Recommended).
- make -j now appears to work under fptools/libraries/. Probably
wouldn't take much to get it working for a whole build.
Diffstat (limited to 'ghc/compiler/iface/TcIface.lhs')
| -rw-r--r-- | ghc/compiler/iface/TcIface.lhs | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/ghc/compiler/iface/TcIface.lhs b/ghc/compiler/iface/TcIface.lhs index 2a875e05f3..7f4e83e395 100644 --- a/ghc/compiler/iface/TcIface.lhs +++ b/ghc/compiler/iface/TcIface.lhs @@ -49,11 +49,11 @@ import TyCon ( tyConDataCons, isTupleTyCon, mkForeignTyCon ) import DataCon ( DataCon, dataConWorkId, dataConTyVars, dataConArgTys, isVanillaDataCon ) import TysWiredIn ( tupleCon, tupleTyCon, listTyCon, intTyCon, boolTyCon, charTyCon, parrTyCon ) import Var ( TyVar, mkTyVar, tyVarKind ) -import Name ( Name, nameModuleName, nameModule, nameIsLocalOrFrom, +import Name ( Name, nameModule, nameIsLocalOrFrom, isWiredInName, wiredInNameTyThing_maybe, nameParent ) import NameEnv import OccName ( OccName ) -import Module ( Module, ModuleName, moduleName ) +import Module ( Module ) import UniqSupply ( initUs_ ) import Outputable import SrcLoc ( noSrcLoc ) @@ -168,10 +168,10 @@ typecheckIface hsc_env iface ; rules | ignore_prags = [] | otherwise = mi_rules iface ; dfuns = mi_insts iface - ; mod_name = moduleName (mi_module iface) + ; mod = mi_module iface } -- Typecheck the decls - ; names <- mappM (lookupOrig mod_name . ifName) decls + ; names <- mappM (lookupOrig mod . ifName) decls ; ty_things <- fixM (\ rec_ty_things -> do { writeMutVar tc_env_var (mkNameEnv (names `zipLazy` rec_ty_things)) -- This only makes available the "main" things, @@ -449,7 +449,7 @@ tcIfaceInst :: IfaceInst -> IfL DFunId tcIfaceInst (IfaceInst { ifDFun = dfun_occ }) = tcIfaceExtId (LocalTop dfun_occ) -selectInsts :: Name -> [Name] -> ExternalPackageState -> (ExternalPackageState, [(ModuleName, IfaceInst)]) +selectInsts :: Name -> [Name] -> ExternalPackageState -> (ExternalPackageState, [(Module, IfaceInst)]) selectInsts cls tycons eps = (eps { eps_insts = insts', eps_stats = stats' }, iface_insts) where @@ -521,7 +521,7 @@ loadImportedRules hsc_env guts } -selectRules :: ExternalPackageState -> (ExternalPackageState, [(ModuleName, IfaceRule)]) +selectRules :: ExternalPackageState -> (ExternalPackageState, [(Module, IfaceRule)]) -- Not terribly efficient. Look at each rule in the pool to see if -- all its gates are in the type env. If so, take it out of the pool. -- If not, trim its gates for next time. @@ -701,7 +701,7 @@ tcIfaceAlt _ (IfaceLitAlt lit, names, rhs) -- by the fact that we omit type annotations because we can -- work them out. True enough, but its not that easy! tcIfaceAlt (tycon, inst_tys) (IfaceDataAlt data_occ, arg_occs, rhs) - = do { let tycon_mod = nameModuleName (tyConName tycon) + = do { let tycon_mod = nameModule (tyConName tycon) ; con <- tcIfaceDataCon (ExtPkg tycon_mod data_occ) ; ASSERT2( con `elem` tyConDataCons tycon, ppr con $$ ppr tycon $$ ppr (tyConDataCons tycon) ) |
