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

Unified Diff: media/base/seekable_buffer.h

Issue 1736012: Merging SeekableBuffer and BufferQueue (Closed)
Patch Set: + 1 TODO Created 10 years, 8 months 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 | « media/base/buffer_queue_unittest.cc ('k') | media/base/seekable_buffer.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/base/seekable_buffer.h
diff --git a/media/base/seekable_buffer.h b/media/base/seekable_buffer.h
index 58b0be98c710999aa2d25c0037d105c35fbf47ea..1a9c6bff22e9997410d65a2fbc4fc1276db86259 100644
--- a/media/base/seekable_buffer.h
+++ b/media/base/seekable_buffer.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// 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.
@@ -37,7 +37,8 @@
#include "base/basictypes.h"
#include "base/lock.h"
-#include "base/scoped_ptr.h"
+#include "base/ref_counted.h"
+#include "media/base/buffers.h"
namespace media {
@@ -49,19 +50,28 @@ class SeekableBuffer {
~SeekableBuffer();
- // Reads a maximum of |size| bytes into |buffer| from the current read
+ // Clears the buffer queue.
+ void Clear();
+
+ // Reads a maximum of |size| bytes into |data| from the current read
// position. Returns the number of bytes read.
// The current read position will advance by the amount of bytes read. If
// reading caused backward_bytes() to exceed backward_capacity(), an eviction
// of the backward buffer will be done internally.
- size_t Read(size_t size, uint8* buffer);
+ size_t Read(uint8* data, size_t size);
+
+ // Copies up to |size| bytes from current position to |data|. Returns
+ // number of bytes copied. Doesn't advance current position.
+ size_t Peek(uint8* data, size_t size);
- // Appends |data| with |size| bytes to this buffer. If this buffer becomes
- // full or is already full then returns false, otherwise returns true.
- // Append operations are always successful. A return value of false only means
- // that forward_bytes() is greater than or equals to forward_capacity(). Data
- // appended is still in this buffer but user is advised not to write any more.
- bool Append(size_t size, const uint8* data);
+ // Appends |buffer_in| to this buffer. Returns false if forward_bytes() is
+ // greater than or equals to forward_capacity(), true otherwise. The data
+ // added to the buffer in any case.
scherkus (not reviewing) 2010/04/27 02:19:26 nit: added -> is added
+ bool Append(Buffer* buffer_in);
+
+ // Appends |size| bytes of |data| to the buffer. Result is the same
+ // as for Append(Buffer*).
+ bool Append(const uint8* data, size_t size);
// Moves the read position by |offset| bytes. If |offset| is positive, the
// current read position is moved forward. If negative, the current read
@@ -90,18 +100,18 @@ class SeekableBuffer {
// direction.
size_t backward_capacity() const { return backward_capacity_; }
- private:
- // A structure that contains a block of data.
- struct Buffer {
- explicit Buffer(size_t len) : data(new uint8[len]), size(len) {}
- // Pointer to data.
- scoped_array<uint8> data;
- // Size of this block.
- size_t size;
- };
+ // Returns the current timestamp, taking into account current offset. The
+ // value calculated based on the timestamp of the current buffer. If
+ // timestamp for the current buffer is set to 0 or the data was added with
+ // Append(const uint*, size_t), then returns value that corresponds to the
+ // last position in a buffer that had timestamp set. 0 is returned if no
+ // buffers we read from had timestamp set.
+ // TODO(sergeyu): Use StreamSample::kInvalidTimestamp here.
+ base::TimeDelta current_time() const { return current_time_; }
+ private:
// Definition of the buffer queue.
- typedef std::list<Buffer*> BufferQueue;
+ typedef std::list<scoped_refptr<Buffer> > BufferQueue;
// A helper method to evict buffers in the backward direction until backward
// bytes is within the backward capacity.
@@ -112,7 +122,7 @@ class SeekableBuffer {
// of bytes read. The current read position will be moved forward by the
// number of bytes read. If |data| is NULL, only the current read position
// will advance but no data will be copied.
- size_t InternalRead(size_t size, uint8* data);
+ size_t InternalRead(uint8* data, size_t size, bool advance_position);
// A helper method that moves the current read position forward by |size|
// bytes.
@@ -128,6 +138,10 @@ class SeekableBuffer {
// the seek operation failed. The current read position is not updated.
bool SeekBackward(size_t size);
+ // Updates |current_time_| with the time that corresponds to the
+ // specified position in the buffer.
+ void UpdateCurrentTime(BufferQueue::iterator buffer, size_t offset);
+
BufferQueue::iterator current_buffer_;
BufferQueue buffers_;
size_t current_buffer_offset_;
@@ -137,6 +151,12 @@ class SeekableBuffer {
size_t forward_capacity_;
size_t forward_bytes_;
+
+ // Keeps track of the most recent time we've seen in case the |buffers_| is
+ // empty when our owner asks what time it is.
+ base::TimeDelta current_time_;
+
+ DISALLOW_COPY_AND_ASSIGN(SeekableBuffer);
};
} // namespace media
« no previous file with comments | « media/base/buffer_queue_unittest.cc ('k') | media/base/seekable_buffer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698