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/cml/src/Win32/win32-os-io.sml
ViewVC logotype

View of /sml/trunk/src/cml/src/Win32/win32-os-io.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 137 - (download) (annotate)
Mon Sep 7 21:09:17 1998 UTC (22 years ago) by monnier
File size: 2508 byte(s)
Initial revision
(* win32-os-io.sml
 *
 * COPYRIGHT (c) 1998 Bell Labs, Lucent Technologies.
 * COPYRIGHT (c) 1996 Bell Laboratories.
 *
 * Replacement of OS.IO structure for Win32.
 * It implements a simple type of polling for file objects.
 *)

structure Win32OSIO =
  struct
    structure W32G = Win32.General
    structure W32FS = Win32.FileSys
    type word32 = Word32.word

    exception SysErr = OS.SysErr

    datatype iodesc = IODesc of W32G.hndl ref  (* OS.IO.iodesc *)

  (* hash: can't assume 32 bits *)
    fun hash (IODesc (ref (0wxffffffff : W32G.hndl))) = 0wx7fffffff : word 
      | hash (IODesc (ref h)) = (Word.fromInt o W32G.Word.toInt) h

    fun compare (IODesc (ref wa),IODesc (ref wb)) = W32G.Word.compare(wa,wb)

    datatype iodesc_kind = K of string

    structure Kind =
      struct
	val file = K "FILE"
	val dir = K "DIR"
	val symlink = K "LINK"
	val tty = K "TTY"
	val pipe = K "PIPE"
	val socket = K "SOCK"
	val device = K "DEV"
      end

    fun kind (IODesc (ref h)) = (case W32FS.getFileAttributes' h
	   of NONE => K "UNKNOWN"
	    | SOME w => if W32FS.isRegularFile h
		then Kind.file
		else Kind.dir
	  (* end case *))

  (* no win32 polling devices for now *)
    val noPolling = "polling not implemented for win32 for this device/type"

    datatype poll_desc = PollDesc of iodesc
    datatype poll_info = PollInfo of poll_desc
	
    fun pollDesc id = SOME (PollDesc id) (* NONE *)
    fun pollToIODesc (PollDesc pd) = pd (* raise Fail("pollToIODesc: "^noPolling) *)
    exception Poll

    fun pollIn pd = pd (* raise Fail("pollIn: "^noPolling) *)
    fun pollOut pd = pd (* raise Fail("pollOut: "^noPolling) *)
    fun pollPri pd = pd (* raise Fail("pollPri: "^noPolling) *)

    local 
      val poll' : (word32 list * (Int32.int * int) option -> word32 list) = 
	    Unsafe.CInterface.c_function "WIN32-IO" "poll"
      fun toPollInfo (w) = PollInfo (PollDesc (IODesc (ref w)))
      fun fromPollDesc (PollDesc (IODesc (ref w))) = w
    in
    fun poll (pdl,t) = let
	  val timeout = (case t
		 of (SOME t) =>
		      SOME(Time.toSeconds t, Int.fromLarge (Time.toMicroseconds t))
		  | NONE => NONE)
	  val info = poll' (List.map fromPollDesc pdl,timeout)
	  in
	    List.map toPollInfo info
	  end
    end (* end local *)
		    
    fun isIn pd = raise Fail("isIn: "^noPolling)
    fun isOut pd = raise Fail("isOut: "^noPolling)
    fun isPri pd = raise Fail("isPri: "^noPolling)

    fun infoToPollDesc (PollInfo pd) = pd (* raise Fail("infoToPollDesc: "^noPolling) *)

    end

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