aboutsummaryrefslogtreecommitdiffhomepage
path: root/proofs
diff options
context:
space:
mode:
authorGravatar aspiwack <aspiwack@85f007b7-540e-0410-9357-904b9bb8a0f7>2011-08-10 14:15:52 +0000
committerGravatar aspiwack <aspiwack@85f007b7-540e-0410-9357-904b9bb8a0f7>2011-08-10 14:15:52 +0000
commit08502c0d2299ed820a07e76fe785b6330ff119cd (patch)
tree65cef26fe43c27526f6861f7a771e2f38a36f537 /proofs
parentab6bdf1f65366c307d3467f451d1fad97d606988 (diff)
Graceful error message for [Proof Mode] and [Set Default Proof Mode] when requiring a non-existing proof mode.
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@14396 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'proofs')
-rw-r--r--proofs/proof_global.ml9
1 files changed, 7 insertions, 2 deletions
diff --git a/proofs/proof_global.ml b/proofs/proof_global.ml
index a32749073..0f3fed704 100644
--- a/proofs/proof_global.ml
+++ b/proofs/proof_global.ml
@@ -29,6 +29,11 @@ type proof_mode = {
}
let proof_modes = Hashtbl.create 6
+let find_proof_mode n =
+ try Hashtbl.find proof_modes n
+ with Not_found ->
+ Util.error (Format.sprintf "No proof mode named \"%s\"." n)
+
let register_proof_mode ({ name = n } as m) = Hashtbl.add proof_modes n m
(* initial mode: standard mode *)
let standard = { name = "No" ; set = (fun ()->()) ; reset = (fun () -> ()) }
@@ -46,7 +51,7 @@ let _ =
let { name = name } = !default_proof_mode in name
end;
optwrite = begin fun n ->
- default_proof_mode := Hashtbl.find proof_modes n
+ default_proof_mode := find_proof_mode n
end
}
@@ -226,7 +231,7 @@ let set_proof_mode m id =
Handles undo.
Applies to current proof, and proof mode name [mn]. *)
let set_proof_mode mn =
- let m = Hashtbl.find proof_modes mn in
+ let m = find_proof_mode mn in
let id = get_current_proof_name () in
let pr = give_me_the_proof () in
Proof.add_undo begin let curr = !current_proof_mode in fun () ->