fclose(FILE *fp)
{
int r;
+ int error = 0;
- if (!__sdidinit)
- __sinit();
+ pthread_once(&__sdidinit, __sinit);
if (fp == NULL) {
errno = EFAULT;
return (EOF);
}
FLOCKFILE(fp);
- r = fp->_flags & __SWR ? __sflush(fp) : 0;
- if (fp->_close != NULL && (*fp->_close)(fp->_cookie) < 0)
+ r = __sflush(fp);
+ if (r < 0) {
+ error = errno;
+ }
+ if (fp->_close != NULL && (*fp->_close)(fp->_cookie) < 0) {
r = EOF;
+ error = errno;
+ }
if (fp->_flags & __SMBF)
free((char *)fp->_bf._base);
if (HASUB(fp))
FREELB(fp);
fp->_file = -1;
fp->_r = fp->_w = 0; /* Mess up if reaccessed. */
- __sfprelease(fp); /* Release this FILE for reuse. */
FUNLOCKFILE(fp);
+ __sfprelease(fp); /* Release this FILE for reuse. */
+ /* Don't clobber errno unnecessarily. */
+ if (error) {
+ errno = error;
+ }
return (r);
}