Browse Source

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>
maint
Jim Meyering 18 years ago committed by Junio C Hamano
parent
commit
61d6ed139f
  1. 15
      builtin-grep.c
  2. 10
      builtin-update-index.c
  3. 2
      convert-objects.c
  4. 13
      git-compat-util.h

15
builtin-grep.c

@ -434,19 +434,6 @@ static const char emsg_missing_context_len[] = @@ -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) @@ -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':

10
builtin-update-index.c

@ -227,6 +227,7 @@ static void read_index_info(int line_termination) @@ -227,6 +227,7 @@ static void read_index_info(int line_termination)
char *path_name;
unsigned char sha1[20];
unsigned int mode;
unsigned long ul;
int stage;

/* This reads lines formatted in one of three formats:
@ -249,9 +250,12 @@ static void read_index_info(int line_termination) @@ -249,9 +250,12 @@ static void read_index_info(int line_termination)
if (buf.eof)
break;

mode = strtoul(buf.buf, &ptr, 8);
if (ptr == buf.buf || *ptr != ' ')
errno = 0;
ul = strtoul(buf.buf, &ptr, 8);
if (ptr == buf.buf || *ptr != ' '
|| errno || (unsigned int) ul != ul)
goto bad_line;
mode = ul;

tab = strchr(ptr, '\t');
if (!tab || tab - ptr < 41)
@ -547,7 +551,7 @@ int cmd_update_index(int argc, const char **argv, const char *prefix) @@ -547,7 +551,7 @@ int cmd_update_index(int argc, const char **argv, const char *prefix)
if (i+3 >= argc)
die("git-update-index: --cacheinfo <mode> <sha1> <path>");

if ((sscanf(argv[i+1], "%o", &mode) != 1) ||
if ((strtoul_ui(argv[i+1], 8, &mode) != 1) ||
get_sha1_hex(argv[i+2], sha1) ||
add_cacheinfo(mode, sha1, argv[i+3], 0))
die("git-update-index: --cacheinfo"

2
convert-objects.c

@ -88,7 +88,7 @@ static int write_subdirectory(void *buffer, unsigned long size, const char *base @@ -88,7 +88,7 @@ static int write_subdirectory(void *buffer, unsigned long size, const char *base
unsigned int mode;
char *slash, *origpath;

if (!path || sscanf(buffer, "%o", &mode) != 1)
if (!path || strtoul_ui(buffer, 8, &mode) != 1)
die("bad tree conversion");
mode = convert_mode(mode);
path++;

13
git-compat-util.h

@ -301,4 +301,17 @@ static inline int prefixcmp(const char *str, const char *prefix) @@ -301,4 +301,17 @@ static inline int prefixcmp(const char *str, const char *prefix)
return strncmp(str, prefix, strlen(prefix));
}

static inline int strtoul_ui(char const *s, int base, unsigned int *result)
{
unsigned long ul;
char *p;

errno = 0;
ul = strtoul(s, &p, base);
if (errno || *p || p == s || (unsigned int) ul != ul)
return -1;
*result = ul;
return 0;
}

#endif

Loading…
Cancel
Save