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/unix-details.sml
ViewVC logotype

View of /sml/branches/dbm-type-blame/system/Basis/Implementation/Sockets/unix-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: 1157 byte(s)
merge from trunk
(* unix-details.sml
 *
 *   Check for would-block error condition on Unix sockets.
 *
 * 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.IODesc

 (* The following is essentially lifted from the CML implementation's
  * handling of non-blocking socket I/O.  I am not sure whether
  * conflating EINPROGRESS, EAGAIN, and EWOULDBLOCK is exactly
  * the right thing, though...
  *)
    val blockErrors = (case Posix.Error.syserror "wouldblock"
	   of NONE => [Posix.Error.again, Posix.Error.inprogress]
	    | SOME e => [e, Posix.Error.again, Posix.Error.inprogress]
	  (* end case *))

    fun blockErr (OSImp.SysErr(_, SOME err)) =
	List.exists (fn err' => err = err') blockErrors
      | 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