Ticket #1012 (new bug)
ghc panic with mutually recursive modules and template haskell
| Reported by: | guest | Owned by: | |
|---|---|---|---|
| Priority: | lowest | Milestone: | 7.6.1 |
| Component: | Template Haskell | Version: | 6.8.2 |
| Keywords: | Cc: | leuschner@… | |
| Operating System: | Unknown/Multiple | Architecture: | Unknown/Multiple |
| Type of failure: | None/Unknown | Difficulty: | Unknown |
| Test Case: | TH_import_loop | Blocked By: | |
| Blocking: | Related Tickets: |
Description
When compiling the files below using ghc --make Main.hs I get the following error:
[1 of 5] Compiling ModuleA[boot] ( ModuleA.hs-boot, nothing )
[2 of 5] Compiling ModuleC ( ModuleC.hs, ModuleC.o )
[3 of 5] Compiling ModuleB ( ModuleB.hs, ModuleB.o )
Loading package base ... linking ... done.
Loading package template-haskell ... linking ... done.
ghc-6.6: panic! (the 'impossible' happened)
(GHC version 6.6 for powerpc-apple-darwin):
Maybe.fromJust: Nothing
ModuleA.hs:
module ModuleA where import ModuleB
ModuleA.hs-boot:
module ModuleA where
ModuleB.hs:
{-# OPTIONS -fth #-}
module ModuleB where
import ModuleC
$(nothing)
ModuleC.hs:
module ModuleC where
import Language.Haskell.TH
import {-# SOURCE #-} ModuleA
nothing = return [] :: Q [Dec]
Main.hs:
module Main.hs import ModuleA main = return ()
Change History
Note: See
TracTickets for help on using
tickets.
