X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fng_kernel%2FnCicPp.ml;h=27b46431ed49b1eedf2e3be8f52386e0ecc3fc92;hb=11b2157bacf59cfc561c2ef6f92ee41ee2c1a006;hp=27590ed3eed7ff1179eb9ec81006961b09b13eb0;hpb=ae578957a656e46c86a23626b219f4e841734b18;p=helm.git diff --git a/helm/software/components/ng_kernel/nCicPp.ml b/helm/software/components/ng_kernel/nCicPp.ml index 27590ed3e..27b46431e 100644 --- a/helm/software/components/ng_kernel/nCicPp.ml +++ b/helm/software/components/ng_kernel/nCicPp.ml @@ -210,11 +210,12 @@ let rec ppcontext ~formatter ?(sep="\n") ~subst ~metasenv = function let rec ppmetasenv ~formatter ~subst metasenv = function | [] -> () | (i,(name, ctx, ty)) :: tl -> + F.fprintf formatter "@["; let name = match name with Some n -> "("^n^")" | _ -> "" in ppcontext ~formatter ~sep:"; " ~subst ~metasenv ctx; - F.fprintf formatter " ⊢ ?%d%s : " i name; + F.fprintf formatter "@;⊢@;?%d%s :@;" i name; ppterm ~formatter ~metasenv ~subst ~context:ctx ty; - F.fprintf formatter "\n"; + F.fprintf formatter "@]@\n"; ppmetasenv ~formatter ~subst metasenv tl ;; @@ -244,43 +245,49 @@ let ppobj ~formatter (u,_,metasenv, subst, o) = ppmetasenv ~formatter ~subst metasenv; F.fprintf formatter "\n"; F.fprintf formatter "subst:\n"; - (*ppsubst subst ~formatter ~metasenv;*) + (*ppsubst subst ~formatter ~metasenv;*) F.fprintf formatter "..."; F.fprintf formatter "\n"; match o with | NCic.Fixpoint (b, fl, _) -> - F.fprintf formatter "{%s}\n" (NUri.string_of_uri u); - F.fprintf formatter "%s" (if b then "let rec " else "let corec "); - HExtlib.list_iter_sep ~sep:(fun ()->F.fprintf formatter "\nand ") + F.fprintf formatter "{%s}@\n@[" (NUri.string_of_uri u); + F.fprintf formatter "@[%s"(if b then "let rec " else "let corec "); + HExtlib.list_iter_sep + ~sep:(fun () -> F.fprintf formatter "@\n@[and ") (fun (_,name,n,ty,bo) -> - F.fprintf formatter "%s on %d : " name n; + F.fprintf formatter "%s on %d :@;" name n; ppterm ~formatter ~metasenv ~subst ~context:[] ty; - F.fprintf formatter " :=\n"; - ppterm ~formatter ~metasenv ~subst ~context:[] ~inside_fix:true bo) fl + F.fprintf formatter "@]@;@[:=@;"; + ppterm ~formatter ~metasenv ~subst ~context:[] ~inside_fix:true bo; + F.fprintf formatter "@]") fl; + F.fprintf formatter "@]" | NCic.Inductive (b, leftno,tyl, _) -> - F.fprintf formatter "{%s} with %d fixed params\n%s" + F.fprintf formatter "{%s} with %d fixed params@\n@[@[%s" (NUri.string_of_uri u) leftno (if b then "inductive " else "coinductive "); - HExtlib.list_iter_sep ~sep:(fun ()->F.fprintf formatter "\nand ") + HExtlib.list_iter_sep + ~sep:(fun () -> F.fprintf formatter "@\n@[and ") (fun (_,name,ty,cl) -> - F.fprintf formatter "%s: " name; + F.fprintf formatter "%s:@;" name; ppterm ~formatter ~metasenv ~subst ~context:[] ty; - F.fprintf formatter " :=\n"; - HExtlib.list_iter_sep ~sep:(fun () -> F.fprintf formatter "\n") + F.fprintf formatter "@]@;@[:=@;"; + HExtlib.list_iter_sep ~sep:(fun () -> F.fprintf formatter "@;") (fun (_,name,ty) -> - F.fprintf formatter " | %s: " name; - ppterm ~formatter ~metasenv ~subst ~context:[] ty) - cl - ) tyl + F.fprintf formatter "| %s: " name; + ppterm ~formatter ~metasenv ~subst ~context:[] ty;) + cl; + F.fprintf formatter "@]" + ) tyl ; + F.fprintf formatter "@]" | NCic.Constant (_,name,None,ty, _) -> - F.fprintf formatter "{%s}\naxiom %s : " (NUri.string_of_uri u) name; + F.fprintf formatter "{%s}@\n@[axiom %s :@;" (NUri.string_of_uri u) name; ppterm ~formatter ~metasenv ~subst ~context:[] ty; - F.fprintf formatter "\n" + F.fprintf formatter "@]@\n" | NCic.Constant (_,name,Some bo,ty, _) -> - F.fprintf formatter "{%s}\ndefinition %s : " (NUri.string_of_uri u) name; + F.fprintf formatter "{%s}@\n@[@[definition %s :@;" (NUri.string_of_uri u) name; ppterm ~formatter ~metasenv ~subst ~context:[] ty; - F.fprintf formatter " := \n"; + F.fprintf formatter "@]@;@[:=@;"; ppterm ~formatter ~metasenv ~subst ~context:[] bo; - F.fprintf formatter "\n" + F.fprintf formatter "@]@\n@]" ;; let ppterm ~context ~subst ~metasenv ?margin ?inside_fix t =