diff options
author | Rob Landley <rob@landley.net> | 2012-11-16 12:26:48 -0600 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2012-11-16 12:26:48 -0600 |
commit | 734b530f3797d6d11dc3ab996a889482cc88a8ab (patch) | |
tree | fd3cb74348445ccfe3d6738061ab49f4a5a2efe2 | |
parent | 4521f416ba8422563db6a762061a4a960db1bbf7 (diff) | |
download | toybox-734b530f3797d6d11dc3ab996a889482cc88a8ab.tar.gz |
Add cut from Jason Kyungwan Han.
-rw-r--r-- | lib/lib.c | 19 | ||||
-rw-r--r-- | lib/lib.h | 3 |
2 files changed, 22 insertions, 0 deletions
@@ -1099,3 +1099,22 @@ char* make_human_readable(unsigned long long size, unsigned long unit) } return NULL; //not reached } + +/* + * used to get the interger value. + */ +unsigned long get_int_value(const char *numstr, unsigned lowrange, unsigned highrange) +{ + unsigned long rvalue = 0; + char *ptr; + if(*numstr == '-' || *numstr == '+' || isspace(*numstr)) perror_exit("invalid number '%s'", numstr); + errno = 0; + rvalue = strtoul(numstr, &ptr, 10); + if(errno || numstr == ptr) perror_exit("invalid number '%s'", numstr); + if(*ptr) perror_exit("invalid number '%s'", numstr); + if(rvalue >= lowrange && rvalue <= highrange) return rvalue; + else { + perror_exit("invalid number '%s'", numstr); + return rvalue; //Not reachable; to avoid waring message. + } +} @@ -175,3 +175,6 @@ int update_password(char *filename, char* username, char* encrypted); // du helper functions char* make_human_readable(unsigned long long size, unsigned long unit); + +// cut helper functions +unsigned long get_int_value(const char *numstr, unsigned lowrange, unsigned highrange); |