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 "modules/fetch/BodyStreamBuffer.h" | 5 #include "modules/fetch/BodyStreamBuffer.h" |
6 | 6 |
7 #include "bindings/core/v8/ScriptState.h" | 7 #include "bindings/core/v8/ScriptState.h" |
8 #include "bindings/core/v8/V8HiddenValue.h" | 8 #include "bindings/core/v8/V8HiddenValue.h" |
9 #include "bindings/core/v8/V8ThrowException.h" | 9 #include "bindings/core/v8/V8ThrowException.h" |
10 #include "core/dom/DOMArrayBuffer.h" | 10 #include "core/dom/DOMArrayBuffer.h" |
(...skipping 28 matching lines...) Expand all Loading... |
39 PassRefPtr<BlobDataHandle> blobDataHandle) override { | 39 PassRefPtr<BlobDataHandle> blobDataHandle) override { |
40 m_buffer->endLoading(); | 40 m_buffer->endLoading(); |
41 m_client->didFetchDataLoadedBlobHandle(std::move(blobDataHandle)); | 41 m_client->didFetchDataLoadedBlobHandle(std::move(blobDataHandle)); |
42 } | 42 } |
43 | 43 |
44 void didFetchDataLoadedArrayBuffer(DOMArrayBuffer* arrayBuffer) override { | 44 void didFetchDataLoadedArrayBuffer(DOMArrayBuffer* arrayBuffer) override { |
45 m_buffer->endLoading(); | 45 m_buffer->endLoading(); |
46 m_client->didFetchDataLoadedArrayBuffer(arrayBuffer); | 46 m_client->didFetchDataLoadedArrayBuffer(arrayBuffer); |
47 } | 47 } |
48 | 48 |
| 49 void didFetchDataLoadedFormData(FormData* formData) override { |
| 50 m_buffer->endLoading(); |
| 51 m_client->didFetchDataLoadedFormData(formData); |
| 52 } |
| 53 |
49 void didFetchDataLoadedString(const String& string) override { | 54 void didFetchDataLoadedString(const String& string) override { |
50 m_buffer->endLoading(); | 55 m_buffer->endLoading(); |
51 m_client->didFetchDataLoadedString(string); | 56 m_client->didFetchDataLoadedString(string); |
52 } | 57 } |
53 | 58 |
54 void didFetchDataLoadedStream() override { | 59 void didFetchDataLoadedStream() override { |
55 m_buffer->endLoading(); | 60 m_buffer->endLoading(); |
56 m_client->didFetchDataLoadedStream(); | 61 m_client->didFetchDataLoadedStream(); |
57 } | 62 } |
58 | 63 |
(...skipping 215 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
274 } | 279 } |
275 | 280 |
276 ScriptState::Scope scope(m_scriptState.get()); | 281 ScriptState::Scope scope(m_scriptState.get()); |
277 NonThrowableExceptionState exceptionState; | 282 NonThrowableExceptionState exceptionState; |
278 ScriptValue reader = ReadableStreamOperations::getReader( | 283 ScriptValue reader = ReadableStreamOperations::getReader( |
279 m_scriptState.get(), stream(), exceptionState); | 284 m_scriptState.get(), stream(), exceptionState); |
280 ReadableStreamOperations::defaultReaderRead(m_scriptState.get(), reader); | 285 ReadableStreamOperations::defaultReaderRead(m_scriptState.get(), reader); |
281 } | 286 } |
282 | 287 |
283 void BodyStreamBuffer::close() { | 288 void BodyStreamBuffer::close() { |
284 controller()->close(); | 289 if (controller()) |
| 290 controller()->close(); |
285 cancelConsumer(); | 291 cancelConsumer(); |
286 } | 292 } |
287 | 293 |
288 void BodyStreamBuffer::error() { | 294 void BodyStreamBuffer::error() { |
289 { | 295 { |
290 ScriptState::Scope scope(m_scriptState.get()); | 296 ScriptState::Scope scope(m_scriptState.get()); |
291 controller()->error(V8ThrowException::createTypeError( | 297 controller()->error(V8ThrowException::createTypeError( |
292 m_scriptState->isolate(), "network error")); | 298 m_scriptState->isolate(), "network error")); |
293 } | 299 } |
294 cancelConsumer(); | 300 cancelConsumer(); |
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
384 } | 390 } |
385 if (isErrored) | 391 if (isErrored) |
386 return BytesConsumer::createErrored(BytesConsumer::Error("error")); | 392 return BytesConsumer::createErrored(BytesConsumer::Error("error")); |
387 | 393 |
388 DCHECK(consumer); | 394 DCHECK(consumer); |
389 consumer->clearClient(); | 395 consumer->clearClient(); |
390 return consumer; | 396 return consumer; |
391 } | 397 } |
392 | 398 |
393 } // namespace blink | 399 } // namespace blink |
OLD | NEW |