package ppxlib
Standard infrastructure for ppx rewriters
Install
Dune Dependency
Authors
Maintainers
Sources
ppxlib-0.30.0.tbz
sha256=dd4a63bde9d29b49810e04d7653937c932f177a941ca0e1982b6ad53ac442110
sha512=0a8c4fa894aaf445cb93213eaa32afb2772235da44aa28c917aba237731a44d5c2687bd960fca49bff62bbe0f9b3fdd9c15730313b429214ae281069f862ffdc
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)"
>