summaryrefslogtreecommitdiff
path: root/src/or/buffers.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-02-21 02:10:38 +0000
committerNick Mathewson <nickm@torproject.org>2008-02-21 02:10:38 +0000
commit0e9dcfab97de3c9d9f608deb67bcdc866ae52c93 (patch)
tree5c8fefbbd2408a31124a78bd48edc8e10fe31553 /src/or/buffers.c
parent3b58f9929f947f2c21a6bfe439d9b0819a9900fe (diff)
downloadtor-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/buffers.c')
-rw-r--r--src/or/buffers.c14
1 files changed, 10 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);