summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsimonpj@microsoft.com <unknown>2010-10-07 09:16:18 +0000
committersimonpj@microsoft.com <unknown>2010-10-07 09:16:18 +0000
commit8fa8c98ee75649c2548d2bd9cb730a93cf80fe5c (patch)
tree437a5fa42184576f40ebc99496fcdb5324184185
parente4b7186c16788b719e0150ac3bc3cc628ea00d64 (diff)
downloadhaskell-8fa8c98ee75649c2548d2bd9cb730a93cf80fe5c.tar.gz
This is just white-space and layout
(At least, I don't think there is anything else.)
-rw-r--r--compiler/typecheck/TcMatches.lhs45
1 files changed, 27 insertions, 18 deletions
diff --git a/compiler/typecheck/TcMatches.lhs b/compiler/typecheck/TcMatches.lhs
index 6080533b72..1442ac68ee 100644
--- a/compiler/typecheck/TcMatches.lhs
+++ b/compiler/typecheck/TcMatches.lhs
@@ -419,12 +419,17 @@ tcLcStmt m_tc ctxt (TransformStmt stmts binders usingExpr maybeByExpr) elt_ty th
case maybeByExpr of
Nothing -> do
-- We must validate that usingExpr :: forall a. [a] -> [a]
- usingExpr' <- tcPolyExpr usingExpr (mkForAllTy alphaTyVar (alphaListTy `mkFunTy` alphaListTy))
+ let using_ty = mkForAllTy alphaTyVar (alphaListTy `mkFunTy` alphaListTy)
+ usingExpr' <- tcPolyExpr usingExpr using_ty
return (usingExpr', Nothing)
Just byExpr -> do
- -- We must infer a type such that e :: t and then check that usingExpr :: forall a. (a -> t) -> [a] -> [a]
+ -- We must infer a type such that e :: t and then check that
+ -- usingExpr :: forall a. (a -> t) -> [a] -> [a]
(byExpr', tTy) <- tcInferRhoNC byExpr
- usingExpr' <- tcPolyExpr usingExpr (mkForAllTy alphaTyVar ((alphaTy `mkFunTy` tTy) `mkFunTy` (alphaListTy `mkFunTy` alphaListTy)))
+ let using_ty = mkForAllTy alphaTyVar $
+ (alphaTy `mkFunTy` tTy)
+ `mkFunTy` alphaListTy `mkFunTy` alphaListTy
+ usingExpr' <- tcPolyExpr usingExpr using_ty
return (usingExpr', Just byExpr')
binders' <- tcLookupLocalIds binders
@@ -439,24 +444,26 @@ tcLcStmt m_tc ctxt (GroupStmt stmts bindersMap by using) elt_ty thing_inside
; (stmts', (bndr_ids, by', using_ty, elt_ty')) <-
tcStmts (TransformStmtCtxt ctxt) (tcLcStmt m_tc) stmts elt_ty $ \elt_ty' -> do
- (by', using_ty) <- case by of
- Nothing -> -- check that using :: forall a. [a] -> [[a]]
- return (Nothing, mkForAllTy alphaTyVar $
- alphaListTy `mkFunTy` alphaListListTy)
-
- Just by_e -> -- check that using :: forall a. (a -> t) -> [a] -> [[a]]
- -- where by :: t
- do { (by_e', t_ty) <- tcInferRhoNC by_e
- ; return (Just by_e', mkForAllTy alphaTyVar $
- (alphaTy `mkFunTy` t_ty)
- `mkFunTy` alphaListTy
- `mkFunTy` alphaListListTy) }
+ (by', using_ty) <-
+ case by of
+ Nothing -> -- check that using :: forall a. [a] -> [[a]]
+ return (Nothing, mkForAllTy alphaTyVar $
+ alphaListTy `mkFunTy` alphaListListTy)
+
+ Just by_e -> -- check that using :: forall a. (a -> t) -> [a] -> [[a]]
+ -- where by :: t
+ do { (by_e', t_ty) <- tcInferRhoNC by_e
+ ; return (Just by_e', mkForAllTy alphaTyVar $
+ (alphaTy `mkFunTy` t_ty)
+ `mkFunTy` alphaListTy
+ `mkFunTy` alphaListListTy) }
-- Find the Ids (and hence types) of all old binders
bndr_ids <- tcLookupLocalIds bndr_names
return (bndr_ids, by', using_ty, elt_ty')
- -- Ensure that every old binder of type b is linked up with its new binder which should have type [b]
+ -- Ensure that every old binder of type b is linked up with
+ -- its new binder which should have type [b]
; let list_bndr_ids = zipWith mk_list_bndr list_bndr_names bndr_ids
bindersMap' = bndr_ids `zip` list_bndr_ids
-- See Note [GroupStmt binder map] in HsExpr
@@ -465,7 +472,8 @@ tcLcStmt m_tc ctxt (GroupStmt stmts bindersMap by using) elt_ty thing_inside
Left e -> do { e' <- tcPolyExpr e using_ty; return (Left e') }
Right e -> do { e' <- tcPolyExpr (noLoc e) using_ty; return (Right (unLoc e')) }
- -- Type check the thing in the environment with these new binders and return the result
+ -- Type check the thing in the environment with
+ -- these new binders and return the result
; thing <- tcExtendIdEnv list_bndr_ids (thing_inside elt_ty')
; return (GroupStmt stmts' bindersMap' by' using', thing) }
where
@@ -473,7 +481,8 @@ tcLcStmt m_tc ctxt (GroupStmt stmts bindersMap by using) elt_ty thing_inside
alphaListListTy = mkTyConApp m_tc [alphaListTy]
mk_list_bndr :: Name -> TcId -> TcId
- mk_list_bndr list_bndr_name bndr_id = mkLocalId list_bndr_name (mkTyConApp m_tc [idType bndr_id])
+ mk_list_bndr list_bndr_name bndr_id
+ = mkLocalId list_bndr_name (mkTyConApp m_tc [idType bndr_id])
tcLcStmt _ _ stmt _ _
= pprPanic "tcLcStmt: unexpected Stmt" (ppr stmt)