From: Alejandro Colomar Date: Tue, 16 Jan 2024 20:29:59 +0000 (+0100) Subject: lib/atoi/: Add a2[su]l() and reimplement get[u]long() in terms of them X-Git-Tag: 4.15.2~58 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=b085c3f612e61d06d7c452953c7e097430ba1b3c;p=thirdparty%2Fshadow.git lib/atoi/: Add a2[su]l() and reimplement get[u]long() in terms of them Signed-off-by: Alejandro Colomar --- diff --git a/lib/Makefile.am b/lib/Makefile.am index 9676c5297..22abb9784 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -31,6 +31,8 @@ libshadow_la_SOURCES = \ agetpass.h \ alloc.c \ alloc.h \ + atoi/a2i.c \ + atoi/a2i.h \ atoi/str2i.c \ atoi/str2i.h \ atoi/strtoi.c \ diff --git a/lib/atoi/a2i.c b/lib/atoi/a2i.c new file mode 100644 index 000000000..1b9037c3b --- /dev/null +++ b/lib/atoi/a2i.c @@ -0,0 +1,13 @@ +// SPDX-FileCopyrightText: 2023-2024, Alejandro Colomar +// SPDX-License-Identifier: BSD-3-Clause + + +#include + +#include "atoi/a2i.h" + + +extern inline int a2sl(long *restrict n, const char *s, + char **restrict endp, int base, long min, long max); +extern inline int a2ul(unsigned long *restrict n, const char *s, + char **restrict endp, int base, unsigned long min, unsigned long max); diff --git a/lib/atoi/a2i.h b/lib/atoi/a2i.h new file mode 100644 index 000000000..2b65f4b3e --- /dev/null +++ b/lib/atoi/a2i.h @@ -0,0 +1,56 @@ +// SPDX-FileCopyrightText: 2023-2024, Alejandro Colomar +// SPDX-License-Identifier: BSD-3-Clause + + +#ifndef SHADOW_INCLUDE_LIB_ATOI_A2I_H_ +#define SHADOW_INCLUDE_LIB_ATOI_A2I_H_ + + +#include + +#include + +#include "atoi/strtoi.h" +#include "atoi/strtou_noneg.h" +#include "attr.h" + + +ATTR_STRING(2) ATTR_ACCESS(write_only, 1) ATTR_ACCESS(write_only, 3) +inline int a2sl(long *restrict n, const char *s, + char **restrict endp, int base, long min, long max); +ATTR_STRING(2) ATTR_ACCESS(write_only, 1) ATTR_ACCESS(write_only, 3) +inline int a2ul(unsigned long *restrict n, const char *s, + char **restrict endp, int base, unsigned long min, unsigned long max); + + +inline int +a2sl(long *restrict n, const char *s, char **restrict endp, + int base, long min, long max) +{ + int status; + + *n = strtoi_(s, endp, base, min, max, &status); + if (status != 0) { + errno = status; + return -1; + } + return 0; +} + + +inline int +a2ul(unsigned long *restrict n, const char *s, char **restrict endp, + int base, unsigned long min, unsigned long max) +{ + int status; + + *n = strtou_noneg(s, endp, base, min, max, &status); + if (status != 0) { + errno = status; + return -1; + } + return 0; +} + + +#endif // include guard diff --git a/lib/atoi/str2i.h b/lib/atoi/str2i.h index 6bf79fc48..b72c509ff 100644 --- a/lib/atoi/str2i.h +++ b/lib/atoi/str2i.h @@ -9,49 +9,30 @@ #include -#include -#include +#include +#include -#include "atoi/str2i.h" -#include "atoi/strtou_noneg.h" +#include "atoi/a2i.h" #include "attr.h" -ATTR_ACCESS(write_only, 2) +ATTR_STRING(1) ATTR_ACCESS(write_only, 2) inline int getlong(const char *restrict s, long *restrict n); -ATTR_ACCESS(write_only, 2) +ATTR_STRING(1) ATTR_ACCESS(write_only, 2) inline int getulong(const char *restrict s, unsigned long *restrict n); inline int getlong(const char *restrict s, long *restrict n) { - char *endp; - long val; - - errno = 0; - val = strtol(s, &endp, 0); - if (('\0' == *s) || ('\0' != *endp) || (0 != errno)) - return -1; - - *n = val; - return 0; + return a2sl(n, s, NULL, 0, LONG_MIN, LONG_MAX); } inline int getulong(const char *restrict s, unsigned long *restrict n) { - char *endp; - unsigned long val; - - errno = 0; - val = strtoul_noneg(s, &endp, 0); - if (('\0' == *s) || ('\0' != *endp) || (0 != errno)) - return -1; - - *n = val; - return 0; + return a2ul(n, s, NULL, 0, 0, ULONG_MAX); }