Clean up redundancies between string.h and strings.h.
* string/string.h [__USE_MISC]: Include strings.h. (__bzero, bcmp, bcopy, bzero, index, rindex) (strcasecmp, strncasecmp, strcasecmp_l, strncasecmp_l) (ffs, ffsl, ffsll): Don't declare. * string/strings.h: Do not suppress the file if string.h has already been included. (bcmp, bcopy, bzero, strcasecmp, strncasecmp): Add __nonnull annotations. (index, rindex): Define inline forwarders even if __CORRECT_ISO_CPP_STRING_H_PROTO is defined. (ffs): Use __attribute_const__. (ffsl, ffsll): Declare here. (strcasecmp_l, strncasecmp_l): Correct comments; these functions have now been standardized. * include/string.h (__bzero): Declare here.
This commit is contained in:
parent
ab9536a75d
commit
7b037c095e
|
@ -41,6 +41,8 @@ extern void *__memrchr (const void *__s, int __c, size_t __n)
|
||||||
extern void *__memchr (const void *__s, int __c, size_t __n)
|
extern void *__memchr (const void *__s, int __c, size_t __n)
|
||||||
__attribute_pure__;
|
__attribute_pure__;
|
||||||
|
|
||||||
|
extern void __bzero (void *__s, size_t __n) __THROW __nonnull ((1));
|
||||||
|
|
||||||
extern int __ffs (int __i) __attribute__ ((const));
|
extern int __ffs (int __i) __attribute__ ((const));
|
||||||
|
|
||||||
extern char *__strerror_r (int __errnum, char *__buf, size_t __buflen);
|
extern char *__strerror_r (int __errnum, char *__buf, size_t __buflen);
|
||||||
|
|
108
string/string.h
108
string/string.h
|
@ -440,117 +440,13 @@ extern char *strerror_r (int __errnum, char *__buf, size_t __buflen)
|
||||||
extern char *strerror_l (int __errnum, __locale_t __l) __THROW;
|
extern char *strerror_l (int __errnum, __locale_t __l) __THROW;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* We define this function always since `bzero' is sometimes needed when
|
|
||||||
the namespace rules does not allow this. */
|
|
||||||
extern void __bzero (void *__s, size_t __n) __THROW __nonnull ((1));
|
|
||||||
|
|
||||||
#ifdef __USE_MISC
|
#ifdef __USE_MISC
|
||||||
/* Copy N bytes of SRC to DEST (like memmove, but args reversed). */
|
# include <strings.h>
|
||||||
extern void bcopy (const void *__src, void *__dest, size_t __n)
|
|
||||||
__THROW __nonnull ((1, 2));
|
|
||||||
|
|
||||||
/* Set N bytes of S to 0. */
|
/* Set N bytes of S to 0. The compiler will not delete a call to this
|
||||||
extern void bzero (void *__s, size_t __n) __THROW __nonnull ((1));
|
|
||||||
|
|
||||||
/* As bzero, but the compiler will not delete a call to this
|
|
||||||
function, even if S is dead after the call. */
|
function, even if S is dead after the call. */
|
||||||
extern void explicit_bzero (void *__s, size_t __n) __THROW __nonnull ((1));
|
extern void explicit_bzero (void *__s, size_t __n) __THROW __nonnull ((1));
|
||||||
|
|
||||||
/* Compare N bytes of S1 and S2 (same as memcmp). */
|
|
||||||
extern int bcmp (const void *__s1, const void *__s2, size_t __n)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2));
|
|
||||||
|
|
||||||
/* Find the first occurrence of C in S (same as strchr). */
|
|
||||||
# ifdef __CORRECT_ISO_CPP_STRING_H_PROTO
|
|
||||||
extern "C++"
|
|
||||||
{
|
|
||||||
extern char *index (char *__s, int __c)
|
|
||||||
__THROW __asm ("index") __attribute_pure__ __nonnull ((1));
|
|
||||||
extern const char *index (const char *__s, int __c)
|
|
||||||
__THROW __asm ("index") __attribute_pure__ __nonnull ((1));
|
|
||||||
|
|
||||||
# if defined __OPTIMIZE__ && !defined __CORRECT_ISO_CPP_STRINGS_H_PROTO
|
|
||||||
__extern_always_inline char *
|
|
||||||
index (char *__s, int __c) __THROW
|
|
||||||
{
|
|
||||||
return __builtin_index (__s, __c);
|
|
||||||
}
|
|
||||||
|
|
||||||
__extern_always_inline const char *
|
|
||||||
index (const char *__s, int __c) __THROW
|
|
||||||
{
|
|
||||||
return __builtin_index (__s, __c);
|
|
||||||
}
|
|
||||||
# endif
|
|
||||||
}
|
|
||||||
# else
|
|
||||||
extern char *index (const char *__s, int __c)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1));
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* Find the last occurrence of C in S (same as strrchr). */
|
|
||||||
# ifdef __CORRECT_ISO_CPP_STRING_H_PROTO
|
|
||||||
extern "C++"
|
|
||||||
{
|
|
||||||
extern char *rindex (char *__s, int __c)
|
|
||||||
__THROW __asm ("rindex") __attribute_pure__ __nonnull ((1));
|
|
||||||
extern const char *rindex (const char *__s, int __c)
|
|
||||||
__THROW __asm ("rindex") __attribute_pure__ __nonnull ((1));
|
|
||||||
|
|
||||||
# if defined __OPTIMIZE__ && !defined __CORRECT_ISO_CPP_STRINGS_H_PROTO
|
|
||||||
__extern_always_inline char *
|
|
||||||
rindex (char *__s, int __c) __THROW
|
|
||||||
{
|
|
||||||
return __builtin_rindex (__s, __c);
|
|
||||||
}
|
|
||||||
|
|
||||||
__extern_always_inline const char *
|
|
||||||
rindex (const char *__s, int __c) __THROW
|
|
||||||
{
|
|
||||||
return __builtin_rindex (__s, __c);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
# else
|
|
||||||
extern char *rindex (const char *__s, int __c)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1));
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* Return the position of the first bit set in I, or 0 if none are set.
|
|
||||||
The least-significant bit is position 1, the most-significant 32. */
|
|
||||||
extern int ffs (int __i) __THROW __attribute__ ((__const__));
|
|
||||||
|
|
||||||
/* The following two functions are non-standard but necessary for non-32 bit
|
|
||||||
platforms. */
|
|
||||||
# ifdef __USE_GNU
|
|
||||||
extern int ffsl (long int __l) __THROW __attribute__ ((__const__));
|
|
||||||
__extension__ extern int ffsll (long long int __ll)
|
|
||||||
__THROW __attribute__ ((__const__));
|
|
||||||
# endif
|
|
||||||
|
|
||||||
/* Compare S1 and S2, ignoring case. */
|
|
||||||
extern int strcasecmp (const char *__s1, const char *__s2)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2));
|
|
||||||
|
|
||||||
/* Compare no more than N chars of S1 and S2, ignoring case. */
|
|
||||||
extern int strncasecmp (const char *__s1, const char *__s2, size_t __n)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2));
|
|
||||||
#endif /* Use misc. */
|
|
||||||
|
|
||||||
#ifdef __USE_GNU
|
|
||||||
/* Again versions of a few functions which use the given locale instead
|
|
||||||
of the global one. */
|
|
||||||
extern int strcasecmp_l (const char *__s1, const char *__s2,
|
|
||||||
__locale_t __loc)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2, 3));
|
|
||||||
|
|
||||||
extern int strncasecmp_l (const char *__s1, const char *__s2,
|
|
||||||
size_t __n, __locale_t __loc)
|
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2, 4));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __USE_MISC
|
|
||||||
/* Return the next DELIM-delimited token from *STRINGP,
|
/* Return the next DELIM-delimited token from *STRINGP,
|
||||||
terminating it with a '\0', and update *STRINGP to point past it. */
|
terminating it with a '\0', and update *STRINGP to point past it. */
|
||||||
extern char *strsep (char **__restrict __stringp,
|
extern char *strsep (char **__restrict __stringp,
|
||||||
|
|
|
@ -18,32 +18,28 @@
|
||||||
#ifndef _STRINGS_H
|
#ifndef _STRINGS_H
|
||||||
#define _STRINGS_H 1
|
#define _STRINGS_H 1
|
||||||
|
|
||||||
/* We don't need and should not read this file if <string.h> was already
|
#include <features.h>
|
||||||
read. The one exception being that if __USE_MISC isn't defined, then
|
#define __need_size_t
|
||||||
these aren't defined in string.h, so we need to define them here. */
|
#include <stddef.h>
|
||||||
#if !defined _STRING_H || !defined __USE_MISC
|
|
||||||
|
|
||||||
# include <features.h>
|
|
||||||
# define __need_size_t
|
|
||||||
# include <stddef.h>
|
|
||||||
|
|
||||||
/* Tell the caller that we provide correct C++ prototypes. */
|
/* Tell the caller that we provide correct C++ prototypes. */
|
||||||
# if defined __cplusplus && __GNUC_PREREQ (4, 4)
|
#if defined __cplusplus && __GNUC_PREREQ (4, 4)
|
||||||
# define __CORRECT_ISO_CPP_STRINGS_H_PROTO
|
# define __CORRECT_ISO_CPP_STRINGS_H_PROTO
|
||||||
# endif
|
#endif
|
||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
# if defined __USE_MISC || !defined __USE_XOPEN2K8
|
#if defined __USE_MISC || !defined __USE_XOPEN2K8
|
||||||
/* Compare N bytes of S1 and S2 (same as memcmp). */
|
/* Compare N bytes of S1 and S2 (same as memcmp). */
|
||||||
extern int bcmp (const void *__s1, const void *__s2, size_t __n)
|
extern int bcmp (const void *__s1, const void *__s2, size_t __n)
|
||||||
__THROW __attribute_pure__;
|
__THROW __attribute_pure__ __nonnull ((1, 2));
|
||||||
|
|
||||||
/* Copy N bytes of SRC to DEST (like memmove, but args reversed). */
|
/* Copy N bytes of SRC to DEST (like memmove, but args reversed). */
|
||||||
extern void bcopy (const void *__src, void *__dest, size_t __n) __THROW;
|
extern void bcopy (const void *__src, void *__dest, size_t __n)
|
||||||
|
__THROW __nonnull ((1, 2));
|
||||||
|
|
||||||
/* Set N bytes of S to 0. */
|
/* Set N bytes of S to 0. */
|
||||||
extern void bzero (void *__s, size_t __n) __THROW;
|
extern void bzero (void *__s, size_t __n) __THROW __nonnull ((1));
|
||||||
|
|
||||||
/* Find the first occurrence of C in S (same as strchr). */
|
/* Find the first occurrence of C in S (same as strchr). */
|
||||||
# ifdef __CORRECT_ISO_CPP_STRINGS_H_PROTO
|
# ifdef __CORRECT_ISO_CPP_STRINGS_H_PROTO
|
||||||
|
@ -54,7 +50,7 @@ extern char *index (char *__s, int __c)
|
||||||
extern const char *index (const char *__s, int __c)
|
extern const char *index (const char *__s, int __c)
|
||||||
__THROW __asm ("index") __attribute_pure__ __nonnull ((1));
|
__THROW __asm ("index") __attribute_pure__ __nonnull ((1));
|
||||||
|
|
||||||
# if defined __OPTIMIZE__ && !defined __CORRECT_ISO_CPP_STRING_H_PROTO
|
# if defined __OPTIMIZE__
|
||||||
__extern_always_inline char *
|
__extern_always_inline char *
|
||||||
index (char *__s, int __c) __THROW
|
index (char *__s, int __c) __THROW
|
||||||
{
|
{
|
||||||
|
@ -82,7 +78,7 @@ extern char *rindex (char *__s, int __c)
|
||||||
extern const char *rindex (const char *__s, int __c)
|
extern const char *rindex (const char *__s, int __c)
|
||||||
__THROW __asm ("rindex") __attribute_pure__ __nonnull ((1));
|
__THROW __asm ("rindex") __attribute_pure__ __nonnull ((1));
|
||||||
|
|
||||||
# if defined __OPTIMIZE__ && !defined __CORRECT_ISO_CPP_STRING_H_PROTO
|
# if defined __OPTIMIZE__
|
||||||
__extern_always_inline char *
|
__extern_always_inline char *
|
||||||
rindex (char *__s, int __c) __THROW
|
rindex (char *__s, int __c) __THROW
|
||||||
{
|
{
|
||||||
|
@ -100,33 +96,39 @@ rindex (const char *__s, int __c) __THROW
|
||||||
extern char *rindex (const char *__s, int __c)
|
extern char *rindex (const char *__s, int __c)
|
||||||
__THROW __attribute_pure__ __nonnull ((1));
|
__THROW __attribute_pure__ __nonnull ((1));
|
||||||
# endif
|
# endif
|
||||||
# endif
|
#endif
|
||||||
|
|
||||||
#if defined __USE_MISC || !defined __USE_XOPEN2K8 || defined __USE_XOPEN2K8XSI
|
#if defined __USE_MISC || !defined __USE_XOPEN2K8 || defined __USE_XOPEN2K8XSI
|
||||||
/* Return the position of the first bit set in I, or 0 if none are set.
|
/* Return the position of the first bit set in I, or 0 if none are set.
|
||||||
The least-significant bit is position 1, the most-significant 32. */
|
The least-significant bit is position 1, the most-significant 32. */
|
||||||
extern int ffs (int __i) __THROW __attribute__ ((const));
|
extern int ffs (int __i) __THROW __attribute_const__;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* The following two functions are non-standard but necessary for non-32 bit
|
||||||
|
platforms. */
|
||||||
|
# ifdef __USE_GNU
|
||||||
|
extern int ffsl (long int __l) __THROW __attribute_const__;
|
||||||
|
__extension__ extern int ffsll (long long int __ll)
|
||||||
|
__THROW __attribute_const__;
|
||||||
|
# endif
|
||||||
|
|
||||||
/* Compare S1 and S2, ignoring case. */
|
/* Compare S1 and S2, ignoring case. */
|
||||||
extern int strcasecmp (const char *__s1, const char *__s2)
|
extern int strcasecmp (const char *__s1, const char *__s2)
|
||||||
__THROW __attribute_pure__;
|
__THROW __attribute_pure__ __nonnull ((1, 2));
|
||||||
|
|
||||||
/* Compare no more than N chars of S1 and S2, ignoring case. */
|
/* Compare no more than N chars of S1 and S2, ignoring case. */
|
||||||
extern int strncasecmp (const char *__s1, const char *__s2, size_t __n)
|
extern int strncasecmp (const char *__s1, const char *__s2, size_t __n)
|
||||||
__THROW __attribute_pure__;
|
__THROW __attribute_pure__ __nonnull ((1, 2));
|
||||||
|
|
||||||
#ifdef __USE_XOPEN2K8
|
#ifdef __USE_XOPEN2K8
|
||||||
/* The following functions are equivalent to the both above but they
|
|
||||||
take the locale they use for the collation as an extra argument.
|
|
||||||
This is not standardsized but something like will come. */
|
|
||||||
# include <xlocale.h>
|
# include <xlocale.h>
|
||||||
|
|
||||||
/* Again versions of a few functions which use the given locale instead
|
/* Compare S1 and S2, ignoring case, using collation rules from LOC. */
|
||||||
of the global one. */
|
|
||||||
extern int strcasecmp_l (const char *__s1, const char *__s2, __locale_t __loc)
|
extern int strcasecmp_l (const char *__s1, const char *__s2, __locale_t __loc)
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2, 3));
|
__THROW __attribute_pure__ __nonnull ((1, 2, 3));
|
||||||
|
|
||||||
|
/* Compare no more than N chars of S1 and S2, ignoring case, using
|
||||||
|
collation rules from LOC. */
|
||||||
extern int strncasecmp_l (const char *__s1, const char *__s2,
|
extern int strncasecmp_l (const char *__s1, const char *__s2,
|
||||||
size_t __n, __locale_t __loc)
|
size_t __n, __locale_t __loc)
|
||||||
__THROW __attribute_pure__ __nonnull ((1, 2, 4));
|
__THROW __attribute_pure__ __nonnull ((1, 2, 4));
|
||||||
|
@ -134,8 +136,6 @@ extern int strncasecmp_l (const char *__s1, const char *__s2,
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|
||||||
#endif /* string.h */
|
|
||||||
|
|
||||||
#if __GNUC_PREREQ (3,4) && __USE_FORTIFY_LEVEL > 0 \
|
#if __GNUC_PREREQ (3,4) && __USE_FORTIFY_LEVEL > 0 \
|
||||||
&& defined __fortify_function
|
&& defined __fortify_function
|
||||||
/* Functions with security checks. */
|
/* Functions with security checks. */
|
||||||
|
|
Loading…
Reference in New Issue