diff options
author | Roger Dingledine <arma@torproject.org> | 2003-12-14 04:18:43 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2003-12-14 04:18:43 +0000 |
commit | 9e3608ce7b2c3178bb2781e32c8bdc320527664b (patch) | |
tree | e728dc18affbfb5b622ee43b690dd66845bb9041 /src | |
parent | a1745b68953c4751f43f1b216fbe18baf2f00aa7 (diff) | |
download | tor-9e3608ce7b2c3178bb2781e32c8bdc320527664b.tar.gz tor-9e3608ce7b2c3178bb2781e32c8bdc320527664b.zip |
more friendly warning when a connection buffer overflows
svn:r918
Diffstat (limited to 'src')
-rw-r--r-- | src/or/buffers.c | 12 |
1 files changed, 3 insertions, 9 deletions
diff --git a/src/or/buffers.c b/src/or/buffers.c index 0cfaae5c96..2ca05a0fce 100644 --- a/src/or/buffers.c +++ b/src/or/buffers.c @@ -208,13 +208,13 @@ int read_to_buf_tls(tor_tls *tls, int at_most, buf_t *buf) { if (buf_ensure_capacity(buf, at_most+buf->datalen)) return -1; - + if (at_most > buf->len - buf->datalen) at_most = buf->len - buf->datalen; if (at_most == 0) return 0; - + r = tor_tls_read(tls, buf->mem+buf->datalen, at_most); if (r<0) return r; @@ -291,15 +291,9 @@ int write_to_buf(const char *string, int string_len, buf_t *buf) { assert(string && BUF_OK(buf)); if (buf_ensure_capacity(buf, buf->datalen+string_len)) + log_fn(LOG_WARN, "buflen too small, can't hold %d bytes.",buf->datalen+string_len); return -1; - /* this is the point where you would grow the buffer, if you want to */ - - if (string_len + buf->datalen > buf->len) { /* we're out of luck */ - log_fn(LOG_WARN, "buflen too small. Time to implement growing dynamic bufs."); - return -1; - } - memcpy(buf->mem+buf->datalen, string, string_len); buf->datalen += string_len; log_fn(LOG_DEBUG,"added %d bytes to buf (now %d total).",string_len, (int)buf->datalen); |