// Copyright (c) 2013 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. #include "net/spdy/spdy_read_queue.h" #include "base/logging.h" #include "base/stl_util.h" #include "net/spdy/spdy_buffer.h" namespace net { SpdyReadQueue::SpdyReadQueue() : total_size_(0) {} SpdyReadQueue::~SpdyReadQueue() { Clear(); } bool SpdyReadQueue::IsEmpty() const { DCHECK_EQ(queue_.empty(), total_size_ == 0); return queue_.empty(); } size_t SpdyReadQueue::GetTotalSize() const { return total_size_; } void SpdyReadQueue::Enqueue(scoped_ptr<SpdyBuffer> buffer) { DCHECK_GT(buffer->GetRemainingSize(), 0u); total_size_ += buffer->GetRemainingSize(); queue_.push_back(buffer.release()); } size_t SpdyReadQueue::Dequeue(char* out, size_t len) { DCHECK_GT(len, 0u); size_t bytes_copied = 0; while (!queue_.empty() && bytes_copied < len) { SpdyBuffer* buffer = queue_.front(); size_t bytes_to_copy = std::min(len - bytes_copied, buffer->GetRemainingSize()); memcpy(out + bytes_copied, buffer->GetRemainingData(), bytes_to_copy); bytes_copied += bytes_to_copy; if (bytes_to_copy == buffer->GetRemainingSize()) { delete queue_.front(); queue_.pop_front(); } else { buffer->Consume(bytes_to_copy); } } total_size_ -= bytes_copied; return bytes_copied; } void SpdyReadQueue::Clear() { STLDeleteElements(&queue_); queue_.clear(); } } // namespace