X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=jbsockets.c;h=a90cf50d8da8d15fc5ab462b3bad0eb2e9bde672;hp=b64c11014f48832859c196543cca634e73a91f70;hb=9fd2c0f49e451b0e327235fe3e0bacc37e1c1eee;hpb=347a4f160388386d7cec3f4a1de940fabd22a924 diff --git a/jbsockets.c b/jbsockets.c index b64c1101..a90cf50d 100644 --- a/jbsockets.c +++ b/jbsockets.c @@ -1,4 +1,4 @@ -const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.16 2001/07/30 22:08:36 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,18 @@ const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.16 2001/07/30 22:08:36 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 + * * Revision 1.16 2001/07/30 22:08:36 jongfoster * Tidying up #defines: * - All feature #defines are now of the form FEATURE_xxx @@ -111,7 +123,9 @@ const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.16 2001/07/30 22:08:36 jongfo #else +#ifndef __OS2__ #include +#endif #include #include #include @@ -120,11 +134,18 @@ const char jbsockets_rcs[] = "$Id: jbsockets.c,v 1.16 2001/07/30 22:08:36 jongfo #ifndef __BEOS__ #include +#ifndef __OS2__ #include +#endif #else #include #endif +#if defined(__EMX__) || defined (__OS2__) +#include /* OS/2/EMX needs a little help with select */ +#include +#endif + #endif #include "project.h" @@ -179,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 */ @@ -213,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); @@ -289,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)); @@ -330,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)); @@ -356,6 +387,8 @@ void close_socket(int fd) closesocket(fd); #elif defined(AMIGA) CloseSocket(fd); +#elif defined(__OS2__) + soclose(fd); #else close(fd); #endif @@ -382,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); @@ -409,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 @@ -418,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) {