From 043ed1f5818681c934c1f781e5c12082c79b771c Mon Sep 17 00:00:00 2001 From: robert Date: Thu, 15 Aug 2002 09:25:04 +0000 Subject: [PATCH] - Add the 'restrict' qualifier to the function prototypes and definitions of the functions that convert strings to numbers and are defined by IEEE Std 1003-1.2001. - Use ANSI-C function definitions for all of the functions mentioned above plus strtouq and strtoq. - Update the prototypes in the manual pages. --- include/inttypes.h | 4 ++-- include/stdlib.h | 10 +++++----- lib/libc/stdlib/strtod.3 | 2 +- lib/libc/stdlib/strtod.c | 4 ++-- lib/libc/stdlib/strtoimax.c | 5 +---- lib/libc/stdlib/strtol.3 | 6 +++--- lib/libc/stdlib/strtol.c | 5 +---- lib/libc/stdlib/strtoll.c | 5 +---- lib/libc/stdlib/strtoq.c | 5 +---- lib/libc/stdlib/strtoul.3 | 6 +++--- lib/libc/stdlib/strtoul.c | 5 +---- lib/libc/stdlib/strtoull.c | 5 +---- lib/libc/stdlib/strtoumax.c | 5 +---- lib/libc/stdlib/strtouq.c | 5 +---- 14 files changed, 24 insertions(+), 48 deletions(-) diff --git a/include/inttypes.h b/include/inttypes.h index cd59bedb90f2..d2b86ddbd44a 100644 --- a/include/inttypes.h +++ b/include/inttypes.h @@ -48,9 +48,9 @@ __BEGIN_DECLS intmax_t imaxabs(intmax_t) __pure2; imaxdiv_t imaxdiv(intmax_t, intmax_t) __pure2; +intmax_t strtoimax(const char *__restrict, char **__restrict, int); +uintmax_t strtoumax(const char *__restrict, char **__restrict, int); /* XXX: The following functions are missing the restrict type qualifier. */ -intmax_t strtoimax(const char *, char **, int); -uintmax_t strtoumax(const char *, char **, int); intmax_t wcstoimax(const wchar_t *, wchar_t **, int); uintmax_t wcstoumax(const wchar_t *, wchar_t **, int); __END_DECLS diff --git a/include/stdlib.h b/include/stdlib.h index f22f1e1d70ab..c3c3cc07bd38 100644 --- a/include/stdlib.h +++ b/include/stdlib.h @@ -114,10 +114,10 @@ void qsort(void *, size_t, size_t, int rand(void); void *realloc(void *, size_t); void srand(unsigned); -double strtod(const char *, char **); -long strtol(const char *, char **, int); +double strtod(const char *__restrict, char **__restrict); +long strtol(const char *__restrict, char **__restrict, int); unsigned long - strtoul(const char *, char **, int); + strtoul(const char *__restrict, char **__restrict, int); int system(const char *); int mblen(const char *, size_t); @@ -198,13 +198,13 @@ void srandomdev(void); #ifdef __LONG_LONG_SUPPORTED /* LONGLONG */ long long - strtoll(const char *, char **, int); + strtoll(const char *__restrict, char **__restrict, int); #endif __int64_t strtoq(const char *, char **, int); #ifdef __LONG_LONG_SUPPORTED /* LONGLONG */ unsigned long long - strtoull(const char *, char **, int); + strtoull(const char *__restrict, char **__restrict, int); #endif __uint64_t strtouq(const char *, char **, int); diff --git a/lib/libc/stdlib/strtod.3 b/lib/libc/stdlib/strtod.3 index 6922e275ea17..5f3a91058a99 100644 --- a/lib/libc/stdlib/strtod.3 +++ b/lib/libc/stdlib/strtod.3 @@ -49,7 +49,7 @@ string to double .Sh SYNOPSIS .In stdlib.h .Ft double -.Fn strtod "const char *nptr" "char **endptr" +.Fn strtod "const char *restrict nptr" "char **restrict endptr" .Sh DESCRIPTION The .Fn strtod diff --git a/lib/libc/stdlib/strtod.c b/lib/libc/stdlib/strtod.c index 929558319527..73765bab9887 100644 --- a/lib/libc/stdlib/strtod.c +++ b/lib/libc/stdlib/strtod.c @@ -1191,9 +1191,9 @@ static double tinytens[] = { 1e-16, 1e-32 }; double strtod #ifdef KR_headers - (s00, se) CONST char *s00; char **se; + (s00, se) CONST char *__restrict s00; char **__restrict se; #else - (CONST char *s00, char **se) + (CONST char *__restrict s00, char **__restrict se) #endif { int bb2, bb5, bbe, bd2, bd5, bbbits, bs2, c, dsign, diff --git a/lib/libc/stdlib/strtoimax.c b/lib/libc/stdlib/strtoimax.c index 5f86e3acfc20..a41c74fc6aeb 100644 --- a/lib/libc/stdlib/strtoimax.c +++ b/lib/libc/stdlib/strtoimax.c @@ -49,10 +49,7 @@ __FBSDID("$FreeBSD$"); * alphabets and digits are each contiguous. */ intmax_t -strtoimax(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtoimax(const char *__restrict nptr, char **__restrict endptr, int base) { const char *s; uintmax_t acc; diff --git a/lib/libc/stdlib/strtol.3 b/lib/libc/stdlib/strtol.3 index 7c610f7bfec5..25acc8a94c6e 100644 --- a/lib/libc/stdlib/strtol.3 +++ b/lib/libc/stdlib/strtol.3 @@ -52,12 +52,12 @@ integer .In stdlib.h .In limits.h .Ft long -.Fn strtol "const char *nptr" "char **endptr" "int base" +.Fn strtol "const char *restrict nptr" "char **restrict endptr" "int base" .Ft long long -.Fn strtoll "const char *nptr" "char **endptr" "int base" +.Fn strtoll "const char *restrict nptr" "char **restrict endptr" "int base" .In inttypes.h .Ft intmax_t -.Fn strtoimax "const char *nptr" "char **endptr" "int base" +.Fn strtoimax "const char *restrict nptr" "char **restrict endptr" "int base" .In sys/types.h .In stdlib.h .In limits.h diff --git a/lib/libc/stdlib/strtol.c b/lib/libc/stdlib/strtol.c index 265b01edfdb6..0f9e1ed34270 100644 --- a/lib/libc/stdlib/strtol.c +++ b/lib/libc/stdlib/strtol.c @@ -50,10 +50,7 @@ __FBSDID("$FreeBSD$"); * alphabets and digits are each contiguous. */ long -strtol(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtol(const char *__restrict nptr, char **__restrict endptr, int base) { const char *s; unsigned long acc; diff --git a/lib/libc/stdlib/strtoll.c b/lib/libc/stdlib/strtoll.c index f0c245fe1e9d..3d0b5c6d095c 100644 --- a/lib/libc/stdlib/strtoll.c +++ b/lib/libc/stdlib/strtoll.c @@ -49,10 +49,7 @@ __FBSDID("$FreeBSD$"); * alphabets and digits are each contiguous. */ long long -strtoll(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtoll(const char *__restrict nptr, char **__restrict endptr, int base) { const char *s; unsigned long long acc; diff --git a/lib/libc/stdlib/strtoq.c b/lib/libc/stdlib/strtoq.c index 78c1b08f8d31..a3e37afab85f 100644 --- a/lib/libc/stdlib/strtoq.c +++ b/lib/libc/stdlib/strtoq.c @@ -45,10 +45,7 @@ __FBSDID("$FreeBSD$"); * Convert a string to a quad integer. */ quad_t -strtoq(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtoq(const char *nptr, char **endptr, int base) { return strtoll(nptr, endptr, base); diff --git a/lib/libc/stdlib/strtoul.3 b/lib/libc/stdlib/strtoul.3 index 3eb602e08fa1..dae6c135f60f 100644 --- a/lib/libc/stdlib/strtoul.3 +++ b/lib/libc/stdlib/strtoul.3 @@ -52,12 +52,12 @@ integer .In stdlib.h .In limits.h .Ft "unsigned long" -.Fn strtoul "const char *nptr" "char **endptr" "int base" +.Fn strtoul "const char *restrict nptr" "char **restrict endptr" "int base" .Ft "unsigned long long" -.Fn strtoull "const char *nptr" "char **endptr" "int base" +.Fn strtoull "const char *restrict nptr" "char **restrict endptr" "int base" .In inttypes.h .Ft uintmax_t -.Fn strtoumax "const char *nptr" "char **endptr" "int base" +.Fn strtoumax "const char *restrict nptr" "char **restrict endptr" "int base" .In sys/types.h .In stdlib.h .In limits.h diff --git a/lib/libc/stdlib/strtoul.c b/lib/libc/stdlib/strtoul.c index ba23bd03b5e8..ee54a41bd3ff 100644 --- a/lib/libc/stdlib/strtoul.c +++ b/lib/libc/stdlib/strtoul.c @@ -49,10 +49,7 @@ __FBSDID("$FreeBSD$"); * alphabets and digits are each contiguous. */ unsigned long -strtoul(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtoul(const char *__restrict nptr, char **__restrict endptr, int base) { const char *s; unsigned long acc; diff --git a/lib/libc/stdlib/strtoull.c b/lib/libc/stdlib/strtoull.c index bda9e3094a58..08bf118ad819 100644 --- a/lib/libc/stdlib/strtoull.c +++ b/lib/libc/stdlib/strtoull.c @@ -49,10 +49,7 @@ __FBSDID("$FreeBSD$"); * alphabets and digits are each contiguous. */ unsigned long long -strtoull(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtoull(const char *__restrict nptr, char **__restrict endptr, int base) { const char *s; unsigned long long acc; diff --git a/lib/libc/stdlib/strtoumax.c b/lib/libc/stdlib/strtoumax.c index 503fb6b3ae98..07206be28fa3 100644 --- a/lib/libc/stdlib/strtoumax.c +++ b/lib/libc/stdlib/strtoumax.c @@ -49,10 +49,7 @@ __FBSDID("$FreeBSD$"); * alphabets and digits are each contiguous. */ uintmax_t -strtoumax(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtoumax(const char *__restrict nptr, char **__restrict endptr, int base) { const char *s; uintmax_t acc; diff --git a/lib/libc/stdlib/strtouq.c b/lib/libc/stdlib/strtouq.c index 8b3e30e381ae..1a14f3676ae7 100644 --- a/lib/libc/stdlib/strtouq.c +++ b/lib/libc/stdlib/strtouq.c @@ -45,10 +45,7 @@ __FBSDID("$FreeBSD$"); * Convert a string to an unsigned quad integer. */ u_quad_t -strtouq(nptr, endptr, base) - const char *nptr; - char **endptr; - int base; +strtouq(const char *nptr, char **endptr, int base) { return strtoull(nptr, endptr, base);