svn commit: trunk/busybox: include libbb
vda at busybox.net
vda at busybox.net
Sat Nov 25 14:49:05 UTC 2006
Author: vda
Date: 2006-11-25 06:49:04 -0800 (Sat, 25 Nov 2006)
New Revision: 16667
Log:
small improvements in str -> num convertors
Modified:
trunk/busybox/include/libbb.h
trunk/busybox/include/xatonum.h
trunk/busybox/libbb/xatonum.c
Changeset:
Modified: trunk/busybox/include/libbb.h
===================================================================
--- trunk/busybox/include/libbb.h 2006-11-25 14:48:09 UTC (rev 16666)
+++ trunk/busybox/include/libbb.h 2006-11-25 14:49:04 UTC (rev 16667)
@@ -317,17 +317,11 @@
};
#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);
Modified: trunk/busybox/include/xatonum.h
===================================================================
--- trunk/busybox/include/xatonum.h 2006-11-25 14:48:09 UTC (rev 16666)
+++ trunk/busybox/include/xatonum.h 2006-11-25 14:49:04 UTC (rev 16667)
@@ -92,3 +92,15 @@
#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();
+}
Modified: trunk/busybox/libbb/xatonum.c
===================================================================
--- trunk/busybox/libbb/xatonum.c 2006-11-25 14:48:09 UTC (rev 16666)
+++ trunk/busybox/libbb/xatonum.c 2006-11-25 14:49:04 UTC (rev 16667)
@@ -52,6 +52,15 @@
#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 @@
uint16_t xatou16(const char *numstr)
{
- return xatoul_range(numstr, 0, 0xffff);
+ return xatou_range(numstr, 0, 0xffff);
}
More information about the busybox-cvs
mailing list