From d052b31b79a3681db7de04177a55b04354320a61 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Fri, 21 Jul 2000 06:15:13 +0000 Subject: [PATCH] Update. * 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. --- ChangeLog | 9 +++++++-- libio/Makefile | 2 +- libio/fwide.c | 53 +++++++++++++++++++++++++++++++++++++++++++++++++++++ libio/iofwide.c | 6 ------ 4 files changed, 61 insertions(+), 9 deletions(-) create mode 100644 libio/fwide.c diff --git a/ChangeLog b/ChangeLog index ecd6fd7..47ee8b7 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,7 +1,12 @@ 2000-07-20 Ulrich Drepper - * 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 ffc6958..3232b80 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 0000000..a4d0e47 --- /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 +#include + +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 12649fd..c0ee083 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; } -- 2.7.4