aboutsummaryrefslogtreecommitdiff
path: root/kernel/vars.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 /kernel/vars.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 'kernel/vars.ml')
-rw-r--r--kernel/vars.ml27
1 files changed, 25 insertions, 2 deletions
diff --git a/kernel/vars.ml b/kernel/vars.ml
index 63d88c659a..f7e28b0cfe 100644
--- a/kernel/vars.ml
+++ b/kernel/vars.ml
@@ -252,12 +252,22 @@ let subst_univs_level_constr subst c =
let u' = Univ.subst_univs_level_universe subst u in
if u' == u then t else
(changed := true; mkSort (Sorts.sort_of_univ u'))
+
| Case (ci,p,CaseInvert {univs;args},c,br) ->
if Univ.Instance.is_empty univs then Constr.map aux t
else
let univs' = f univs in
if univs' == univs then Constr.map aux t
else (changed:=true; Constr.map aux (mkCase (ci,p,CaseInvert {univs=univs';args},c,br)))
+
+ | Array (u,elems,def,ty) ->
+ let u' = f u in
+ let elems' = CArray.Smart.map aux elems in
+ let def' = aux def in
+ let ty' = aux ty in
+ if u == u' && elems == elems' && def == def' && ty == ty' then t
+ else (changed := true; mkArray (u',elems',def',ty'))
+
| _ -> Constr.map aux t
in
let c' = aux c in
@@ -294,10 +304,20 @@ let subst_instance_constr subst c =
let u' = Univ.subst_instance_universe subst u in
if u' == u then t else
(mkSort (Sorts.sort_of_univ u'))
+
| Case (ci,p,CaseInvert {univs;args},c,br) ->
let univs' = f univs in
if univs' == univs then Constr.map aux t
else Constr.map aux (mkCase (ci,p,CaseInvert {univs=univs';args},c,br))
+
+ | Array (u,elems,def,ty) ->
+ let u' = f u in
+ let elems' = CArray.Smart.map aux elems in
+ let def' = aux def in
+ let ty' = aux ty in
+ if u == u' && elems == elems' && def == def' && ty == ty' then t
+ else mkArray (u',elems',def',ty')
+
| _ -> Constr.map aux t
in
aux c
@@ -319,11 +339,14 @@ let universes_of_constr c =
let rec aux s c =
match kind c with
| Const (_c, u) ->
- LSet.fold LSet.add (Instance.levels u) s
+ LSet.fold LSet.add (Instance.levels u) s
| Ind ((_mind,_), u) | Construct (((_mind,_),_), u) ->
- LSet.fold LSet.add (Instance.levels u) s
+ LSet.fold LSet.add (Instance.levels u) s
| Sort u when not (Sorts.is_small u) ->
let u = Sorts.univ_of_sort u in
LSet.fold LSet.add (Universe.levels u) s
+ | Array (u,_,_,_) ->
+ let s = LSet.fold LSet.add (Instance.levels u) s in
+ Constr.fold aux s c
| _ -> Constr.fold aux s c
in aux LSet.empty c