X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=matita%2Fcomponents%2Fgrafite%2FgrafiteAstPp.ml;fp=matita%2Fcomponents%2Fgrafite%2FgrafiteAstPp.ml;h=48fc8691c08c37b66a6425d1cd944760c0b24564;hb=894d518aa760c9f816ddb0dc2b3fa88e1fe20a94;hp=c20a5d8c388430e2966dd9d25035599f8a07dcd8;hpb=a4a2345e2efaf4cc64aa4daf40e2bce05a400f12;p=helm.git diff --git a/matita/components/grafite/grafiteAstPp.ml b/matita/components/grafite/grafiteAstPp.ml index c20a5d8c3..48fc8691c 100644 --- a/matita/components/grafite/grafiteAstPp.ml +++ b/matita/components/grafite/grafiteAstPp.ml @@ -32,62 +32,62 @@ let tactical_terminator = "" let tactic_terminator = tactical_terminator let command_terminator = tactical_terminator -let pp_tactic_pattern ~map_unicode_to_tex (what, hyp, goal) = +let pp_tactic_pattern status ~map_unicode_to_tex (what, hyp, goal) = if what = None && hyp = [] && goal = None then "" else let what_text = match what with | None -> "" - | Some t -> Printf.sprintf "in match (%s) " (NotationPp.pp_term t) in + | Some t -> Printf.sprintf "in match (%s) " (NotationPp.pp_term status t) in let hyp_text = String.concat " " (List.map (fun (name, p) -> Printf.sprintf "%s:(%s)" name - (NotationPp.pp_term p)) hyp) in + (NotationPp.pp_term status p)) hyp) in let goal_text = match goal with | None -> "" | Some t -> let vdash = if map_unicode_to_tex then "\\vdash" else "⊢" in - Printf.sprintf "%s (%s)" vdash (NotationPp.pp_term t) + Printf.sprintf "%s (%s)" vdash (NotationPp.pp_term status t) in Printf.sprintf "%sin %s%s" what_text hyp_text goal_text -let rec pp_ntactic ~map_unicode_to_tex = +let rec pp_ntactic status ~map_unicode_to_tex = let pp_tactic_pattern = pp_tactic_pattern ~map_unicode_to_tex in function - | NApply (_,t) -> "napply " ^ NotationPp.pp_term t + | NApply (_,t) -> "napply " ^ NotationPp.pp_term status t | NSmartApply (_,t) -> "fixme" | NAuto (_,(None,flgs)) -> "nautobatch" ^ String.concat " " (List.map (fun a,b -> a ^ "=" ^ b) flgs) | NAuto (_,(Some l,flgs)) -> "nautobatch" ^ " by " ^ - (String.concat "," (List.map NotationPp.pp_term l)) ^ + (String.concat "," (List.map (NotationPp.pp_term status) l)) ^ String.concat " " (List.map (fun a,b -> a ^ "=" ^ b) flgs) - | NCases (_,what,where) -> "ncases " ^ NotationPp.pp_term what ^ + | NCases (_,what,where) -> "ncases " ^ NotationPp.pp_term status what ^ "...to be implemented..." ^ " " ^ "...to be implemented..." | NConstructor (_,None,l) -> "@ " ^ - String.concat " " (List.map NotationPp.pp_term l) + String.concat " " (List.map (NotationPp.pp_term status) l) | NConstructor (_,Some x,l) -> "@" ^ string_of_int x ^ " " ^ - String.concat " " (List.map NotationPp.pp_term l) + String.concat " " (List.map (NotationPp.pp_term status) l) | NCase1 (_,n) -> "*" ^ n ^ ":" | NChange (_,what,wwhat) -> "nchange " ^ "...to be implemented..." ^ - " with " ^ NotationPp.pp_term wwhat - | NCut (_,t) -> "ncut " ^ NotationPp.pp_term t -(*| NDiscriminate (_,t) -> "ndiscriminate " ^ NotationPp.pp_term t - | NSubst (_,t) -> "nsubst " ^ NotationPp.pp_term t *) + " with " ^ NotationPp.pp_term status wwhat + | NCut (_,t) -> "ncut " ^ NotationPp.pp_term status t +(*| NDiscriminate (_,t) -> "ndiscriminate " ^ NotationPp.pp_term status t + | NSubst (_,t) -> "nsubst " ^ NotationPp.pp_term status t *) | NClear (_,l) -> "nclear " ^ String.concat " " l | NDestruct (_,dom,skip) -> "ndestruct ..." - | NElim (_,what,where) -> "nelim " ^ NotationPp.pp_term what ^ + | NElim (_,what,where) -> "nelim " ^ NotationPp.pp_term status what ^ "...to be implemented..." ^ " " ^ "...to be implemented..." | NId _ -> "nid" | NIntro (_,n) -> "#" ^ n | NIntros (_,l) -> "#" ^ String.concat " " l - | NInversion (_,what,where) -> "ninversion " ^ NotationPp.pp_term what ^ + | NInversion (_,what,where) -> "ninversion " ^ NotationPp.pp_term status what ^ assert false ^ " " ^ assert false - | NLApply (_,t) -> "lapply " ^ NotationPp.pp_term t + | NLApply (_,t) -> "lapply " ^ NotationPp.pp_term status t | NRewrite (_,dir,n,where) -> "nrewrite " ^ (match dir with `LeftToRight -> ">" | `RightToLeft -> "<") ^ - " " ^ NotationPp.pp_term n ^ " " ^ pp_tactic_pattern where + " " ^ NotationPp.pp_term status n ^ " " ^ pp_tactic_pattern status where | NReduce _ | NGeneralize _ | NLetIn _ | NAssert _ -> "TO BE IMPLEMENTED" | NDot _ -> "." | NSemicolon _ -> ";" @@ -102,15 +102,15 @@ let rec pp_ntactic ~map_unicode_to_tex = (String.concat " " (List.map string_of_int l)) | NUnfocus _ -> "unfocus" | NSkip _ -> "skip" - | NTry (_,tac) -> "ntry " ^ pp_ntactic ~map_unicode_to_tex tac + | NTry (_,tac) -> "ntry " ^ pp_ntactic status ~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 + "(" ^ String.concat " " (List.map (pp_ntactic status ~map_unicode_to_tex) l)^ ")" + | NRepeat (_,t) -> "nrepeat " ^ pp_ntactic status ~map_unicode_to_tex t ;; -let pp_nmacro = function - | NCheck (_, term) -> Printf.sprintf "ncheck %s" (NotationPp.pp_term term) +let pp_nmacro status = function + | NCheck (_, term) -> Printf.sprintf "ncheck %s" (NotationPp.pp_term status term) | Screenshot (_, name) -> Printf.sprintf "screenshot \"%s\"" name ;; @@ -153,22 +153,22 @@ let pp_dir_opt = function | Some `LeftToRight -> "> " | Some `RightToLeft -> "< " -let pp_notation dir_opt l1_pattern assoc prec l2_pattern = +let pp_notation status dir_opt l1_pattern assoc prec l2_pattern = sprintf "notation %s\"%s\" %s %s for %s." (pp_dir_opt dir_opt) - (pp_l1_pattern l1_pattern) + (pp_l1_pattern status l1_pattern) (pp_associativity assoc) (pp_precedence prec) - (pp_l2_pattern l2_pattern) + (pp_l2_pattern status l2_pattern) -let pp_ncommand = function +let pp_ncommand status = function | UnificationHint (_,t, n) -> - "unification hint " ^ string_of_int n ^ " " ^ NotationPp.pp_term t + "unification hint " ^ string_of_int n ^ " " ^ NotationPp.pp_term status t | NDiscriminator (_,_) | NInverter (_,_,_,_,_) | NUnivConstraint (_) -> "not supported" | NCoercion (_) -> "not supported" - | NObj (_,obj) -> NotationPp.pp_obj NotationPp.pp_term obj + | NObj (_,obj) -> NotationPp.pp_obj (NotationPp.pp_term status) obj | NQed (_) -> "nqed" | NCopy (_,name,uri,map) -> "copy " ^ name ^ " from " ^ NUri.string_of_uri uri ^ " with " ^ @@ -185,24 +185,24 @@ let pp_ncommand = function | Interpretation (_, dsc, (symbol, arg_patterns), cic_appl_pattern) -> pp_interpretation dsc symbol arg_patterns cic_appl_pattern | Notation (_, dir_opt, l1_pattern, assoc, prec, l2_pattern) -> - pp_notation dir_opt l1_pattern assoc prec l2_pattern + pp_notation status dir_opt l1_pattern assoc prec l2_pattern ;; -let pp_executable ~map_unicode_to_tex = +let pp_executable status ~map_unicode_to_tex = function - | NMacro (_, macro) -> pp_nmacro macro ^ "." + | NMacro (_, macro) -> pp_nmacro status macro ^ "." | NTactic (_,tacl) -> - String.concat " " (List.map (pp_ntactic ~map_unicode_to_tex) tacl) - | NCommand (_, cmd) -> pp_ncommand cmd ^ "." + String.concat " " (List.map (pp_ntactic status ~map_unicode_to_tex) tacl) + | NCommand (_, cmd) -> pp_ncommand status cmd ^ "." -let pp_comment ~map_unicode_to_tex = +let pp_comment status ~map_unicode_to_tex = function | Note (_,"") -> Printf.sprintf "\n" | Note (_,str) -> Printf.sprintf "\n(* %s *)" str | Code (_,code) -> - Printf.sprintf "\n(** %s. **)" (pp_executable ~map_unicode_to_tex code) + Printf.sprintf "\n(** %s. **)" (pp_executable status ~map_unicode_to_tex code) -let pp_statement = +let pp_statement status = function - | Executable (_, ex) -> pp_executable ex - | Comment (_, c) -> pp_comment c + | Executable (_, ex) -> pp_executable status ex + | Comment (_, c) -> pp_comment status c