Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "net/filter/mock_source_stream.h" | |
| 6 | |
| 7 #include "base/logging.h" | |
| 8 #include "net/base/io_buffer.h" | |
| 9 | |
| 10 namespace net { | |
| 11 | |
| 12 MockSourceStream::MockSourceStream() | |
| 13 : SourceStream(SourceStream::TYPE_NONE), | |
| 14 awaiting_completion_(false), | |
| 15 dest_buffer_(nullptr), | |
| 16 dest_buffer_size_(0) {} | |
| 17 | |
| 18 MockSourceStream::~MockSourceStream() { | |
| 19 DCHECK(results_.empty()); | |
| 20 } | |
| 21 | |
| 22 int MockSourceStream::Read(IOBuffer* dest_buffer, | |
| 23 int buffer_size, | |
| 24 const CompletionCallback& callback) { | |
| 25 DCHECK(!awaiting_completion_); | |
| 26 DCHECK(!results_.empty()); | |
|
Randy Smith (Not in Mondays)
2016/08/22 22:37:16
I'd vote gently against these DCHECKs. My rule of
mmenke
2016/08/22 22:46:42
I tend to prefer this, just because if something u
xunjieli
2016/08/29 16:25:29
Acknowledged. Thanks for the suggestions and the d
| |
| 27 | |
| 28 if (results_.empty()) | |
| 29 return ERR_UNEXPECTED; | |
| 30 | |
| 31 QueuedResult r = results_.front(); | |
| 32 DCHECK_GE(buffer_size, r.len); | |
|
Randy Smith (Not in Mondays)
2016/08/22 22:37:17
Same comment here--this could be the result of an
xunjieli
2016/08/29 16:25:29
Acknowledged.
| |
| 33 if (r.mode == ASYNC) { | |
| 34 awaiting_completion_ = true; | |
| 35 dest_buffer_ = dest_buffer; | |
| 36 dest_buffer_size_ = buffer_size; | |
| 37 callback_ = callback; | |
| 38 return ERR_IO_PENDING; | |
| 39 } | |
| 40 | |
| 41 results_.pop(); | |
| 42 memcpy(dest_buffer->data(), r.data, r.len); | |
| 43 return r.error == OK ? r.len : r.error; | |
| 44 } | |
| 45 | |
| 46 std::string MockSourceStream::OrderedTypeStringList() const { | |
| 47 return ""; | |
| 48 } | |
| 49 | |
| 50 MockSourceStream::QueuedResult::QueuedResult(const char* data, | |
| 51 int len, | |
| 52 Error error, | |
| 53 Mode mode) | |
| 54 : data(data), len(len), error(error), mode(mode) {} | |
| 55 | |
| 56 void MockSourceStream::AddReadResult(const char* data, | |
| 57 int len, | |
| 58 Error error, | |
| 59 Mode mode) { | |
| 60 QueuedResult result(data, len, error, mode); | |
| 61 results_.push(result); | |
| 62 } | |
| 63 | |
| 64 void MockSourceStream::CompleteNextRead() { | |
| 65 DCHECK(awaiting_completion_); | |
|
Randy Smith (Not in Mondays)
2016/08/22 22:37:16
And here, unless its part of the contract that the
xunjieli
2016/08/29 16:25:29
Done. I added documentation in the header file.
| |
| 66 | |
| 67 awaiting_completion_ = false; | |
| 68 QueuedResult r = results_.front(); | |
| 69 DCHECK_EQ(ASYNC, r.mode); | |
| 70 results_.pop(); | |
| 71 DCHECK_GE(dest_buffer_size_, r.len); | |
| 72 memcpy(dest_buffer_->data(), r.data, r.len); | |
| 73 dest_buffer_ = nullptr; | |
| 74 callback_.Run(r.error == OK ? r.len : r.error); | |
| 75 } | |
| 76 | |
| 77 } // namespace net | |
| OLD | NEW |