package ppxlib
Standard library for ppx rewriters
Install
Dune Dependency
Authors
Maintainers
Sources
ppxlib-0.29.0.tbz
sha256=8e8b104ddbf0ef39787533e98d49460b36151eaa5cdfabde9ffc94c0139658ba
sha512=d2772572b2a1770f7bad237ab4824865ace635e344eceeafc81198546a17f812ba453b3727e4d261b539767132c1904f0a65dd3a0aa95444a2fd7028d6cf127b
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)"
>