xref: /netbsd-src/lib/libc/stdlib/strtol.3 (revision 946379e7b37692fc43f68eb0d1c10daa0a7f3b6c)
1.\"	$NetBSD: strtol.3,v 1.35 2015/11/13 16:00:32 christos Exp $
2.\"
3.\" Copyright (c) 1990, 1991, 1993
4.\"	The Regents of the University of California.  All rights reserved.
5.\"
6.\" This code is derived from software contributed to Berkeley by
7.\" Chris Torek and the American National Standards Committee X3,
8.\" on Information Processing Systems.
9.\"
10.\" Redistribution and use in source and binary forms, with or without
11.\" modification, are permitted provided that the following conditions
12.\" are met:
13.\" 1. Redistributions of source code must retain the above copyright
14.\"    notice, this list of conditions and the following disclaimer.
15.\" 2. Redistributions in binary form must reproduce the above copyright
16.\"    notice, this list of conditions and the following disclaimer in the
17.\"    documentation and/or other materials provided with the distribution.
18.\" 3. Neither the name of the University nor the names of its contributors
19.\"    may be used to endorse or promote products derived from this software
20.\"    without specific prior written permission.
21.\"
22.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32.\" SUCH DAMAGE.
33.\"
34.\"     from: @(#)strtol.3	8.1 (Berkeley) 6/4/93
35.\"
36.Dd November 13, 2015
37.Dt STRTOL 3
38.Os
39.Sh NAME
40.Nm strtol ,
41.Nm strtoll ,
42.Nm strtoimax ,
43.Nm strtoq
44.Nd convert string value to a long, long long, intmax_t or quad_t integer
45.Sh LIBRARY
46.Lb libc
47.Sh SYNOPSIS
48.In stdlib.h
49.In limits.h
50.Ft long int
51.Fn strtol "const char * restrict nptr" "char ** restrict endptr" "int base"
52.Ft long long int
53.Fn strtoll "const char * restrict nptr" "char ** restrict endptr" "int base"
54.Pp
55.In inttypes.h
56.Ft intmax_t
57.Fn strtoimax "const char * restrict nptr" "char ** restrict endptr" "int base"
58.Pp
59.In sys/types.h
60.In stdlib.h
61.In limits.h
62.Ft quad_t
63.Fn strtoq "const char * restrict nptr" "char ** restrict endptr" "int base"
64.Sh DESCRIPTION
65The
66.Fn strtol
67function
68converts the string in
69.Fa nptr
70to a
71.Ft long int
72value.
73The
74.Fn strtoll
75function
76converts the string in
77.Fa nptr
78to a
79.Ft long long int
80value.
81The
82.Fn strtoimax
83function
84converts the string in
85.Fa nptr
86to an
87.Ft intmax_t
88value.
89The
90.Fn strtoq
91function
92converts the string in
93.Fa nptr
94to a
95.Ft quad_t
96value.
97.Pp
98The conversion is done according to the given
99.Fa base ,
100which must be between 2 and 36 inclusive,
101or be the special value 0.
102.Pp
103The string may begin with an arbitrary amount of white space
104(as determined by
105.Xr isspace 3 )
106followed by a single optional
107.Ql +
108or
109.Ql -
110sign.
111If
112.Fa base
113is zero or 16,
114the string may then include a
115.Ql 0x
116or
117.Ql 0X
118prefix,
119and the number will be read in base 16; otherwise,
120.\" if the
121.\" .Fa base
122.\" is zero or 2,
123.\" the string may then include a
124.\" .Ql 0b
125.\" or
126.\" .Ql 0B
127.\" prefix,
128.\" and the number will be read in base 2; otherwise,
129a zero
130.Fa base
131is taken as 10 (decimal) unless the next character is
132.Ql 0 ,
133in which case it is taken as 8 (octal).
134.Pp
135The remainder of the string is converted to an appropriate value
136in the obvious manner,
137stopping at the first character which is not a valid digit in the given base.
138(In bases above 10, the letter
139.Ql A
140in either upper or lower case
141represents 10,
142.Ql B
143represents 11, and so forth, with
144.Ql Z
145representing 35.)
146.Pp
147If
148.Fa endptr
149is non-nil, the functions store the address of the first invalid character in
150.Fa *endptr .
151If there were no digits at all, however,
152the functions store the original value of
153.Fa nptr
154in
155.Fa *endptr .
156(Thus, if
157.Fa *nptr
158is not
159.Ql \e0
160but
161.Fa **endptr
162is
163.Ql \e0
164on return, the entire string was valid.)
165.Sh RETURN VALUES
166The
167.Fn strtol
168function
169returns the result of the conversion,
170unless the value would underflow or overflow.
171If an underflow occurs,
172.Fn strtol
173returns
174.Dv LONG_MIN ,
175.Fn strtoll
176returns
177.Dv LLONG_MIN ,
178and
179.Fn strtoimax
180returns
181.Dv INTMAX_MIN .
182If an overflow occurs,
183.Fn strtol
184returns
185.Dv LONG_MAX ,
186.Fn strtoll
187returns
188.Dv LLONG_MAX ,
189and
190.Fn strtoimax
191returns
192.Dv INTMAX_MAX .
193In these cases,
194.Va errno
195is set to
196.Er ERANGE .
197If the
198.Fa base
199argument is not supported then
200.Va errno
201is set to
202.Er EINVAL
203and the functions return 0.
204.Pp
205If no error occurs,
206.Va errno
207is left unchanged.
208This behavior (which is unlike most library functions) is guaranteed
209by the pertinent standards.
210.Sh EXAMPLES
211Because the return value of
212.Fn strtol
213cannot be used unambiguously to detect an error,
214.Va errno
215is left unchanged after a successful call.
216To ensure that a string is a valid number (i.e., in range and containing no
217trailing characters), clear
218.Va errno
219beforehand explicitly, then check it afterwards:
220.Bd -literal -offset indent
221char *ep;
222long lval;
223
224\&...
225
226errno = 0;
227lval = strtol(buf, \*[Am]ep, 10);
228if (buf[0] == '\e0' || *ep != '\e0')
229	goto not_a_number;
230if (errno == ERANGE \*[Am]\*[Am] (lval == LONG_MAX || lval == LONG_MIN))
231	goto out_of_range;
232.Ed
233.Pp
234This example will accept
235.Dq 12
236but not
237.Dq 12foo
238or
239.Dq 12\en .
240If trailing whitespace is acceptable, further checks must be done on
241.Va *ep ;
242alternately, use
243.Xr sscanf 3 .
244.Pp
245If
246.Fn strtol
247is being used instead of
248.Xr atoi 3 ,
249error checking is further complicated because the desired return value is an
250.Li int
251rather than a
252.Li long ;
253however, on some architectures integers and long integers are the same size.
254Thus the following is necessary:
255.Bd -literal -offset indent
256char *ep;
257int ival;
258long lval;
259
260\&...
261
262errno = 0;
263lval = strtol(buf, \*[Am]ep, 10);
264if (buf[0] == '\e0' || *ep != '\e0')
265	goto not_a_number;
266if ((errno == ERANGE \*[Am]\*[Am] (lval == LONG_MAX || lval == LONG_MIN)) ||
267    (lval \*[Gt] INT_MAX || lval \*[Lt] INT_MIN))
268	goto out_of_range;
269ival = lval;
270.Ed
271.Sh ERRORS
272.Bl -tag -width Er
273.It Bq Er EINVAL
274The
275.Ar base
276is not between 2 and 36 and does not contain the special value 0.
277.It Bq Er ERANGE
278The given string was out of range; the value converted has been clamped.
279.El
280.Sh SEE ALSO
281.Xr atof 3 ,
282.Xr atoi 3 ,
283.Xr atol 3 ,
284.Xr atoll 3 ,
285.Xr strtod 3 ,
286.Xr strtou 3 ,
287.Xr strtoul 3 ,
288.Xr strtoull 3 ,
289.Xr strtoumax 3
290.Sh STANDARDS
291The
292.Fn strtol
293function
294conforms to
295.St -ansiC .
296The
297.Fn strtoll
298and
299.Fn strtoimax
300functions conform to
301.St -isoC-99 .
302.Pp
303The
304.Fn strtoq
305function is a
306.Bx
307legacy function equivalent to
308.Fn strtoll
309and should not be used in a new code.
310.Sh BUGS
311Ignores the current locale.
312