summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Andersen2003-03-07 17:29:12 +0000
committerEric Andersen2003-03-07 17:29:12 +0000
commita9c6bc41e99e0c28d524060805429c7b742546a7 (patch)
treed22470e744557d02a92e205de822fd418d3190b1
parentbae7c1ac240211bd3183d48888708bfbc4f96a6d (diff)
downloadbusybox-a9c6bc41e99e0c28d524060805429c7b742546a7.zip
busybox-a9c6bc41e99e0c28d524060805429c7b742546a7.tar.gz
Define bb_xgetlarg as a standard interface for extracting
numbers from getopt which includes careful error checking. -Erik
-rw-r--r--include/libbb.h1
-rw-r--r--libbb/Makefile.in2
-rw-r--r--libbb/bb_xgetlarg.c28
3 files changed, 30 insertions, 1 deletions
diff --git a/include/libbb.h b/include/libbb.h
index c057ce4..8cb72de 100644
--- a/include/libbb.h
+++ b/include/libbb.h
@@ -121,6 +121,7 @@ int recursive_action(const char *fileName, int recurse, int followLinks, int dep
void* userData);
extern int parse_mode( const char* s, mode_t* theMode);
+extern long bb_xgetlarg(char *arg, int base, long lower, long upper);
extern int get_kernel_revision(void);
diff --git a/libbb/Makefile.in b/libbb/Makefile.in
index 08f8028..09c629e 100644
--- a/libbb/Makefile.in
+++ b/libbb/Makefile.in
@@ -43,7 +43,7 @@ LIBBB_SRC:= \
setup_environment.c simplify_path.c syscalls.c syslog_msg_with_name.c \
time_string.c trim.c u_signal_names.c vdprintf.c verror_msg.c \
vherror_msg.c vperror_msg.c wfopen.c xconnect.c xgetcwd.c xfuncs.c \
- xgethostbyname.c xgethostbyname2.c xreadlink.c xregcomp.c
+ xgethostbyname.c xgethostbyname2.c xreadlink.c xregcomp.c bb_xgetlarg.c
LIBBB_OBJS=$(patsubst %.c,$(LIBBB_DIR)%.o, $(LIBBB_SRC))
diff --git a/libbb/bb_xgetlarg.c b/libbb/bb_xgetlarg.c
new file mode 100644
index 0000000..598b0b3
--- /dev/null
+++ b/libbb/bb_xgetlarg.c
@@ -0,0 +1,28 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * Copyright (C) 2003 Erik Andersen <andersee@debian.org>
+ */
+
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <getopt.h>
+#include <errno.h>
+#include <assert.h>
+
+#include "busybox.h"
+
+extern long bb_xgetlarg(char *arg, int base, long lower, long upper)
+{
+ long result;
+ char *endptr;
+ int errno_save = errno;
+
+ assert(arg!=NULL);
+ errno = 0;
+ result = strtol(arg, &endptr, base);
+ if (errno != 0 || *endptr!='\0' || result < lower || result > upper)
+ show_usage();
+ errno = errno_save;
+ return result;
+}