File: thread-switch-size.sml

package info (click to toggle)
mlton 20100608-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 34,980 kB
  • ctags: 69,089
  • sloc: ansic: 18,421; lisp: 2,879; makefile: 1,570; sh: 1,325; pascal: 256; 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"])