diff options
author | msozeau <msozeau@85f007b7-540e-0410-9357-904b9bb8a0f7> | 2008-06-17 12:46:46 +0000 |
---|---|---|
committer | msozeau <msozeau@85f007b7-540e-0410-9357-904b9bb8a0f7> | 2008-06-17 12:46:46 +0000 |
commit | ecd526ca4bfe53f2bcfc6eddd1243e1e59750820 (patch) | |
tree | 546c7c1a1e97d30074fd424fe42741d2903eae9d /tactics/class_tactics.ml4 | |
parent | 90899bd52f32ef608754f937c5b23d250dc41ed8 (diff) |
Fixes w.r.t. let binders in class contexts and Add Parametric
Morphism/Relation bindings.
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@11132 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'tactics/class_tactics.ml4')
-rw-r--r-- | tactics/class_tactics.ml4 | 35 |
1 files changed, 18 insertions, 17 deletions
diff --git a/tactics/class_tactics.ml4 b/tactics/class_tactics.ml4 index ad627c841..97129a56b 100644 --- a/tactics/class_tactics.ml4 +++ b/tactics/class_tactics.ml4 @@ -1236,31 +1236,31 @@ let declare_relation ?(binders=[]) a aeq n refl symm trans = ignore (declare_instance_refl binders a aeq n lemma1); ignore (declare_instance_sym binders a aeq n lemma2) | (Some lemma1, None, Some lemma3) -> - let lemma_refl = declare_instance_refl binders a aeq n lemma1 in - let lemma_trans = declare_instance_trans binders a aeq n lemma3 in + let _lemma_refl = declare_instance_refl binders a aeq n lemma1 in + let _lemma_trans = declare_instance_trans binders a aeq n lemma3 in let instance = declare_instance a aeq n "Coq.Classes.RelationClasses.PreOrder" in ignore( anew_instance binders instance - [((dummy_loc,id_of_string "PreOrder_Reflexive"), [], mkIdentC lemma_refl); - ((dummy_loc,id_of_string "PreOrder_Transitive"),[], mkIdentC lemma_trans)]) + [((dummy_loc,id_of_string "PreOrder_Reflexive"), [], lemma1); + ((dummy_loc,id_of_string "PreOrder_Transitive"),[], lemma3)]) | (None, Some lemma2, Some lemma3) -> - let lemma_sym = declare_instance_sym binders a aeq n lemma2 in - let lemma_trans = declare_instance_trans binders a aeq n lemma3 in + let _lemma_sym = declare_instance_sym binders a aeq n lemma2 in + let _lemma_trans = declare_instance_trans binders a aeq n lemma3 in let instance = declare_instance a aeq n "Coq.Classes.RelationClasses.PER" in ignore( anew_instance binders instance - [((dummy_loc,id_of_string "PER_Symmetric"), [], mkIdentC lemma_sym); - ((dummy_loc,id_of_string "PER_Transitive"),[], mkIdentC lemma_trans)]) + [((dummy_loc,id_of_string "PER_Symmetric"), [], lemma2); + ((dummy_loc,id_of_string "PER_Transitive"),[], lemma3)]) | (Some lemma1, Some lemma2, Some lemma3) -> - let lemma_refl = declare_instance_refl binders a aeq n lemma1 in - let lemma_sym = declare_instance_sym binders a aeq n lemma2 in - let lemma_trans = declare_instance_trans binders a aeq n lemma3 in + let _lemma_refl = declare_instance_refl binders a aeq n lemma1 in + let _lemma_sym = declare_instance_sym binders a aeq n lemma2 in + let _lemma_trans = declare_instance_trans binders a aeq n lemma3 in let instance = declare_instance a aeq n "Coq.Classes.RelationClasses.Equivalence" in ignore( anew_instance binders instance - [((dummy_loc,id_of_string "Equivalence_Reflexive"), [], mkIdentC lemma_refl); - ((dummy_loc,id_of_string "Equivalence_Symmetric"), [], mkIdentC lemma_sym); - ((dummy_loc,id_of_string "Equivalence_Transitive"),[], mkIdentC lemma_trans)]) + [((dummy_loc,id_of_string "Equivalence_Reflexive"), [], lemma1); + ((dummy_loc,id_of_string "Equivalence_Symmetric"), [], lemma2); + ((dummy_loc,id_of_string "Equivalence_Transitive"),[], lemma3)]) type 'a binders_let_argtype = (local_binder list, 'a) Genarg.abstract_argument_type @@ -1410,9 +1410,10 @@ let build_morphism_signature m = let morph = mkApp (Lazy.force morphism_type, [| t; sig_; m |]) in - let evd = resolve_all_evars_once false (true, default_eauto_depth) env - (fun x evi -> class_of_constr evi.Evd.evar_concl <> None) !isevars in - Evarutil.nf_isevar evd morph + let evd = + Typeclasses.resolve_typeclasses ~fail:true ~onlyargs:false env !isevars in + let m = Evarutil.nf_isevar evd morph in + Evarutil.check_evars env Evd.empty evd m; m let default_morphism sign m = let env = Global.env () in |