X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fgetusershell.c;h=9b60f18d5b60b02bdc55ec16bd2a83a82c2b78ac;hb=dd9099e721075856534d551184fb02023a463e1a;hp=c026ec0a9c2482b8bf077c97b0f55028fb200d34;hpb=15d3d56a7b7603e5ed4056ca2fce9d923a6649b6;p=gnulib.git diff --git a/lib/getusershell.c b/lib/getusershell.c index c026ec0a9..9b60f18d5 100644 --- a/lib/getusershell.c +++ b/lib/getusershell.c @@ -145,29 +145,17 @@ readname (char **name, size_t *size, FILE *stream) int c; size_t name_index = 0; - if (*name == NULL) - { - /* The initial size must be a power of two, so that the overflow - check works. */ - *size = 16; - - *name = xmalloc (*size); - } - /* Skip blank space. */ while ((c = getc (stream)) != EOF && ISSPACE (c)) /* Do nothing. */ ; - while (c != EOF && !ISSPACE (c)) + for (;;) { + if (*size <= name_index) + *name = x2nrealloc (*name, size, sizeof **name); + if (c == EOF || ISSPACE (c)) + break; (*name)[name_index++] = c; - if (*size < name_index) - { - *size *= 2; - if (! *size) - xalloc_die (); - *name = xrealloc (*name, *size); - } c = getc (stream); } (*name)[name_index] = '\0';