1 /* Copyright (C) 1989, 1990, 1991 Free Software Foundation, Inc.
2 Written by James Clark (jjc@jclark.uucp)
4 This file is part of groff.
6 groff is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 1, or (at your option) any later
11 groff is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License along
17 with groff; see the file LICENSE. If not, write to the Free Software
18 Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
24 /* Not everybody has limits.h. Sigh. */
28 #define LONG_MAX INT_MAX
31 #define LONG_MIN INT_MIN
34 long strtol(str
, ptr
, base
)
42 static char digits
[] = "0123456789abcdefghijklmnopqrstuvwxyz";
44 while (isascii(*str
) && isspace(*str
))
53 if (str
[1] == 'x' || str
[1] == 'X') {
63 if (base
< 2 || base
> 36)
65 else if (base
== 16 && *str
== '0' && (str
[1] == 'x' || str
[1] == 'X'))
68 p
= strchr(digits
, isascii(*str
) && isupper(*str
) ? tolower(*str
) : *str
);
69 if (p
== 0 || (val
= (p
- digits
)) >= base
) {
70 if (base
== 16 && str
> start
&& (str
[-1] == 'x' || str
[-1] == 'X')) {
84 while (*++str
!= '\0') {
87 p
= strchr(digits
, isascii(*str
) && isupper(*str
) ? tolower(*str
) : *str
);
94 if (-(unsigned long)val
> (-(unsigned long)LONG_MIN
- n
)/base
) {
102 if (val
> (LONG_MAX
- n
)/base
) {