X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fng_tactics%2FnTactics.ml;h=01a57f0c45fa2851722bfac93e9f4e8bc8afceb6;hb=7ca0a000878e864c92d94f77900bc2ca0ac143b9;hp=d8a9fba5ed84bcb0203832f97b029192ebac591b;hpb=a82bb964ad0bf0969dae008a4de854532846e455;p=helm.git diff --git a/helm/software/components/ng_tactics/nTactics.ml b/helm/software/components/ng_tactics/nTactics.ml index d8a9fba5e..01a57f0c4 100644 --- a/helm/software/components/ng_tactics/nTactics.ml +++ b/helm/software/components/ng_tactics/nTactics.ml @@ -402,6 +402,19 @@ let generalize_tac ~where = ) s) ] ;; +let cut_tac t = + block_tac [ + exact_tac ("",0, Ast.Appl [Ast.Implicit `JustOne; Ast.Implicit `JustOne]); + branch_tac; + pos_tac [2]; exact_tac t; + shift_tac; pos_tac [1]; skip_tac; + merge_tac ] +;; + +let lapply_tac (s,n,t) = + exact_tac (s,n, Ast.Appl [Ast.Implicit `JustOne; t]) +;; + let reduce_tac ~reduction ~where = let change status t = match reduction with @@ -464,33 +477,31 @@ let analyze_indty_tac ~what indtyref = exec id_tac status goal) ;; +let sort_of_goal_tac sortref = distribute_tac (fun status goal -> + let goalty = get_goalty status goal in + let status,sort = typeof status (ctx_of goalty) goalty in + let sort = fix_sorts sort in + let status, sort = term_of_cic_term status sort (ctx_of goalty) in + sortref := sort; + status) +;; + let elim_tac ~what:(txt,len,what) ~where = let what = txt, len, Ast.Appl [what; Ast.Implicit `Vector] in let indtyinfo = ref None in - let sort = ref None in - let compute_goal_sort_tac = distribute_tac (fun status goal -> - let goalty = get_goalty status goal in - let status, goalsort = typeof status (ctx_of goalty) goalty in - let goalsort = fix_sorts goalsort in - sort := Some goalsort; - exec id_tac status goal) - in + let sort = ref (NCic.Rel 1) in atomic_tac (block_tac [ analyze_indty_tac ~what indtyinfo; (fun s -> select_tac ~where ~job:(`Substexpand ((HExtlib.unopt !indtyinfo).rightno+1)) true s); - compute_goal_sort_tac; + sort_of_goal_tac sort; (fun status -> - let sort = HExtlib.unopt !sort in let ity = HExtlib.unopt !indtyinfo in let NReference.Ref (uri, _) = ity.reference in - let status, sort = term_of_cic_term status sort (ctx_of sort) in - let name = NUri.name_of_uri uri ^ - match sort with - | NCic.Sort NCic.Prop -> "_ind" - | NCic.Sort NCic.Type u -> - "_rect_" ^ NCicPp.ppterm ~metasenv:[] ~subst:[] ~context:[] sort - | _ -> assert false + let name = + NUri.name_of_uri uri ^ "_" ^ + snd (NCicElim.ast_of_sort + (match !sort with NCic.Sort x -> x | _ -> assert false)) in let eliminator = let _,_,w = what in @@ -499,23 +510,11 @@ let elim_tac ~what:(txt,len,what) ~where = exact_tac ("",0,eliminator) status) ]) ;; -let sort_of_goal_tac sortref = distribute_tac (fun status goal -> - let goalty = get_goalty status goal in - let status,sort = typeof status (ctx_of goalty) goalty in - let status,sort = term_of_cic_term status sort (ctx_of goalty) in - sortref := sort; - status) -;; - let rewrite_tac ~dir ~what:(_,_,what) ~where status = let sortref = ref (NCic.Rel 1) in let status = sort_of_goal_tac sortref status in - let suffix = - match !sortref with - | NCic.Sort NCic.Prop -> "_ind" - | NCic.Sort NCic.Type u -> - "_rect_" ^ NCicPp.ppterm ~metasenv:[] ~subst:[] ~context:[] !sortref - | _ -> assert false + let suffix = "_" ^ snd (NCicElim.ast_of_sort + (match !sortref with NCic.Sort x -> x | _ -> assert false)) in let name = match dir with @@ -573,15 +572,20 @@ let case1_tac name = if name = "_clearme" then clear_tac ["_clearme"] else id_tac ] ;; -let constructor ?(num=1) status goal = +let constructor ?(num=1) ~args status goal = if num < 1 then fail (lazy "constructor numbers begin with 1"); let gty = get_goalty status goal in let status, (r,_,_,_) = analyse_indty status gty in let ref = NReference.mk_constructor num r in - exec (apply_tac ("",0,Ast.NRef ref)) status goal + let t = + if args = [] then Ast.NRef ref else + Ast.Appl (HExtlib.list_concat ~sep:[Ast.Implicit `Vector] + ([Ast.NRef ref] :: List.map (fun _,_,x -> [x]) args)) + in + exec (apply_tac ("",0,t)) status goal ;; -let constructor_tac ?num = distribute_tac (constructor ?num);; +let constructor_tac ?num ~args = distribute_tac (constructor ?num ~args);; let assert0_tac (hyps,concl) = distribute_tac (fun status goal -> let gty = get_goalty status goal in