From: Matt Kraai Date: Sat, 5 May 2001 16:19:13 +0000 (-0000) Subject: Rewrite -c and -b processing to shrink code and eliminate buffer overrun. X-Git-Tag: 0_52~235 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=2e6c87876353cf5e038d8430c076f645be51da75;p=oweals%2Fbusybox.git Rewrite -c and -b processing to shrink code and eliminate buffer overrun. --- diff --git a/coreutils/cut.c b/coreutils/cut.c index d852ab3be..efcb325df 100644 --- a/coreutils/cut.c +++ b/coreutils/cut.c @@ -108,20 +108,10 @@ static void cut_file(FILE *file) for (line = NULL; (line = get_line_from_file(file)) != NULL; free(line)) { /* cut based on chars/bytes */ if (part == 'c' || part == 'b') { - int i; - /* a valid end position has been specified */ - if (endpos > 0) { - for (i = startpos-1; i < endpos; i++) { - fputc(line[i], stdout); - } - fputc('\n', stdout); - } - /* otherwise, just go to the end of the line */ - else { - for (i = startpos-1; line[i]; i++) { - fputc(line[i], stdout); - } - } + chomp(line); + if (0 < endpos && endpos < strlen(line)) + line[endpos] = '\0'; + puts(line + startpos - 1); } /* cut based on fields */ else if (part == 'f') { diff --git a/cut.c b/cut.c index d852ab3be..efcb325df 100644 --- a/cut.c +++ b/cut.c @@ -108,20 +108,10 @@ static void cut_file(FILE *file) for (line = NULL; (line = get_line_from_file(file)) != NULL; free(line)) { /* cut based on chars/bytes */ if (part == 'c' || part == 'b') { - int i; - /* a valid end position has been specified */ - if (endpos > 0) { - for (i = startpos-1; i < endpos; i++) { - fputc(line[i], stdout); - } - fputc('\n', stdout); - } - /* otherwise, just go to the end of the line */ - else { - for (i = startpos-1; line[i]; i++) { - fputc(line[i], stdout); - } - } + chomp(line); + if (0 < endpos && endpos < strlen(line)) + line[endpos] = '\0'; + puts(line + startpos - 1); } /* cut based on fields */ else if (part == 'f') {