Catala_utils.Pos
Source code position
A position in the source code is a file, as well as begin and end location of the form col:line, and optionally, attributes
val from_lpos : (Stdlib.Lexing.position * Stdlib.Lexing.position) -> t
val from_info : string -> int -> int -> int -> int -> t
val get_law_info : t -> string list
val get_start_line : t -> int
val get_start_column : t -> int
val get_end_line : t -> int
val get_end_column : t -> int
val get_file : t -> string
Raises Invalid_argument
if the attribute appears multiple times
Removes the found attribute if it is present
Returns the smallest range including both supplied ranges. Attributes are merged ; law info is taken from the earliest position.
val to_string : t -> string
Formats a position like this:
in file <file>, from <start_line>:<start_col> to <end_line>:<end_col>
val to_string_short : t -> string
Formats a position like this:
<file>;<start_line>:<start_col>--<end_line>:<end_col>
This function is compliant with the GNU coding standards.
val to_string_shorter : t -> string
Like to_string_short
, but skips directory names and extension
val format_loc_text : Stdlib.Format.formatter -> t -> unit
Open the file corresponding to the position and retrieves the text concerned by the position
val format_loc_text_parts :
t ->
(Stdlib.Format.formatter ->
unit)
* (Stdlib.Format.formatter ->
unit)
* (Stdlib.Format.formatter -> unit) option
Like format_loc_text
, but returns the printing functions in 3 separate parts: the file name header, the line context, and the law headers
val void : t
Placeholder position