]> matita.cs.unibo.it Git - helm.git/commitdiff
added some flags to render subproofs (an hack)
authorEnrico Tassi <enrico.tassi@inria.fr>
Thu, 24 May 2007 15:52:48 +0000 (15:52 +0000)
committerEnrico Tassi <enrico.tassi@inria.fr>
Thu, 24 May 2007 15:52:48 +0000 (15:52 +0000)
helm/software/components/acic_procedural/acic2Procedural.ml
helm/software/components/acic_procedural/acic2Procedural.mli

index d54130a0cd75fdac58377ec0a4920660aa921852..23b934d51d35fc151f0833f2e518838c820a59ac 100644 (file)
@@ -54,7 +54,9 @@ type status = {
    intros: string option list;
    clears: string list;
    clears_note: string;
-   case: int list
+   case: int list;
+   skip_thm_and_qed : bool;
+   skip_initial_lambdas : bool;
 }
 
 (* helpers ******************************************************************)
@@ -374,9 +376,14 @@ and proc_proof st t =
          (Pp.ppterm (H.cic it)) (Pp.ppterm (H.cic et))) 
          | None          -> None, "\nNo types"
       in
-      let context, clears = Cn.get_clears st.context (H.cic t) xtypes in
+      let context, clears = 
+        if st.skip_initial_lambdas then
+          st.context, []
+        else
+          Cn.get_clears st.context (H.cic t) xtypes 
+      in
       let note = Pp.ppcontext st.context ^ note in
-      {st with context = context; clears = clears; clears_note = note}
+      {st with context = context; clears = clears; clears_note = note}
    in
    match t with
       | C.ALambda (_, name, w, t)        -> proc_lambda st name w t
@@ -422,13 +429,22 @@ let proc_obj st = function
       let ast = proc_proof st v in
       let steps, nodes = T.count_steps 0 ast, T.count_nodes 0 ast in
       let text = Printf.sprintf "tactics: %u\nnodes: %u" steps nodes in
-      T.Theorem (Some s, t, "") :: ast @ [T.Qed text]
+      let ast = 
+        if st.skip_initial_lambdas then 
+          match ast with
+            | T.Intros _::tl -> tl
+            | ast -> ast
+        else ast
+      in
+      if st.skip_thm_and_qed then ast
+      else T.Theorem (Some s, t, "") :: ast @ [T.Qed text]
    | _                                                               ->
       failwith "not a theorem"
 
 (* interface functions ******************************************************)
 
-let acic2procedural ~ids_to_inner_sorts ~ids_to_inner_types ?depth prefix aobj = 
+let acic2procedural ~ids_to_inner_sorts ~ids_to_inner_types ?depth
+?(skip_thm_and_qed=false) ?(skip_initial_lambdas=false) prefix aobj = 
    let st = {
       sorts       = ids_to_inner_sorts;
       types       = ids_to_inner_types;
@@ -439,7 +455,9 @@ let acic2procedural ~ids_to_inner_sorts ~ids_to_inner_types ?depth prefix aobj =
       intros      = [];
       clears      = [];
       clears_note = "";
-      case        = []
+      case        = [];
+      skip_thm_and_qed = skip_thm_and_qed;
+      skip_initial_lambdas = skip_initial_lambdas;
    } in
    HLog.debug "Procedural: level 2 transformation";
    let steps = proc_obj st aobj in
index d1ff6a0c20e18695ed4b5b504e96fde40a85888f..35092fb16099d1279263bf181b5b969b460b994e 100644 (file)
@@ -26,7 +26,8 @@
 val acic2procedural:
    ids_to_inner_sorts:(Cic.id, Cic2acic.sort_kind) Hashtbl.t ->
    ids_to_inner_types:(Cic.id, Cic2acic.anntypes) Hashtbl.t -> 
-   ?depth:int -> string -> Cic.annobj ->
+   ?depth:int -> ?skip_thm_and_qed:bool -> ?skip_initial_lambdas:bool ->
+     string -> Cic.annobj ->
       (Cic.annterm, Cic.annterm,
        Cic.annterm GrafiteAst.reduction, Cic.annterm CicNotationPt.obj, string)
       GrafiteAst.statement list