mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-05 01:00:14 +00:00
Update.
* libio/fileops.c (_IO_new_file_open): Recognize ,ccs= in mode string and load appropriate conversions. * libio/iofwide.c (__libio_codecvt): Renamed from libio_codecvt and made global. * libio/libioP.h: Declare __libio_codecvt. * manual/stdio.texi: Document ,ccs= option for fopen. * wcsmbs/wcsmbsload.c (__wcsmbs_named_conv): New function. * wcsmbs/wcsmbsload.h (__wcsmbs_named_conv): Declare. * libio/iofclose.c: Free conversion data if stream was wide-oriented. * sysdeps/unix/sysv/linux/i386/Dist: Add sys/io.h.
This commit is contained in:
parent
c36897fb5b
commit
4e2e99997a
13
ChangeLog
13
ChangeLog
@ -1,5 +1,18 @@
|
|||||||
2000-01-25 Ulrich Drepper <drepper@cygnus.com>
|
2000-01-25 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* libio/fileops.c (_IO_new_file_open): Recognize ,ccs= in mode string
|
||||||
|
and load appropriate conversions.
|
||||||
|
* libio/iofwide.c (__libio_codecvt): Renamed from libio_codecvt and
|
||||||
|
made global.
|
||||||
|
* libio/libioP.h: Declare __libio_codecvt.
|
||||||
|
* manual/stdio.texi: Document ,ccs= option for fopen.
|
||||||
|
* wcsmbs/wcsmbsload.c (__wcsmbs_named_conv): New function.
|
||||||
|
* wcsmbs/wcsmbsload.h (__wcsmbs_named_conv): Declare.
|
||||||
|
|
||||||
|
* libio/iofclose.c: Free conversion data if stream was wide-oriented.
|
||||||
|
|
||||||
|
* sysdeps/unix/sysv/linux/i386/Dist: Add sys/io.h.
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/Dist: Remove sys/io.h.
|
* sysdeps/unix/sysv/linux/Dist: Remove sys/io.h.
|
||||||
|
|
||||||
* posix/fnmatch_loop.c: Fix problem with FNM_LEADING_DIR.
|
* posix/fnmatch_loop.c: Fix problem with FNM_LEADING_DIR.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1993, 1995, 1997, 1998, 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1993, 1995, 1997-1999, 2000 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU IO Library.
|
This file is part of the GNU IO Library.
|
||||||
Written by Per Bothner <bothner@cygnus.com>.
|
Written by Per Bothner <bothner@cygnus.com>.
|
||||||
|
|
||||||
@ -37,6 +37,9 @@
|
|||||||
#ifdef __STDC__
|
#ifdef __STDC__
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
#if _LIBC
|
||||||
|
# include "../wcsmbs/wcsmbsload.h"
|
||||||
|
#endif
|
||||||
#ifndef errno
|
#ifndef errno
|
||||||
extern int errno;
|
extern int errno;
|
||||||
#endif
|
#endif
|
||||||
@ -214,6 +217,11 @@ _IO_new_file_fopen (fp, filename, mode, is32not64)
|
|||||||
int read_write;
|
int read_write;
|
||||||
int oprot = 0666;
|
int oprot = 0666;
|
||||||
int i;
|
int i;
|
||||||
|
_IO_FILE *result;
|
||||||
|
#if _LIBC
|
||||||
|
const char *cs;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (_IO_file_is_open (fp))
|
if (_IO_file_is_open (fp))
|
||||||
return 0;
|
return 0;
|
||||||
switch (*mode)
|
switch (*mode)
|
||||||
@ -257,8 +265,54 @@ _IO_new_file_fopen (fp, filename, mode, is32not64)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return _IO_file_open (fp, filename, omode|oflags, oprot, read_write,
|
result = _IO_file_open (fp, filename, omode|oflags, oprot, read_write,
|
||||||
is32not64);
|
is32not64);
|
||||||
|
|
||||||
|
|
||||||
|
#if _LIBC
|
||||||
|
/* Test whether the mode string specifies the conversion. */
|
||||||
|
cs = strstr (mode, ",ccs=");
|
||||||
|
if (cs != NULL)
|
||||||
|
{
|
||||||
|
/* Yep. Load the appropriate conversions and set the orientation
|
||||||
|
to wide. */
|
||||||
|
struct gconv_fcts fcts;
|
||||||
|
struct _IO_codecvt *cc = &fp->_wide_data->_codecvt;
|
||||||
|
|
||||||
|
if (__wcsmbs_named_conv (&fcts, cs + 5) != 0)
|
||||||
|
{
|
||||||
|
/* Something went wrong, we cannot load the conversion modules.
|
||||||
|
This means we cannot proceed since the user explicitly asked
|
||||||
|
for these. */
|
||||||
|
_IO_new_fclose (result);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* The functions are always the same. */
|
||||||
|
*cc = __libio_codecvt;
|
||||||
|
|
||||||
|
cc->__cd_in.__cd.__nsteps = 1; /* Only one step allowed. */
|
||||||
|
cc->__cd_in.__cd.__steps = fcts.towc;
|
||||||
|
|
||||||
|
cc->__cd_in.__cd.__data[0].__invocation_counter = 0;
|
||||||
|
cc->__cd_in.__cd.__data[0].__internal_use = 1;
|
||||||
|
cc->__cd_in.__cd.__data[0].__is_last = 1;
|
||||||
|
cc->__cd_in.__cd.__data[0].__statep = &result->_wide_data->_IO_state;
|
||||||
|
|
||||||
|
cc->__cd_out.__cd.__nsteps = 1; /* Only one step allowed. */
|
||||||
|
cc->__cd_out.__cd.__steps = fcts.tomb;
|
||||||
|
|
||||||
|
cc->__cd_out.__cd.__data[0].__invocation_counter = 0;
|
||||||
|
cc->__cd_out.__cd.__data[0].__internal_use = 1;
|
||||||
|
cc->__cd_out.__cd.__data[0].__is_last = 1;
|
||||||
|
cc->__cd_out.__cd.__data[0].__statep = &result->_wide_data->_IO_state;
|
||||||
|
|
||||||
|
/* Set the mode now. */
|
||||||
|
result->_mode = 1;
|
||||||
|
}
|
||||||
|
#endif /* GNU libc */
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
_IO_FILE *
|
_IO_FILE *
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1993, 1995, 1997, 1998, 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1993, 1995, 1997-1999, 2000 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU IO Library.
|
This file is part of the GNU IO Library.
|
||||||
|
|
||||||
This library is free software; you can redistribute it and/or
|
This library is free software; you can redistribute it and/or
|
||||||
@ -27,6 +27,9 @@
|
|||||||
#ifdef __STDC__
|
#ifdef __STDC__
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
#if _LIBC
|
||||||
|
# include "../iconv/gconv_int.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
int
|
int
|
||||||
_IO_new_fclose (fp)
|
_IO_new_fclose (fp)
|
||||||
@ -52,6 +55,25 @@ _IO_new_fclose (fp)
|
|||||||
status = fp->_flags & _IO_ERR_SEEN ? -1 : 0;
|
status = fp->_flags & _IO_ERR_SEEN ? -1 : 0;
|
||||||
_IO_FINISH (fp);
|
_IO_FINISH (fp);
|
||||||
_IO_funlockfile (fp);
|
_IO_funlockfile (fp);
|
||||||
|
if (fp->_mode > 0)
|
||||||
|
{
|
||||||
|
#if _LIBC
|
||||||
|
/* This stream has a wide orientation. This means we have to free
|
||||||
|
the conversion functions. */
|
||||||
|
struct _IO_codecvt *cc = &fp->_wide_data->_codecvt;
|
||||||
|
|
||||||
|
if (cc->__cd_in.__cd.__steps->__shlib_handle != NULL)
|
||||||
|
{
|
||||||
|
--cc->__cd_in.__cd.__steps->__counter;
|
||||||
|
__gconv_close_transform (cc->__cd_in.__cd.__steps, 1);
|
||||||
|
}
|
||||||
|
if (cc->__cd_out.__cd.__steps->__shlib_handle != NULL)
|
||||||
|
{
|
||||||
|
--cc->__cd_out.__cd.__steps->__counter;
|
||||||
|
__gconv_close_transform (cc->__cd_out.__cd.__steps, 1);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
_IO_cleanup_region_end (0);
|
_IO_cleanup_region_end (0);
|
||||||
if (_IO_have_backup (fp))
|
if (_IO_have_backup (fp))
|
||||||
_IO_free_backup_area (fp);
|
_IO_free_backup_area (fp);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1999, 2000 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU IO Library.
|
This file is part of the GNU IO Library.
|
||||||
|
|
||||||
This library is free software; you can redistribute it and/or
|
This library is free software; you can redistribute it and/or
|
||||||
@ -62,7 +62,7 @@ static int do_always_noconv (struct _IO_codecvt *codecvt);
|
|||||||
|
|
||||||
|
|
||||||
/* The functions used in `codecvt' for libio are always the same. */
|
/* The functions used in `codecvt' for libio are always the same. */
|
||||||
static struct _IO_codecvt libio_codecvt =
|
struct _IO_codecvt __libio_codecvt =
|
||||||
{
|
{
|
||||||
.__codecvt_destr = NULL, /* Destructor, never used. */
|
.__codecvt_destr = NULL, /* Destructor, never used. */
|
||||||
.__codecvt_do_out = do_out,
|
.__codecvt_do_out = do_out,
|
||||||
@ -114,7 +114,7 @@ _IO_fwide (fp, mode)
|
|||||||
__wcsmbs_clone_conv (&fcts);
|
__wcsmbs_clone_conv (&fcts);
|
||||||
|
|
||||||
/* The functions are always the same. */
|
/* The functions are always the same. */
|
||||||
*cc = libio_codecvt;
|
*cc = __libio_codecvt;
|
||||||
|
|
||||||
cc->__cd_in.__cd.__nsteps = 1; /* Only one step allowed. */
|
cc->__cd_in.__cd.__nsteps = 1; /* Only one step allowed. */
|
||||||
cc->__cd_in.__cd.__steps = fcts.towc;
|
cc->__cd_in.__cd.__steps = fcts.towc;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1993, 1997, 1998, 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1993, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU IO Library.
|
This file is part of the GNU IO Library.
|
||||||
|
|
||||||
This library is free software; you can redistribute it and/or
|
This library is free software; you can redistribute it and/or
|
||||||
@ -390,6 +390,7 @@ extern struct _IO_jump_t _IO_proc_jumps;
|
|||||||
extern struct _IO_jump_t _IO_old_proc_jumps;
|
extern struct _IO_jump_t _IO_old_proc_jumps;
|
||||||
extern struct _IO_jump_t _IO_str_jumps;
|
extern struct _IO_jump_t _IO_str_jumps;
|
||||||
extern struct _IO_jump_t _IO_wstr_jumps;
|
extern struct _IO_jump_t _IO_wstr_jumps;
|
||||||
|
extern struct _IO_codecvt __libio_codecvt;
|
||||||
extern int _IO_do_write __P ((_IO_FILE *, const char *, _IO_size_t));
|
extern int _IO_do_write __P ((_IO_FILE *, const char *, _IO_size_t));
|
||||||
extern int _IO_new_do_write __P ((_IO_FILE *, const char *, _IO_size_t));
|
extern int _IO_new_do_write __P ((_IO_FILE *, const char *, _IO_size_t));
|
||||||
extern int _IO_old_do_write __P ((_IO_FILE *, const char *, _IO_size_t));
|
extern int _IO_old_do_write __P ((_IO_FILE *, const char *, _IO_size_t));
|
||||||
|
@ -206,6 +206,21 @@ difference in POSIX systems (including the GNU system). If both
|
|||||||
@samp{+} and @samp{b} are specified, they can appear in either order.
|
@samp{+} and @samp{b} are specified, they can appear in either order.
|
||||||
@xref{Binary Streams}.
|
@xref{Binary Streams}.
|
||||||
|
|
||||||
|
@cindex stream orientation
|
||||||
|
@cindex orientation, stream
|
||||||
|
If the @var{opentype} string contains the sequence
|
||||||
|
@code{,ccs=@var{STRING}} then @var{STRING} is taken as the name of a
|
||||||
|
coded character set and @code{fopen} will mark the stream as
|
||||||
|
wide-oriented which appropriate conversion functions in place to convert
|
||||||
|
from and to the character set @var{STRING} is place. Any other stream
|
||||||
|
is opened initially unoriented and the orientation is decided with the
|
||||||
|
first file operation. If the first operation is a wide character
|
||||||
|
operation, the stream is not only marked as wide-oriented, also the
|
||||||
|
conversion functions to convert to the coded character set used for the
|
||||||
|
current locale are loaded. This will not change anymore from this point
|
||||||
|
on even if the locale selected for the @code{LC_CTYPE} category is
|
||||||
|
changed.
|
||||||
|
|
||||||
Any other characters in @var{opentype} are simply ignored. They may be
|
Any other characters in @var{opentype} are simply ignored. They may be
|
||||||
meaningful in other systems.
|
meaningful in other systems.
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ setfsuid.c
|
|||||||
setfsgid.c
|
setfsgid.c
|
||||||
sys/debugreg.h
|
sys/debugreg.h
|
||||||
sys/elf.h
|
sys/elf.h
|
||||||
|
sys/io.h
|
||||||
sys/perm.h
|
sys/perm.h
|
||||||
sys/procfs.h
|
sys/procfs.h
|
||||||
sys/reg.h
|
sys/reg.h
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1998, 1999, 2000 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
||||||
|
|
||||||
@ -250,3 +250,29 @@ __wcsmbs_clone_conv (struct gconv_fcts *copy)
|
|||||||
|
|
||||||
__libc_lock_unlock (lock);
|
__libc_lock_unlock (lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Clone the current conversion function set. */
|
||||||
|
int
|
||||||
|
internal_function
|
||||||
|
__wcsmbs_named_conv (struct gconv_fcts *copy, const char *name)
|
||||||
|
{
|
||||||
|
copy->towc = getfct ("INTERNAL", name);
|
||||||
|
if (copy->towc != NULL)
|
||||||
|
{
|
||||||
|
copy->tomb = getfct (name, "INTERNAL");
|
||||||
|
if (copy->tomb == NULL)
|
||||||
|
__gconv_close_transform (copy->towc, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (copy->towc == NULL || copy->tomb == NULL)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
/* Now increment the usage counters. */
|
||||||
|
if (copy->towc->__shlib_handle != NULL)
|
||||||
|
++copy->towc->__counter;
|
||||||
|
if (copy->tomb->__shlib_handle != NULL)
|
||||||
|
++copy->tomb->__counter;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
/* Copyright (C) 1998, 1999, 2000 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
||||||
|
|
||||||
@ -45,6 +45,10 @@ extern void __wcsmbs_load_conv (const struct locale_data *new_category)
|
|||||||
extern void __wcsmbs_clone_conv (struct gconv_fcts *copy)
|
extern void __wcsmbs_clone_conv (struct gconv_fcts *copy)
|
||||||
internal_function;
|
internal_function;
|
||||||
|
|
||||||
|
/* Find the conversion functions for converting to and from NAME. */
|
||||||
|
extern int __wcsmbs_named_conv (struct gconv_fcts *copy, const char *name)
|
||||||
|
internal_function;
|
||||||
|
|
||||||
|
|
||||||
/* Check whether the LC_CTYPE locale changed since the last call.
|
/* Check whether the LC_CTYPE locale changed since the last call.
|
||||||
Update the pointers appropriately. */
|
Update the pointers appropriately. */
|
||||||
|
Loading…
Reference in New Issue
Block a user