diff options
author | Jim Meyering <jim@meyering.net> | 2003-08-09 15:32:42 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2003-08-09 15:32:42 +0000 |
commit | fd54759957a6440377f8c27403436613d5a182f2 (patch) | |
tree | 78ca6e5902c1643270175c7095a1b5e4f65411a5 | |
parent | 5422ec14eaa2a07d5d713e49c43259ce732a6797 (diff) | |
download | coreutils-fd54759957a6440377f8c27403436613d5a182f2.tar.xz |
(pipe_lines): Use memchr to skip lines, rather than an explicit loop.
-rw-r--r-- | src/tail.c | 34 |
1 files changed, 18 insertions, 16 deletions
diff --git a/src/tail.c b/src/tail.c index a0aba190a..a0b7a7bba 100644 --- a/src/tail.c +++ b/src/tail.c @@ -524,7 +524,6 @@ pipe_lines (const char *pretty_filename, int fd, uintmax_t n_lines, }; typedef struct linebuffer LBUFFER; LBUFFER *first, *last, *tmp; - size_t i; /* Index into buffers. */ size_t total_lines = 0; /* Total number of newlines in all buffers. */ int errors = 0; size_t n_read; /* Size in bytes of most recent read */ @@ -614,21 +613,24 @@ pipe_lines (const char *pretty_filename, int fd, uintmax_t n_lines, total_lines -= tmp->nlines; /* Find the correct beginning, then print the rest of the file. */ - if (total_lines > n_lines) - { - const char *cp; - - /* Skip `total_lines' - `n_lines' newlines. We made sure that - `total_lines' - `n_lines' <= `tmp->nlines'. */ - cp = tmp->buffer; - for (i = total_lines - n_lines; i; --i) - while (*cp++ != '\n') - /* Do nothing. */ ; - i = cp - tmp->buffer; - } - else - i = 0; - xwrite (STDOUT_FILENO, &tmp->buffer[i], tmp->nbytes - i); + { + char const *beg = tmp->buffer; + char const *buffer_end = tmp->buffer + tmp->nbytes; + if (total_lines > n_lines) + { + /* Skip `total_lines' - `n_lines' newlines. We made sure that + `total_lines' - `n_lines' <= `tmp->nlines'. */ + size_t j; + for (j = total_lines - n_lines; j; --j) + { + beg = memchr (beg, '\n', buffer_end - beg); + assert (beg); + ++beg; + } + } + + xwrite (STDOUT_FILENO, beg, buffer_end - beg); + } for (tmp = tmp->next; tmp; tmp = tmp->next) xwrite (STDOUT_FILENO, tmp->buffer, tmp->nbytes); |