mirror of
https://github.com/CatalaLang/catala.git
synced 2024-11-09 01:35:56 +03:00
62 lines
2.4 KiB
OCaml
62 lines
2.4 KiB
OCaml
(* This file is part of the Catala compiler, a specification language for tax
|
|
and social benefits computation rules. Copyright (C) 2020 Inria, contributor:
|
|
Denis Merigoux <denis.merigoux@inria.fr>
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
use this file except in compliance with the License. You may obtain a copy of
|
|
the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
License for the specific language governing permissions and limitations under
|
|
the License. *)
|
|
|
|
(** Error formatting and helper functions *)
|
|
|
|
(** {1 Error exception and printing} *)
|
|
|
|
exception StructuredError of (string * (string option * Pos.t) list)
|
|
(** The payload of the expression is a main error message, with a list of
|
|
secondary positions related to the error, each carrying an optional
|
|
secondary message to describe what is pointed by the position. *)
|
|
|
|
let print_structured_error (msg : string) (pos : (string option * Pos.t) list) :
|
|
string =
|
|
Printf.sprintf "%s%s%s" msg
|
|
(if List.length pos = 0 then "" else "\n\n")
|
|
(String.concat "\n\n"
|
|
(List.map
|
|
(fun (msg, pos) ->
|
|
Printf.sprintf "%s%s"
|
|
(match msg with None -> "" | Some msg -> msg ^ "\n")
|
|
(Pos.retrieve_loc_text pos))
|
|
pos))
|
|
|
|
(** {1 Error exception and printing} *)
|
|
|
|
let raise_spanned_error ?(span_msg : string option) (span : Pos.t) format =
|
|
Format.kasprintf
|
|
(fun msg -> raise (StructuredError (msg, [span_msg, span])))
|
|
format
|
|
|
|
let raise_multispanned_error (spans : (string option * Pos.t) list) format =
|
|
Format.kasprintf (fun msg -> raise (StructuredError (msg, spans))) format
|
|
|
|
let raise_error format =
|
|
Format.kasprintf (fun msg -> raise (StructuredError (msg, []))) format
|
|
|
|
(** {1 Warning printing}*)
|
|
|
|
let format_multispanned_warning (pos : (string option * Pos.t) list) format =
|
|
Format.kasprintf
|
|
(fun msg -> Cli.warning_print "%s" (print_structured_error msg pos))
|
|
format
|
|
|
|
let format_spanned_warning ?(span_msg : string option) (span : Pos.t) format =
|
|
format_multispanned_warning [span_msg, span] format
|
|
|
|
let format_warning format = format_multispanned_warning [] format
|