Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "config.h" | 5 #include "config.h" |
| 6 #include "modules/fetch/BodyStreamBuffer.h" | 6 #include "modules/fetch/BodyStreamBuffer.h" |
| 7 | 7 |
| 8 #include "core/dom/DOMArrayBuffer.h" | 8 #include "core/dom/DOMArrayBuffer.h" |
| 9 #include "core/dom/ExceptionCode.h" | |
| 9 | 10 |
| 10 namespace blink { | 11 namespace blink { |
| 11 | 12 |
| 12 namespace { | 13 namespace { |
| 13 | 14 |
| 14 class BlobCreator final : public BodyStreamBuffer::Observer { | 15 class BlobCreator final : public BodyStreamBuffer::Observer { |
| 15 public: | 16 public: |
| 16 BlobCreator(BodyStreamBuffer* buffer, const String& contentType, BodyStreamB uffer::BlobHandleCreatorClient* client) | 17 BlobCreator(BodyStreamBuffer* buffer, const String& contentType, BodyStreamB uffer::BlobHandleCreatorClient* client) |
| 17 : m_buffer(buffer) | 18 : m_buffer(buffer) |
| 18 , m_client(client) | 19 , m_client(client) |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 127 m_inBuffer->unregisterObserver(); | 128 m_inBuffer->unregisterObserver(); |
| 128 m_inBuffer.clear(); | 129 m_inBuffer.clear(); |
| 129 m_outBuffer1.clear(); | 130 m_outBuffer1.clear(); |
| 130 m_outBuffer2.clear(); | 131 m_outBuffer2.clear(); |
| 131 } | 132 } |
| 132 Member<BodyStreamBuffer> m_inBuffer; | 133 Member<BodyStreamBuffer> m_inBuffer; |
| 133 Member<BodyStreamBuffer> m_outBuffer1; | 134 Member<BodyStreamBuffer> m_outBuffer1; |
| 134 Member<BodyStreamBuffer> m_outBuffer2; | 135 Member<BodyStreamBuffer> m_outBuffer2; |
| 135 }; | 136 }; |
| 136 | 137 |
| 138 // WebDataConsumerHandleAdapter is used to migrate incrementally | |
| 139 // from BodyStreamBuffer to FetchDataConsumerHandle and will be removed | |
| 140 // after the migration. | |
| 141 class WebDataConsumerHandleAdapter | |
| 142 : public GarbageCollectedFinalized<WebDataConsumerHandleAdapter> | |
| 143 , public WebDataConsumerHandle::Client { | |
| 144 public: | |
| 145 WebDataConsumerHandleAdapter(PassOwnPtr<WebDataConsumerHandle> handle, const String& failureMessage) | |
| 146 : m_reader(handle->obtainReader(this)) | |
| 147 , m_failureMessage(failureMessage) | |
| 148 , m_outputBuffer(new BodyStreamBuffer(new Canceller(this))) | |
| 149 { | |
| 150 ASSERT(m_reader); | |
| 151 } | |
| 152 | |
| 153 ~WebDataConsumerHandleAdapter() override { } | |
|
yhirano
2015/06/17 01:34:02
Do we need an empty destructor?
hiroshige
2015/06/17 07:21:28
Done.
| |
| 154 | |
| 155 BodyStreamBuffer* outputBuffer() { return m_outputBuffer; } | |
| 156 | |
| 157 DEFINE_INLINE_TRACE() | |
| 158 { | |
| 159 visitor->trace(m_outputBuffer); | |
| 160 } | |
| 161 | |
| 162 private: | |
| 163 class Canceller : public BodyStreamBuffer::Canceller { | |
| 164 public: | |
| 165 Canceller(WebDataConsumerHandleAdapter* source) : m_source(source) { } | |
|
yhirano
2015/06/17 01:34:03
explicit
hiroshige
2015/06/17 07:21:28
Done.
| |
| 166 | |
| 167 void cancel() override | |
| 168 { | |
| 169 m_source->close(); | |
| 170 } | |
| 171 | |
| 172 DEFINE_INLINE_VIRTUAL_TRACE() | |
| 173 { | |
| 174 BodyStreamBuffer::Canceller::trace(visitor); | |
| 175 visitor->trace(m_source); | |
| 176 } | |
| 177 | |
| 178 private: | |
| 179 Member<WebDataConsumerHandleAdapter> m_source; | |
| 180 }; | |
| 181 | |
| 182 void didGetReadable() override | |
| 183 { | |
| 184 while (true) { | |
| 185 const void* buffer; | |
| 186 size_t available; | |
| 187 WebDataConsumerHandle::Result result = m_reader->beginRead(&buffer, WebDataConsumerHandle::FlagNone, &available); | |
| 188 switch (result) { | |
| 189 case WebDataConsumerHandle::Ok: | |
| 190 m_outputBuffer->write(DOMArrayBuffer::create(buffer, available)) ; | |
| 191 m_reader->endRead(available); | |
| 192 break; | |
| 193 | |
| 194 case WebDataConsumerHandle::Done: | |
| 195 close(); | |
| 196 return; | |
| 197 | |
| 198 case WebDataConsumerHandle::ShouldWait: | |
| 199 return; | |
| 200 | |
| 201 case WebDataConsumerHandle::Busy: | |
| 202 case WebDataConsumerHandle::ResourceExhausted: | |
| 203 case WebDataConsumerHandle::UnexpectedError: | |
| 204 error(); | |
| 205 return; | |
| 206 } | |
| 207 } | |
| 208 } | |
| 209 | |
| 210 void error() | |
| 211 { | |
| 212 m_reader.clear(); | |
| 213 m_outputBuffer->error(DOMException::create(NetworkError, m_failureMessag e)); | |
| 214 m_outputBuffer.clear(); | |
| 215 } | |
| 216 | |
| 217 void close() | |
| 218 { | |
| 219 m_reader.clear(); | |
| 220 m_outputBuffer->close(); | |
| 221 m_outputBuffer.clear(); | |
| 222 } | |
| 223 | |
| 224 OwnPtr<WebDataConsumerHandle::Reader> m_reader; | |
| 225 String m_failureMessage; | |
| 226 | |
| 227 Member<BodyStreamBuffer> m_outputBuffer; | |
| 228 }; | |
| 229 | |
| 230 | |
| 137 } // namespace | 231 } // namespace |
| 138 | 232 |
| 139 PassRefPtr<DOMArrayBuffer> BodyStreamBuffer::read() | 233 PassRefPtr<DOMArrayBuffer> BodyStreamBuffer::read() |
| 140 { | 234 { |
| 141 if (m_queue.isEmpty()) | 235 if (m_queue.isEmpty()) |
| 142 return PassRefPtr<DOMArrayBuffer>(); | 236 return PassRefPtr<DOMArrayBuffer>(); |
| 143 return m_queue.takeFirst(); | 237 return m_queue.takeFirst(); |
| 144 } | 238 } |
| 145 | 239 |
| 146 void BodyStreamBuffer::write(PassRefPtr<DOMArrayBuffer> chunk) | 240 void BodyStreamBuffer::write(PassRefPtr<DOMArrayBuffer> chunk) |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 211 visitor->trace(m_canceller); | 305 visitor->trace(m_canceller); |
| 212 } | 306 } |
| 213 | 307 |
| 214 BodyStreamBuffer::BodyStreamBuffer(Canceller* canceller) | 308 BodyStreamBuffer::BodyStreamBuffer(Canceller* canceller) |
| 215 : m_isClosed(false) | 309 : m_isClosed(false) |
| 216 , m_canceller(canceller) | 310 , m_canceller(canceller) |
| 217 { | 311 { |
| 218 } | 312 } |
| 219 | 313 |
| 220 } // namespace blink | 314 } // namespace blink |
| OLD | NEW |