package ppxlib
Standard library for ppx rewriters
Install
Dune Dependency
Authors
Maintainers
Sources
ppxlib-0.26.0.tbz
sha256=63117b67ea5863935455fe921f88fe333c0530f0483f730313303a93af817efd
sha512=9cfc9587657d17cdee5483e2a03292f872c42886e512bcc7442652e6418ce74c0135c731d8a68288c7fecae7f1b2defd93fe5acf8edb41e25144a8cec2806227
doc/src/ppxlib.ast/location_error.ml.html
Source file location_error.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
open Import type t = Astlib.Location.Error.t let to_extension (error : Astlib.Location.Error.t) = let open Astlib.Location.Error in let open Ast_helper in if not (is_well_formed error) then raise (Invalid_argument "to_extension: expected kind Report_error"); let sub_msgs = sub_msgs error in let main_msg = main_msg error in let err_extension_name loc = { Location.loc; txt = "ocaml.error" } in let mk_string_constant x = Str.eval (Exp.constant (Const.string x)) in let extension_of_sub_msg (sub_msg : string Location.loc) = Str.extension (err_extension_name sub_msg.loc, PStr [ mk_string_constant sub_msg.txt ]) in ( err_extension_name main_msg.loc, Parsetree.PStr (mk_string_constant main_msg.txt :: List.map extension_of_sub_msg sub_msgs) ) let register_error_of_exn = Astlib.Location.register_error_of_exn let message error = let { Astlib.Location.txt; _ } = Astlib.Location.Error.main_msg error in txt let set_message = Astlib.Location.Error.set_main_msg let make ~loc txt ~sub = let sub = List.map (fun (loc, txt) -> { Astlib.Location.loc; txt }) sub in Astlib.Location.Error.make ~sub { loc; txt } let update_loc = Astlib.Location.Error.set_main_loc let get_location error = let { Astlib.Location.loc; _ } = Astlib.Location.Error.main_msg error in loc let of_exn = Astlib.Location.Error.of_exn let raise error = raise (Astlib.Location.Error error)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>