File: js_hisig_test.ml

package info (click to toggle)
react 1.2.2-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 320 kB
  • sloc: ml: 3,571; makefile: 18
file content (55 lines) | stat: -rw-r--r-- 2,099 bytes parent folder | download | duplicates (2)
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
(* Test for ~strong stop, how to gc a higher-order signal *)

open React

let strong = true

(* Artificially increase memory usage *)
let high_e e =
  let id e = E.map (fun v -> v) e in
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@ id @@
  e

let counter_ui =
  let none () = assert false in
  let el = Dom_html.window ##. document ## (getElementById (Js.string "count")) in
  Js.Opt.get el none

let count = ref 0
let set_counter_ui v =
  counter_ui ##. innerHTML := Js.string (string_of_int v)

let tick, send_tick = E.create ()
let ss =
  S.hold ~eq:( == )
    (S.const 0)
    (E.map (fun v -> S.hold v (high_e tick)) tick)

let gc_ss = S.diff (fun _ old -> S.stop ~strong:true old) ss

let s = S.map (fun v -> set_counter_ui v) (S.switch ss)

let rec loop () =
  incr count;
  send_tick !count;
  ignore (Dom_html.window ## (setTimeout (Js.wrap_callback loop) (1.)))


let main _ = loop (); Js._false

let () = Dom_html.window ##. onload := Dom_html.handler main