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

Side by Side Diff: webrtc/base/copyonwritebuffer.h

Issue 2328553002: Make CopyOnWriteBuffer keep capacity (Closed)
Patch Set: Guarantee capacity Created 4 years, 3 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2016 The WebRTC Project Authors. All rights reserved. 2 * Copyright 2016 The WebRTC Project Authors. All rights reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
(...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after
146 return cdata()[index]; 146 return cdata()[index];
147 } 147 }
148 148
149 // Replace the contents of the buffer. Accepts the same types as the 149 // Replace the contents of the buffer. Accepts the same types as the
150 // constructors. 150 // constructors.
151 template <typename T, 151 template <typename T,
152 typename std::enable_if< 152 typename std::enable_if<
153 internal::BufferCompat<uint8_t, T>::value>::type* = nullptr> 153 internal::BufferCompat<uint8_t, T>::value>::type* = nullptr>
154 void SetData(const T* data, size_t size) { 154 void SetData(const T* data, size_t size) {
155 RTC_DCHECK(IsConsistent()); 155 RTC_DCHECK(IsConsistent());
156 if (!buffer_ || !buffer_->HasOneRef()) { 156 if (!buffer_) {
157 buffer_ = size > 0 ? new RefCountedObject<Buffer>(data, size) 157 buffer_ = size > 0 ? new RefCountedObject<Buffer>(data, size) : nullptr;
158 : nullptr; 158 } else if (!buffer_->HasOneRef()) {
159 buffer_ = new RefCountedObject<Buffer>(
160 data, size, std::max(size, buffer_->capacity()));
kwiberg-webrtc 2016/09/13 09:24:30 I don't think you need the std::max---the Buffer c
danilchap 2016/09/13 09:56:36 Done. It is nicer without extra max.
159 } else { 161 } else {
160 buffer_->SetData(data, size); 162 buffer_->SetData(data, size);
161 } 163 }
162 RTC_DCHECK(IsConsistent()); 164 RTC_DCHECK(IsConsistent());
163 } 165 }
164 166
165 template <typename T, 167 template <typename T,
166 size_t N, 168 size_t N,
167 typename std::enable_if< 169 typename std::enable_if<
168 internal::BufferCompat<uint8_t, T>::value>::type* = nullptr> 170 internal::BufferCompat<uint8_t, T>::value>::type* = nullptr>
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after
246 return; 248 return;
247 } else if (capacity <= buffer_->capacity()) { 249 } else if (capacity <= buffer_->capacity()) {
248 return; 250 return;
249 } 251 }
250 252
251 CloneDataIfReferenced(std::max(buffer_->capacity(), capacity)); 253 CloneDataIfReferenced(std::max(buffer_->capacity(), capacity));
252 buffer_->EnsureCapacity(capacity); 254 buffer_->EnsureCapacity(capacity);
253 RTC_DCHECK(IsConsistent()); 255 RTC_DCHECK(IsConsistent());
254 } 256 }
255 257
256 // Resets the buffer to zero size and capacity. 258 // Resets the buffer to zero size without altering capacity. Works even if the
259 // buffer has been moved from.
257 void Clear() { 260 void Clear() {
258 RTC_DCHECK(IsConsistent()); 261 if (!buffer_)
259 if (!buffer_ || !buffer_->HasOneRef()) { 262 return;
260 buffer_ = nullptr; 263
264 if (!buffer_->HasOneRef()) {
kwiberg-webrtc 2016/09/13 09:24:30 You can eliminate the negation if you swap the if
danilchap 2016/09/13 09:56:36 Done.
265 buffer_ = new RefCountedObject<Buffer>(0, buffer_->capacity());
261 } else { 266 } else {
262 buffer_->Clear(); 267 buffer_->Clear();
263 } 268 }
264 RTC_DCHECK(IsConsistent()); 269 RTC_DCHECK(IsConsistent());
265 } 270 }
266 271
267 // Swaps two buffers. 272 // Swaps two buffers.
268 friend void swap(CopyOnWriteBuffer& a, CopyOnWriteBuffer& b) { 273 friend void swap(CopyOnWriteBuffer& a, CopyOnWriteBuffer& b) {
269 std::swap(a.buffer_, b.buffer_); 274 std::swap(a.buffer_, b.buffer_);
270 } 275 }
(...skipping 16 matching lines...) Expand all
287 return (!buffer_ || buffer_->capacity() > 0); 292 return (!buffer_ || buffer_->capacity() > 0);
288 } 293 }
289 294
290 // buffer_ is either null, or points to an rtc::Buffer with capacity > 0. 295 // buffer_ is either null, or points to an rtc::Buffer with capacity > 0.
291 scoped_refptr<RefCountedObject<Buffer>> buffer_; 296 scoped_refptr<RefCountedObject<Buffer>> buffer_;
292 }; 297 };
293 298
294 } // namespace rtc 299 } // namespace rtc
295 300
296 #endif // WEBRTC_BASE_COPYONWRITEBUFFER_H_ 301 #endif // WEBRTC_BASE_COPYONWRITEBUFFER_H_
OLDNEW
« no previous file with comments | « no previous file | webrtc/base/copyonwritebuffer_unittest.cc » ('j') | webrtc/base/copyonwritebuffer_unittest.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698