diff --git a/src/libraries/utils/markdown.ml b/src/libraries/utils/markdown.ml index 2a5d1ec16564ac91be7d972736ae33456a122c5d..61a484b6a148950dcea6c8131a9fc27619e83948 100644 --- a/src/libraries/utils/markdown.ml +++ b/src/libraries/utils/markdown.ml @@ -65,11 +65,13 @@ let local ctxt job data = (* --- Combinators --- *) (* -------------------------------------------------------------------------- *) +let nil _fmt = () +let empty= nil let space fmt = Format.pp_print_space fmt () let newline fmt = Format.pp_print_newline fmt () let merge sep ds fmt = - match ds with + match List.filter (fun d -> d != nil) ds with | [] -> () | d::ds -> d fmt ; List.iter (fun d -> sep fmt ; d fmt) ds @@ -78,9 +80,20 @@ let glue ?sep ds fmt = | None -> List.iter (fun d -> d fmt) ds | Some s -> merge s ds fmt -let (<@>) a b fmt = a fmt ; b fmt -let (<+>) a b fmt = a fmt ; space fmt ; b fmt -let (</>) a b fmt = a fmt ; newline fmt ; b fmt +let (<@>) a b = + if a == empty then b else + if b == empty then a else + fun fmt -> a fmt ; b fmt + +let (<+>) a b = + if a == empty then b else + if b == empty then a else + fun fmt -> a fmt ; space fmt ; b fmt + +let (</>) a b = + if a == empty then b else + if b == empty then a else + fun fmt -> a fmt ; newline fmt ; b fmt let fmt_text k fmt = Format.fprintf fmt "@[<h 0>%t@]" k let fmt_block k fmt = Format.fprintf fmt "@[<v 0>%t@]" k @@ -151,8 +164,6 @@ let href ?title (h : href) fmt = (* --- Blocks --- *) (* -------------------------------------------------------------------------- *) -let empty _fmt = () - let aname anchor fmt = Format.fprintf fmt "<a name=\"%s\"></a>@\n" anchor diff --git a/src/libraries/utils/markdown.mli b/src/libraries/utils/markdown.mli index 31fb5e003f6ad94e9145bcdeffe9ca75e7f0110f..34b955919fcc8696722172e66ad43680b689335c 100644 --- a/src/libraries/utils/markdown.mli +++ b/src/libraries/utils/markdown.mli @@ -42,6 +42,7 @@ val (</>) : block -> block -> block (** Infix operator for [concat] *) (** {2 Text Constructors} *) +val nil : text (** Empty *) val raw : string -> text (** inlined markdown format *) val rm : string -> text (** roman (normal) style *) val it : string -> text (** italic style *)