Home My Page Projects Code Snippets Project Openings SML/NJ
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files

SCM Repository

[smlnj] View of /sml/trunk/src/MLRISC/gc-safety/gc-cells.sml
ViewVC logotype

View of /sml/trunk/src/MLRISC/gc-safety/gc-cells.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 775 - (download) (annotate)
Fri Jan 12 01:17:51 2001 UTC (18 years, 6 months ago) by leunga
File size: 964 byte(s)

    Merging the types labexp and mltree.
    tag leunga-20010111-labexp=mltree
(*
 * 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
  
   (*
    * 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 C.CELL{an, ...} = new()
       in  an := set(gc,!an); r end
   in  genVar
   end

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

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

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

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0