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/branches/dbm-type-blame/system/Basis/Implementation/Sockets/win32-details.sml
ViewVC logotype

View of /sml/branches/dbm-type-blame/system/Basis/Implementation/Sockets/win32-details.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3594 - (download) (annotate)
Thu May 12 16:06:32 2011 UTC (9 years, 5 months ago) by dbm
File size: 778 byte(s)
merge from trunk
(* win32-details.sml
 *
 *   Check for would-block error condition on WinSockets.
 *
 * Copyright (c) 2003 by The Fellowship of SML/NJ
 *
 * Author: Matthias Blume (blume@tti-c.org)
 *)

structure OpsysDetails : sig

    val mkIODesc : int -> PreOS.IO.iodesc
    val wrapNB_o : ('a -> 'b) -> ('a -> 'b option)
    val wrapNB_b : ('a -> unit) -> ('a -> bool)

  end = struct

    val mkIODesc = PreOS.IO.SockDesc

    (* This is a placeholder for a correct implementation that actually
     * checks the error condition... *)
    fun blockErr (OSImp.SysErr _) = true
      | blockErr _ = false

    fun wrapNB_o f x = SOME (f x)
	handle ex => if blockErr ex then NONE else raise ex

    fun wrapNB_b f x = (f x; true)
	handle ex => if blockErr ex then false else raise ex

  end

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