X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=components%2Ftactics%2Fdeclarative.ml;h=c248d0cad0bf15c9bbe2119eec36346cf12fed86;hb=249d11773d32add20d665c4f8521b7380e4fec0a;hp=24801542dabcb76f57a6684a6d60fccaef31a488;hpb=190662b877ba89ccb152f0bf5c67df62be737335;p=helm.git diff --git a/components/tactics/declarative.ml b/components/tactics/declarative.ml index 24801542d..c248d0cad 100644 --- a/components/tactics/declarative.ml +++ b/components/tactics/declarative.ml @@ -63,18 +63,24 @@ let by_term_we_proved ~dbd ~universe t ty id ty' = ~continuation:just ) | Some id -> - let continuation = + let ty',continuation = match ty' with - None -> Tacticals.id_tac + None -> ty,just | Some ty' -> - Tactics.change ~pattern:(None,[id,Cic.Implicit (Some `Hole)],None) - (fun _ metasenv ugraph -> ty',metasenv,ugraph) + ty', + Tacticals.then_ + ~start: + (Tactics.change + ~with_cast:true + ~pattern:(None,[id,Cic.Implicit (Some `Hole)],None) + (fun _ metasenv ugraph -> ty,metasenv,ugraph)) + ~continuation:just in Tacticals.thens ~start: - (Tactics.cut ty + (Tactics.cut ty' ~mk_fresh_name_callback:(fun _ _ _ ~typ -> Cic.Name id)) - ~continuations:[ continuation ; just ] + ~continuations:[ Tacticals.id_tac ; continuation ] ;; let bydone ~dbd ~universe t = @@ -165,7 +171,7 @@ let rewritingstep ~dbd ~universe lhs rhs just last_step = in let ty,_ = CicTypeChecker.type_of_aux' metasenv context rhs CicUniv.empty_ugraph in - let just = + let just' = match just with `Auto params -> let params = @@ -193,6 +199,8 @@ let rewritingstep ~dbd ~universe lhs rhs just last_step = ~universe:(Universe.index Universe.empty (Universe.key ty) just) ~steps:1 () (* Tactics.apply just *) + | `Proof -> + Tacticals.id_tac in let plhs,prhs,prepare = match lhs with @@ -238,8 +246,9 @@ let rewritingstep ~dbd ~universe lhs rhs just last_step = ~continuations:[Tacticals.id_tac ; continuation]) (proof,goal) in let goals = - match goals with - [g1;g2] -> [g2;newmeta;g1] + match just,goals with + `Proof, [g1;g2;g3] -> [g2;g3;newmeta;g1] + | _, [g1;g2] -> [g2;newmeta;g1] | _ -> assert false in proof,goals) @@ -247,11 +256,11 @@ let rewritingstep ~dbd ~universe lhs rhs just last_step = let continuation = if last_step then (*CSC:manca controllo sul fatto che rhs sia convertibile con prhs*) - just + just' else Tacticals.thens ~start:(Tactics.apply ~term:(Cic.Appl [trans;ty;plhs;rhs;prhs])) - ~continuations:[just ; Tacticals.id_tac] + ~continuations:[just' ; Tacticals.id_tac] in prepare continuation in