package merlin-lib
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  Merlin's libraries
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      merlin-4.16-414.tbz
    
    
        
    
  
  
  
    
  
  
    
  
        sha256=c5e91975f3df56849e1b306f356c31709a2b139d7d57634b8d21e473266fcf2d
    
    
  sha512=1d2db379b496dc0b95874f312011cce1a48f6808e098f1aff768de0eef0caff222adc17ab61b85c7aac8d889bf9d829fb5d0211267c7a85572ce201c1cbcb990
    
    
  doc/src/merlin-lib.dot_protocol/merlin_dot_protocol.ml.html
Source file merlin_dot_protocol.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 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223(* {{{ COPYING *( This file is part of Merlin, an helper for ocaml editors Copyright (C) 2019 Frédéric Bour <frederic.bour(_)lakaban.net> Thomas Refis <refis.thomas(_)gmail.com> Simon Castellan <simon.castellan(_)iuwt.fr> Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. The Software is provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the Software. )* }}} *) open Merlin_utils.Std open Merlin_utils.Std.Result module Directive = struct type include_path = [ `B of string | `S of string | `CMI of string | `CMT of string ] type no_processing_required = [ `EXT of string list | `FLG of string list | `STDLIB of string | `SUFFIX of string | `READER of string list | `EXCLUDE_QUERY_DIR | `USE_PPX_CACHE | `UNKNOWN_TAG of string ] module Processed = struct type acceptable_in_input = [ include_path | no_processing_required ] type t = [ acceptable_in_input | `ERROR_MSG of string ] end module Raw = struct type t = [ Processed.acceptable_in_input | `PKG of string list | `FINDLIB of string | `FINDLIB_PATH of string | `FINDLIB_TOOLCHAIN of string ] end end type directive = Directive.Processed.t module Sexp = struct type t = Csexp.t = Atom of string | List of t list let atoms_of_strings = List.map ~f:(fun s -> Atom s) let strings_of_atoms = List.filter_map ~f:(function Atom s -> Some s | _ -> None) let rec to_string = function | Atom s -> s | List l -> String.concat ~sep:" " ( List.concat [["("]; List.map ~f:to_string l;[")"]]) let to_directive sexp = match sexp with | List [ Atom tag; Atom value ] -> begin match tag with | "S" -> `S value | "B" -> `B value | "CMI" -> `CMI value | "CMT" -> `CMT value | "STDLIB" -> `STDLIB value | "SUFFIX" -> `SUFFIX value | "ERROR" -> `ERROR_MSG value | "FLG" -> (* This means merlin asked dune 2.6 for configuration. But the protocole evolved, only dune 2.8 should be used *) `ERROR_MSG "No .merlin file found. Try building the project." | tag -> `UNKNOWN_TAG tag end | List [ Atom tag; List l ] -> let value = strings_of_atoms l in begin match tag with | "EXT" -> `EXT value | "FLG" -> `FLG value | "READER" -> `READER value | tag -> `UNKNOWN_TAG tag end | List [ Atom "EXCLUDE_QUERY_DIR" ] -> `EXCLUDE_QUERY_DIR | List [ Atom "USE_PPX_CACHE" ] -> `USE_PPX_CACHE | _ -> `ERROR_MSG "Unexpected output from external config reader" let from_directives (directives : Directive.Processed.t list) = let f t = let tag, body = let single s = [ Atom s ] in match t with | `B s -> ("B", single s) | `S s -> ("S", single s) | `CMI s -> ("CMI", single s) | `CMT s -> ("CMT", single s) | `EXT ss -> ("EXT", [ List (atoms_of_strings ss) ]) | `FLG ss -> ("FLG", [ List (atoms_of_strings ss) ]) | `STDLIB s -> ("STDLIB", single s) | `SUFFIX s -> ("SUFFIX", single s) | `READER ss -> ("READER", [ List (atoms_of_strings ss) ]) | `EXCLUDE_QUERY_DIR -> ("EXCLUDE_QUERY_DIR", []) | `USE_PPX_CACHE -> ("USE_PPX_CACHE", []) | `UNKNOWN_TAG tag -> ("ERROR", single @@ Printf.sprintf "Unknown tag in .merlin: %s" tag) | `ERROR_MSG s -> ("ERROR", single s) in List (Atom tag :: body) in List (List.map ~f directives) end type read_error = | Unexpected_output of string | Csexp_parse_error of string type command = File of string | Halt | Unknown module type S = sig type 'a io type in_chan type out_chan (** [read] reads one csexp from the channel and returns the list of directives it represents *) val read : in_chan -> (directive list, read_error) Merlin_utils.Std.Result.t io val write : out_chan -> directive list -> unit io module Commands : sig val read_input : in_chan -> command io val send_file : out_chan -> string -> unit io val halt : out_chan -> unit io end end module Make (IO : sig type 'a t module O : sig val ( let+ ) : 'a t -> ('a -> 'b) -> 'b t end end) (Chan : sig type in_chan type out_chan val read : in_chan -> (Csexp.t, string) result IO.t val write : out_chan -> Csexp.t -> unit IO.t end) = struct type 'a io = 'a IO.t type in_chan = Chan.in_chan type out_chan = Chan.out_chan module Commands = struct let read_input chan = let open Sexp in let open IO.O in let+ input = Chan.read chan in match input with | Ok (List [Atom "File"; Atom path]) -> File path | Ok (Atom "Halt") -> Halt | Ok _ -> Unknown | Error _ -> Halt let send_file chan path = Chan.write chan Sexp.(List [Atom "File"; Atom path]) let halt chan = Chan.write chan (Sexp.Atom "Halt") end let read chan = let open IO.O in let+ res = Chan.read chan in match res with | Ok (Sexp.List directives) -> Ok (List.map directives ~f:Sexp.to_directive) | Ok sexp -> let msg = Printf.sprintf "A list of directives was expected, instead got: \"%s\"" (Sexp.to_string sexp) in Error (Unexpected_output msg) | Error msg -> Error (Csexp_parse_error msg) let write out_chan (directives : directive list) = directives |> Sexp.from_directives |> Chan.write out_chan end module Blocking = Make (struct type 'a t = 'a module O = struct let ( let+ ) x f = f x end end) (struct type in_chan = in_channel type out_chan = out_channel let read = Csexp.input let write = Csexp.to_channel end)
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >