small improvements in str -> num convertors
authorDenis Vlasenko <vda.linux@googlemail.com>
Sat, 25 Nov 2006 14:49:04 +0000 (14:49 -0000)
committerDenis Vlasenko <vda.linux@googlemail.com>
Sat, 25 Nov 2006 14:49:04 +0000 (14:49 -0000)
include/libbb.h
include/xatonum.h
libbb/xatonum.c

index 152fb7e0196a049fa98ba74e917ac120cd404b23..5cba27932edcf3938476ccf54406b6d81ac61fba 100644 (file)
@@ -317,17 +317,11 @@ struct suffix_mult {
 };
 #include "xatonum.h"
 /* Specialized: */
-unsigned xatou_range(const char *numstr, unsigned lower, unsigned upper);
-unsigned xatou_sfx(const char *numstr, const struct suffix_mult *suffixes);
-unsigned xatou(const char *numstr);
-int xatoi_range(const char *numstr, int lower, int upper);
-int xatoi(const char *numstr);
 /* Using xatoi() instead of naive atoi() is not always convenient -
  * in many places people want *non-negative* values, but store them
  * in signed int. Therefore we need this one:
  * dies if input is not in [0, INT_MAX] range. Also will reject '-0' etc */
 int xatoi_u(const char *numstr);
-uint32_t xatou32(const char *numstr);
 /* Useful for reading port numbers */
 uint16_t xatou16(const char *numstr);
 
index cdb5e7393ee6b0109ebfceeff65215b0b8555f82..46e49b0eb2426937b6c7062649e5a2b7c2169f19 100644 (file)
@@ -92,3 +92,15 @@ DEFINE_EQUIV_STR_CONV(int, i, l, u, ul)
 #else
 DECLARE_STR_CONV(int, i, u)
 #endif
+
+/* Specialized */
+
+int BUG_xatou32_unimplemented(void);
+extern inline uint32_t xatou32(const char *numstr)
+{
+       if (UINT_MAX == 0xffffffff)
+               return xatou(numstr);
+       if (ULONG_MAX == 0xffffffff)
+               return xatoul(numstr);
+       return BUG_xatou32_unimplemented();
+}
index 910667c14ffa3dd5c083ed45ec698e114f07d097..0d487dd9be2dce33fbc458da46f70cde59ccf760 100644 (file)
 #endif
 
 #if UINT_MAX != ULONG_MAX
+extern inline unsigned bb_strtoui(const char *str, char **end, int b)
+{
+       unsigned long v = strtoul(str, end, b);
+       if (v > UINT_MAX) {
+               errno = ERANGE;
+               return UINT_MAX;
+       }
+       return v;
+}
 #define type int
 #define xstrtou(rest) xstrtou##rest
 #define xstrto(rest) xstrtoi##rest
@@ -60,7 +69,8 @@
 #define XSTR_UTYPE_MAX UINT_MAX
 #define XSTR_TYPE_MAX INT_MAX
 #define XSTR_TYPE_MIN INT_MIN
-#define XSTR_STRTOU strtoul
+/* libc has no strtoui, so we need to create/use our own */
+#define XSTR_STRTOU bb_strtoui
 #include "xatonum_template.c"
 #undef type
 #undef xstrtou
@@ -77,7 +87,7 @@
 
 int xatoi_u(const char *numstr)
 {
-       return xatoul_range(numstr, 0, INT_MAX);
+       return xatou_range(numstr, 0, INT_MAX);
 }
 
 uint32_t xatou32(const char *numstr)
@@ -87,5 +97,5 @@ uint32_t xatou32(const char *numstr)
 
 uint16_t xatou16(const char *numstr)
 {
-       return xatoul_range(numstr, 0, 0xffff);
+       return xatou_range(numstr, 0, 0xffff);
 }