]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Add a zero-copy buffer move implementation.
authorNick Mathewson <nickm@torproject.org>
Wed, 6 Sep 2017 13:30:50 +0000 (09:30 -0400)
committerNick Mathewson <nickm@torproject.org>
Thu, 2 Nov 2017 14:00:32 +0000 (10:00 -0400)
src/common/buffers.c
src/common/buffers.h

index d7c4e4d8c3a61b3bb87533ca683f47f364ec7d62..d1725cf1a19e86048f41a5f6139a723bcf880d9b 100644 (file)
@@ -838,6 +838,28 @@ buf_move_to_buf(buf_t *buf_out, buf_t *buf_in, size_t *buf_flushlen)
   return (int)cp;
 }
 
+/** Moves all data from <b>buf_in</b> to <b>buf_out</b>, without copying.
+ */
+void
+buf_move_all(buf_t *buf_out, buf_t *buf_in)
+{
+  tor_assert(buf_out);
+  if (!buf_in)
+    return;
+
+  if (buf_out->head == NULL) {
+    buf_out->head = buf_in->head;
+    buf_out->tail = buf_in->tail;
+  } else {
+    buf_out->tail->next = buf_in->head;
+    buf_out->tail = buf_in->tail;
+  }
+
+  buf_out->datalen += buf_in->datalen;
+  buf_in->head = buf_in->tail = NULL;
+  buf_in->datalen = 0;
+}
+
 /** Internal structure: represents a position in a buffer. */
 typedef struct buf_pos_t {
   const chunk_t *chunk; /**< Which chunk are we pointing to? */
index b05c5b13d4b3116f42ec7536f815dea3d69d4ad5..56ba7c77bad03358130d544ffc8887535f2df9fb 100644 (file)
@@ -51,6 +51,7 @@ void buf_add_vprintf(buf_t *buf, const char *format, va_list args)
 int buf_add_compress(buf_t *buf, struct tor_compress_state_t *state,
                           const char *data, size_t data_len, int done);
 int buf_move_to_buf(buf_t *buf_out, buf_t *buf_in, size_t *buf_flushlen);
+void buf_move_all(buf_t *buf_out, buf_t *buf_in);
 void buf_peek(const buf_t *buf, char *string, size_t string_len);
 void buf_drain(buf_t *buf, size_t n);
 int buf_get_bytes(buf_t *buf, char *string, size_t string_len);