aboutsummaryrefslogtreecommitdiff
path: root/pretyping/keys.ml
diff options
context:
space:
mode:
authorMaxime Dénès2020-02-03 18:19:42 +0100
committerMaxime Dénès2020-07-06 11:22:43 +0200
commit0ea2d0ff4ed84e1cc544c958b8f6e98f6ba2e9b6 (patch)
treefbad060c3c2e29e81751dea414c898b5cb0fa22d /pretyping/keys.ml
parentcf388fdb679adb88a7e8b3122f65377552d2fb94 (diff)
Primitive persistent arrays
Persistent arrays expose a functional interface but are implemented using an imperative data structure. The OCaml implementation is based on Jean-Christophe Filliâtre's. Co-authored-by: Benjamin Grégoire <Benjamin.Gregoire@inria.fr> Co-authored-by: Gaëtan Gilbert <gaetan.gilbert@skyskimmer.net>
Diffstat (limited to 'pretyping/keys.ml')
-rw-r--r--pretyping/keys.ml4
1 files changed, 4 insertions, 0 deletions
diff --git a/pretyping/keys.ml b/pretyping/keys.ml
index 1e4f2f2340..7a7099c195 100644
--- a/pretyping/keys.ml
+++ b/pretyping/keys.ml
@@ -27,6 +27,7 @@ type key =
| KRel
| KInt
| KFloat
+ | KArray
module KeyOrdered = struct
type t = key
@@ -44,6 +45,7 @@ module KeyOrdered = struct
| KRel -> 7
| KInt -> 8
| KFloat -> 9
+ | KArray -> 10
let compare gr1 gr2 =
match gr1, gr2 with
@@ -138,6 +140,7 @@ let constr_key kind c =
| LetIn _ -> KLet
| Int _ -> KInt
| Float _ -> KFloat
+ | Array _ -> KArray
in Some (aux c)
with Not_found -> None
@@ -155,6 +158,7 @@ let pr_key pr_global = function
| KRel -> str"Rel"
| KInt -> str"Int"
| KFloat -> str"Float"
+ | KArray -> str"Array"
let pr_keyset pr_global v =
prlist_with_sep spc (pr_key pr_global) (Keyset.elements v)