package b0
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Software construction and deployment kit
Install
dune-project
Dependency
Authors
Maintainers
Sources
b0-0.0.5.tbz
sha512=00a6868b4dfa34565d0141b335622a81a0e8d5b9e3c6dfad025dabfa3df2db2a1302b492953bbbce30c3a4406c324fcec25250a00b38f6d18a69e15605e3b07e
doc/src/b0_b00_kit/b00_cmark.ml.html
Source file b00_cmark.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83(*--------------------------------------------------------------------------- Copyright (c) 2019 The b0 programmers. All rights reserved. Distributed under the ISC license, see terms at the end of the file. ---------------------------------------------------------------------------*) open B0_std open B00 let tool = Tool.by_name "cmark" let cmd ?(validate_utf_8 = true) ?(format = "html") m ~opts ~mds ~o = let cmark = Memo.tool m tool in let validate = Cmd.if' validate_utf_8 (Cmd.atom "--validate-utf8") in Memo.spawn m ~reads:mds ~writes:[o] ~stdout:(`File o) @@ cmark Cmd.(atom "--to" % format %% validate %% opts %% unstamp (paths mds)) let to_html ?generator ?lang ?scripts ?styles ?title m ~opts ~mds ~o_frag:frag ~o = cmd m ~opts ~mds ~o:frag; B00_htmlg.El.write_page ?generator ?lang ?scripts ?styles ?title m ~frag ~o let first_section ~preamble md = let atx_heading s (* trimmed *) = (* approximate https://spec.commonmark.org/0.29/#atx-headings *) let num, title = String.span_left (Char.equal '#') s in let num = String.length num and tlen = String.length title in if num = 0 || num > 6 then None else if tlen = 0 then Some (num, "") else if title.[0] <> ' ' then None else Some (num, String.trim title) in let setex_heading s (* trimmed *) = (* approximate https://spec.commonmark.org/0.29/#setext-headings *) if String.starts_with ~prefix:"==" s then Some 1 else if String.starts_with ~prefix:"--" s then Some 2 else None in let nl = "\n" in let prev_lines prev = String.trim (String.concat nl (List.rev prev)) in let rec find_content num title prev = function | [] -> Some (title, String.concat nl (List.rev prev)) | l :: ls -> let ltrim = String.trim l in match atx_heading ltrim with | Some (n, _) when n <= num || preamble -> Some (title, prev_lines prev) | Some _ -> find_content num title (l :: prev) ls | None -> match setex_heading ltrim with | Some n when n <= num || preamble -> let prev = match prev with [] -> [] | _ :: prev -> prev in Some (title, prev_lines prev) | Some _ | None -> find_content num title (l :: prev) ls and find_heading prev = function | [] -> None | l :: ls -> let l = String.trim l in if String.is_empty l then find_heading [] ls else match atx_heading l with | Some (num, title) -> find_content num title [] ls | None -> match setex_heading l with | None -> find_heading (l :: prev) ls | Some num -> let title = prev_lines prev in find_content num title [] ls in find_heading [] (B00_lines.of_string md) (*--------------------------------------------------------------------------- Copyright (c) 2019 The b0 programmers Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ---------------------------------------------------------------------------*)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>