 Chromium Code Reviews
 Chromium Code Reviews Issue 1233573002:
  [Fetch API] Remove DrainingBuffer.  (Closed) 
  Base URL: svn://svn.chromium.org/blink/trunk
    
  
    Issue 1233573002:
  [Fetch API] Remove DrainingBuffer.  (Closed) 
  Base URL: svn://svn.chromium.org/blink/trunk| 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/serviceworkers/RespondWithObserver.h" | 6 #include "modules/serviceworkers/RespondWithObserver.h" | 
| 7 | 7 | 
| 8 #include "bindings/core/v8/ScriptFunction.h" | 8 #include "bindings/core/v8/ScriptFunction.h" | 
| 9 #include "bindings/core/v8/ScriptPromise.h" | 9 #include "bindings/core/v8/ScriptPromise.h" | 
| 10 #include "bindings/core/v8/ScriptValue.h" | 10 #include "bindings/core/v8/ScriptValue.h" | 
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 54 case WebServiceWorkerResponseErrorUnknown: | 54 case WebServiceWorkerResponseErrorUnknown: | 
| 55 default: | 55 default: | 
| 56 errorMessage = errorMessage + "an unexpected error occurred."; | 56 errorMessage = errorMessage + "an unexpected error occurred."; | 
| 57 break; | 57 break; | 
| 58 } | 58 } | 
| 59 return errorMessage; | 59 return errorMessage; | 
| 60 } | 60 } | 
| 61 | 61 | 
| 62 } // namespace | 62 } // namespace | 
| 63 | 63 | 
| 64 namespace { | |
| 
hiroshige
2015/07/24 12:47:03
nit: can we merge two anonymous namespaces (i.e. r
 
yhirano
2015/07/29 08:45:02
Done.
 | |
| 65 | |
| 66 class LoaderClient final : public GarbageCollectedFinalized<LoaderClient>, publi c FetchDataLoader::Client { | |
| 
hiroshige
2015/07/24 12:47:03
nit optional: how about a name like NoopLoaderClie
 
yhirano
2015/07/29 08:45:02
Done.
 | |
| 67 WTF_MAKE_NONCOPYABLE(LoaderClient); | |
| 68 USING_GARBAGE_COLLECTED_MIXIN(LoaderClient); | |
| 69 public: | |
| 70 LoaderClient() = default; | |
| 71 void didFetchDataLoadedStream() override {} | |
| 72 void didFetchDataLoadFailed() override {} | |
| 73 DEFINE_INLINE_TRACE() { FetchDataLoader::Client::trace(visitor); } | |
| 74 }; | |
| 75 | |
| 76 } // namespace | |
| 77 | |
| 64 class RespondWithObserver::ThenFunction final : public ScriptFunction { | 78 class RespondWithObserver::ThenFunction final : public ScriptFunction { | 
| 65 public: | 79 public: | 
| 66 enum ResolveType { | 80 enum ResolveType { | 
| 67 Fulfilled, | 81 Fulfilled, | 
| 68 Rejected, | 82 Rejected, | 
| 69 }; | 83 }; | 
| 70 | 84 | 
| 71 static v8::Local<v8::Function> createFunction(ScriptState* scriptState, Resp ondWithObserver* observer, ResolveType type) | 85 static v8::Local<v8::Function> createFunction(ScriptState* scriptState, Resp ondWithObserver* observer, ResolveType type) | 
| 72 { | 86 { | 
| 73 ThenFunction* self = new ThenFunction(scriptState, observer, type); | 87 ThenFunction* self = new ThenFunction(scriptState, observer, type); | 
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 182 } | 196 } | 
| 183 if (m_frameType != WebURLRequest::FrameTypeNone && responseType != FetchResp onseData::BasicType && responseType != FetchResponseData::DefaultType) { | 197 if (m_frameType != WebURLRequest::FrameTypeNone && responseType != FetchResp onseData::BasicType && responseType != FetchResponseData::DefaultType) { | 
| 184 responseWasRejected(WebServiceWorkerResponseErrorResponseTypeNotBasicOrD efault); | 198 responseWasRejected(WebServiceWorkerResponseErrorResponseTypeNotBasicOrD efault); | 
| 185 return; | 199 return; | 
| 186 } | 200 } | 
| 187 if (response->bodyUsed()) { | 201 if (response->bodyUsed()) { | 
| 188 responseWasRejected(WebServiceWorkerResponseErrorBodyUsed); | 202 responseWasRejected(WebServiceWorkerResponseErrorBodyUsed); | 
| 189 return; | 203 return; | 
| 190 } | 204 } | 
| 191 | 205 | 
| 192 response->lockBody(Body::PassBody); | 206 response->setBodyPassed(); | 
| 193 if (OwnPtr<DrainingBodyStreamBuffer> buffer = response->createInternalDraini ngStream()) { | |
| 194 WebServiceWorkerResponse webResponse; | |
| 195 response->populateWebServiceWorkerResponse(webResponse); | |
| 196 if (RefPtr<BlobDataHandle> blobDataHandle = buffer->drainAsBlobDataHandl e(FetchDataConsumerHandle::Reader::AllowBlobWithInvalidSize)) { | |
| 197 webResponse.setBlobDataHandle(blobDataHandle); | |
| 198 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleF etchEvent(m_eventID, webResponse); | |
| 199 m_state = Done; | |
| 200 return; | |
| 201 } | |
| 202 Stream* outStream = Stream::create(executionContext(), ""); | |
| 203 webResponse.setStreamURL(outStream->url()); | |
| 204 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleFetch Event(m_eventID, webResponse); | |
| 205 FetchDataLoader* loader = FetchDataLoader::createLoaderAsStream(outStrea m); | |
| 206 buffer->startLoading(loader, nullptr); | |
| 207 m_state = Done; | |
| 208 return; | |
| 209 } | |
| 210 WebServiceWorkerResponse webResponse; | 207 WebServiceWorkerResponse webResponse; | 
| 211 response->populateWebServiceWorkerResponse(webResponse); | 208 response->populateWebServiceWorkerResponse(webResponse); | 
| 209 BodyStreamBuffer* buffer = response->internalBodyBuffer(); | |
| 210 if (buffer->hasBody()) { | |
| 211 RefPtr<BlobDataHandle> blobDataHandle = buffer->drainAsBlobDataHandle(Fe tchDataConsumerHandle::Reader::AllowBlobWithInvalidSize); | |
| 212 if (blobDataHandle) { | |
| 213 webResponse.setBlobDataHandle(blobDataHandle); | |
| 214 } else { | |
| 215 Stream* outStream = Stream::create(executionContext(), ""); | |
| 216 webResponse.setStreamURL(outStream->url()); | |
| 217 buffer->startLoading(executionContext(), FetchDataLoader::createLoad erAsStream(outStream), new LoaderClient); | |
| 218 } | |
| 219 } | |
| 212 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleFetchEven t(m_eventID, webResponse); | 220 ServiceWorkerGlobalScopeClient::from(executionContext())->didHandleFetchEven t(m_eventID, webResponse); | 
| 213 m_state = Done; | 221 m_state = Done; | 
| 214 } | 222 } | 
| 215 | 223 | 
| 216 RespondWithObserver::RespondWithObserver(ExecutionContext* context, int eventID, const KURL& requestURL, WebURLRequest::FetchRequestMode requestMode, WebURLRequ est::FrameType frameType) | 224 RespondWithObserver::RespondWithObserver(ExecutionContext* context, int eventID, const KURL& requestURL, WebURLRequest::FetchRequestMode requestMode, WebURLRequ est::FrameType frameType) | 
| 217 : ContextLifecycleObserver(context) | 225 : ContextLifecycleObserver(context) | 
| 218 , m_eventID(eventID) | 226 , m_eventID(eventID) | 
| 219 , m_requestURL(requestURL) | 227 , m_requestURL(requestURL) | 
| 220 , m_requestMode(requestMode) | 228 , m_requestMode(requestMode) | 
| 221 , m_frameType(frameType) | 229 , m_frameType(frameType) | 
| 222 , m_state(Initial) | 230 , m_state(Initial) | 
| 223 { | 231 { | 
| 224 } | 232 } | 
| 225 | 233 | 
| 226 DEFINE_TRACE(RespondWithObserver) | 234 DEFINE_TRACE(RespondWithObserver) | 
| 227 { | 235 { | 
| 228 ContextLifecycleObserver::trace(visitor); | 236 ContextLifecycleObserver::trace(visitor); | 
| 229 } | 237 } | 
| 230 | 238 | 
| 231 } // namespace blink | 239 } // namespace blink | 
| OLD | NEW |