Update.
* include/sys/socket.h: Declare __libc_sa_len_internal and define SA_LEN macro to use it if not NOT_IN_libc. * sysdeps/unix/sysv/linux/sa_len.c: Use INTDEF for __libc_sa_len. * include/fcntl.h: Declare __open_internal and define __open and __libc_open macros if not NOT_IN_libc. * sysdeps/generic/open.c: Use INTDEF for __open. * sysdeps/mach/hurd/open.c: Likewise. * sysdeps/unix/sysv/aix/open.c: Likewise. * sysdeps/unix/syscalls.list: Add __open_internal alias. * sysdeps/generic/check_fds.c: Make sure newly opened file descriptor has correct number. * include/fcntl.h: Define __libc_fcntl macro if not NOT_IN_libc. * sysdeps/mach/hurd/fcntl.c: Undefine __libc_fcntl as well. * sysdeps/unix/sysv/aix/fcntl.c: Likewise. * sysdeps/unix/sysv/linux/i386/fcntl.c: Likewise. * include/wctype.h: Declare __iswalpha_l_internal, __iswdigit_l_internal, __iswspace_l_internal, __iswxdigit_l_internal, and __iswctype_internal. Define __iswalpha_l, __iswctype, __iswdigit_l, __iswspace_l, and __iswxdigit_l macros if not NOT_IN_libc. * wctype/iswctype.c: Use INTDEF for __iswctype. * wctype/wcfuncs_l.c: Use INTDEF for all __iswXXX_l.
This commit is contained in:
parent
f83af095b6
commit
08f600749e
27
ChangeLog
27
ChangeLog
@ -1,5 +1,32 @@
|
||||
2002-04-14 Ulrich Drepper <drepper@redhat.com>
|
||||
|
||||
* include/sys/socket.h: Declare __libc_sa_len_internal and define
|
||||
SA_LEN macro to use it if not NOT_IN_libc.
|
||||
* sysdeps/unix/sysv/linux/sa_len.c: Use INTDEF for __libc_sa_len.
|
||||
|
||||
* include/fcntl.h: Declare __open_internal and define __open and
|
||||
__libc_open macros if not NOT_IN_libc.
|
||||
* sysdeps/generic/open.c: Use INTDEF for __open.
|
||||
* sysdeps/mach/hurd/open.c: Likewise.
|
||||
* sysdeps/unix/sysv/aix/open.c: Likewise.
|
||||
* sysdeps/unix/syscalls.list: Add __open_internal alias.
|
||||
|
||||
* sysdeps/generic/check_fds.c: Make sure newly opened file descriptor
|
||||
has correct number.
|
||||
|
||||
* include/fcntl.h: Define __libc_fcntl macro if not NOT_IN_libc.
|
||||
* sysdeps/mach/hurd/fcntl.c: Undefine __libc_fcntl as well.
|
||||
* sysdeps/unix/sysv/aix/fcntl.c: Likewise.
|
||||
* sysdeps/unix/sysv/linux/i386/fcntl.c: Likewise.
|
||||
|
||||
* include/wctype.h: Declare __iswalpha_l_internal,
|
||||
__iswdigit_l_internal, __iswspace_l_internal,
|
||||
__iswxdigit_l_internal, and __iswctype_internal. Define
|
||||
__iswalpha_l, __iswctype, __iswdigit_l, __iswspace_l, and
|
||||
__iswxdigit_l macros if not NOT_IN_libc.
|
||||
* wctype/iswctype.c: Use INTDEF for __iswctype.
|
||||
* wctype/wcfuncs_l.c: Use INTDEF for all __iswXXX_l.
|
||||
|
||||
* include/math.h: Declare __isinf_internal, __isinfl_internal,
|
||||
__isnan_internal, and __isnanl_internal.
|
||||
* stdio-common/printf_fp.c: Use INTUSE for calls to __isinf, __isinfl,
|
||||
|
@ -7,11 +7,19 @@ extern int __libc_open64 (const char *file, int oflag, ...);
|
||||
extern int __libc_open (const char *file, int oflag, ...);
|
||||
extern int __libc_fcntl (int fd, int cmd, ...);
|
||||
extern int __open (__const char *__file, int __oflag, ...);
|
||||
extern int __open_internal (__const char *__file, int __oflag, ...)
|
||||
attribute_hidden;
|
||||
extern int __fcntl (int __fd, int __cmd, ...);
|
||||
extern int __fcntl_internal (int __fd, int __cmd, ...);
|
||||
extern int __fcntl_internal (int __fd, int __cmd, ...) attribute_hidden;
|
||||
|
||||
#ifndef NOT_IN_libc
|
||||
# define __fcntl(fd, cmd, args...) INTUSE(__fcntl) (fd, cmd, ##args)
|
||||
# define __open(file, oflag, args...) INTUSE(__open) (file, oflag, ##args)
|
||||
# ifdef SHARED
|
||||
# define __libc_fcntl(fd, cmd, args...) __fcntl_internal (fd, cmd, ##args)
|
||||
# define __libc_open(file, oflag, args...) \
|
||||
__open_internal (file, oflag, ##args)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
@ -34,8 +34,13 @@ extern int __connect_internal (int __fd, __CONST_SOCKADDR_ARG __addr,
|
||||
#ifdef _HAVE_SA_LEN
|
||||
# define SA_LEN(_x) (_x)->sa_len
|
||||
#else
|
||||
extern int __libc_sa_len (sa_family_t __af);
|
||||
extern int __libc_sa_len_internal (sa_family_t __af) attribute_hidden;
|
||||
# ifndef NOT_IN_libc
|
||||
# define SA_LEN(_x) INTUSE(__libc_sa_len)((_x)->sa_family)
|
||||
# else
|
||||
# define SA_LEN(_x) __libc_sa_len((_x)->sa_family)
|
||||
extern int __libc_sa_len (sa_family_t __af) __THROW;
|
||||
# endif
|
||||
#endif
|
||||
|
||||
|
||||
|
@ -3,10 +3,26 @@
|
||||
#include <wctype/wctype.h>
|
||||
|
||||
/* Internal interfaces. */
|
||||
extern int __iswalpha_l_internal (wint_t __wc, __locale_t __locale)
|
||||
attribute_hidden;
|
||||
extern int __iswdigit_l_internal (wint_t __wc, __locale_t __locale)
|
||||
attribute_hidden;
|
||||
extern int __iswspace_l_internal (wint_t __wc, __locale_t __locale)
|
||||
attribute_hidden;
|
||||
extern int __iswxdigit_l_internal (wint_t __wc, __locale_t __locale)
|
||||
attribute_hidden;
|
||||
extern int __iswspace (wint_t __wc);
|
||||
extern int __iswctype (wint_t __wc, wctype_t __desc);
|
||||
extern int __iswctype_internal (wint_t __wc, wctype_t __desc) attribute_hidden;
|
||||
extern wctype_t __wctype (__const char *__property);
|
||||
extern wint_t __towctrans (wint_t __wc, wctrans_t __desc);
|
||||
|
||||
#ifndef NOT_IN_libc
|
||||
# define __iswalpha_l(wc, loc) INTUSE(__iswalpha_l) (wc, loc)
|
||||
# define __iswctype(wc, desc) INTUSE(__iswctype) (wc, desc)
|
||||
# define __iswdigit_l(wc, loc) INTUSE(__iswdigit_l) (wc, loc)
|
||||
# define __iswspace_l(wc, loc) INTUSE(__iswspace_l) (wc, loc)
|
||||
# define __iswxdigit_l(wc, loc) INTUSE(__iswxdigit_l) (wc, loc)
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 2000 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 2000, 2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -50,9 +50,13 @@ check_one_fd (int fd, int mode)
|
||||
int nullfd = __libc_open (_PATH_DEVNULL, mode);
|
||||
/* We are very paranoid here. With all means we try to ensure
|
||||
that we are actually opening the /dev/null device and nothing
|
||||
else. */
|
||||
if (__builtin_expect (nullfd, 0) == -1
|
||||
|| __builtin_expect (__fxstat64 (_STAT_VER, nullfd, &st), 0) != 0
|
||||
else.
|
||||
|
||||
Note that the following code assumes that STDIN_FILENO,
|
||||
STDOUT_FILENO, STDERR_FILENO are the three lowest file
|
||||
decsriptor numbers, in this order. */
|
||||
if (__builtin_expect (nullfd != fd, 0)
|
||||
|| __builtin_expect (__fxstat64 (_STAT_VER, fd, &st), 0) != 0
|
||||
|| __builtin_expect (S_ISCHR (st.st_mode), 1) == 0
|
||||
#if defined DEV_NULL_MAJOR && defined DEV_NULL_MINOR
|
||||
|| st.st_rdev != makedev (DEV_NULL_MAJOR, DEV_NULL_MINOR)
|
||||
@ -72,7 +76,7 @@ __libc_check_standard_fds (void)
|
||||
{
|
||||
/* This is really paranoid but some people actually are. If /dev/null
|
||||
should happen to be a symlink to somewhere else and not the device
|
||||
commonly known as "/dev/null" be bail out. We can detect this with
|
||||
commonly known as "/dev/null" we bail out. We can detect this with
|
||||
the O_NOFOLLOW flag for open() but only on some system. */
|
||||
#ifndef O_NOFOLLOW
|
||||
# define O_NOFOLLOW 0
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1991, 1995, 1996, 1997 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1991, 1995, 1996, 1997, 2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -21,6 +21,8 @@
|
||||
#include <stdarg.h>
|
||||
#include <stddef.h>
|
||||
|
||||
#undef __open
|
||||
|
||||
/* Open FILE with access OFLAG. If OFLAG includes O_CREAT,
|
||||
a third argument is the file protection. */
|
||||
int
|
||||
@ -49,5 +51,6 @@ __open (file, oflag)
|
||||
}
|
||||
stub_warning (open)
|
||||
|
||||
INTDEF(__open)
|
||||
weak_alias (__open, open)
|
||||
#include <stub-tag.h>
|
||||
|
@ -23,6 +23,7 @@
|
||||
#include <stdarg.h>
|
||||
#include <sys/file.h> /* XXX for LOCK_* */
|
||||
|
||||
#undef __libc_fcntl
|
||||
#undef __fcntl
|
||||
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1992,93,94,95,97,2000 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1992,93,94,95,97,2000,2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -22,6 +22,9 @@
|
||||
#include <hurd.h>
|
||||
#include <hurd/fd.h>
|
||||
|
||||
#undef __libc_open
|
||||
#undef __open
|
||||
|
||||
/* Open FILE with access OFLAG. If OFLAG includes O_CREAT,
|
||||
a third argument is the file protection. */
|
||||
int
|
||||
@ -47,5 +50,6 @@ __libc_open (const char *file, int oflag, ...)
|
||||
return _hurd_intern_fd (port, oflag, 1);
|
||||
}
|
||||
|
||||
INTDEF2(__libc_open, __open)
|
||||
weak_alias (__libc_open, __open)
|
||||
weak_alias (__libc_open, open)
|
||||
|
@ -26,7 +26,7 @@ kill - kill i:ii __kill kill
|
||||
link - link i:ss __link link
|
||||
lseek - lseek i:iii __libc_lseek __lseek lseek
|
||||
mkdir - mkdir i:si __mkdir mkdir
|
||||
open - open i:siv __libc_open __open open
|
||||
open - open i:siv __libc_open __open open __open_internal
|
||||
profil - profil i:piii profil
|
||||
ptrace - ptrace i:iiii ptrace
|
||||
read - read i:ibn __libc_read __read read
|
||||
|
@ -19,6 +19,7 @@
|
||||
#include <fcntl.h>
|
||||
#include <stdarg.h>
|
||||
|
||||
#undef __libc_fcntl
|
||||
#undef __fcntl
|
||||
|
||||
extern int kfcntl (int fdes, int cmd, unsigned long int arg);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1999, 2000 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1999, 2000, 2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -20,6 +20,9 @@
|
||||
#include <stdarg.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#undef __libc_open
|
||||
#undef __open
|
||||
|
||||
int
|
||||
__open (const char *file, int oflag, ...)
|
||||
{
|
||||
@ -36,3 +39,4 @@ __open (const char *file, int oflag, ...)
|
||||
return open (file, oflag, mode);
|
||||
}
|
||||
strong_alias (__open, __libc_open)
|
||||
INTDEF(__open)
|
||||
|
@ -25,6 +25,7 @@
|
||||
#include <sys/syscall.h>
|
||||
#include "../kernel-features.h"
|
||||
|
||||
#undef __libc_fcntl
|
||||
#undef __fcntl
|
||||
|
||||
extern int __syscall_fcntl (int __fd, int __cmd, ...);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1998, 1999, 2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -56,3 +56,4 @@ __libc_sa_len (sa_family_t af)
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
INTDEF(__libc_sa_len)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1996, 2000 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1996, 2000, 2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
Contributed by Ulrich Drepper, <drepper@gnu.ai.mit.edu>.
|
||||
|
||||
@ -22,6 +22,7 @@
|
||||
|
||||
#include "wchar-lookup.h"
|
||||
|
||||
#undef __iswctype
|
||||
|
||||
int
|
||||
__iswctype (wint_t wc, wctype_t desc)
|
||||
@ -33,4 +34,5 @@ __iswctype (wint_t wc, wctype_t desc)
|
||||
|
||||
return wctype_table_lookup ((const char *) desc, wc);
|
||||
}
|
||||
INTDEF(__iswctype)
|
||||
weak_alias (__iswctype, iswctype)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1996, 1997, 2000, 2001 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1996, 1997, 2000, 2001, 2002 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
|
||||
The GNU C Library is free software; you can redistribute it and/or
|
||||
@ -24,6 +24,11 @@
|
||||
#define USE_IN_EXTENDED_LOCALE_MODEL
|
||||
#include "wchar-lookup.h"
|
||||
|
||||
#undef __iswalpha_l
|
||||
#undef __iswdigit_l
|
||||
#undef __iswspace_l
|
||||
#undef __iswxdigit_l
|
||||
|
||||
/* Provide real-function versions of all the wctype macros. */
|
||||
|
||||
#define func(name, type) \
|
||||
@ -32,7 +37,8 @@
|
||||
size_t i = locale->__locales[LC_CTYPE]->values[_NL_ITEM_INDEX (_NL_CTYPE_CLASS_OFFSET)].word + type; \
|
||||
const char *desc = locale->__locales[LC_CTYPE]->values[i].string; \
|
||||
return wctype_table_lookup (desc, wc); \
|
||||
}
|
||||
} \
|
||||
INTDEF(name)
|
||||
|
||||
func (__iswalnum_l, __ISwalnum)
|
||||
func (__iswalpha_l, __ISwalpha)
|
||||
|
Loading…
x
Reference in New Issue
Block a user