package ppxlib
Standard library for ppx rewriters
Install
Dune Dependency
Authors
Maintainers
Sources
ppxlib-0.27.0.tbz
sha256=764b96121d6ffd6a73820e0ec5235176bfc42b94cf2ff97e32d068a5c4b28c62
sha512=2dcce0be6acdb3e185bfdad2785303a405c617f99949316abe6793f785d7227c10795ca49e79290bd385873da635191b44e8a5c211de114a168846d5d26f505c
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)"
>