Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/browser/streams/stream.h" | 5 #include "content/browser/streams/stream.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/message_loop_proxy.h" | 8 #include "base/message_loop_proxy.h" |
| 9 #include "content/browser/streams/stream_handle_impl.h" | |
| 9 #include "content/browser/streams/stream_read_observer.h" | 10 #include "content/browser/streams/stream_read_observer.h" |
| 10 #include "content/browser/streams/stream_registry.h" | 11 #include "content/browser/streams/stream_registry.h" |
| 11 #include "content/browser/streams/stream_write_observer.h" | 12 #include "content/browser/streams/stream_write_observer.h" |
| 12 #include "net/base/io_buffer.h" | 13 #include "net/base/io_buffer.h" |
| 13 | 14 |
| 14 namespace { | 15 namespace { |
| 15 // Start throttling the connection at about 1MB. | 16 // Start throttling the connection at about 1MB. |
| 16 const size_t kDeferSizeThreshold = 40 * 32768; | 17 const size_t kDeferSizeThreshold = 40 * 32768; |
| 17 } | 18 } |
| 18 | 19 |
| 19 namespace content { | 20 namespace content { |
| 20 | 21 |
| 21 Stream::Stream(StreamRegistry* registry, | 22 Stream::Stream(StreamRegistry* registry, |
| 22 StreamWriteObserver* write_observer, | 23 StreamWriteObserver* write_observer, |
| 23 const GURL& security_origin, | 24 const GURL& security_origin, |
| 24 const GURL& url) | 25 const GURL& url) |
| 25 : bytes_read_(0), | 26 : bytes_read_(0), |
| 26 can_add_data_(true), | 27 can_add_data_(true), |
| 27 security_origin_(security_origin), | 28 security_origin_(security_origin), |
| 28 url_(url), | 29 url_(url), |
| 29 data_length_(0), | 30 data_length_(0), |
| 30 registry_(registry), | 31 registry_(registry), |
| 31 read_observer_(NULL), | 32 read_observer_(NULL), |
| 32 write_observer_(write_observer), | 33 write_observer_(write_observer), |
| 34 stream_handle_(NULL), | |
| 33 weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) { | 35 weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) { |
| 34 CreateByteStream(base::MessageLoopProxy::current(), | 36 CreateByteStream(base::MessageLoopProxy::current(), |
| 35 base::MessageLoopProxy::current(), | 37 base::MessageLoopProxy::current(), |
| 36 kDeferSizeThreshold, | 38 kDeferSizeThreshold, |
| 37 &writer_, | 39 &writer_, |
| 38 &reader_); | 40 &reader_); |
| 39 | 41 |
| 40 // Setup callback for writing. | 42 // Setup callback for writing. |
| 41 writer_->RegisterCallback(base::Bind(&Stream::OnSpaceAvailable, | 43 writer_->RegisterCallback(base::Bind(&Stream::OnSpaceAvailable, |
| 42 weak_ptr_factory_.GetWeakPtr())); | 44 weak_ptr_factory_.GetWeakPtr())); |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 54 return false; | 56 return false; |
| 55 read_observer_ = observer; | 57 read_observer_ = observer; |
| 56 return true; | 58 return true; |
| 57 } | 59 } |
| 58 | 60 |
| 59 void Stream::RemoveReadObserver(StreamReadObserver* observer) { | 61 void Stream::RemoveReadObserver(StreamReadObserver* observer) { |
| 60 DCHECK(observer == read_observer_); | 62 DCHECK(observer == read_observer_); |
| 61 read_observer_ = NULL; | 63 read_observer_ = NULL; |
| 62 } | 64 } |
| 63 | 65 |
| 66 void Stream::RemoveWriteObserver(StreamWriteObserver* observer) { | |
| 67 DCHECK(observer == write_observer_); | |
| 68 write_observer_ = NULL; | |
| 69 } | |
| 70 | |
| 64 void Stream::AddData(scoped_refptr<net::IOBuffer> buffer, size_t size) { | 71 void Stream::AddData(scoped_refptr<net::IOBuffer> buffer, size_t size) { |
| 65 can_add_data_ = writer_->Write(buffer, size); | 72 can_add_data_ = writer_->Write(buffer, size); |
| 66 } | 73 } |
| 67 | 74 |
| 68 void Stream::Finalize() { | 75 void Stream::Finalize() { |
| 69 writer_->Close(DOWNLOAD_INTERRUPT_REASON_NONE); | 76 writer_->Close(DOWNLOAD_INTERRUPT_REASON_NONE); |
| 70 writer_.reset(NULL); | 77 writer_.reset(NULL); |
| 71 | 78 |
| 72 OnDataAvailable(); | 79 OnDataAvailable(); |
| 73 } | 80 } |
| 74 | 81 |
| 75 Stream::StreamState Stream::ReadRawData(net::IOBuffer* buf, | 82 Stream::StreamState Stream::ReadRawData(net::IOBuffer* buf, |
| 76 int buf_size, | 83 int buf_size, |
| 77 int* bytes_read) { | 84 int* bytes_read) { |
| 78 if (!data_) { | 85 if (!data_) { |
| 79 data_length_ = 0; | 86 data_length_ = 0; |
| 80 bytes_read_ = 0; | 87 bytes_read_ = 0; |
| 81 ByteStreamReader::StreamState state = reader_->Read(&data_, &data_length_); | 88 ByteStreamReader::StreamState state = reader_->Read(&data_, &data_length_); |
| 82 switch (state) { | 89 switch (state) { |
| 83 case ByteStreamReader::STREAM_HAS_DATA: | 90 case ByteStreamReader::STREAM_HAS_DATA: |
| 84 break; | 91 break; |
| 85 case ByteStreamReader::STREAM_COMPLETE: | 92 case ByteStreamReader::STREAM_COMPLETE: |
| 93 if (stream_handle_) | |
| 94 stream_handle_->SendCloseEvent(); | |
| 86 registry_->UnregisterStream(url()); | 95 registry_->UnregisterStream(url()); |
|
darin (slow to review)
2013/03/19 06:12:51
is there any possibility that SendCloseEvent could
Zachary Kuznia
2013/03/19 06:59:35
Done.
| |
| 87 return STREAM_COMPLETE; | 96 return STREAM_COMPLETE; |
| 88 case ByteStreamReader::STREAM_EMPTY: | 97 case ByteStreamReader::STREAM_EMPTY: |
| 89 return STREAM_EMPTY; | 98 return STREAM_EMPTY; |
| 90 } | 99 } |
| 91 } | 100 } |
| 92 | 101 |
| 93 size_t remaining_bytes = data_length_ - bytes_read_; | 102 size_t remaining_bytes = data_length_ - bytes_read_; |
| 94 size_t to_read = | 103 size_t to_read = |
| 95 static_cast<size_t>(buf_size) < remaining_bytes ? | 104 static_cast<size_t>(buf_size) < remaining_bytes ? |
| 96 buf_size : remaining_bytes; | 105 buf_size : remaining_bytes; |
| 97 memcpy(buf->data(), data_->data() + bytes_read_, to_read); | 106 memcpy(buf->data(), data_->data() + bytes_read_, to_read); |
| 98 bytes_read_ += to_read; | 107 bytes_read_ += to_read; |
| 99 if (bytes_read_ >= data_length_) | 108 if (bytes_read_ >= data_length_) |
| 100 data_ = NULL; | 109 data_ = NULL; |
| 101 | 110 |
| 102 *bytes_read = to_read; | 111 *bytes_read = to_read; |
| 103 return STREAM_HAS_DATA; | 112 return STREAM_HAS_DATA; |
| 104 } | 113 } |
| 105 | 114 |
| 115 scoped_ptr<StreamHandle> Stream::CreateHandle() { | |
| 116 CHECK(!stream_handle_); | |
| 117 stream_handle_ = new StreamHandleImpl(weak_ptr_factory_.GetWeakPtr()); | |
| 118 return scoped_ptr<StreamHandle>(stream_handle_).Pass(); | |
| 119 } | |
| 120 | |
| 121 void Stream::CloseHandle() { | |
| 122 CHECK(stream_handle_); | |
| 123 stream_handle_ = NULL; | |
| 124 if (write_observer_) | |
| 125 write_observer_->OnClose(this); | |
|
darin (slow to review)
2013/03/19 06:12:51
ditto: calling out to the write observer is calli
Zachary Kuznia
2013/03/19 06:59:35
Done.
| |
| 126 registry_->UnregisterStream(url()); | |
| 127 } | |
| 128 | |
| 106 void Stream::OnSpaceAvailable() { | 129 void Stream::OnSpaceAvailable() { |
| 107 can_add_data_ = true; | 130 can_add_data_ = true; |
| 108 write_observer_->OnSpaceAvailable(this); | 131 if (write_observer_) |
| 132 write_observer_->OnSpaceAvailable(this); | |
| 109 } | 133 } |
| 110 | 134 |
| 111 void Stream::OnDataAvailable() { | 135 void Stream::OnDataAvailable() { |
| 112 if (read_observer_) | 136 if (read_observer_) |
| 113 read_observer_->OnDataAvailable(this); | 137 read_observer_->OnDataAvailable(this); |
| 114 } | 138 } |
| 115 | 139 |
| 116 } // namespace content | 140 } // namespace content |
| 117 | 141 |
| OLD | NEW |