Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(623)

Side by Side Diff: Source/modules/serviceworkers/Body.cpp

Issue 606653006: bindings: Adds DOMArrayBuffer, etc. as thin wrappers for ArrayBuffer, etc. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Synced. Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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/Body.h" 6 #include "modules/serviceworkers/Body.h"
7 7
8 #include "bindings/core/v8/ScriptPromiseResolver.h" 8 #include "bindings/core/v8/ScriptPromiseResolver.h"
9 #include "bindings/core/v8/ScriptState.h" 9 #include "bindings/core/v8/ScriptState.h"
10 #include "bindings/core/v8/V8ThrowException.h" 10 #include "bindings/core/v8/V8ThrowException.h"
11 #include "core/dom/DOMArrayBuffer.h"
11 #include "core/fileapi/Blob.h" 12 #include "core/fileapi/Blob.h"
12 #include "core/fileapi/FileReaderLoader.h" 13 #include "core/fileapi/FileReaderLoader.h"
13 #include "core/fileapi/FileReaderLoaderClient.h" 14 #include "core/fileapi/FileReaderLoaderClient.h"
14 15
15 namespace blink { 16 namespace blink {
16 17
17 ScriptPromise Body::readAsync(ScriptState* scriptState, ResponseType type) 18 ScriptPromise Body::readAsync(ScriptState* scriptState, ResponseType type)
18 { 19 {
19 if (m_bodyUsed) 20 if (m_bodyUsed)
20 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr ror("Already read", scriptState->isolate())); 21 return ScriptPromise::reject(scriptState, V8ThrowException::createTypeEr ror("Already read", scriptState->isolate()));
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after
159 // FileReaderLoaderClient functions. 160 // FileReaderLoaderClient functions.
160 void Body::didStartLoading() { } 161 void Body::didStartLoading() { }
161 void Body::didReceiveData() { } 162 void Body::didReceiveData() { }
162 void Body::didFinishLoading() 163 void Body::didFinishLoading()
163 { 164 {
164 if (!m_resolver->executionContext() || m_resolver->executionContext()->activ eDOMObjectsAreStopped()) 165 if (!m_resolver->executionContext() || m_resolver->executionContext()->activ eDOMObjectsAreStopped())
165 return; 166 return;
166 167
167 switch (m_responseType) { 168 switch (m_responseType) {
168 case ResponseAsArrayBuffer: 169 case ResponseAsArrayBuffer:
169 m_resolver->resolve(m_loader->arrayBufferResult()); 170 m_resolver->resolve(DOMArrayBuffer::create(m_loader->arrayBufferResult() ));
170 break; 171 break;
171 case ResponseAsBlob: { 172 case ResponseAsBlob: {
172 ASSERT(blobDataHandle()->size() == kuint64max); 173 ASSERT(blobDataHandle()->size() == kuint64max);
173 OwnPtr<BlobData> blobData = BlobData::create(); 174 OwnPtr<BlobData> blobData = BlobData::create();
174 RefPtr<ArrayBuffer> buffer = m_loader->arrayBufferResult(); 175 RefPtr<ArrayBuffer> buffer = m_loader->arrayBufferResult();
175 blobData->appendArrayBuffer(buffer.get()); 176 blobData->appendArrayBuffer(buffer.get());
176 const size_t length = blobData->length(); 177 const size_t length = blobData->length();
177 m_resolver->resolve(Blob::create(BlobDataHandle::create(blobData.release (), length))); 178 m_resolver->resolve(Blob::create(BlobDataHandle::create(blobData.release (), length)));
178 break; 179 break;
179 } 180 }
(...skipping 16 matching lines...) Expand all
196 { 197 {
197 ASSERT(m_resolver); 198 ASSERT(m_resolver);
198 if (!m_resolver->executionContext() || m_resolver->executionContext()->activ eDOMObjectsAreStopped()) 199 if (!m_resolver->executionContext() || m_resolver->executionContext()->activ eDOMObjectsAreStopped())
199 return; 200 return;
200 201
201 m_resolver->resolve(""); 202 m_resolver->resolve("");
202 m_resolver.clear(); 203 m_resolver.clear();
203 } 204 }
204 205
205 } // namespace blink 206 } // namespace blink
OLDNEW
« no previous file with comments | « Source/modules/mediastream/RTCDataChannel.cpp ('k') | Source/modules/serviceworkers/RequestInit.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698