X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=compiler%2Ftypecheck%2FTcHsSyn.lhs;h=2a17fe8a4e1f6c9a2e7bb2ecf593cfa70e2a2dfd;hp=35da6557fcb8b3fab8c61c908ee6f219138b96a4;hb=3391a03562d4056de7b16cd0f632e6c43ae44cca;hpb=ca53c38335cdc671f0b1e0949aa1514fc3fd72a5 diff --git a/compiler/typecheck/TcHsSyn.lhs b/compiler/typecheck/TcHsSyn.lhs index 35da655..2a17fe8 100644 --- a/compiler/typecheck/TcHsSyn.lhs +++ b/compiler/typecheck/TcHsSyn.lhs @@ -52,7 +52,7 @@ import SrcLoc import Bag import FastString import Outputable -import Data.Traversable( traverse ) +-- import Data.Traversable( traverse ) \end{code} \begin{code} @@ -121,7 +121,7 @@ shortCutLit (HsIntegral i) ty | isIntTy ty && inIntRange i = Just (HsLit (HsInt i)) | isWordTy ty && inWordRange i = Just (mkLit wordDataCon (HsWordPrim i)) | isIntegerTy ty = Just (HsLit (HsInteger i ty)) - | otherwise = shortCutLit (HsFractional (fromInteger i)) ty + | otherwise = shortCutLit (HsFractional (FL { fl_text = show i, fl_value = fromInteger i })) ty -- The 'otherwise' case is important -- Consider (3 :: Float). Syntactically it looks like an IntLit, -- so we'll call shortCutIntLit, but of course it's a float @@ -129,8 +129,8 @@ shortCutLit (HsIntegral i) ty -- literals, compiled without -O shortCutLit (HsFractional f) ty - | isFloatTy ty = Just (mkLit floatDataCon (HsFloatPrim f)) - | isDoubleTy ty = Just (mkLit doubleDataCon (HsDoublePrim f)) + | isFloatTy ty = Just (mkLit floatDataCon (HsFloatPrim (fl_value f))) + | isDoubleTy ty = Just (mkLit doubleDataCon (HsDoublePrim (fl_value f))) | otherwise = Nothing shortCutLit (HsIsString s) ty @@ -1129,7 +1129,6 @@ zonkTcCoToCo env co go (AxiomInstCo ax cos) = do { cos' <- mapM go cos; return (AxiomInstCo ax cos') } go (AppCo co1 co2) = do { co1' <- go co1; co2' <- go co2 ; return (mkAppCo co1' co2') } - go (PredCo pco) = do { pco' <- go `traverse` pco; return (mkPredCo pco') } go (UnsafeCo t1 t2) = do { t1' <- zonkTcTypeToType env t1 ; t2' <- zonkTcTypeToType env t2 ; return (mkUnsafeCo t1' t2') }