X-Git-Url: http://www.privoxy.org/gitweb/?a=blobdiff_plain;f=jbsockets.c;h=a90cf50d8da8d15fc5ab462b3bad0eb2e9bde672;hb=fb42e7db1228ade6d4d25a0af403383c54199898;hp=3b36d9db3b249085e3b7db9f8d1e52e121cbea49;hpb=796854d7e8559a2904dd032904ba28c377e6fdee;p=privoxy.git diff --git a/jbsockets.c b/jbsockets.c index 3b36d9db..a90cf50d 100644 --- a/jbsockets.c +++ b/jbsockets.c @@ -1,4 +1,4 @@ -const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.17 2001/09/13 20:11:46 jongfoster Exp $"; +const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.19 2001/10/25 03:40:47 david__schmidt Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/jbsockets.c,v $ @@ -35,6 +35,15 @@ const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.17 2001/09/13 20:11:46 jongfo * * Revisions : * $Log: jbsockets.c,v $ + * Revision 1.19 2001/10/25 03:40:47 david__schmidt + * Change in porting tactics: OS/2's EMX porting layer doesn't allow multiple + * threads to call select() simultaneously. So, it's time to do a real, live, + * native OS/2 port. See defines for __EMX__ (the porting layer) vs. __OS2__ + * (native). Both versions will work, but using __OS2__ offers multi-threading. + * + * Revision 1.18 2001/09/21 23:02:02 david__schmidt + * Cleaning up 2 compiler warnings on OS/2. + * * Revision 1.17 2001/09/13 20:11:46 jongfoster * Fixing 2 compiler warnings under Win32 * @@ -114,7 +123,9 @@ const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.17 2001/09/13 20:11:46 jongfo #else +#ifndef __OS2__ #include +#endif #include #include #include @@ -123,13 +134,16 @@ const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.17 2001/09/13 20:11:46 jongfo #ifndef __BEOS__ #include +#ifndef __OS2__ #include +#endif #else #include #endif -#ifdef __EMX__ +#if defined(__EMX__) || defined (__OS2__) #include /* OS/2/EMX needs a little help with select */ +#include #endif #endif @@ -186,7 +200,11 @@ int connect_to(const char *host, int portnum, struct client_state *csp) if (block_acl(dst, csp)) { +#ifdef __OS2__ + errno = SOCEPERM; +#else errno = EPERM; +#endif return(-1); } #endif /* def FEATURE_ACL */ @@ -220,39 +238,45 @@ int connect_to(const char *host, int portnum, struct client_state *csp) } #endif /* def TCP_NODELAY */ -#if !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) +#if !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) && !defined(__OS2__) if ((flags = fcntl(fd, F_GETFL, 0)) != -1) { flags |= O_NDELAY; fcntl(fd, F_SETFL, flags); } -#endif /* !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) */ +#endif /* !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) && !defined(__OS2__) */ while (connect(fd, (struct sockaddr *) & inaddr, sizeof inaddr) == -1) { #ifdef _WIN32 if (errno == WSAEINPROGRESS) +#elif __OS2__ + if (sock_errno() == EINPROGRESS) #else /* ifndef _WIN32 */ if (errno == EINPROGRESS) -#endif /* ndef _WIN32 */ +#endif /* ndef _WIN32 || __OS2__ */ { break; } +#ifdef __OS2__ + if (sock_errno() != EINTR) +#else if (errno != EINTR) +#endif /* __OS2__ */ { close_socket(fd); return(-1); } } -#if !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) +#if !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) && !defined(__OS2__) if (flags != -1) { flags &= ~O_NDELAY; fcntl(fd, F_SETFL, flags); } -#endif /* !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) */ +#endif /* !defined(_WIN32) && !defined(__BEOS__) && !defined(AMIGA) && !defined(__OS2__) */ /* wait for connection to complete */ FD_ZERO(&wfds); @@ -296,7 +320,7 @@ int write_socket(int fd, const char *buf, int len) log_error(LOG_LEVEL_LOG, "%N", len, buf); -#if defined(_WIN32) || defined(__BEOS__) || defined(AMIGA) +#if defined(_WIN32) || defined(__BEOS__) || defined(AMIGA) || defined(__OS2__) return( send(fd, buf, len, 0)); #else return( write(fd, buf, len)); @@ -337,7 +361,7 @@ int read_socket(int fd, char *buf, int len) return(0); } -#if defined(_WIN32) || defined(__BEOS__) || defined(AMIGA) +#if defined(_WIN32) || defined(__BEOS__) || defined(AMIGA) || defined(__OS2__) return( recv(fd, buf, len, 0)); #else return( read(fd, buf, len)); @@ -363,6 +387,8 @@ void close_socket(int fd) closesocket(fd); #elif defined(AMIGA) CloseSocket(fd); +#elif defined(__OS2__) + soclose(fd); #else close(fd); #endif @@ -389,7 +415,11 @@ int bind_port(const char *hostnam, int portnum) { struct sockaddr_in inaddr; int fd; +#if 0 +#ifndef _WIN32 int one = 1; +#endif /* ndef _WIN32 */ +#endif memset((char *)&inaddr, '\0', sizeof inaddr); @@ -416,6 +446,7 @@ int bind_port(const char *hostnam, int portnum) return(-1); } +#if 0 #ifndef _WIN32 /* * FIXME: This is not needed for Win32 - in fact, it stops @@ -425,6 +456,7 @@ int bind_port(const char *hostnam, int portnum) */ setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, (char *)&one, sizeof(one)); #endif /* ndef _WIN32 */ +#endif if (bind (fd, (struct sockaddr *)&inaddr, sizeof(inaddr)) < 0) {