package lsp
LSP protocol implementation in OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
jsonrpc-1.4.0.tbz
sha256=fd138e6c4fcff32c6d15eb66cc9391b7e1183717a6d1a47c688c7f6d320a159f
sha512=567a73b3c10bb59c5a4d4e8291d1aeefdfd34438a95313fba8a485638294ca5fb8034334719631243c304d3328c27afa90dfd564fdb1e7390507a06db3a4ad03
doc/src/lsp.stdune/string_split.ml.html
Source file string_split.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
module List = Stdlib.ListLabels module String = Stdlib.StringLabels open String let split s ~on = let rec loop i j = if j = length s then [ sub s ~pos:i ~len:(j - i) ] else if s.[j] = on then sub s ~pos:i ~len:(j - i) :: loop (j + 1) (j + 1) else loop i (j + 1) in loop 0 0 let split_lines s = let rec loop ~last_is_cr ~acc i j = if j = length s then let acc = if j = i || (j = i + 1 && last_is_cr) then acc else sub s ~pos:i ~len:(j - i) :: acc in List.rev acc else match s.[j] with | '\r' -> loop ~last_is_cr:true ~acc i (j + 1) | '\n' -> let line = let len = if last_is_cr then j - i - 1 else j - i in sub s ~pos:i ~len in loop ~acc:(line :: acc) (j + 1) (j + 1) ~last_is_cr:false | _ -> loop ~acc i (j + 1) ~last_is_cr:false in loop ~acc:[] 0 0 ~last_is_cr:false
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>