Bug in the handling of wired-in packages (like template-haskell)
|Reported by:||simonmar||Owned by:||simonmar|
|Type of failure:||None/Unknown||Test Case:|
|Related Tickets:||Differential Revisions:|
If you install an older version of a wired-in package (e.g. template-haskell) and then try to use it, GHC will use the newer one as the "wired-in" package rather than the older one.
This happened when trying to build aeson-0.4.0.0 with ghc 7.4: aeson requires template-haskell-220.127.116.11, but GHC ships with 18.104.22.168. Cabal installed template-haskell-22.214.171.124, but while building aeson against it we get:
Data/Aeson/TH.hs:181:1: Bad interface file: /Users/tibbe/.cabal/lib/template-haskell-126.96.36.199/ghc-188.8.131.5211213/Language/Haskell/TH.hi Something is amiss; requested module template-haskell-184.108.40.206:Language.Haskell.TH differs from name found in the interface file template-haskell:Language.Haskell.TH
the bug is that findWiredInPackage has picked template-haskell-220.127.116.11 to be the wired-in package:
wired-in package template-haskell mapped to template-haskell-18.104.22.168-inplace
whereas we wanted to use template-haskell-22.214.171.124.
Not immediately obvious what the fix should be, so I'm making a ticket for this. The workaround is to update the dependency in aeson to allow template-haskell-126.96.36.199.