diff options
| author | Jim Meyering <jim@meyering.net> | 2007-04-10 01:01:44 +0200 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2007-04-11 19:13:55 -0700 | 
| commit | 6aead43db34313e6cdbc72e2f7a70f6b82c78cf2 (patch) | |
| tree | 6b07be3cba39adf0b1edeac27a1e73d16f3b4bb7 /builtin-grep.c | |
| parent | 171ddd91771f042e49db49ff068694b5ed6f845d (diff) | |
| download | git-6aead43db34313e6cdbc72e2f7a70f6b82c78cf2.tar.gz | |
sscanf/strtoul: parse integers robustly
* builtin-grep.c (strtoul_ui): Move function definition from here, to...
* git-compat-util.h (strtoul_ui): ...here, with an added "base" parameter.
* builtin-grep.c (cmd_grep): Update use of strtoul_ui to include base, "10".
* builtin-update-index.c (read_index_info): Diagnose an invalid mode integer
that is out of range or merely larger than INT_MAX.
(cmd_update_index): Use strtoul_ui, not sscanf.
* convert-objects.c (write_subdirectory): Likewise.
Signed-off-by: Jim Meyering <jim@meyering.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'builtin-grep.c')
| -rw-r--r-- | builtin-grep.c | 15 | 
1 files changed, 1 insertions, 14 deletions
| diff --git a/builtin-grep.c b/builtin-grep.c index 981f3d4d8e..e13cb31f2b 100644 --- a/builtin-grep.c +++ b/builtin-grep.c @@ -434,19 +434,6 @@ static const char emsg_missing_context_len[] =  static const char emsg_missing_argument[] =  "option requires an argument -%s"; -static int strtoul_ui(char const *s, unsigned int *result) -{ -	unsigned long ul; -	char *p; - -	errno = 0; -	ul = strtoul(s, &p, 10); -	if (errno || *p || p == s || (unsigned int) ul != ul) -		return -1; -	*result = ul; -	return 0; -} -  int cmd_grep(int argc, const char **argv, const char *prefix)  {  	int hit = 0; @@ -569,7 +556,7 @@ int cmd_grep(int argc, const char **argv, const char *prefix)  				scan = arg + 1;  				break;  			} -			if (strtoul_ui(scan, &num)) +			if (strtoul_ui(scan, 10, &num))  				die(emsg_invalid_context_len, scan);  			switch (arg[1]) {  			case 'A': | 
