diff options
author | 2008-06-17 12:46:46 +0000 | |
---|---|---|
committer | 2008-06-17 12:46:46 +0000 | |
commit | ecd526ca4bfe53f2bcfc6eddd1243e1e59750820 (patch) | |
tree | 546c7c1a1e97d30074fd424fe42741d2903eae9d /toplevel/classes.ml | |
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 'toplevel/classes.ml')
-rw-r--r-- | toplevel/classes.ml | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/toplevel/classes.ml b/toplevel/classes.ml index db5c54855..8c34c32ed 100644 --- a/toplevel/classes.ml +++ b/toplevel/classes.ml @@ -235,6 +235,10 @@ let decompose_named_assum = let decl = (na,None,substl subst t) in let subst' = mkVar na :: subst in prodec_rec subst' (add_named_decl decl l) (substl subst' c) + | LetIn (Name na, b, t, c) -> + let decl = (na,Some (substl subst b),substl subst t) in + let subst' = mkVar na :: subst in + prodec_rec subst' (add_named_decl decl l) (substl subst' c) | Cast (c,_,_) -> prodec_rec subst l c | _ -> l,c in prodec_rec [] [] @@ -492,12 +496,12 @@ let new_instance ?(global=false) ctx (instid, bk, cl) props ?(on_free_vars=defau let gen_ctx = Implicit_quantifiers.binder_list_of_ids gen_ids in let ctx, avoid = name_typeclass_binders bound ctx in let ctx = List.append ctx (List.rev gen_ctx) in - let k, ctx', subst = + let k, ctx', imps, subst = let c = Command.generalize_constr_expr tclass ctx in - let _imps, c' = interp_type_evars isevars env c in + let imps, c' = interp_type_evars isevars env c in let ctx, c = decompose_named_assum c' in let cl, args = Typeclasses.dest_class_app c in - cl, ctx, substitution_of_constrs (List.map snd cl.cl_context) (List.rev (Array.to_list args)) + cl, ctx, imps, substitution_of_constrs (List.map snd cl.cl_context) (List.rev (Array.to_list args)) in let id = match snd instid with @@ -515,11 +519,6 @@ let new_instance ?(global=false) ctx (instid, bk, cl) props ?(on_free_vars=defau isevars := resolve_typeclasses env !isevars; let sigma = Evd.evars_of !isevars in let substctx = Typeclasses.nf_substitution sigma subst in - let imps = - Util.list_map_i - (fun i (na, b, t) -> ExplByPos (i, Some na), (true, true)) - 1 ctx' - in if Lib.is_modtype () then begin let _, ty_constr = instance_constructor k (List.rev_map snd substctx) in |