summaryrefslogtreecommitdiff
path: root/testsuite/tests/asmcomp/unrolling_flambda2.ml
blob: 70843c69eca50ff1cfca5c0a64ea5e07dc592831 (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
(* TEST
 flambda;
 native;
*)

type t = { fn : t -> t -> int -> unit -> unit }

let rec foo f b n x =
  if n < 0 then ()
  else begin
    foo f b (n - 1) x;
    b.fn f b (n - 1) x
  end
[@@specialise always]

let rec bar f b n x =
  if n < 0 then ()
  else begin
    bar f b (n - 1) x;
    f.fn f b (n - 1) x
  end
[@@specialise always]

let () = foo {fn = foo} {fn = bar} 10 ()