summaryrefslogtreecommitdiff
path: root/ghc/compiler/main/Packages.lhs
diff options
context:
space:
mode:
authorsimonpj <unknown>2002-09-13 15:02:50 +0000
committersimonpj <unknown>2002-09-13 15:02:50 +0000
commit9af77fa423926fbda946b31e174173d0ec5ebac8 (patch)
tree140cc94aa3e04f6e50c4bf07ceb0efe67d11b9c6 /ghc/compiler/main/Packages.lhs
parent69e55e7476392a2b59b243a32065350c258d4970 (diff)
downloadhaskell-9af77fa423926fbda946b31e174173d0ec5ebac8.tar.gz
[project @ 2002-09-13 15:02:25 by simonpj]
-------------------------------------- Make Template Haskell into the HEAD -------------------------------------- This massive commit transfers to the HEAD all the stuff that Simon and Tim have been doing on Template Haskell. The meta-haskell-branch is no more! WARNING: make sure that you * Update your links if you are using link trees. Some modules have been added, some have gone away. * Do 'make clean' in all library trees. The interface file format has changed, and you can get strange panics (sadly) if GHC tries to read old interface files: e.g. ghc-5.05: panic! (the `impossible' happened, GHC version 5.05): Binary.get(TyClDecl): ForeignType * You need to recompile the rts too; Linker.c has changed However the libraries are almost unaltered; just a tiny change in Base, and to the exports in Prelude. NOTE: so far as TH itself is concerned, expression splices work fine, but declaration splices are not complete. --------------- The main change --------------- The main structural change: renaming and typechecking have to be interleaved, because we can't rename stuff after a declaration splice until after we've typechecked the stuff before (and the splice itself). * Combine the renamer and typecheker monads into one (TcRnMonad, TcRnTypes) These two replace TcMonad and RnMonad * Give them a single 'driver' (TcRnDriver). This driver replaces TcModule.lhs and Rename.lhs * The haskell-src library package has a module Language/Haskell/THSyntax which defines the Haskell data type seen by the TH programmer. * New modules: hsSyn/Convert.hs converts THSyntax -> HsSyn deSugar/DsMeta.hs converts HsSyn -> THSyntax * New module typecheck/TcSplice type-checks Template Haskell splices. ------------- Linking stuff ------------- * ByteCodeLink has been split into ByteCodeLink (which links) ByteCodeAsm (which assembles) * New module ghci/ObjLink is the object-code linker. * compMan/CmLink is removed entirely (was out of place) Ditto CmTypes (which was tiny) * Linker.c initialises the linker when it is first used (no need to call initLinker any more). Template Haskell makes it harder to know when and whether to initialise the linker. ------------------------------------- Gathering the LIE in the type checker ------------------------------------- * Instead of explicitly gathering constraints in the LIE tcExpr :: RenamedExpr -> TcM (TypecheckedExpr, LIE) we now dump the constraints into a mutable varabiable carried by the monad, so we get tcExpr :: RenamedExpr -> TcM TypecheckedExpr Much less clutter in the code, and more efficient too. (Originally suggested by Mark Shields.) ----------------- Remove "SysNames" ----------------- Because the renamer and the type checker were entirely separate, we had to carry some rather tiresome implicit binders (or "SysNames") along inside some of the HsDecl data structures. They were both tiresome and fragile. Now that the typechecker and renamer are more intimately coupled, we can eliminate SysNames (well, mostly... default methods still carry something similar). ------------- Clean up HsPat ------------- One big clean up is this: instead of having two HsPat types (InPat and OutPat), they are now combined into one. This is more consistent with the way that HsExpr etc is handled; there are some 'Out' constructors for the type checker output. So: HsPat.InPat --> HsPat.Pat HsPat.OutPat --> HsPat.Pat No 'pat' type parameter in HsExpr, HsBinds, etc Constructor patterns are nicer now: they use HsPat.HsConDetails for the three cases of constructor patterns: prefix, infix, and record-bindings The *same* data type HsConDetails is used in the type declaration of the data type (HsDecls.TyData) Lots of associated clean-up operations here and there. Less code. Everything is wonderful.
Diffstat (limited to 'ghc/compiler/main/Packages.lhs')
-rw-r--r--ghc/compiler/main/Packages.lhs74
1 files changed, 67 insertions, 7 deletions
diff --git a/ghc/compiler/main/Packages.lhs b/ghc/compiler/main/Packages.lhs
index 190a1f8a2b..74e65a7412 100644
--- a/ghc/compiler/main/Packages.lhs
+++ b/ghc/compiler/main/Packages.lhs
@@ -4,11 +4,18 @@
\section{Package manipulation}
\begin{code}
-module Packages ( PackageConfig(..),
- defaultPackageConfig,
- mungePackagePaths,
- showPackages
- )
+module Packages (
+ PackageConfig(..),
+ defaultPackageConfig,
+ mungePackagePaths, packageDependents,
+ showPackages,
+
+ PackageName, -- Instance of Outputable
+ mkPackageName, packageNameString,
+ preludePackage, rtsPackage, stdPackage, haskell98Package, -- :: PackageName
+
+ PackageConfigMap, emptyPkgMap, extendPkgMap, lookupPkg
+ )
where
#include "HsVersions.h"
@@ -19,8 +26,16 @@ import CmdLineOpts ( dynFlag, verbosity )
import DriverUtil ( my_prefix_match )
import ErrUtils ( dumpIfSet )
import Outputable ( docToSDoc )
+import FastString
+import UniqFM
\end{code}
+%*********************************************************
+%* *
+\subsection{Basic data types}
+%* *
+%*********************************************************
+
\begin{code}
#define WANT_PRETTY
#define INTERNAL_PRETTY
@@ -29,9 +44,52 @@ import Outputable ( docToSDoc )
-- There's a blob of code shared with ghc-pkg,
-- so we just include it from there
+-- Primarily it defines
+-- PackageConfig (a record)
+-- PackageName (FastString)
+
#include "../utils/ghc-pkg/Package.hs"
\end{code}
+\begin{code}
+type PackageName = FastString -- No encoding at all
+
+mkPackageName :: String -> PackageName
+mkPackageName = mkFastString
+
+packageNameString :: PackageName -> String
+packageNameString = unpackFS
+
+stdPackage, rtsPackage, preludePackage, haskell98Package :: PackageName
+preludePackage = FSLIT("base")
+stdPackage = FSLIT("std") -- Do we still have this?
+rtsPackage = FSLIT("rts")
+haskell98Package = FSLIT("haskell98")
+
+packageDependents :: PackageConfig -> [PackageName]
+-- Impedence matcher, because PackageConfig has Strings
+-- not PackageNames at the moment. Sigh.
+packageDependents pkg = map mkPackageName (package_deps pkg)
+\end{code}
+
+A PackageConfigMap maps a PackageName to a PackageConfig
+
+\begin{code}
+type PackageConfigMap = UniqFM PackageConfig
+
+lookupPkg :: PackageConfigMap -> PackageName -> Maybe PackageConfig
+emptyPkgMap :: PackageConfigMap
+
+emptyPkgMap = emptyUFM
+lookupPkg = lookupUFM
+
+extendPkgMap :: PackageConfigMap -> [PackageConfig] -> PackageConfigMap
+extendPkgMap pkg_map new_pkgs
+ = foldl add pkg_map new_pkgs
+ where
+ add pkg_map p = addToUFM pkg_map (mkFastString (name p)) p
+\end{code}
+
%*********************************************************
%* *
\subsection{Load the config file}
@@ -64,11 +122,13 @@ mungePackagePaths top_dir ps = map munge_pkg ps
%*********************************************************
\begin{code}
-showPackages :: [PackageConfig] -> IO ()
+showPackages :: PackageConfigMap -> IO ()
-- Show package info on console, if verbosity is >= 3
-showPackages ps
+showPackages pkg_map
= do { verb <- dynFlag verbosity
; dumpIfSet (verb >= 3) "Packages"
(docToSDoc (vcat (map dumpPkgGuts ps)))
}
+ where
+ ps = eltsUFM pkg_map
\end{code}