X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=compiler%2Ftypecheck%2FTcSplice.lhs;h=7139fa8da844b7a9b3ebef0816944ee4d80f192c;hp=d63b4a016190e14f57842c53e073ce15d026287b;hb=66579ff945831c5fc9a17c58c722ff01f2268d76;hpb=81466110ff8104ca60e20d617bab83f6f78f0ec2 diff --git a/compiler/typecheck/TcSplice.lhs b/compiler/typecheck/TcSplice.lhs index d63b4a0..7139fa8 100644 --- a/compiler/typecheck/TcSplice.lhs +++ b/compiler/typecheck/TcSplice.lhs @@ -73,6 +73,8 @@ import qualified Language.Haskell.TH.Syntax as TH import GHC.Exts ( unsafeCoerce#, Int#, Int(..) ) #if __GLASGOW_HASKELL__ < 609 import qualified Exception ( userErrors ) +#else +import System.IO.Error #endif \end{code} @@ -603,9 +605,15 @@ runMeta convert expr -> failM -- Error already in Tc monad | otherwise -> failWithTc (mk_msg "run" exn) -- Exception #else - Left (SomeException exn) -> do + Left (SomeException exn) -> case cast exn of - Just (ErrorCall "IOEnv failure") -> + Just (ErrorCall "IOEnv failure") -> + failM -- Error already in Tc monad + _ -> + case cast exn of + Just ioe + | isUserError ioe && + (ioeGetErrorString ioe == "IOEnv failure") -> failM -- Error already in Tc monad _ -> failWithTc (mk_msg "run" exn) -- Exception #endif @@ -932,7 +940,7 @@ reifyName thing -- have free variables, we may need to generate NameL's for them. where name = getName thing - mod = nameModule name + mod = ASSERT( isExternalName name ) nameModule name pkg_str = packageIdString (modulePackageId mod) mod_str = moduleNameString (moduleName mod) occ_str = occNameString occ