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

Unified Diff: media/base/data_buffer.cc

Issue 149573: Refactor WritableBuffer interface for more useful ptr management. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years, 5 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/data_buffer.h ('k') | media/base/data_buffer_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/base/data_buffer.cc
===================================================================
--- media/base/data_buffer.cc (revision 20532)
+++ media/base/data_buffer.cc (working copy)
@@ -7,36 +7,36 @@
namespace media {
-DataBuffer::DataBuffer()
- : data_(NULL),
- buffer_size_(0),
+DataBuffer::DataBuffer(uint8* buffer, size_t buffer_size)
+ : data_(buffer),
+ buffer_size_(buffer_size),
+ data_size_(buffer_size) {
+}
+
+DataBuffer::DataBuffer(size_t buffer_size)
+ : data_(new uint8[buffer_size]),
+ buffer_size_(buffer_size),
data_size_(0) {
+ CHECK(data_.get()) << "DataBuffer ctor failed to allocate memory";
+
+ // Prevent arbitrary pointers.
+ if (buffer_size == 0)
+ data_.reset(NULL);
}
DataBuffer::~DataBuffer() {
- delete [] data_;
}
const uint8* DataBuffer::GetData() const {
- return data_;
+ return data_.get();
}
size_t DataBuffer::GetDataSize() const {
return data_size_;
}
-uint8* DataBuffer::GetWritableData(size_t buffer_size) {
- if (buffer_size > buffer_size_) {
- delete [] data_;
- data_ = new uint8[buffer_size];
- if (!data_) {
- NOTREACHED();
- buffer_size = 0;
- }
- buffer_size_ = buffer_size;
- }
- data_size_ = buffer_size;
- return data_;
+uint8* DataBuffer::GetWritableData() {
+ return data_.get();
}
@@ -45,4 +45,8 @@
data_size_ = data_size;
}
+size_t DataBuffer::GetBufferSize() const {
+ return buffer_size_;
+}
+
} // namespace media
« no previous file with comments | « media/base/data_buffer.h ('k') | media/base/data_buffer_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698