aboutsummaryrefslogtreecommitdiffhomepage
path: root/plugins/extraction/table.ml
diff options
context:
space:
mode:
authorGravatar letouzey <letouzey@85f007b7-540e-0410-9357-904b9bb8a0f7>2011-03-07 15:37:59 +0000
committerGravatar letouzey <letouzey@85f007b7-540e-0410-9357-904b9bb8a0f7>2011-03-07 15:37:59 +0000
commit0a2738fe2e171cc6661824cd6525ee5d5c317334 (patch)
tree41c4eaff941fa572f46236197e087037cb0c158e /plugins/extraction/table.ml
parent654f4e0f4dfae3073f8af5ccf54636f927191276 (diff)
Extraction: a warning when an opaque constant is enterred
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@13891 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'plugins/extraction/table.ml')
-rw-r--r--plugins/extraction/table.ml27
1 files changed, 26 insertions, 1 deletions
diff --git a/plugins/extraction/table.ml b/plugins/extraction/table.ml
index 6d4f06e14..8c9fdf37d 100644
--- a/plugins/extraction/table.ml
+++ b/plugins/extraction/table.ml
@@ -175,6 +175,15 @@ let add_info_axiom r = info_axioms := Refset'.add r !info_axioms
let remove_info_axiom r = info_axioms := Refset'.remove r !info_axioms
let add_log_axiom r = log_axioms := Refset'.add r !log_axioms
+let opaques_ok = ref Refset'.empty
+let opaques_ko = ref Refset'.empty
+let init_opaques () = opaques_ok := Refset'.empty; opaques_ko := Refset'.empty
+let add_opaque_ok r = opaques_ok := Refset'.add r !opaques_ok
+let add_opaque_ko r = opaques_ko := Refset'.add r !opaques_ko
+let remove_opaque r =
+ opaques_ok := Refset'.remove r !opaques_ok;
+ opaques_ko := Refset'.remove r !opaques_ko
+
(*s Extraction modes: modular or monolithic, library or minimal ?
Nota:
@@ -256,6 +265,22 @@ let warning_axioms () =
fnl ())
end
+let warning_opaques () =
+ let opaques_ok = Refset'.elements !opaques_ok in
+ if opaques_ok = [] then ()
+ else msg_warning
+ (str "Extraction is accessing the body of the following opaque constants:"
+ ++ hov 1 (spc () ++ prlist_with_sep spc safe_pr_global opaques_ok)
+ ++ str "." ++ fnl ()
+ ++ str "Be careful if using option -dont-load-proofs later." ++ fnl ());
+ let opaques_ko = Refset'.elements !opaques_ko in
+ if opaques_ko = [] then ()
+ else msg_warning
+ (str "Extraction cannot access the body of the following opaque constants:"
+ ++ hov 1 (spc () ++ prlist_with_sep spc safe_pr_global opaques_ko)
+ ++ fnl () ++ str "due to option -dont-load-proofs. "
+ ++ str "These constants are treated as axioms." ++ fnl ())
+
let warning_both_mod_and_cst q mp r =
msg_warning
(str "The name " ++ pr_qualid q ++ str " is ambiguous, " ++
@@ -778,4 +803,4 @@ let extract_inductive r s l optstr =
let reset_tables () =
init_terms (); init_types (); init_inductives (); init_recursors ();
- init_projs (); init_axioms (); reset_modfile ()
+ init_projs (); init_axioms (); init_opaques (); reset_modfile ()