Catala_utils.MessageInterface for emitting compiler messages.
All messages are expected to use the Format module. Flush, "@?", "@.", "%!" etc. are not supposed to be used outside of this module.
WARNING: this module performs side-effects at load time, adding support for ocolor tags (e.g. "@{<blue>text@}") to the standard string formatter used by e.g. Format.sprintf. (In this case, the tags are ignored, for color output you should use the functions of this module that toggle support depending on cli flags and terminal support).
module Content : sig ... endThis functions emits the message according to the emission type defined by Cli.message_format_flag.
exception CompilerError of Content.texception CompilerErrors of (Content.t * Stdlib.Printexc.raw_backtrace) listtype lsp_error = {kind : lsp_error_kind;message : Content.message;pos : Pos.t option;suggestion : string list option;}val register_lsp_error_notifier : (lsp_error -> unit) -> unitval register_lsp_error_absorber : (lsp_error -> bool) -> unitThe raised error is absorbed if the hook returns false
Converts f to a string, discarding formatting and skipping newlines and indents
Prints the given character the given number of times (assuming it is of width 1)
val formatter_of_out_channel :
?nocolor:bool ->
Stdlib.out_channel ->
unit ->
Stdlib.Format.formatterCreates a new formatter from the given out channel, with correct handling of the ocolor tags. Actual use of escape codes in the output depends on Cli.style_flag -- and wether the channel is a tty if that is set to auto.
type ('a, 'b) emitter =
?header:Content.message ->
?internal:bool ->
?main_pos:Pos.t ->
?pos:Pos.t ->
?pos_msg:Content.message ->
?extra_pos:(string * Pos.t) list ->
?fmt_pos:(Content.message * Pos.t) list ->
?outcome:Content.message list ->
?suggestion:string list ->
('a, Stdlib.Format.formatter, unit, 'b) Stdlib.format4 ->
'aval log : ('a, unit) emitterval debug : ('a, unit) emitterval result : ('a, unit) emitterval warning : ('a, unit) emitterval error : ?kind:lsp_error_kind -> ('a, 'exn) emitterval results : ?title:string -> Content.message list -> unitMultiple errors
report_delayed_errors_if_any checks whether some delayed errors are registered and raises the pending errors if any are present. Current registered delayed errors are also deleted.
val delayed_error : ?kind:lsp_error_kind -> 'b -> ('a, 'b) emitterval wrap_to_delayed_error : ?kind:lsp_error_kind -> 'a -> (unit -> 'a) -> 'awrap_to_delayed_error ?kind dft_val f protects with a try-with the call of f and converts fatal errors (i.e., error) into delayed errors. This is useful when no good default value can be provided in a callee without heavy refactoring . The position is guessed by scanning locations from the message's content.
val combine_with_pending_errors :
Content.t ->
Stdlib.Printexc.raw_backtrace ->
(Content.t * Stdlib.Printexc.raw_backtrace) listcombine_with_pending_errors error bt adds the given error and its backtrace bt to the current pending errors (if any) and returns the ordered list of errors to eventually emit with Content.emit_n.