From 343810d95a1343a7d3f996827c938fb3109053bc Mon Sep 17 00:00:00 2001 From: Guy Harris Date: Sun, 27 Feb 2005 21:15:30 +0000 Subject: Move "get_natural_int()" and "get_positive_int()" from "capture_opts.c" to "clopts_common.c", make them not static, and use them in "gtk/main.c". svn path=/trunk/; revision=13541 --- clopts_common.c | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) (limited to 'clopts_common.c') diff --git a/clopts_common.c b/clopts_common.c index 487dbd5bf3..12227c4485 100644 --- a/clopts_common.c +++ b/clopts_common.c @@ -61,3 +61,45 @@ handle_dashG_option(int argc, char **argv, char *progname) exit(0); } } + +int +get_natural_int(const char *appname, const char *string, const char *name) +{ + long number; + char *p; + + number = strtol(string, &p, 10); + if (p == string || *p != '\0') { + fprintf(stderr, "%s: The specified %s \"%s\" isn't a decimal number\n", + appname, name, string); + exit(1); + } + if (number < 0) { + fprintf(stderr, "%s: The specified %s \"%s\" is a negative number\n", + appname, name, string); + exit(1); + } + if (number > INT_MAX) { + fprintf(stderr, "%s: The specified %s \"%s\" is too large (greater than %d)\n", + appname, name, string, INT_MAX); + exit(1); + } + return number; +} + + +int +get_positive_int(const char *appname, const char *string, const char *name) +{ + long number; + + number = get_natural_int(appname, string, name); + + if (number == 0) { + fprintf(stderr, "%s: The specified %s is zero\n", + appname, name); + exit(1); + } + + return number; +} -- cgit v1.2.3