[project @ 1998-02-02 17:27:26 by simonm]
[ghc-hetmet.git] / ghc / lib / misc / cbits / listenSocket.c
1 #if 0
2 %
3 % (c) The GRASP/AQUA Project, Glasgow University, 1996
4 %
5 \subsection[listenSocket.lc]{Indicate willingness to receive connections}
6
7 \begin{code}
8 #endif
9
10 #define NON_POSIX_SOURCE
11 #include "rtsdefs.h"
12 #include "ghcSockets.h"
13
14 StgInt
15 listenSocket(I_ sockfd, I_ backlog)
16 {
17     int rc;
18     
19     while ((rc = listen((int) sockfd, (int) backlog)) < 0) {
20       if (errno != EINTR) {
21           cvtErrno();
22           switch (ghc_errno) {
23           default:
24               stdErrno();
25               break;
26           case GHC_EBADF:
27               ghc_errtype = ERR_INVALIDARGUMENT;
28               ghc_errstr  = "Not a valid descriptor";
29               break;
30           case GHC_ENOTSOCK:
31               ghc_errtype = ERR_INVALIDARGUMENT;
32               ghc_errstr  = "Descriptor not a socket";
33               break;
34           case GHC_EOPNOTSUPP:
35               ghc_errtype = ERR_INVALIDARGUMENT;
36               ghc_errstr  = "Socket not of type that supports listen";
37               break;
38           }
39           return -1;
40       }
41     }
42     return 0;
43 }