1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
|
/* Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
*/
#include <ctype.h>
#include <string.h>
#define import_spp
#define import_libc
#include <iraf.h>
#define tointeg(c) ((c)-'0')
/* ATOL -- Ascii to long integer. Convert a simple integer in decimal radix to
** a binary long integer value.
*/
long
atol (char *str)
{
register char *ip = str;
register int ch;
register long lval;
int neg;
if (*str == EOS)
return (0);
/* Skip leading whitespace. */
while (isspace (*ip))
ip++;
/* Check for indefinite. */
if ((ch = *--ip) == 'I')
if (strncmp (ip, "INDEF", 5) == 0)
if (! (isalnum (ch = *(ip+5)) || ch == '_'))
return (INDEFL);
/* Check for leading + or - sign. */
neg = 0;
if (ch == '-') {
neg++;
ip++;
} else if (ch == '+')
ip++;
/* Accumulate sequence of digits. */
lval = 0;
while (isdigit (ch = *ip++))
lval = lval * 10 + tointeg(ch);
return (neg ? -lval : lval);
}
|