[project @ 1998-08-11 19:24:33 by sof]
[ghc-hetmet.git] / ghc / lib / misc / cbits / readDescriptor.c
1 #if 0
2 %
3 % (c) The GRASP/AQUA Project, Glasgow University, 1996
4 %
5 \subsection[readDescriptor.lc]{Suck some bytes from a descriptor}
6
7 \begin{code}
8 #endif
9
10 #define NON_POSIX_SOURCE
11 #include "rtsdefs.h"
12 #include "ghcSockets.h"
13
14 StgInt
15 readDescriptor(I_ fd, A_ buf, I_ nbytes)
16 {
17     StgInt sucked;
18     
19     while ((sucked = read((int) fd, (char *) buf, (int) nbytes)) < 0) {
20       if (errno != EINTR) {
21           cvtErrno();
22           switch (ghc_errno) {
23           case GHC_EBADF:
24               ghc_errtype = ERR_INVALIDARGUMENT;
25               ghc_errstr  = "Not a valid read descriptor";
26               break;
27           case GHC_EBADMSG:
28               ghc_errtype = ERR_SYSTEMERROR;
29               ghc_errstr  = "Message waiting to be read is not a data message";
30               break;
31           case GHC_EFAULT:
32               ghc_errtype = ERR_INVALIDARGUMENT;
33               ghc_errstr  = "Data buffer not in readable part of user address space";
34               break;
35           case GHC_EINVAL:
36               ghc_errtype = ERR_INVALIDARGUMENT;
37               ghc_errstr  = "Seek pointer associated with descriptor negative";
38               break;
39           case GHC_EIO:
40               ghc_errtype = ERR_SYSTEMERROR;
41               ghc_errstr  = "I/O error occurred while reading";
42               break;
43           case GHC_EISDIR:
44               ghc_errtype = ERR_INAPPROPRIATETYPE;
45               ghc_errstr  = "Descriptor refers to a directory";
46               break;
47           case GHC_EAGAIN:
48           case GHC_EWOULDBLOCK:
49               ghc_errtype = ERR_OTHERERROR;
50               ghc_errstr  = "No data could be read immediately";
51               break;
52           default:
53               stdErrno();
54               break;
55           }
56           return -1;
57       }
58     }
59     return sucked;
60 }