aboutsummaryrefslogtreecommitdiff
path: root/engine/univSubst.ml
diff options
context:
space:
mode:
Diffstat (limited to 'engine/univSubst.ml')
-rw-r--r--engine/univSubst.ml7
1 files changed, 7 insertions, 0 deletions
diff --git a/engine/univSubst.ml b/engine/univSubst.ml
index f06aeaf54e..335c2e5e68 100644
--- a/engine/univSubst.ml
+++ b/engine/univSubst.ml
@@ -151,6 +151,13 @@ let nf_evars_and_universes_opt_subst f subst =
let univs' = Instance.subst_fn lsubst univs in
if univs' == univs then Constr.map aux c
else Constr.map aux (mkCase (ci,p,CaseInvert {univs=univs';args},t,br))
+ | Array (u,elems,def,ty) ->
+ let u' = Univ.Instance.subst_fn lsubst 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 c
+ else mkArray (u',elems',def',ty')
| _ -> Constr.map aux c
in aux