Lock the file once per call and use the unlocked fgetwc()/fputwc() variants.

This commit is contained in:
Tim J. Robbins 2002-09-20 13:25:40 +00:00
parent 9260341650
commit 7591ae56ae
2 changed files with 20 additions and 9 deletions

View File

@ -41,20 +41,23 @@ fgetws(wchar_t * __restrict ws, int n, FILE * __restrict fp)
wchar_t *wsp;
wint_t wc;
ORIENTLOCK(fp, 1);
FLOCKFILE(fp);
ORIENT(fp, 1);
if (n <= 0)
return (NULL);
if (n <= 0) {
errno = EINVAL;
goto error;
}
wsp = ws;
while (n-- > 1) {
/* XXX Inefficient */
if ((wc = fgetwc(fp)) == WEOF && errno == EILSEQ)
return (NULL);
if ((wc = __fgetwc(fp)) == WEOF && errno == EILSEQ)
goto error;
if (wc == WEOF) {
if (wsp == ws)
/* EOF/error, no characters read yet. */
return (NULL);
goto error;
break;
}
*wsp++ = (wchar_t)wc;
@ -62,6 +65,11 @@ fgetws(wchar_t * __restrict ws, int n, FILE * __restrict fp)
break;
}
*wsp++ = L'\0';
FUNLOCKFILE(fp);
return (ws);
error:
FUNLOCKFILE(fp);
return (NULL);
}

View File

@ -39,12 +39,15 @@ int
fputws(const wchar_t * __restrict ws, FILE * __restrict fp)
{
ORIENTLOCK(fp, 1);
FLOCKFILE(fp);
ORIENT(fp, 1);
/* XXX Inefficient */
while (*ws != '\0')
if (fputwc(*ws++, fp) == WEOF)
if (__fputwc(*ws++, fp) == WEOF) {
FUNLOCKFILE(fp);
return (-1);
}
FUNLOCKFILE(fp);
return (0);
}