Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(891)

Unified Diff: remoting/base/compound_buffer.h

Issue 4779001: Added CompoundBuffer that will be used to store data in the encoding/decoding (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: merged CompoundBuffer with MultipleArrayInputStream Created 10 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | remoting/base/compound_buffer.cc » ('j') | remoting/base/compound_buffer.cc » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: remoting/base/compound_buffer.h
diff --git a/remoting/base/compound_buffer.h b/remoting/base/compound_buffer.h
new file mode 100644
index 0000000000000000000000000000000000000000..aead23f45ddf70dbd9487e6b79eb0bc558eaa371
--- /dev/null
+++ b/remoting/base/compound_buffer.h
@@ -0,0 +1,91 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// CompoundBuffer implements a data buffer that is composed of several pieces,
+// each stored in a refcounted IOBuffer. It is needed for encoding/decoding
+// video pipeline to represent data packet and minimize data copying.
+// It is particularly useful for splitting data between multiple RTP packets
+// and assembling them into one buffer on the receiving side.
awong 2010/11/12 02:40:06 Hmm...it feels like we just reimplemented rope. :P
Sergey Ulanov 2010/11/13 04:43:39 hmm, yeah. Except rope doesn't use IOBuffer, so yo
awong 2010/11/16 00:04:57 Yeah...that sucks. :-/
+//
+// CompoundBuffer also implements ZeroCopyInputStream interface to be used by
+// protobuf to decode bytes into a protocol buffer message.
+
+#ifndef REMOTING_BASE_COMPOUND_BUFFER_H_
+#define REMOTING_BASE_COMPOUND_BUFFER_H_
+
+#include <deque>
+
+#include "base/basictypes.h"
+#include "base/ref_counted.h"
+#include "google/protobuf/io/zero_copy_stream.h"
+
+namespace net {
+class IOBuffer;
+class IOBufferWithSize;
+} // namespace net
+
+namespace remoting {
+
+class CompoundBuffer :
+ public google::protobuf::io::ZeroCopyInputStream {
awong 2010/11/12 02:40:06 Isn't this just supposed to go in 4-spaces?
Sergey Ulanov 2010/11/13 04:43:39 ":" must be on this line. Done.
+ public:
+ CompoundBuffer();
+ virtual ~CompoundBuffer();
+
+ void Clear();
+
+ // Adds new chunk to the buffer. |data| must point to start of the data
awong 2010/11/12 02:40:06 How about rename |data| to |start|? Also, specify
Sergey Ulanov 2010/11/13 04:43:39 Done.
+ // within |buffer|.
+ void Append(net::IOBuffer* buffer, int data_size);
+ void Append(net::IOBuffer* buffer, const char* data, int data_size);
awong 2010/11/12 02:40:06 overloading is frowned upon by the style guide. R
Sergey Ulanov 2010/11/13 04:43:39 I think this is a legal use of overloading, as bot
awong 2010/11/16 00:04:57 Yeah...I don't feel fully comfortable with it, but
+ void Prepend(net::IOBuffer* buffer, int data_size);
+ void Prepend(net::IOBuffer* buffer, const char* data, int data_size);
+
+ // Same as above, but creates new IOBuffer and copies the data.
+ void CopyAndAppend(const char* data, int data_size);
awong 2010/11/12 02:40:06 CopyFrom() below implies a clear. These do not.
Sergey Ulanov 2010/11/13 04:43:39 Done.
+ void CopyAndPrepend(const char* data, int data_size);
+
+ // Current size of the buffer.
+ int total_bytes() const { return total_bytes_; }
+
+ // Assemble all chunks in one buffer.
awong 2010/11/12 02:40:06 The word "buffer" has too many meanings in this fi
Sergey Ulanov 2010/11/13 04:43:39 Done.
+ net::IOBufferWithSize* Assemble() const;
+ void Assemble(char* data, int data_size) const;
awong 2010/11/12 02:40:06 How about the names: OutputAsIOBufferWithSize() T
Sergey Ulanov 2010/11/13 04:43:39 Renamed to ToIOBufferWithSize().
+
+ // Drops current content of the buffer, and initializes it with the interval
awong 2010/11/12 02:40:06 How about "Calls Clear(), and then initializes..."
Sergey Ulanov 2010/11/13 04:43:39 The fact that it calls Clear() is an implementatio
+ // from |buffer| starting at |start| and ending at |end|. The data itself
+ // isn't copied.
+ void CopyFrom(const CompoundBuffer& source, int start, int end);
+
+ // google::protobuf::io::ZeroCopyInputStream interface.
awong 2010/11/12 02:40:06 There seems to be some funky API interactions. Nam
Sergey Ulanov 2010/11/13 04:43:39 Done. Also added Lock() method to ensure that the
+ virtual bool Next(const void** data, int* size);
+ virtual void BackUp(int count);
+ virtual bool Skip(int count);
+ virtual int64 ByteCount() const;
+
+ private:
+ struct DataChunk {
+ DataChunk(net::IOBuffer* buffer, const char* data_start, int data_size);
+
+ scoped_refptr<net::IOBuffer> buffer;
+ const char* data_start;
+ int data_size;
+ };
+ typedef std::deque<DataChunk> DataChunkList;
+
+ DataChunkList buffers_;
+ int total_bytes_;
+
+ // Current position for ZeroCopyInputStream.
awong 2010/11/12 02:40:06 What happens to all this stuff if you start using
Sergey Ulanov 2010/11/13 04:43:39 Moved these to CompoundBufferInputStream
+ size_t current_buffer_;
+ int current_buffer_position_;
+ int position_;
+ int last_returned_size_;
+
+ DISALLOW_COPY_AND_ASSIGN(CompoundBuffer);
+};
+
+} // namespace remoting
+
+#endif // REMOTING_BASE_COMPOUND_BUFFER_H_
« no previous file with comments | « no previous file | remoting/base/compound_buffer.cc » ('j') | remoting/base/compound_buffer.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698