diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-02-21 02:10:38 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-02-21 02:10:38 +0000 |
commit | 0e9dcfab97de3c9d9f608deb67bcdc866ae52c93 (patch) | |
tree | 5c8fefbbd2408a31124a78bd48edc8e10fe31553 /src/or | |
parent | 3b58f9929f947f2c21a6bfe439d9b0819a9900fe (diff) | |
download | tor-0e9dcfab97de3c9d9f608deb67bcdc866ae52c93.tar.gz tor-0e9dcfab97de3c9d9f608deb67bcdc866ae52c93.zip |
r18286@catbus: nickm | 2008-02-20 21:10:33 -0500
Fix a bug that kept buf_find_string_offset from finding a string at the very end of the buffer. Add a unit test for this. Also, do not save a pointer to a chunk that might get reallocated by buf_pullup().
svn:r13635
Diffstat (limited to 'src/or')
-rw-r--r-- | src/or/buffers.c | 14 | ||||
-rw-r--r-- | src/or/test.c | 1 |
2 files changed, 11 insertions, 4 deletions
diff --git a/src/or/buffers.c b/src/or/buffers.c index 8c5e2efca5..7a5fa6e946 100644 --- a/src/or/buffers.c +++ b/src/or/buffers.c @@ -1072,18 +1072,24 @@ static int buf_matches_at_pos(const buf_pos_t *pos, const char *s, size_t n) { buf_pos_t p; + if (!n) + return 1; + memcpy(&p, pos, sizeof(p)); - while (n) { + while (1) { char ch = p.chunk->data[p.pos]; if (ch != *s) return 0; ++s; - --n; + /* If we're out of characters that don't match, we match. Check this + * _before_ we test incrementing pos, in case we're at the end of the + * string. */ + if (--n == 0) + return 1; if (buf_pos_inc(&p)<0) return 0; } - return 1; } /** Return the first position in <b>buf</b> at which the <b>n</b>-character @@ -1137,7 +1143,6 @@ fetch_from_buf_http(buf_t *buf, if (!buf->head) return 0; - headers = buf->head->data; crlf_offset = buf_find_string_offset(buf, "\r\n\r\n", 4); if (crlf_offset > (int)max_headerlen || (crlf_offset < 0 && buf->datalen > max_headerlen)) { @@ -1153,6 +1158,7 @@ fetch_from_buf_http(buf_t *buf, buf_pullup(buf, crlf_offset+4, 0); headerlen = crlf_offset + 4; + headers = buf->head->data; bodylen = buf->datalen - headerlen; log_debug(LD_HTTP,"headerlen %d, bodylen %d.", (int)headerlen, (int)bodylen); diff --git a/src/or/test.c b/src/or/test.c index f68bc97efa..c18eccff66 100644 --- a/src/or/test.c +++ b/src/or/test.c @@ -267,6 +267,7 @@ test_buffers(void) test_eq(39, buf_find_string_offset(buf, "ing str", 7)); test_eq(35, buf_find_string_offset(buf, "Testing str", 11)); test_eq(32, buf_find_string_offset(buf, "ng ", 3)); + test_eq(43, buf_find_string_offset(buf, "string.", 7)); test_eq(-1, buf_find_string_offset(buf, "shrdlu", 6)); test_eq(-1, buf_find_string_offset(buf, "Testing thing", 13)); test_eq(-1, buf_find_string_offset(buf, "ngx", 3)); |