File: thread-switch-size.sml

package info (click to toggle)
mlton 20130715-3
  • links: PTS
  • area: main
  • in suites: stretch
  • size: 60,900 kB
  • ctags: 69,386
  • sloc: xml: 34,418; ansic: 17,399; lisp: 2,879; makefile: 1,605; sh: 1,254; pascal: 256; python: 143; asm: 97
file content (22 lines) | stat: -rw-r--r-- 545 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
(* Access the current stack in the heap via a MLton.size object trace. *)
val rt : MLton.Thread.Runnable.t option ref = ref NONE
val rs : int ref = ref 0

fun stats () =
   let
      val () = rs := MLton.size rt
   in
      ()
   end

fun switcheroo () =
   MLton.Thread.switch
   (fn t => let
               val () = rt := SOME (MLton.Thread.prepare (t, ()))
               val () = stats ()
            in
               valOf (!rt)
            end)

val () = switcheroo ()
val _ = print (concat ["!rs > 0 = ", Bool.toString (!rs > 0), "\n"])