File: gc-cells.sml

package info (click to toggle)
mlton 20210117%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 58,464 kB
  • sloc: ansic: 27,682; sh: 4,455; asm: 3,569; lisp: 2,879; makefile: 2,347; perl: 1,169; python: 191; pascal: 68; javascript: 7
file content (36 lines) | stat: -rw-r--r-- 998 bytes parent folder | download | duplicates (5)
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
(*
 * This makes a new cell function that automatically propagate gc type info.
 *)
functor GCCells(structure C : CELLS
                structure GC : GC_TYPE
               ) : GC_CELLS =
struct

   structure C  = C
   structure GC = GC
   structure CB = CellsBasis
  
   (*
    * Generate a new virtual register and update the gc information 
    * at the same time.
    *)
   fun newCell k = 
   let val new = C.newCell k
       val set = #set GC.GC_TYPE
       fun genVar gc =
       let val r as CB.CELL{an, ...} = new()
       in  an := set(gc,!an); r end
   in  genVar
   end

   fun getGCType(CB.CELL{an, ...}) = #lookup GC.GC_TYPE (!an)
   fun setGCType(CB.CELL{an, ...}, gc) = an := #set GC.GC_TYPE (gc, !an)

   fun printType(CB.CELL{an, ...}) = 
       case #get GC.GC_TYPE (!an) of
         SOME ty => ":"^GC.toString ty
       | NONE    => ":?"

   val GCLIVEOUT = Annotations.new(SOME(fn _ => "GCLIVEOUT")) 
                     : (CB.cell * GC.gctype) list Annotations.property
end