diff options
author | Pierre Boutillier <pierre.boutillier@ens-lyon.org> | 2014-02-03 14:04:30 +0100 |
---|---|---|
committer | Pierre Boutillier <pierre.boutillier@ens-lyon.org> | 2014-02-24 13:35:05 +0100 |
commit | 6c7adbe89b69a08cba9cc47b39ecf1cdc9cc536d (patch) | |
tree | d9e4fb25cecdf3054c222f862e35e11935f43323 /pretyping/unification.ml | |
parent | c8c5bd077699599ec48447bd9676317a22170c8a (diff) |
Reductionops.Stack.strip* are ready to deal with Shift
Diffstat (limited to 'pretyping/unification.ml')
-rw-r--r-- | pretyping/unification.ml | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/pretyping/unification.ml b/pretyping/unification.ml index 49f12438b..fbb7de7af 100644 --- a/pretyping/unification.ml +++ b/pretyping/unification.ml @@ -637,17 +637,18 @@ let unify_0_with_initial_metas (sigma,ms,es as subst) conv_at_top env cv_pb flag (evd', mkMeta mv :: ks, m - 1)) (sigma,[],List.length bs - 1) bs in - let unilist2 f substn l l' = - try List.fold_left2 f substn l l' - with Invalid_argument "List.fold_left2" -> error_cannot_unify (fst curenvnb) sigma (cM,cN) - in - let substn = unilist2 (fun s u1 u -> unirec_rec curenvnb pb b false s u1 (substl ks u)) - (evd,ms,es) us2 us in - let substn = unilist2 (fun s u1 u -> unirec_rec curenvnb pb b false s u1 (substl ks u)) - substn params1 params in - let (substn,_,_) = Reductionops.Stack.fold2 (unirec_rec curenvnb pb b false) substn ts ts1 in - let app = mkApp (c, Array.rev_of_list ks) in + try + let (substn,_,_) = Reductionops.Stack.fold2 + (fun s u1 u -> unirec_rec curenvnb pb b false s u1 (substl ks u)) + (evd,ms,es) us2 us in + let (substn,_,_) = Reductionops.Stack.fold2 + (fun s u1 u -> unirec_rec curenvnb pb b false s u1 (substl ks u)) + substn params1 params in + let (substn,_,_) = Reductionops.Stack.fold2 (unirec_rec curenvnb pb b false) substn ts ts1 in + let app = mkApp (c, Array.rev_of_list ks) in unirec_rec curenvnb pb b false substn c1 app + with Invalid_argument "Reductionops.Stack.fold2" -> + error_cannot_unify (fst curenvnb) sigma (cM,cN) else error_cannot_unify (fst curenvnb) sigma (cM,cN) in let evd = sigma in |