aboutsummaryrefslogtreecommitdiff
path: root/vernac
diff options
context:
space:
mode:
authorPierre-Marie Pédrot2019-02-04 15:18:59 +0100
committerPierre-Marie Pédrot2019-02-04 15:18:59 +0100
commitd5722a22c9ae4dec43f8c444fbebb1b1072fb686 (patch)
tree2b1d2af4154149828cf5d69bad83f6549e670853 /vernac
parent8e73ceb7b4bdb6a17d039b17fd5e44ceffe255a2 (diff)
parent30d0b1052b6351a539558ff1fe16e4f8578c03ba (diff)
Merge PR #9144: Fixes #4633: clearer message unknown existential
Ack-by: herbelin Reviewed-by: ppedrot
Diffstat (limited to 'vernac')
-rw-r--r--vernac/himsg.ml16
1 files changed, 16 insertions, 0 deletions
diff --git a/vernac/himsg.ml b/vernac/himsg.ml
index ebbec86b9c..f78b43e2fa 100644
--- a/vernac/himsg.ml
+++ b/vernac/himsg.ml
@@ -598,6 +598,20 @@ let explain_var_not_found env id =
spc () ++ str "was not found" ++
spc () ++ str "in the current" ++ spc () ++ str "environment" ++ str "."
+
+let explain_evar_not_found env sigma id =
+ let undef = Evar.Map.domain (Evd.undefined_map sigma) in
+ let all_undef_evars = Evar.Set.elements undef in
+ let f ev = Id.equal id (Termops.evar_suggested_name ev sigma) in
+ if List.exists f all_undef_evars then
+ (* The name is used for printing but is not user-given *)
+ str "?" ++ Id.print id ++
+ strbrk " is a generated name. Only user-given names for existential variables" ++
+ strbrk " can be referenced. To give a user name to an existential variable," ++
+ strbrk " introduce it with the ?[name] syntax."
+ else
+ str "Unknown existential variable."
+
let explain_wrong_case_info env (ind,u) ci =
let pi = pr_inductive env ind in
if eq_ind ci.ci_ind ind then
@@ -812,6 +826,7 @@ let explain_pretype_error env sigma err =
| UnifOccurCheck (ev,rhs) -> explain_occur_check env sigma ev rhs
| UnsolvableImplicit (evk,exp) -> explain_unsolvable_implicit env sigma evk exp
| VarNotFound id -> explain_var_not_found env id
+ | EvarNotFound id -> explain_evar_not_found env sigma id
| UnexpectedType (actual,expect) ->
let env, actual, expect = contract2 env sigma actual expect in
explain_unexpected_type env sigma actual expect
@@ -833,6 +848,7 @@ let explain_pretype_error env sigma err =
| TypingError t -> explain_type_error env sigma t
| CannotUnifyOccurrences (b,c1,c2,e) -> explain_cannot_unify_occurrences env sigma b c1 c2 e
| UnsatisfiableConstraints (c,comp) -> explain_unsatisfiable_constraints env sigma c comp
+
(* Module errors *)
open Modops