File: gc-map.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 (23 lines) | stat: -rw-r--r-- 713 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
functor GCMap(GC : GC_TYPE) : GC_MAP =
struct
   structure C = CellsBasis
   structure GC = GC
   exception GCMap

   type gcmap = GC.gctype C.HashTable.hash_table

   val GCMAP = Annotations.new(SOME(fn _ => "gcmap")) 
                 : gcmap Annotations.property

   fun toString gcmap =
   let val lookup = C.HashTable.lookup gcmap
       fun f r = "{" ^ GC.toString(lookup r)^ "}" handle _ => "{?}"
   in  f end

   fun pr(r,gc) = "r" ^ Int.toString(C.cellId r) ^ ":" ^ GC.toString gc
   fun prSet S = "{"^foldr (fn (x,"") => pr x | (x,y) => pr x^","^y) "" S^"}"

   val GCLIVEIN  = Annotations.new(SOME(fn S => "livein: "^prSet S))
   val GCLIVEOUT = Annotations.new(SOME(fn S => "liveout: "^prSet S))

end