On Sun, Feb 22, 2015 at 07:57:41PM -0500, Tom Lane wrote: > Robert Haas <robertmh...@gmail.com> writes: > > On Fri, Feb 20, 2015 at 12:59 AM, Noah Misch <n...@leadboat.com> wrote: > >> On Mon, Feb 02, 2015 at 03:48:33PM -0500, Robert Haas wrote: > >>> If readir() fails and closedir() succeeds, the return will be -1 but > >>> errno will be 0. > > >> Out of curiosity, have you seen a closedir() implementation behave that > >> way? > >> It would violate C99 ("The value of errno is zero at program startup, but > >> is > >> never set to zero by any library function.") and POSIX. > > > No. Good point, I didn't think about that. I think this way is safer, > > though. > > While the spec forbids library functions from setting errno to zero, there > is no restriction on them changing errno in other ways despite returning > success; their exit-time value of errno is only well-defined if they fail. > So we do need to preserve errno explicitly across closedir(), or we may > report the wrong failure from readdir().
Yes. I'm happy with the commit itself. -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers