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/runtime/c-libs/posix-io/read.c
ViewVC logotype

View of /sml/trunk/src/runtime/c-libs/posix-io/read.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3 - (download) (as text) (annotate)
Sat Oct 4 23:33:46 1997 UTC (22 years, 10 months ago)
Original Path: sml/branches/SMLNJ/src/runtime/c-libs/posix-io/read.c
File size: 991 byte(s)
This commit was manufactured by cvs2svn to create branch 'SMLNJ'.
/* read.c
 *
 * COPYRIGHT (c) 1995 by AT&T Bell Laboratories.
 */

#include "ml-unixdep.h"
#include <unistd.h>
#include "ml-base.h"
#include "ml-values.h"
#include "ml-objects.h"
#include "ml-c.h"
#include "cfun-proto-list.h"

/* _ml_P_IO_read : (int * int) -> Word8Vector.vector
 *                  fd    nbytes
 *
 * Read the specified number of bytes from the specified file,
 * returning them in a vector.
 */
ml_val_t _ml_P_IO_read (ml_state_t *msp, ml_val_t arg)
{
    int		    fd = REC_SELINT(arg, 0);
    int		    nbytes = REC_SELINT(arg, 1);
    ml_val_t	    vec;
    int		    n;

  /* allocate the vector; note that this might cause a GC */
    vec = ML_AllocString (msp, nbytes);
    n = read (fd, PTR_MLtoC(char, vec), nbytes);
    if (n < 0)
	return RaiseSysError(msp, NIL(char *));

    if (n < nbytes) {
      /* we need to correct the length in the descriptor */
	PTR_MLtoC(ml_val_t, vec)[-1] = MAKE_DESC(n, DTAG_string);
    }

    return vec;

} /* end of _ml_P_IO_read */

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