1*2fe8fb19SBen Gras.\" $NetBSD: getwc.3,v 1.9 2010/12/16 17:42:27 wiz Exp $ 2*2fe8fb19SBen Gras.\" 3*2fe8fb19SBen Gras.\" Copyright (c) 1990, 1991, 1993 4*2fe8fb19SBen Gras.\" The Regents of the University of California. All rights reserved. 5*2fe8fb19SBen Gras.\" 6*2fe8fb19SBen Gras.\" This code is derived from software contributed to Berkeley by 7*2fe8fb19SBen Gras.\" Chris Torek and the American National Standards Committee X3, 8*2fe8fb19SBen Gras.\" on Information Processing Systems. 9*2fe8fb19SBen Gras.\" 10*2fe8fb19SBen Gras.\" Redistribution and use in source and binary forms, with or without 11*2fe8fb19SBen Gras.\" modification, are permitted provided that the following conditions 12*2fe8fb19SBen Gras.\" are met: 13*2fe8fb19SBen Gras.\" 1. Redistributions of source code must retain the above copyright 14*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer. 15*2fe8fb19SBen Gras.\" 2. Redistributions in binary form must reproduce the above copyright 16*2fe8fb19SBen Gras.\" notice, this list of conditions and the following disclaimer in the 17*2fe8fb19SBen Gras.\" documentation and/or other materials provided with the distribution. 18*2fe8fb19SBen Gras.\" 3. Neither the name of the University nor the names of its contributors 19*2fe8fb19SBen Gras.\" may be used to endorse or promote products derived from this software 20*2fe8fb19SBen Gras.\" without specific prior written permission. 21*2fe8fb19SBen Gras.\" 22*2fe8fb19SBen Gras.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 23*2fe8fb19SBen Gras.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 24*2fe8fb19SBen Gras.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 25*2fe8fb19SBen Gras.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 26*2fe8fb19SBen Gras.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 27*2fe8fb19SBen Gras.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 28*2fe8fb19SBen Gras.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 29*2fe8fb19SBen Gras.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 30*2fe8fb19SBen Gras.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 31*2fe8fb19SBen Gras.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 32*2fe8fb19SBen Gras.\" SUCH DAMAGE. 33*2fe8fb19SBen Gras.\" 34*2fe8fb19SBen Gras.\" @(#)getc.3 8.1 (Berkeley) 6/4/93 35*2fe8fb19SBen Gras.\" 36*2fe8fb19SBen Gras.Dd May 6, 2010 37*2fe8fb19SBen Gras.Dt GETWC 3 38*2fe8fb19SBen Gras.Os 39*2fe8fb19SBen Gras.Sh NAME 40*2fe8fb19SBen Gras.Nm fgetwc , 41*2fe8fb19SBen Gras.Nm getwc , 42*2fe8fb19SBen Gras.Nm getwchar , 43*2fe8fb19SBen Gras.Nd get next wide character from input stream 44*2fe8fb19SBen Gras.Sh LIBRARY 45*2fe8fb19SBen Gras.Lb libc 46*2fe8fb19SBen Gras.Sh SYNOPSIS 47*2fe8fb19SBen Gras.In stdio.h 48*2fe8fb19SBen Gras.In wchar.h 49*2fe8fb19SBen Gras.Ft wint_t 50*2fe8fb19SBen Gras.Fn fgetwc "FILE *stream" 51*2fe8fb19SBen Gras.Ft wint_t 52*2fe8fb19SBen Gras.Fn getwc "FILE *stream" 53*2fe8fb19SBen Gras.Ft wint_t 54*2fe8fb19SBen Gras.Fn getwchar 55*2fe8fb19SBen Gras.Sh DESCRIPTION 56*2fe8fb19SBen GrasThe 57*2fe8fb19SBen Gras.Fn fgetwc 58*2fe8fb19SBen Grasfunction 59*2fe8fb19SBen Grasobtains the next input wide character (if present) from the stream pointed at by 60*2fe8fb19SBen Gras.Fa stream , 61*2fe8fb19SBen Grasor the next character pushed back on the stream via 62*2fe8fb19SBen Gras.Xr ungetwc 3 . 63*2fe8fb19SBen Gras.Pp 64*2fe8fb19SBen GrasThe 65*2fe8fb19SBen Gras.Fn getwc 66*2fe8fb19SBen Grasfunction 67*2fe8fb19SBen Grasacts essentially identically to 68*2fe8fb19SBen Gras.Fn fgetwc , 69*2fe8fb19SBen Grasbut is a macro that expands in-line. 70*2fe8fb19SBen Gras.Pp 71*2fe8fb19SBen GrasThe 72*2fe8fb19SBen Gras.Fn getwchar 73*2fe8fb19SBen Grasfunction 74*2fe8fb19SBen Grasis equivalent to 75*2fe8fb19SBen Gras.Fn getwc 76*2fe8fb19SBen Graswith the argument stdin. 77*2fe8fb19SBen Gras.Sh RETURN VALUES 78*2fe8fb19SBen GrasIf successful, these routines return the next wide character 79*2fe8fb19SBen Grasfrom the 80*2fe8fb19SBen Gras.Fa stream . 81*2fe8fb19SBen GrasIf the stream is at end-of-file or a read error occurs, 82*2fe8fb19SBen Grasthe routines return 83*2fe8fb19SBen Gras.Dv WEOF . 84*2fe8fb19SBen GrasThe routines 85*2fe8fb19SBen Gras.Xr feof 3 86*2fe8fb19SBen Grasand 87*2fe8fb19SBen Gras.Xr ferror 3 88*2fe8fb19SBen Grasmust be used to distinguish between end-of-file and error. 89*2fe8fb19SBen GrasIf an error occurs, the global variable 90*2fe8fb19SBen Gras.Va errno 91*2fe8fb19SBen Grasis set to indicate the error. 92*2fe8fb19SBen GrasThe end-of-file condition is remembered, even on a terminal, and all 93*2fe8fb19SBen Grassubsequent attempts to read will return 94*2fe8fb19SBen Gras.Dv WEOF 95*2fe8fb19SBen Grasuntil the condition is cleared with 96*2fe8fb19SBen Gras.Xr clearerr 3 . 97*2fe8fb19SBen Gras.Sh SEE ALSO 98*2fe8fb19SBen Gras.Xr ferror 3 , 99*2fe8fb19SBen Gras.Xr fopen 3 , 100*2fe8fb19SBen Gras.Xr fread 3 , 101*2fe8fb19SBen Gras.Xr putwc 3 , 102*2fe8fb19SBen Gras.Xr stdio 3 , 103*2fe8fb19SBen Gras.Xr ungetwc 3 104*2fe8fb19SBen Gras.Sh STANDARDS 105*2fe8fb19SBen GrasThe 106*2fe8fb19SBen Gras.Fn fgetwc , 107*2fe8fb19SBen Gras.Fn getwc 108*2fe8fb19SBen Grasand 109*2fe8fb19SBen Gras.Fn getwchar 110*2fe8fb19SBen Grasfunctions 111*2fe8fb19SBen Grasconform to 112*2fe8fb19SBen Gras.St -isoC-99 113*2fe8fb19SBen Grasand 114*2fe8fb19SBen Gras.St -p1003.1-2001 . 115