Introduce new file format for the package database binary cache
authorDuncan Coutts <duncan@well-typed.com>
Tue, 19 Aug 2014 19:33:10 +0000 (20:33 +0100)
committerEdward Z. Yang <ezyang@cs.stanford.edu>
Fri, 29 Aug 2014 11:39:04 +0000 (12:39 +0100)
commit8d7a1dcdbee47a980d0ecc8fa8e9336866a75d1b
treec9f7a599c9d96dfd49ab96ff081ff6e76a204870
parentce29a2609cdd2c1941fcd184d7c76a73cdd050f9
Introduce new file format for the package database binary cache

The purpose of the new format is to make it possible for the compiler
to not depend on the Cabal library. The new cache file format contains
more or less the same information duplicated in two different sections
using different representations.

One section is basically the same as what the package db contains now,
a list of packages using the types defined in the Cabal library. This
section is read back by ghc-pkg, and used for things like ghc-pkg dump
which have to produce output using the Cabal InstalledPackageInfo text
representation.

The other section is a ghc-local type which contains a subset of the
information from the Cabal InstalledPackageInfo -- just the bits that
the compiler cares about.

The trick is that the compiler can read this second section without
needing to know the representation (or types) of the first part. The
ghc-pkg tool knows about both representations and writes both.

This patch introduces the new cache file format but does not yet use it
properly. More patches to follow. (As of this patch, the compiler reads
the part intended for ghc-pkg so it still depends on Cabal and the
ghc-local package type is not yet fully defined.)
compiler/main/Packages.lhs
libraries/bin-package-db/Distribution/InstalledPackageInfo/Binary.hs
libraries/bin-package-db/GHC/PackageDb.hs [new file with mode: 0644]
libraries/bin-package-db/bin-package-db.cabal
utils/ghc-pkg/Main.hs