summaryrefslogtreecommitdiff
path: root/testsuite/tests/tmc/tupled_function.ml
blob: 605bab98861810847979794a8a030e478fbc853d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
(* TEST
   * bytecode
   * native
*)
type 'a t =
  | N of 'a
  | C of 'a t * 'a t

(* This function is recognized as 'tupled' by the backend; it is
   a regression-test to check that our TMC transformation works as
   expected for tupled (rather than curried) functions.

   Note: it is important to test the 'native' compiler here, as the
   bytecode does not perform the same arity-raising optimizations. *)
let[@tail_mod_cons] rec map (f, l) =
  match l with
  | N v -> N (f v)
  | C (a, b) ->
      C (map (f, a), (map [@tailcall]) (f, b))

let v = C (C (N 1, N 2), N 3)

let v' =
  let arg = (succ, v) in
  map arg

let () =
  assert (v' = C (C (N 2, N 3), N 4))