atol and atoi get old-fashioned behaviour

This commit is contained in:
ceriel 1990-05-22 10:48:12 +00:00
parent 24c9be9777
commit ef69de1614
2 changed files with 38 additions and 15 deletions

View file

@ -4,15 +4,27 @@
*/
/* $Header$ */
#include <stdlib.h>
#include <errno.h>
#include <ctype.h>
/* We do not use strtol here for backwards compatibility in behaviour on
overflow.
*/
int
atoi(const char *nptr)
atol(register const char *nptr)
{
int i, e = errno;
int total = 0;
register unsigned int digit;
int minus = 0;
i = (int)strtol(nptr, (char **)NULL, 10);
errno = e;
return i;
while (isspace(*nptr)) nptr++;
if (*nptr == '+') nptr++;
else if (*nptr == '-') {
minus = 1;
nptr++;
}
while (isdigit(*nptr)) {
total *= 10;
total += (*nptr++ - '0');
}
return minus ? -total : total;
}

View file

@ -4,16 +4,27 @@
*/
/* $Header$ */
#include <stdlib.h>
#include <errno.h>
#include <ctype.h>
/* We do not use strtol here for backwards compatibility in behaviour on
overflow.
*/
long
atol(const char *nptr)
atol(register const char *nptr)
{
long l;
int e = errno;
long total = 0;
register unsigned int digit;
int minus = 0;
l = strtol(nptr, (char **)NULL, 10);
errno = e;
return l;
while (isspace(*nptr)) nptr++;
if (*nptr == '+') nptr++;
else if (*nptr == '-') {
minus = 1;
nptr++;
}
while (isdigit(*nptr)) {
total *= 10;
total += (*nptr++ - '0');
}
return minus ? -total : total;
}