diff options
| author | Maxime Dénès | 2017-11-03 10:31:32 +0100 |
|---|---|---|
| committer | Maxime Dénès | 2017-11-03 10:31:32 +0100 |
| commit | 8964ee7244d702a9a512c683740769e0e5d847d1 (patch) | |
| tree | c8b6e851ab7fda07b06e05a1825db0e324a57a46 | |
| parent | e5659c8ffe735c530a707a61c692a3af21a79a9a (diff) | |
| parent | c24bcae8dbc2ef82f72b3351783cbf73d3b12795 (diff) | |
Merge PR #924: Fixing part of #5669: unification heuristics sensitive to alphabet
| -rw-r--r-- | pretyping/evarsolve.ml | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/pretyping/evarsolve.ml b/pretyping/evarsolve.ml index ad1409f5b1..7f81d1aa34 100644 --- a/pretyping/evarsolve.ml +++ b/pretyping/evarsolve.ml @@ -842,6 +842,15 @@ let rec find_solution_type evarenv = function | (id,ProjectEvar _)::l -> find_solution_type evarenv l | [] -> assert false +let find_most_recent_projection evi sols = + let sign = List.map get_id (evar_filtered_context evi) in + match sols with + | y::l -> + List.fold_right (fun (id,p as x) (id',_ as y) -> + if List.index Id.equal id sign < List.index Id.equal id' sign then x else y) + l y + | _ -> assert false + (* In case the solution to a projection problem requires the instantiation of * subsidiary evars, [do_projection_effects] performs them; it * also try to instantiate the type of those subsidiary evars if their @@ -1429,7 +1438,8 @@ let rec invert_definition conv_algo choose env evd pbty (evk,argsv as ev) rhs = let c, p = match sols with | [] -> raise Not_found | [id,p] -> (mkVar id, p) - | (id,p)::_::_ -> + | _ -> + let (id,p) = find_most_recent_projection evi sols in if choose then (mkVar id, p) else raise (NotUniqueInType sols) in let ty = lazy (Retyping.get_type_of env !evdref (of_alias t)) in |
