about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog9
-rw-r--r--libio/Makefile2
-rw-r--r--libio/fwide.c53
-rw-r--r--libio/iofwide.c6
4 files changed, 61 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index ecd6fd7ca5..47ee8b7f2b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,7 +1,12 @@
 2000-07-20  Ulrich Drepper  <drepper@redhat.com>
 
-	* elf/dl-load.c (_dl_map_object): Implement handling of
-	DF_1_NODEFLIB.
+	* libio/Makefile (routines): Add fwide.
+	* libio/iofwide.c (_IO_fwide): Remove locking.  This is done in
+	fwide now.  Internal calls to _IO_fwide must do locking themselves
+	or don't need locking.
+	* libio/fwide.c: New file.
+
+	* elf/dl-load.c (_dl_map_object): Implement handling of DF_1_NODEFLIB.
 
 	* elf/Makefile: Add no modules for nodelete test.
 	* elf/nodelmod3.c: New file.
diff --git a/libio/Makefile b/libio/Makefile
index ffc6958ae9..3232b80738 100644
--- a/libio/Makefile
+++ b/libio/Makefile
@@ -34,7 +34,7 @@ routines	:=							      \
 	iofputws iofputws_u iogetwline iowpadn ioungetwc putwc putwc_u	      \
 	putwchar putwchar_u putchar putchar_u fwprintf swprintf vwprintf      \
 	wprintf wscanf fwscanf vwscanf vswprintf iovswscanf swscanf wgenops   \
-	wstrops wfileops iofwide					      \
+	wstrops wfileops iofwide fwide					      \
 									      \
 	clearerr feof ferror fileno fputc freopen fseek getc getchar	      \
 	memstream pclose putc putchar rewind setbuf setlinebuf vasprintf      \
diff --git a/libio/fwide.c b/libio/fwide.c
new file mode 100644
index 0000000000..a4d0e4708c
--- /dev/null
+++ b/libio/fwide.c
@@ -0,0 +1,53 @@
+/* Copyright (C) 1999, 2000 Free Software Foundation, Inc.
+   This file is part of the GNU IO Library.
+
+   This library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU General Public License as
+   published by the Free Software Foundation; either version 2, or (at
+   your option) any later version.
+
+   This library is distributed in the hope that it will be useful, but
+   WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this library; see the file COPYING.  If not, write to
+   the Free Software Foundation, 59 Temple Place - Suite 330, Boston,
+   MA 02111-1307, USA.
+
+   As a special exception, if you link this library with files
+   compiled with a GNU compiler to produce an executable, this does
+   not cause the resulting executable to be covered by the GNU General
+   Public License.  This exception does not however invalidate any
+   other reasons why the executable file might be covered by the GNU
+   General Public License.  */
+
+#include <libioP.h>
+#include <stdio.h>
+
+int
+fwide (fp, mode)
+     _IO_FILE *fp;
+     int mode;
+{
+  int result;
+
+  /* Normalize the value.  */
+  mode = mode < 0 ? -1 : (mode == 0 ? 0 : 1);
+
+  if (mode == 0 || fp->_mode != 0)
+    /* The caller simply wants to know about the current orientation
+       or the orientation already has been determined.  */
+    return fp->_mode;
+
+  _IO_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp);
+  _IO_flockfile (fp);
+
+  result = _IO_fwide (fp, mode);
+
+  _IO_funlockfile (fp);
+  _IO_cleanup_region_end (0);
+
+  return result;
+}
diff --git a/libio/iofwide.c b/libio/iofwide.c
index 12649fd9c7..c0ee083029 100644
--- a/libio/iofwide.c
+++ b/libio/iofwide.c
@@ -92,9 +92,6 @@ _IO_fwide (fp, mode)
        or the orientation already has been determined.  */
     return fp->_mode;
 
-  _IO_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp);
-  _IO_flockfile (fp);
-
   /* Set the orientation appropriately.  */
   if (mode > 0)
     {
@@ -150,9 +147,6 @@ _IO_fwide (fp, mode)
   /* Set the mode now.  */
   fp->_mode = mode;
 
-  _IO_funlockfile (fp);
-  _IO_cleanup_region_end (0);
-
   return mode;
 }