[project @ 1998-12-02 13:17:09 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 "Rts.h"
12 #include "ghcSockets.h"
13 #include "stgio.h"
14
15 StgInt
16 listenSocket(I_ sockfd, I_ backlog)
17 {
18     int rc;
19     
20     while ((rc = listen((int) sockfd, (int) backlog)) < 0) {
21       if (errno != EINTR) {
22           cvtErrno();
23           switch (ghc_errno) {
24           default:
25               stdErrno();
26               break;
27           case GHC_EBADF:
28               ghc_errtype = ERR_INVALIDARGUMENT;
29               ghc_errstr  = "Not a valid descriptor";
30               break;
31           case GHC_ENOTSOCK:
32               ghc_errtype = ERR_INVALIDARGUMENT;
33               ghc_errstr  = "Descriptor not a socket";
34               break;
35           case GHC_EOPNOTSUPP:
36               ghc_errtype = ERR_INVALIDARGUMENT;
37               ghc_errstr  = "Socket not of type that supports listen";
38               break;
39           }
40           return -1;
41       }
42     }
43     return 0;
44 }