package lsp
LSP protocol implementation in OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
jsonrpc-1.6.1.tbz
sha256=bccc0d7194714a4c40c362766ad9095d3c58505a1d4f1dc4becd9b3d1bda8209
sha512=199bee8c74aec6822bc83bf9a7c3757206bdaa55a19cd1f5cf480127618a078baa1e917f6a90a6135a5277e4eb87977e685c10e6503f546997e6b985949e190f
doc/src/lsp.stdune/digest.ml.html
Source file digest.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 84 85 86 87 88 89 90 91 92 93
# 1 "submodules/dune/otherlibs/stdune-unstable/digest.ml" type t = string module D = Stdlib.Digest module Set = String.Set module Map = String.Map module type Digest_impl = sig val file : string -> t val string : string -> t end module Direct_impl : Digest_impl = struct let file = D.file let string = D.string end module Mutable_impl = struct let file_ref = ref D.file let string_ref = ref D.string let file f = !file_ref f let string s = !string_ref s end let override_impl ~file ~string = Mutable_impl.file_ref := file; Mutable_impl.string_ref := string module Impl : Digest_impl = Mutable_impl let hash = Hashtbl.hash let equal = String.equal let file p = Impl.file (Path.to_string p) let compare x y = Ordering.of_int (D.compare x y) let to_string = D.to_hex let to_dyn s = let open Dyn.Encoder in constr "digest" [ string (to_string s) ] let from_hex s = match D.from_hex s with | s -> Some s | exception Invalid_argument _ -> None let string = Impl.string let to_string_raw s = s (* We use [No_sharing] to avoid generating different digests for inputs that differ only in how they share internal values. Without [No_sharing], if a command line contains duplicate flags, such as multiple occurrences of the flag [-I], then [Marshal.to_string] will produce different digests depending on whether the corresponding strings ["-I"] point to the same memory location or to different memory locations. *) let generic a = string (Marshal.to_string a [ No_sharing ]) let file_with_executable_bit ~executable path = (* We follow the digest scheme used by Jenga. *) let string_and_bool ~digest_hex ~bool = Impl.string (digest_hex ^ if bool then "\001" else "\000") in let content_digest = file path in string_and_bool ~digest_hex:content_digest ~bool:executable let file_with_stats path (stats : Unix.stats) = match stats.st_kind with | S_DIR -> generic (stats.st_size, stats.st_perm, stats.st_mtime, stats.st_ctime) | S_BLK | S_CHR | S_LNK | S_FIFO | S_SOCK -> failwith "Unexpected file kind" | S_REG -> let executable = stats.st_perm land 0o100 <> 0 in file_with_executable_bit ~executable path
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>