diff --git a/newlib/ChangeLog b/newlib/ChangeLog index 71856f586..894fe5c34 100644 --- a/newlib/ChangeLog +++ b/newlib/ChangeLog @@ -1,3 +1,22 @@ +2001-10-01 Charles Wilson + + * libc/include/stdlib.h: add declarations for + _strtoull_r, _strtoll_r, strtoull, and strtoll. + * libc/stdio/local.h: remove declarations of + __strtoull_r and __strtoll_r. + * libc/stdio/vfscanf.c(__svfscanf_r): call + _strtoull_r instead of __strtoull_r. Ditto + _strtoll_r vs. __strtoll_r. + * libc/stdlib/Makefile.am: add new files to + .c list and .def list + * libc/stdlib/Makefile.in: regenerate + * libc/stdlib/strtoll_r.c: rename __strtoll_r + as _strtoll_r + * libc/stdlib/strtoull_r.c: rename __strtoull_r + as _strtoull_r + * libc/stdlib/strtoull.c: new file + * libc/stdlib/strtoll.c: new file + Mon Sep 17 17:29:47 2001 Christopher Faylor * libc/include/process.h: Add getpid() declaration. diff --git a/newlib/libc/include/stdlib.h b/newlib/libc/include/stdlib.h index a6f1041e7..3932584c7 100644 --- a/newlib/libc/include/stdlib.h +++ b/newlib/libc/include/stdlib.h @@ -88,15 +88,16 @@ _VOID _EXFUN(qsort,(_PTR __base, size_t __nmemb, size_t __size, int(*_compar)(co int _EXFUN(rand,(_VOID)); _PTR _EXFUN(realloc,(_PTR __r, size_t __size)); _VOID _EXFUN(srand,(unsigned __seed)); -double _EXFUN(strtod,(const char *__n, char **_end_PTR)); -double _EXFUN(_strtod_r,(struct _reent *,const char *__n, char **_end_PTR)); +double _EXFUN(strtod,(const char *__n, char **__end_PTR)); +double _EXFUN(_strtod_r,(struct _reent *,const char *__n, char **__end_PTR)); #ifndef __STRICT_ANSI__ -float _EXFUN(strtodf,(const char *__n, char **_end_PTR)); +float _EXFUN(strtodf,(const char *__n, char **__end_PTR)); #endif -long _EXFUN(strtol,(const char *__n, char **_end_PTR, int __base)); -long _EXFUN(_strtol_r,(struct _reent *,const char *__n, char **_end_PTR, int __base)); -unsigned long _EXFUN(strtoul,(const char *_n_PTR, char **_end_PTR, int __base)); -unsigned long _EXFUN(_strtoul_r,(struct _reent *,const char *_n_PTR, char **_end_PTR, int __base)); +long _EXFUN(strtol,(const char *__n, char **__end_PTR, int __base)); +long _EXFUN(_strtol_r,(struct _reent *,const char *__n, char **__end_PTR, int __base)); +unsigned long _EXFUN(strtoul,(const char *__n, char **__end_PTR, int __base)); +unsigned long _EXFUN(_strtoul_r,(struct _reent *,const char *__n, char **__end_PTR, int __base)); + int _EXFUN(system,(const char *__string)); #ifndef __STRICT_ANSI__ @@ -136,6 +137,10 @@ unsigned short * _EXFUN(_seed48_r,(struct _reent *, unsigned short [3])); _VOID _EXFUN(srand48,(long)); _VOID _EXFUN(_srand48_r,(struct _reent *, long)); +long long _EXFUN(strtoll,(const char *__n, char **__end_PTR, int __base)); +long long _EXFUN(_strtoll_r,(struct _reent *, const char *__n, char **__end_PTR, int __base)); +unsigned long long _EXFUN(strtoull,(const char *__n, char **__end_PTR, int __base)); +unsigned long long _EXFUN(_strtoull_r,(struct _reent *, const char *__n, char **__end_PTR, int __base)); #ifndef __CYGWIN__ _VOID _EXFUN(cfree,(_PTR)); diff --git a/newlib/libc/stdio/local.h b/newlib/libc/stdio/local.h index d8ae29d9f..8b55503c8 100644 --- a/newlib/libc/stdio/local.h +++ b/newlib/libc/stdio/local.h @@ -86,12 +86,6 @@ char *_EXFUN(_licvt,(char *, long, char)); char *_EXFUN(_llicvt,(char *, long long, char)); #endif -/* The following are found in the stdlib directory, not here */ -#ifdef __GNUC__ -long long _EXFUN(__strtoll_r,(struct _reent *, const char *, char **, int)); -unsigned long long _EXFUN(__strtoull_r,(struct _reent *, const char *, char **, int)); -#endif - #define CVT_BUF_SIZE 128 #define NDYNAMIC 4 /* add four more whenever necessary */ diff --git a/newlib/libc/stdio/vfscanf.c b/newlib/libc/stdio/vfscanf.c index 313a6b85b..8f49141f1 100644 --- a/newlib/libc/stdio/vfscanf.c +++ b/newlib/libc/stdio/vfscanf.c @@ -822,9 +822,9 @@ __svfscanf_r (rptr, fp, fmt0, ap) { u_long_long resll; if (ccfn == _strtoul_r) - resll = __strtoull_r (rptr, buf, (char **) NULL, base); + resll = _strtoull_r (rptr, buf, (char **) NULL, base); else - resll = __strtoll_r (rptr, buf, (char **) NULL, base); + resll = _strtoll_r (rptr, buf, (char **) NULL, base); llp = va_arg (ap, long long*); *llp = resll; } diff --git a/newlib/libc/stdlib/Makefile.am b/newlib/libc/stdlib/Makefile.am index 1d41fe15f..8bf5b8e8b 100644 --- a/newlib/libc/stdlib/Makefile.am +++ b/newlib/libc/stdlib/Makefile.am @@ -70,8 +70,10 @@ lib_a_SOURCES = \ strdup_r.c \ strtod.c \ strtol.c \ + strtoll.c \ strtoll_r.c \ strtoul.c \ + strtoull.c \ strtoull_r.c \ system.c \ valloc.c \ @@ -150,7 +152,9 @@ CHEWOUT_FILES= \ rand48.def \ strtod.def \ strtol.def \ + strtoll.def \ strtoul.def \ + strtoull.def \ system.def \ wcstombs.def \ wctomb.def diff --git a/newlib/libc/stdlib/Makefile.in b/newlib/libc/stdlib/Makefile.in index f7d1879ac..a955fb087 100644 --- a/newlib/libc/stdlib/Makefile.in +++ b/newlib/libc/stdlib/Makefile.in @@ -152,8 +152,10 @@ lib_a_SOURCES = \ strdup_r.c \ strtod.c \ strtol.c \ + strtoll.c \ strtoll_r.c \ strtoul.c \ + strtoull.c \ strtoull_r.c \ system.c \ valloc.c \ @@ -198,7 +200,9 @@ CHEWOUT_FILES = \ rand48.def \ strtod.def \ strtol.def \ + strtoll.def \ strtoul.def \ + strtoull.def \ system.def \ wcstombs.def \ wctomb.def @@ -231,9 +235,9 @@ labs.o lcong48.o ldiv.o ldtoa.o lrand48.o malign.o malloc.o mblen.o \ mblen_r.o mbstowcs.o mbstowcs_r.o mbtowc.o mbtowc_r.o mlock.o mprec.o \ mrand48.o msize.o mstats.o mtrim.o nrand48.o putenv.o putenv_r.o \ qsort.o rand.o rand48.o rand_r.o realloc.o seed48.o setenv.o setenv_r.o \ -srand48.o strdup.o strdup_r.o strtod.o strtol.o strtoll_r.o strtoul.o \ -strtoull_r.o system.o valloc.o wcstombs.o wcstombs_r.o wctomb.o \ -wctomb_r.o +srand48.o strdup.o strdup_r.o strtod.o strtol.o strtoll.o strtoll_r.o \ +strtoul.o strtoull.o strtoull_r.o system.o valloc.o wcstombs.o \ +wcstombs_r.o wctomb.o wctomb_r.o CFLAGS = @CFLAGS@ COMPILE = $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) CCLD = $(CC) diff --git a/newlib/libc/stdlib/strtoll.c b/newlib/libc/stdlib/strtoll.c new file mode 100644 index 000000000..fdba09f24 --- /dev/null +++ b/newlib/libc/stdlib/strtoll.c @@ -0,0 +1,138 @@ +/* +FUNCTION + <>---string to long long + +INDEX + strtoll +INDEX + _strtoll_r + +ANSI_SYNOPSIS + #include + long long strtoll(const char *<[s]>, char **<[ptr]>,int <[base]>); + + long long _strtoll_r(void *<[reent]>, + const char *<[s]>, char **<[ptr]>,int <[base]>); + +TRAD_SYNOPSIS + #include + long strtoll (<[s]>, <[ptr]>, <[base]>) + char *<[s]>; + char **<[ptr]>; + int <[base]>; + + long _strtoll_r (<[reent]>, <[s]>, <[ptr]>, <[base]>) + char *<[reent]>; + char *<[s]>; + char **<[ptr]>; + int <[base]>; + +DESCRIPTION +The function <> converts the string <<*<[s]>>> to +a <>. First, it breaks down the string into three parts: +leading whitespace, which is ignored; a subject string consisting +of characters resembling an integer in the radix specified by <[base]>; +and a trailing portion consisting of zero or more unparseable characters, +and always including the terminating null character. Then, it attempts +to convert the subject string into a <> and returns the +result. + +If the value of <[base]> is 0, the subject string is expected to look +like a normal C integer constant: an optional sign, a possible `<<0x>>' +indicating a hexadecimal base, and a number. If <[base]> is between +2 and 36, the expected form of the subject is a sequence of letters +and digits representing an integer in the radix specified by <[base]>, +with an optional plus or minus sign. The letters <>--<> (or, +equivalently, <>--<>) are used to signify values from 10 to 35; +only letters whose ascribed values are less than <[base]> are +permitted. If <[base]> is 16, a leading <<0x>> is permitted. + +The subject sequence is the longest initial sequence of the input +string that has the expected form, starting with the first +non-whitespace character. If the string is empty or consists entirely +of whitespace, or if the first non-whitespace character is not a +permissible letter or digit, the subject string is empty. + +If the subject string is acceptable, and the value of <[base]> is zero, +<> attempts to determine the radix from the input string. A +string with a leading <<0x>> is treated as a hexadecimal value; a string with +a leading 0 and no <> is treated as octal; all other strings are +treated as decimal. If <[base]> is between 2 and 36, it is used as the +conversion radix, as described above. If the subject string begins with +a minus sign, the value is negated. Finally, a pointer to the first +character past the converted subject string is stored in <[ptr]>, if +<[ptr]> is not <>. + +If the subject string is empty (or not in acceptable form), no conversion +is performed and the value of <[s]> is stored in <[ptr]> (if <[ptr]> is +not <>). + +The alternate function <<_strtoll_r>> is a reentrant version. The +extra argument <[reent]> is a pointer to a reentrancy structure. + +RETURNS +<> returns the converted value, if any. If no conversion was +made, 0 is returned. + +<> returns <> or <> if the magnitude of +the converted value is too large, and sets <> to <>. + +PORTABILITY +<> is nonstandard. + +No supporting OS subroutines are required. +*/ + +/*- + * Copyright (c) 1990 The Regents of the University of California. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by the University of + * California, Berkeley and its contributors. + * 4. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + + +#include <_ansi.h> +#include +#include +#include +#include +#include + +#ifndef _REENT_ONLY + +long long +_DEFUN (strtoll, (s, ptr, base), + _CONST char *s _AND + char **ptr _AND + int base) +{ + return _strtoll_r (_REENT, s, ptr, base); +} + +#endif diff --git a/newlib/libc/stdlib/strtoll_r.c b/newlib/libc/stdlib/strtoll_r.c index 6181507a3..b814f68be 100644 --- a/newlib/libc/stdlib/strtoll_r.c +++ b/newlib/libc/stdlib/strtoll_r.c @@ -2,7 +2,7 @@ This code is based on strtoul.c which has the following copyright. It is used to convert a string into a signed long long. - long long __strtoll_r (struct _reent *rptr, const char *s, + long long _strtoll_r (struct _reent *rptr, const char *s, char **ptr, int base); */ @@ -56,7 +56,7 @@ * alphabets and digits are each contiguous. */ long long -_DEFUN (__strtoll_r, (rptr, nptr, endptr, base), +_DEFUN (_strtoll_r, (rptr, nptr, endptr, base), struct _reent *rptr _AND _CONST char *nptr _AND char **endptr _AND diff --git a/newlib/libc/stdlib/strtoull.c b/newlib/libc/stdlib/strtoull.c new file mode 100644 index 000000000..f7ab963a0 --- /dev/null +++ b/newlib/libc/stdlib/strtoull.c @@ -0,0 +1,139 @@ +/* +FUNCTION + <>---string to unsigned long long + +INDEX + strtoull +INDEX + _strtoull_r + +ANSI_SYNOPSIS + #include + unsigned long long strtoull(const char *<[s]>, char **<[ptr]>, + int <[base]>); + + unsigned long long _strtoull_r(void *<[reent]>, const char *<[s]>, + char **<[ptr]>, int <[base]>); + +TRAD_SYNOPSIS + #include + unsigned long long strtoull(<[s]>, <[ptr]>, <[base]>) + char *<[s]>; + char **<[ptr]>; + int <[base]>; + + unsigned long long _strtoull_r(<[reent]>, <[s]>, <[ptr]>, <[base]>) + char *<[reent]>; + char *<[s]>; + char **<[ptr]>; + int <[base]>; + +DESCRIPTION +The function <> converts the string <<*<[s]>>> to +an <>. First, it breaks down the string into three parts: +leading whitespace, which is ignored; a subject string consisting +of the digits meaningful in the radix specified by <[base]> +(for example, <<0>> through <<7>> if the value of <[base]> is 8); +and a trailing portion consisting of one or more unparseable characters, +which always includes the terminating null character. Then, it attempts +to convert the subject string into an unsigned long long integer, and returns the +result. + +If the value of <[base]> is zero, the subject string is expected to look +like a normal C integer constant (save that no optional sign is permitted): +a possible <<0x>> indicating hexadecimal radix, and a number. +If <[base]> is between 2 and 36, the expected form of the subject is a +sequence of digits (which may include letters, depending on the +base) representing an integer in the radix specified by <[base]>. +The letters <>--<> (or <>--<>) are used as digits valued from +10 to 35. If <[base]> is 16, a leading <<0x>> is permitted. + +The subject sequence is the longest initial sequence of the input +string that has the expected form, starting with the first +non-whitespace character. If the string is empty or consists entirely +of whitespace, or if the first non-whitespace character is not a +permissible digit, the subject string is empty. + +If the subject string is acceptable, and the value of <[base]> is zero, +<> attempts to determine the radix from the input string. A +string with a leading <<0x>> is treated as a hexadecimal value; a string with +a leading <<0>> and no <> is treated as octal; all other strings are +treated as decimal. If <[base]> is between 2 and 36, it is used as the +conversion radix, as described above. Finally, a pointer to the first +character past the converted subject string is stored in <[ptr]>, if +<[ptr]> is not <>. + +If the subject string is empty (that is, if <<*>><[s]> does not start +with a substring in acceptable form), no conversion +is performed and the value of <[s]> is stored in <[ptr]> (if <[ptr]> is +not <>). + +The alternate function <<_strtoull_r>> is a reentrant version. The +extra argument <[reent]> is a pointer to a reentrancy structure. + + +RETURNS +<> returns the converted value, if any. If no conversion was +made, <<0>> is returned. + +<> returns <> if the magnitude of the converted +value is too large, and sets <> to <>. + +PORTABILITY +<> is nonstandard. + +<> requires no supporting OS subroutines. +*/ + +/* + * Copyright (c) 1990 Regents of the University of California. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by the University of + * California, Berkeley and its contributors. + * 4. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#include <_ansi.h> +#include +#include +#include +#include +#include + +#ifndef _REENT_ONLY + +unsigned long long +_DEFUN (strtoull, (s, ptr, base), + _CONST char *s _AND + char **ptr _AND + int base) +{ + return _strtoull_r (_REENT, s, ptr, base); +} + +#endif diff --git a/newlib/libc/stdlib/strtoull_r.c b/newlib/libc/stdlib/strtoull_r.c index 014e4b649..d8a86b3f4 100644 --- a/newlib/libc/stdlib/strtoull_r.c +++ b/newlib/libc/stdlib/strtoull_r.c @@ -2,7 +2,7 @@ This code is based on strtoul.c which has the following copyright. It is used to convert a string into an unsigned long long. - long long __strtoull_r (struct _reent *rptr, const char *s, + long long _strtoull_r (struct _reent *rptr, const char *s, char **ptr, int base); */ @@ -57,7 +57,7 @@ * alphabets and digits are each contiguous. */ unsigned long long -_DEFUN (__strtoull_r, (rptr, nptr, endptr, base), +_DEFUN (_strtoull_r, (rptr, nptr, endptr, base), struct _reent *rptr _AND _CONST char *nptr _AND char **endptr _AND