(************************************************************************) (* v * The Coq Proof Assistant / The Coq Development Team *) (* std_ppcmds val stras : int * string -> std_ppcmds val brk : int * int -> std_ppcmds val tbrk : int * int -> std_ppcmds val tab : unit -> std_ppcmds val fnl : unit -> std_ppcmds val pifb : unit -> std_ppcmds val ws : int -> std_ppcmds val mt : unit -> std_ppcmds val ismt : std_ppcmds -> bool val comment : string list -> std_ppcmds (** {6 Manipulation commands} *) val app : std_ppcmds -> std_ppcmds -> std_ppcmds (** Concatenation. *) val (++) : std_ppcmds -> std_ppcmds -> std_ppcmds (** Infix alias for [app]. *) val eval_ppcmds : std_ppcmds -> std_ppcmds (** Force computation. *) val is_empty : std_ppcmds -> bool (** Test emptyness. *) (** {6 Derived commands} *) val spc : unit -> std_ppcmds val cut : unit -> std_ppcmds val align : unit -> std_ppcmds val int : int -> std_ppcmds val real : float -> std_ppcmds val bool : bool -> std_ppcmds val qstring : string -> std_ppcmds val qs : string -> std_ppcmds val quote : std_ppcmds -> std_ppcmds val strbrk : string -> std_ppcmds (** {6 Boxing commands} *) val h : int -> std_ppcmds -> std_ppcmds val v : int -> std_ppcmds -> std_ppcmds val hv : int -> std_ppcmds -> std_ppcmds val hov : int -> std_ppcmds -> std_ppcmds val t : std_ppcmds -> std_ppcmds (** {6 Opening and closing of boxes} *) val hb : int -> std_ppcmds val vb : int -> std_ppcmds val hvb : int -> std_ppcmds val hovb : int -> std_ppcmds val tb : unit -> std_ppcmds val close : unit -> std_ppcmds val tclose : unit -> std_ppcmds (** {6 Opening and closing of tags} *) module Tag : sig type t (** Type of tags. Tags are dynamic types comparable to {Dyn.t}. *) type 'a key (** Keys used to inject tags *) val create : string -> 'a key (** Create a key with the given name. Two keys cannot share the same name, if ever this is the case this function raises an assertion failure. *) val inj : 'a -> 'a key -> t (** Inject an object into a tag. *) val prj : t -> 'a key -> 'a option (** Project an object from a tag. *) end val tag : Tag.t -> std_ppcmds -> std_ppcmds val open_tag : Tag.t -> std_ppcmds val close_tag : unit -> std_ppcmds (** {6 Utilities} *) val string_of_ppcmds : std_ppcmds -> string (** {6 Printing combinators} *) val pr_comma : unit -> std_ppcmds (** Well-spaced comma. *) val pr_semicolon : unit -> std_ppcmds (** Well-spaced semicolon. *) val pr_bar : unit -> std_ppcmds (** Well-spaced pipe bar. *) val pr_arg : ('a -> std_ppcmds) -> 'a -> std_ppcmds (** Adds a space in front of its argument. *) val pr_non_empty_arg : ('a -> std_ppcmds) -> 'a -> std_ppcmds (** Adds a space in front of its argument if non empty. *) val pr_opt : ('a -> std_ppcmds) -> 'a option -> std_ppcmds (** Inner object preceded with a space if [Some], nothing otherwise. *) val pr_opt_no_spc : ('a -> std_ppcmds) -> 'a option -> std_ppcmds (** Same as [pr_opt] but without the leading space. *) val pr_nth : int -> std_ppcmds (** Ordinal number with the correct suffix (i.e. "st", "nd", "th", etc.). *) val prlist : ('a -> std_ppcmds) -> 'a list -> std_ppcmds (** Concatenation of the list contents, without any separator. Unlike all other functions below, [prlist] works lazily. If a strict behavior is needed, use [prlist_strict] instead. *) val prlist_strict : ('a -> std_ppcmds) -> 'a list -> std_ppcmds (** Same as [prlist], but strict. *) val prlist_with_sep : (unit -> std_ppcmds) -> ('a -> std_ppcmds) -> 'a list -> std_ppcmds (** [prlist_with_sep sep pr [a ; ... ; c]] outputs [pr a ++ sep() ++ ... ++ sep() ++ pr c]. *) val prvect : ('a -> std_ppcmds) -> 'a array -> std_ppcmds (** As [prlist], but on arrays. *) val prvecti : (int -> 'a -> std_ppcmds) -> 'a array -> std_ppcmds (** Indexed version of [prvect]. *) val prvect_with_sep : (unit -> std_ppcmds) -> ('a -> std_ppcmds) -> 'a array -> std_ppcmds (** As [prlist_with_sep], but on arrays. *) val prvecti_with_sep : (unit -> std_ppcmds) -> (int -> 'a -> std_ppcmds) -> 'a array -> std_ppcmds (** Indexed version of [prvect_with_sep]. *) val pr_enum : ('a -> std_ppcmds) -> 'a list -> std_ppcmds (** [pr_enum pr [a ; b ; ... ; c]] outputs [pr a ++ str "," ++ pr b ++ str "," ++ ... ++ str "and" ++ pr c]. *) val pr_sequence : ('a -> std_ppcmds) -> 'a list -> std_ppcmds (** Sequence of objects separated by space (unless an element is empty). *) val surround : std_ppcmds -> std_ppcmds (** Surround with parenthesis. *) val pr_vertical_list : ('b -> std_ppcmds) -> 'b list -> std_ppcmds val pr_loc : Loc.t -> std_ppcmds (** {6 Low-level pretty-printing functions with and without flush} *) (** FIXME: These ignore the logging settings and call [Format] directly *) type tag_handler = Tag.t -> Format.tag (** [msg_with ?pp_tag fmt pp] Print [pp] to [fmt] and flush [fmt] *) val msg_with : ?pp_tag:tag_handler -> Format.formatter -> std_ppcmds -> unit (** [msg_with ?pp_tag fmt pp] Print [pp] to [fmt] and don't flush [fmt] *) val pp_with : ?pp_tag:tag_handler -> Format.formatter -> std_ppcmds -> unit