diff options
author | Jim Meyering <jim@meyering.net> | 2002-10-08 06:19:00 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2002-10-08 06:19:00 +0000 |
commit | 7a58f340c1dc95abdc8a6b3f24b2546e9316514a (patch) | |
tree | b6857496fb4a0d8eee2a680e6ecf47a6fcca3c25 /src/sort.c | |
parent | ea544336d732ac8f781d3e7c922f5060903e4c62 (diff) | |
download | coreutils-7a58f340c1dc95abdc8a6b3f24b2546e9316514a.tar.xz |
(begfield, limfield): Don't advance the write pointer past the
end of the write buffer.
Diffstat (limited to 'src/sort.c')
-rw-r--r-- | src/sort.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/sort.c b/src/sort.c index 9ba085dc5..9a36464ac 100644 --- a/src/sort.c +++ b/src/sort.c @@ -777,6 +777,7 @@ begfield (const struct line *line, const struct keyfield *key) register char *ptr = line->text, *lim = ptr + line->length - 1; register size_t sword = key->sword; register size_t schar = key->schar; + register size_t remaining_bytes; if (tab) while (ptr < lim && sword--) @@ -799,7 +800,9 @@ begfield (const struct line *line, const struct keyfield *key) while (ptr < lim && blanks[UCHAR (*ptr)]) ++ptr; - if (ptr + schar <= lim) + /* Advance PTR by SCHAR (if possible), but no further than LIM. */ + remaining_bytes = lim - ptr; + if (schar < remaining_bytes) ptr += schar; else ptr = lim; @@ -815,6 +818,7 @@ limfield (const struct line *line, const struct keyfield *key) { register char *ptr = line->text, *lim = ptr + line->length - 1; register size_t eword = key->eword, echar = key->echar; + register size_t remaining_bytes; /* Note: from the POSIX spec: The leading field separator itself is included in @@ -902,7 +906,8 @@ limfield (const struct line *line, const struct keyfield *key) ++ptr; /* Advance PTR by ECHAR (if possible), but no further than LIM. */ - if (ptr + echar < lim) + remaining_bytes = lim - ptr; + if (echar < remaining_bytes) ptr += echar; else ptr = lim; |