diff options
| author | Matthieu Sozeau | 2016-07-25 15:00:47 +0200 |
|---|---|---|
| committer | Matthieu Sozeau | 2016-07-26 14:00:27 +0200 |
| commit | 46a866aa5fd63cc577c4a453bcf26ee75c47c433 (patch) | |
| tree | 9896794ed3b31663b95ff843b2e3b5164cffd392 /tactics | |
| parent | b36fc3478dc893b05edd2884972622531105d43d (diff) | |
Fix bug #4754, allow conversion problems to remain
when checking that the rewrite relation is homogeneous in
setoid_rewrite.
Diffstat (limited to 'tactics')
| -rw-r--r-- | tactics/rewrite.ml | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/tactics/rewrite.ml b/tactics/rewrite.ml index c7cfc4dc72..0892dc9e6c 100644 --- a/tactics/rewrite.ml +++ b/tactics/rewrite.ml @@ -424,14 +424,22 @@ let split_head = function hd :: tl -> hd, tl | [] -> assert(false) +let eq_pb (ty, env, x, y as pb) (ty', env', x', y' as pb') = + pb == pb' || (ty == ty' && Constr.equal x x' && Constr.equal y y') + +let problem_inclusion x y = + List.for_all (fun pb -> List.exists (fun pb' -> eq_pb pb pb') y) x + let evd_convertible env evd x y = try - let evd = Evarconv.the_conv_x env x y evd in (* Unfortunately, the_conv_x might say they are unifiable even if some - unsolvable constraints remain, so we check them here *) - let evd = Evarconv.consider_remaining_unif_problems env evd in - let () = Evarconv.check_problems_are_solved env evd in - Some evd + unsolvable constraints remain, so we check that this unification + does not introduce any new problem. *) + let _, pbs = Evd.extract_all_conv_pbs evd in + let evd' = Evarconv.the_conv_x env x y evd in + let _, pbs' = Evd.extract_all_conv_pbs evd' in + if evd' == evd || problem_inclusion pbs' pbs then Some evd' + else None with e when Errors.noncritical e -> None let convertible env evd x y = |
