X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Fcomponents%2Fgrafite%2FgrafiteAstPp.ml;h=2cd7a4f4fcddfee286d115b84ff79c5a18cee9ad;hb=4442acec319822fbc4eb2e873808dbfc1893f390;hp=cdf90c5b989883ff54a2e98d6a4c7e6c527901e8;hpb=8ae1653eb75d2b57c50e077c49cb9d078313ea9d;p=helm.git diff --git a/helm/software/components/grafite/grafiteAstPp.ml b/helm/software/components/grafite/grafiteAstPp.ml index cdf90c5b9..2cd7a4f4f 100644 --- a/helm/software/components/grafite/grafiteAstPp.ml +++ b/helm/software/components/grafite/grafiteAstPp.ml @@ -89,7 +89,7 @@ let pp_just ~term_pp = | `Auto params -> pp_auto_params ~term_pp params ;; -let pp_ntactic ~map_unicode_to_tex = function +let rec pp_ntactic ~map_unicode_to_tex = function | NApply (_,t) -> "napply " ^ CicNotationPp.pp_term t | NCases (_,what,where) -> "ncases " ^ CicNotationPp.pp_term what ^ assert false ^ " " ^ assert false @@ -101,7 +101,29 @@ let pp_ntactic ~map_unicode_to_tex = function | NId _ -> "nid" | NIntro (_,n) -> "#" ^ n | NRewrite (_,dir,n,where) -> "nrewrite" ^ assert false - | NReduce _ | NGeneralize _ | NLetIn _ | NAssert _ | NAuto _ -> assert false + | NAuto (_,(l,flgs)) -> + "nauto" ^ + (if l <> [] then (" by " ^ + (String.concat "," (List.map CicNotationPp.pp_term l))) else "") ^ + String.concat " " (List.map (fun a,b -> a ^ "=" ^ b) flgs) + | NReduce _ | NGeneralize _ | NLetIn _ | NAssert _ -> assert false + | NDot _ -> "##." + | NSemicolon _ -> "##;" + | NBranch _ -> "##[" + | NShift _ -> "##|" + | NPos (_, l) -> "##" ^String.concat "," (List.map string_of_int l)^ ":" + | NWildcard _ -> "##*:" + | NMerge _ -> "##]" + | NFocus (_,l) -> + Printf.sprintf "##focus %s" + (String.concat " " (List.map string_of_int l)) + | NUnfocus _ -> "##unfocus" + | NSkip _ -> "##skip" + | NTry (_,tac) -> "ntry " ^ pp_ntactic ~map_unicode_to_tex tac + | NAssumption _ -> "nassumption" + | NBlock (_,l) -> + "(" ^ String.concat " " (List.map (pp_ntactic ~map_unicode_to_tex) l)^ ")" + | NRepeat (_,t) -> "nrepeat " ^ pp_ntactic ~map_unicode_to_tex t ;; let rec pp_tactic ~map_unicode_to_tex ~term_pp ~lazy_term_pp = @@ -282,13 +304,14 @@ let pp_macro ~term_pp ~lazy_term_pp = let pp_param = function | IPPrefix prefix -> "prefix = \"" ^ prefix ^ "\"" | IPAs flavour -> flavour_pp flavour + | IPCoercions -> "coercions" + | IPDebug debug -> "debug = " ^ string_of_int debug | IPProcedural -> "procedural" | IPNoDefaults -> "nodefaults" | IPDepth depth -> "depth = " ^ string_of_int depth | IPLevel level -> "level = " ^ string_of_int level | IPComments -> "comments" - | IPCoercions -> "coercions" - | IPDebug debug -> "debug = " ^ string_of_int debug + | IPCR -> "cr" in let s = String.concat " " (List.map pp_param l) in if s = "" then s else " " ^ s @@ -331,6 +354,14 @@ let pp_coercion ~term_pp t do_composites arity saturations= Printf.sprintf "coercion %s %d %d %s" (term_pp t) arity saturations (if do_composites then "" else "nocomposites") + +let pp_ncommand = function + | UnificationHint (_,t, n) -> + "unification hint " ^ string_of_int n ^ " " ^ CicNotationPp.pp_term t + | NObj (_,_) + | NUnivConstraint (_) -> "not supported" + | NCoercion (_) -> "not supported" + | NQed (_) -> "nqed" let pp_command ~term_pp ~obj_pp = function | Index (_,_,uri) -> "Indexing " ^ UriManager.string_of_uri uri @@ -341,12 +372,11 @@ let pp_command ~term_pp ~obj_pp = function "prefer coercion " ^ term_pp t | Inverter (_,n,ty,params) -> "inverter " ^ n ^ " for " ^ term_pp ty ^ " " ^ List.fold_left (fun acc x -> acc ^ (match x with true -> "%" | _ -> "?")) "" params - | UnificationHint (_,t, n) -> - "unification hint " ^ string_of_int n ^ " " ^ term_pp t | Default (_,what,uris) -> pp_default what uris | Drop _ -> "drop" - | Include (_,true,path) -> "include \"" ^ path ^ "\"" - | Include (_,false,path) -> "include source \"" ^ path ^ "\"" + | Include (_,true,`OldAndNew,path) -> "include \"" ^ path ^ "\"" + | Include (_,false,`OldAndNew,path) -> "include source \"" ^ path ^ "\"" + | Include (_,_,`New,path) -> "RECURSIVELY INCLUDING " ^ path | Obj (_,obj) -> obj_pp obj | Qed _ -> "qed" | Relation (_,id,a,aeq,refl,sym,trans) -> @@ -362,9 +392,6 @@ let pp_command ~term_pp ~obj_pp = function | None -> "") | Print (_,s) -> "print " ^ s | Set (_, name, value) -> Printf.sprintf "set \"%s\" \"%s\"" name value - | NObj (_,o) -> "not supported" - | NUnivConstraint (_) -> "not supported" - | NQed (_) -> "not supported" | Pump (_) -> "not supported" let pp_punctuation_tactical = @@ -392,16 +419,13 @@ let pp_executable ~map_unicode_to_tex ~term_pp ~lazy_term_pp ~obj_pp = ^ pp_punctuation_tactical punct | Tactic (_, None, punct) -> pp_punctuation_tactical punct - | NTactic (_,tac, punct) -> - pp_ntactic ~map_unicode_to_tex tac - ^ pp_punctuation_tactical punct + | NTactic (_,tacl) -> + String.concat " " (List.map (pp_ntactic ~map_unicode_to_tex) tacl) | NonPunctuationTactical (_, tac, punct) -> pp_non_punctuation_tactical tac ^ pp_punctuation_tactical punct - | NNonPunctuationTactical (_, tac, punct) -> - pp_non_punctuation_tactical tac - ^ pp_punctuation_tactical punct | Command (_, cmd) -> pp_command ~term_pp ~obj_pp cmd ^ "." + | NCommand (_, cmd) -> pp_ncommand cmd ^ "." let pp_comment ~map_unicode_to_tex ~term_pp ~lazy_term_pp ~obj_pp = function