diff options
author | Simon Peyton Jones <simonpj@microsoft.com> | 2013-05-30 22:02:17 +0100 |
---|---|---|
committer | Simon Peyton Jones <simonpj@microsoft.com> | 2013-05-30 22:03:47 +0100 |
commit | 3d81b68d48e86f9dff032321aff20b76ad3ea081 (patch) | |
tree | d2782d570c69eae25febdb6654c8944b2435dcf3 | |
parent | 7849266ce2a9f45633d41532a07d870ea6a27fbb (diff) | |
download | haskell-3d81b68d48e86f9dff032321aff20b76ad3ea081.tar.gz |
Define chkAppend, and use it
Somtimes we need (xs ++ ys) in situations where ys is
almost always empty. Utils.chkAppend checks for that
case first.
-rw-r--r-- | compiler/types/FamInstEnv.lhs | 4 | ||||
-rw-r--r-- | compiler/utils/Util.lhs | 9 |
2 files changed, 9 insertions, 4 deletions
diff --git a/compiler/types/FamInstEnv.lhs b/compiler/types/FamInstEnv.lhs index 34f1701354..6ccd44d70b 100644 --- a/compiler/types/FamInstEnv.lhs +++ b/compiler/types/FamInstEnv.lhs @@ -754,13 +754,11 @@ find match_fun match_tys (inst@(FamInst { fi_branches = branches, fi_branched = where match = FamInstMatch { fim_instance = inst , fim_index = ind - , fim_tys = substTyVars subst tvs `add_on` match_tys2} + , fim_tys = substTyVars subst tvs `chkAppend` match_tys2} where -- Deal with over-saturation -- See Note [Over-saturated matches] (match_tys1, match_tys2) = splitAtList mb_tcs match_tys - add_on tys1 [] = tys1 -- The wildly common case - add_on tys1 tys2 = tys1 ++ tys2 lookup_fam_inst_env -- The worker, local to this module :: MatchFun diff --git a/compiler/utils/Util.lhs b/compiler/utils/Util.lhs index 90a2077c71..e2fd0aa093 100644 --- a/compiler/utils/Util.lhs +++ b/compiler/utils/Util.lhs @@ -18,7 +18,7 @@ module Util ( unzipWith, - mapFst, mapSnd, + mapFst, mapSnd, chkAppend, mapAndUnzip, mapAndUnzip3, mapAccumL2, nOfThem, filterOut, partitionWith, splitEithers, @@ -259,6 +259,13 @@ splitEithers (e : es) = case e of Left x -> (x:xs, ys) Right y -> (xs, y:ys) where (xs,ys) = splitEithers es + +chkAppend :: [a] -> [a] -> [a] +-- Checks for the second arguemnt being empty +-- Used in situations where that situation is common +chkAppend xs ys + | null ys = xs + | otherwise = xs ++ ys \end{code} A paranoid @zip@ (and some @zipWith@ friends) that checks the lists |