diff options
author | Jim Meyering <jim@meyering.net> | 2000-03-06 06:20:59 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2000-03-06 06:20:59 +0000 |
commit | 57bb2e656e63c2335767086083e882997e0043ab (patch) | |
tree | ab40b5531baad16352206b2ad03b155c4c5da30e | |
parent | 12ad88f5c1d05ba0cbb8dafbdf698248952cb9f8 (diff) | |
download | coreutils-57bb2e656e63c2335767086083e882997e0043ab.tar.xz |
(struct buffer.newline_free): New member.
(initbuf, findlines): Set it.
(fillbuf): Do not double the size of a full buffer to append a newline
unless the buffer is known to be newline free.
-rw-r--r-- | src/sort.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/src/sort.c b/src/sort.c index 2b064db57..acd564202 100644 --- a/src/sort.c +++ b/src/sort.c @@ -127,7 +127,9 @@ struct buffer char *buf; /* Dynamically allocated buffer. */ int used; /* Number of bytes used. */ int alloc; /* Number of bytes allocated. */ - int left; /* Number of bytes left after line parsing. */ + int left; /* Number of bytes left from previous reads. */ + int newline_free; /* Number of left bytes that are known + to be newline-free. */ }; struct keyfield @@ -534,7 +536,7 @@ initbuf (struct buffer *buf, int alloc) { buf->alloc = alloc; buf->buf = xmalloc (buf->alloc); - buf->used = buf->left = 0; + buf->used = buf->left = buf->newline_free = 0; } /* Fill BUF reading from FP, moving buf->left bytes from the end @@ -575,6 +577,11 @@ fillbuf (struct buffer *buf, FILE *fp) { if (buf->used == buf->alloc) { + /* If the buffer isn't parsed yet, don't increase the buffer + size to append a newline, as this won't be needed unless + the buffer turns out to be newline-free. */ + if (buf->newline_free != buf->used) + return buf->used; buf->alloc *= 2; buf->buf = xrealloc (buf->buf, buf->alloc); } @@ -795,7 +802,7 @@ findlines (struct buffer *buf, struct lines *lines) beg = ptr + 1; } - buf->left = lim - beg; + buf->newline_free = buf->left = lim - beg; } /* Compare strings A and B containing decimal fractions < 1. Each string |