Skip to content

Commit

Permalink
array elements are global (ocaml-flambda#67)
Browse files Browse the repository at this point in the history
  • Loading branch information
riaqn authored Nov 23, 2022
1 parent 8788ff6 commit 6c50831
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 3 deletions.
36 changes: 36 additions & 0 deletions testsuite/tests/typing-local/local.ml
Original file line number Diff line number Diff line change
Expand Up @@ -2573,3 +2573,39 @@ Line 3, characters 23-24:
^
Error: This value escapes its region
|}]


(* test of arrays *)
(* as elements of arrays are mutable *)
(* it is only safe for them to be at global mode *)
(* cf: similarly reference cell can contain only global values *)

(* on construction of array, we ensure elements are global *)

let f (local_ x : string) =
[|x; "foo"|]
[%%expect{|
Line 2, characters 4-5:
2 | [|x; "foo"|]
^
Error: This value escapes its region
|}]

let f (x : string) =
[|x; "foo"|]
[%%expect{|
val f : string -> string array = <fun>
|}]


(* on pattern matching of array,
elements are strengthened to global
even if array itself is local *)
let f (local_ a : string array) =
match a with
| [| x; _ |] -> ref x
| _ -> ref "foo"

[%%expect{|
val f : local_ string array -> string ref = <fun>
|}]
5 changes: 4 additions & 1 deletion testsuite/tests/typing-local/nosyntax.ml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,10 @@ let local_ref (f : lfn -> unit) =
f (fun s -> let _ = [|s;s;s|] in 1)

[%%expect{|
val local_ref : (lfn -> unit) -> unit = <fun>
Line 2, characters 24-25:
2 | f (fun s -> let _ = [|s;s;s|] in 1)
^
Error: This value escapes its region
|}]

type foo = {
Expand Down
5 changes: 3 additions & 2 deletions typing/typecore.ml
Original file line number Diff line number Diff line change
Expand Up @@ -2250,7 +2250,8 @@ and type_pat_aux
end
| Ppat_array spl ->
let ty_elt = solve_Ppat_array ~refine loc env expected_ty in
map_fold_cont (fun p -> type_pat Value p ty_elt) spl (fun pl ->
map_fold_cont (fun p -> type_pat ~alloc_mode:(simple_pat_mode Value_mode.global)
Value p ty_elt) spl (fun pl ->
rvp k {
pat_desc = Tpat_array pl;
pat_loc = loc; pat_extra=[];
Expand Down Expand Up @@ -4152,7 +4153,7 @@ and type_expect_
let to_unify = Predef.type_array ty in
with_explanation (fun () ->
unify_exp_types loc env to_unify (generic_instance ty_expected));
let argument_mode = mode_subcomponent expected_mode in
let argument_mode = mode_global in
let argl =
List.map
(fun sarg -> type_expect env argument_mode sarg (mk_expected ty))
Expand Down

0 comments on commit 6c50831

Please sign in to comment.