summaryrefslogtreecommitdiff
path: root/libc/stdio/ungetwc.c
diff options
context:
space:
mode:
authorManuel Novoa III <mjn3@codepoet.org>2004-02-11 23:48:50 +0000
committerManuel Novoa III <mjn3@codepoet.org>2004-02-11 23:48:50 +0000
commit082e680bd54e999f2bb4eb77141958938b1e9ee9 (patch)
tree203c45b85ca608e1550d8ffc459456fc9cf0b30b /libc/stdio/ungetwc.c
parent17c21765b4a97c6f0b74ba8466073e5a3f97cdee (diff)
New stdio core. Should be more maintainable. Fixes a couple of bugs.
Codepaths streamlined. Improved performance for nonthreaded apps when linked with a thread-enabled libc. Minor iconv bug and some locale/thread related startup issues fixed. These showed up in getting a gcj-compiled java helloworld app running. Removed some old extension functions... _stdio_fdout and _stdio_fsfopen.
Diffstat (limited to 'libc/stdio/ungetwc.c')
-rw-r--r--libc/stdio/ungetwc.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/libc/stdio/ungetwc.c b/libc/stdio/ungetwc.c
new file mode 100644
index 000000000..cf4b9c488
--- /dev/null
+++ b/libc/stdio/ungetwc.c
@@ -0,0 +1,48 @@
+/* Copyright (C) 2004 Manuel Novoa III <mjn3@codepoet.org>
+ *
+ * GNU Library General Public License (LGPL) version 2 or later.
+ *
+ * Dedicated to Toni. See uClibc/DEDICATION.mjn3 for details.
+ */
+
+#include "_stdio.h"
+
+/* Note: This is the application-callable ungetwc. If wscanf calls this, it
+ * should also set stream->__ungot[1] to 0 if this is the only ungot, as well
+ * as reset stream->__ungot_width[1] for use by _stdio_adjpos().
+ */
+
+wint_t ungetwc(wint_t c, register FILE *stream)
+{
+ __STDIO_AUTO_THREADLOCK_VAR;
+
+ __STDIO_AUTO_THREADLOCK(stream);
+ __STDIO_STREAM_VALIDATE(stream); /* debugging only */
+
+ /* Note: Even if c == WEOF, we need to initialize/verify the
+ * stream's orientation and ensure the stream is in reading
+ * mode (if readable and properly oriented). */
+ if ((!__STDIO_STREAM_IS_WIDE_READING(stream)
+ && __STDIO_STREAM_TRANS_TO_READ(stream, __FLAG_WIDE))
+ || ((stream->__modeflags & __FLAG_UNGOT)
+ && ((stream->__modeflags & 1) || stream->__ungot[1]))
+ || (c == WEOF)
+ ) {
+ c = WEOF;
+ } else {
+ /* In the wide case, getc macros should already be disabled. */
+ /* __STDIO_STREAM_DISABLE_GETC(stream); */
+
+ /* Flag this as a user ungot, as scanf does the necessary fixup. */
+ stream->__ungot[1] = 1;
+ stream->__ungot[(++stream->__modeflags) & 1] = c;
+ /* Note: ungot_width is handled by fgetwc. */
+
+ __STDIO_STREAM_CLEAR_EOF(stream); /* Must clear end-of-file flag. */
+ }
+
+ __STDIO_STREAM_VALIDATE(stream);
+ __STDIO_AUTO_THREADUNLOCK(stream);
+
+ return c;
+}