2020-11-23 13:42:29 +03:00
|
|
|
(* 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. *)
|
|
|
|
|
2020-12-14 20:09:38 +03:00
|
|
|
(** Global identifiers factories using a generative functor *)
|
|
|
|
|
|
|
|
(** The information carried in global identifiers *)
|
2020-11-23 13:42:29 +03:00
|
|
|
module type Info = sig
|
|
|
|
type info
|
|
|
|
|
2022-08-17 17:14:14 +03:00
|
|
|
val to_string : info -> string
|
2020-12-05 20:12:53 +03:00
|
|
|
val format_info : Format.formatter -> info -> unit
|
2022-08-25 13:09:51 +03:00
|
|
|
|
|
|
|
val equal : info -> info -> bool
|
|
|
|
(** Equality disregards position *)
|
|
|
|
|
|
|
|
val compare : info -> info -> int
|
|
|
|
(** Comparison disregards position *)
|
2020-11-23 13:42:29 +03:00
|
|
|
end
|
|
|
|
|
2022-05-30 12:20:48 +03:00
|
|
|
module MarkedString : Info with type info = string Marked.pos
|
2020-12-14 20:09:38 +03:00
|
|
|
(** The only kind of information carried in Catala identifiers is the original
|
|
|
|
string of the identifier annotated with the position where it is declared or
|
|
|
|
used. *)
|
2020-11-23 13:42:29 +03:00
|
|
|
|
2020-12-14 20:09:38 +03:00
|
|
|
(** Identifiers have abstract types, but are comparable so they can be used as
|
|
|
|
keys in maps or sets. Their underlying information can be retrieved at any
|
|
|
|
time. *)
|
2020-11-23 13:42:29 +03:00
|
|
|
module type Id = sig
|
|
|
|
type t
|
|
|
|
type info
|
|
|
|
|
|
|
|
val fresh : info -> t
|
|
|
|
val get_info : t -> info
|
|
|
|
val compare : t -> t -> int
|
2022-08-22 19:53:30 +03:00
|
|
|
val equal : t -> t -> bool
|
2020-11-25 13:53:56 +03:00
|
|
|
val format_t : Format.formatter -> t -> unit
|
2020-11-23 13:42:29 +03:00
|
|
|
val hash : t -> int
|
2022-11-21 11:57:41 +03:00
|
|
|
|
|
|
|
module Set: Set.S with type elt = t
|
|
|
|
module Map: Map.S with type key = t
|
2020-11-23 13:42:29 +03:00
|
|
|
end
|
|
|
|
|
2020-12-14 20:09:38 +03:00
|
|
|
(** This is the generative functor that ensures that two modules resulting from
|
|
|
|
two different calls to [Make] will be viewed as different types [t] by the
|
|
|
|
OCaml typechecker. Prevents mixing up different sorts of identifiers. *)
|
2020-11-25 16:35:26 +03:00
|
|
|
module Make (X : Info) () : Id with type info = X.info
|
2022-11-21 12:11:51 +03:00
|
|
|
|
|
|
|
(** Shortcut for creating a kind of uids over marked strings *)
|
|
|
|
module Gen () : Id with type info = MarkedString.info
|