Re: [pgsql-hackers-win32] Win32 lost signals open item - Mailing list pgsql-hackers

From Tom Lane
Subject Re: [pgsql-hackers-win32] Win32 lost signals open item
Date
Msg-id 25350.1099343470@sss.pgh.pa.us
Whole thread Raw
In response to Re: [pgsql-hackers-win32] Win32 lost signals open item  ("Magnus Hagander" <mha@sollentuna.net>)
List pgsql-hackers
"Magnus Hagander" <mha@sollentuna.net> writes:
> Nope, we need to pass the handle. Only one process can be the
> server-side of the pipe, and once the postmaster has opened it, the
> child process can't do it - the only way to get it is through
> inheritance.

Grumble.  Having to call write_backend_variables from two different
places seems Really Ugly.

How about Plan B?  It occurs to me that what this proposal really does
is to delay the postmaster until after the child process has been
created.  What about doing that in some more straightforward fashion
--- that is, the postmaster doesn't return from win32_forkexec until
it sees that the child has gotten at least as far as being able to
accept signals?  (A simple way to do it would just be to loop trying to
kill(0) the child PID.)  I guess the tricky part here is recovering if
the child fails to start at all --- a timeout would perhaps do but it's
ugly.  Still, seems less ugly than the way this idea is panning out.

            regards, tom lane

pgsql-hackers by date:

Previous
From: "Magnus Hagander"
Date:
Subject: Re: [pgsql-hackers-win32] Win32 lost signals open item
Next
From: "Roland Volkmann"
Date:
Subject: FW: Charset WIN1252