2020-06-15 14:18:57 +00:00
|
|
|
|
/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:2;tab-width:8;coding:utf-8 -*-│
|
|
|
|
|
│vi: set net ft=c ts=2 sts=2 sw=2 fenc=utf-8 :vi│
|
|
|
|
|
╞══════════════════════════════════════════════════════════════════════════════╡
|
|
|
|
|
│ Copyright 2020 Justine Alexandra Roberts Tunney │
|
|
|
|
|
│ │
|
2020-12-28 01:18:44 +00:00
|
|
|
|
│ Permission to use, copy, modify, and/or distribute this software for │
|
|
|
|
|
│ any purpose with or without fee is hereby granted, provided that the │
|
|
|
|
|
│ above copyright notice and this permission notice appear in all copies. │
|
2020-06-15 14:18:57 +00:00
|
|
|
|
│ │
|
2020-12-28 01:18:44 +00:00
|
|
|
|
│ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL │
|
|
|
|
|
│ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED │
|
|
|
|
|
│ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE │
|
|
|
|
|
│ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL │
|
|
|
|
|
│ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR │
|
|
|
|
|
│ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER │
|
|
|
|
|
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
|
|
|
|
|
│ PERFORMANCE OF THIS SOFTWARE. │
|
2020-06-15 14:18:57 +00:00
|
|
|
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
2021-08-13 18:18:25 +00:00
|
|
|
|
#include "libc/errno.h"
|
2020-12-09 23:04:54 +00:00
|
|
|
|
#include "libc/fmt/conv.h"
|
2020-06-15 14:18:57 +00:00
|
|
|
|
#include "libc/limits.h"
|
2021-08-13 18:18:25 +00:00
|
|
|
|
#include "libc/str/str.h"
|
2020-06-15 14:18:57 +00:00
|
|
|
|
|
|
|
|
|
/**
|
2021-08-13 18:18:25 +00:00
|
|
|
|
* Decodes decimal integer from ASCII string.
|
2020-06-15 14:18:57 +00:00
|
|
|
|
*
|
2021-09-28 05:58:51 +00:00
|
|
|
|
* atoi 10⁸ 22𝑐 7𝑛𝑠
|
|
|
|
|
* strtol 10⁸ 37𝑐 12𝑛𝑠
|
|
|
|
|
* strtoul 10⁸ 35𝑐 11𝑛𝑠
|
|
|
|
|
* wcstol 10⁸ 30𝑐 10𝑛𝑠
|
|
|
|
|
* wcstoul 10⁸ 30𝑐 10𝑛𝑠
|
|
|
|
|
* strtoimax 10⁸ 80𝑐 26𝑛𝑠
|
|
|
|
|
* strtoumax 10⁸ 78𝑐 25𝑛𝑠
|
|
|
|
|
* wcstoimax 10⁸ 77𝑐 25𝑛𝑠
|
|
|
|
|
* wcstoumax 10⁸ 76𝑐 25𝑛𝑠
|
|
|
|
|
*
|
2021-08-13 18:18:25 +00:00
|
|
|
|
* @param s is a non-null nul-terminated string
|
|
|
|
|
* @return the decoded signed saturated integer
|
2020-06-15 14:18:57 +00:00
|
|
|
|
*/
|
2020-11-25 16:19:00 +00:00
|
|
|
|
int atoi(const char *s) {
|
2021-08-13 18:18:25 +00:00
|
|
|
|
int x, c, d;
|
|
|
|
|
do {
|
|
|
|
|
c = *s++;
|
|
|
|
|
} while (c == ' ' || c == '\t');
|
|
|
|
|
d = c == '-' ? -1 : 1;
|
|
|
|
|
if (c == '-' || c == '+') c = *s++;
|
|
|
|
|
for (x = 0; isdigit(c); c = *s++) {
|
|
|
|
|
if (__builtin_mul_overflow(x, 10, &x) ||
|
|
|
|
|
__builtin_add_overflow(x, (c - '0') * d, &x)) {
|
|
|
|
|
errno = ERANGE;
|
|
|
|
|
if (d > 0) {
|
|
|
|
|
return INT_MAX;
|
|
|
|
|
} else {
|
|
|
|
|
return INT_MIN;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return x;
|
2020-11-25 16:19:00 +00:00
|
|
|
|
}
|