mirror of
https://github.com/CatalaLang/catala.git
synced 2024-11-08 07:51:43 +03:00
0f9ee2c72e
- Use separate functions for successive passes in module `Driver.Passes` - Use other functions for end results printing in module `Driver.Commands` As a consequence, it is much more flexible to use by plugins or libs and we no longer need the complex polymorphic variant parameter. This patch leverages previous changes to use Cmdliner subcommands and effectively specialises the flags of each Catala subcommand. Other changes include: - an attempt to normalise the generic options and reduce the number of global references. Some are ok, like `debug` ; some would better be further cleaned up, e.g. the ones used by Proof backend were moved to a `Proof.globals` module and need discussion. The printer no longer relies on the global languages and prints money amounts in an agnostic way. - the plugin directory is automatically guessed and loaded even in dev setups. Plugins are shown by the main `catala` command and listed in `catala --help` - exception catching at the toplevel has been refactored a bit as well; return codes are normalised to follow the manpage and avoid codes >= 128 that are generally reserved for shells. Update tests
64 lines
2.1 KiB
OCaml
64 lines
2.1 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. *)
|
|
|
|
(** Source code position *)
|
|
|
|
type t
|
|
(** A position in the source code is a file, as well as begin and end location
|
|
of the form col:line *)
|
|
|
|
(**{2 Constructor and getters}*)
|
|
|
|
val from_lpos : Lexing.position * Lexing.position -> t
|
|
val from_info : string -> int -> int -> int -> int -> t
|
|
val overwrite_law_info : t -> string list -> 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
|
|
|
|
val join : t -> t -> t
|
|
(** Returns the smallest range including both supplied ranges.
|
|
|
|
@raise Invalid_argument
|
|
if they don't belong to the same file. The law position used is the one of
|
|
the earliest position. *)
|
|
|
|
(**{2 Formatters}*)
|
|
|
|
val to_string : t -> string
|
|
(** Formats a position like this:
|
|
|
|
{v in file <file>, from <start_line>:<start_col> to <end_line>:<end_col> v} *)
|
|
|
|
val to_string_short : t -> string
|
|
(** Formats a position like this:
|
|
|
|
{v <file>;<start_line>:<start_col>--<end_line>:<end_col> v}
|
|
|
|
This function is compliant with the
|
|
{{:https://www.gnu.org/prep/standards/standards.html#Errors} GNU coding
|
|
standards}. *)
|
|
|
|
val format_loc_text : Format.formatter -> t -> unit
|
|
(** Open the file corresponding to the position and retrieves the text concerned
|
|
by the position *)
|
|
|
|
val no_pos : t
|
|
(** Placeholder position *)
|