Re: close() vs. closesocket() - Mailing list pgsql-hackers

From mlw
Subject Re: close() vs. closesocket()
Date
Msg-id 3EA92A29.3070708@mohawksoft.com
Whole thread Raw
In response to close() vs. closesocket()  (Bruce Momjian <pgman@candle.pha.pa.us>)
Responses Re: close() vs. closesocket()  (Tom Lane <tgl@sss.pgh.pa.us>)
Re: close() vs. closesocket()  (Bruce Momjian <pgman@candle.pha.pa.us>)
List pgsql-hackers
In porting to Windows, I would create a new source file called pgsocket, 
or something, and implement *all* the socket cruft there. Where ever you 
mess with a socket, i.e. send, recv,  poll,  accept, listen, 
get/setsockopt, select, etc. make it a function. Furthermore, try to 
bring some of the logical cruft that goes along with sockets and bring 
it into the module, i.e. don't call select(...) then call recv, call 
SocketSelectRead(...).

Windows' sockets aren't very good. They will be good enough to be 
functional, but eventually, someone will want to rewrite with completion 
ports.


Bruce Momjian wrote:

>Looking at libpq, you can see Win32 requires closesocket() while Unix
>uses just uses close().
>
>I have to add this type of change to the backend for Win32, so I am
>inclined to make all the socket close calls closesocket() and #define
>that as close() on Unix?  It would remove quite a few Win32 defs from
>libpq too.
>
>Comments?
>
>  
>



pgsql-hackers by date:

Previous
From: Olleg Samojlov
Date:
Subject: Re: default locale considered harmful? (was Re: [GENERAL] Using
Next
From: Tom Lane
Date:
Subject: Re: STABLE functions