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

Side by Side Diff: webkit/glue/resource_request_body.cc

Issue 11778016: net: Stop using base::WorkerPool from UploadFileElementReader (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: _ Created 7 years, 11 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
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "webkit/glue/resource_request_body.h" 5 #include "webkit/glue/resource_request_body.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "net/base/upload_bytes_element_reader.h" 8 #include "net/base/upload_bytes_element_reader.h"
9 #include "net/base/upload_data_stream.h" 9 #include "net/base/upload_data_stream.h"
10 #include "net/base/upload_file_element_reader.h" 10 #include "net/base/upload_file_element_reader.h"
11 #include "webkit/blob/blob_storage_controller.h" 11 #include "webkit/blob/blob_storage_controller.h"
12 #include "webkit/fileapi/file_system_context.h"
13 #include "webkit/fileapi/file_system_task_runners.h"
12 14
13 using webkit_blob::BlobData; 15 using webkit_blob::BlobData;
14 using webkit_blob::BlobStorageController; 16 using webkit_blob::BlobStorageController;
15 17
16 namespace webkit_glue { 18 namespace webkit_glue {
17 19
18 namespace { 20 namespace {
19 21
20 // A subclass of net::UploadBytesElementReader which owns ResourceRequestBody. 22 // A subclass of net::UploadBytesElementReader which owns ResourceRequestBody.
21 class BytesElementReader : public net::UploadBytesElementReader { 23 class BytesElementReader : public net::UploadBytesElementReader {
(...skipping 12 matching lines...) Expand all
34 36
35 DISALLOW_COPY_AND_ASSIGN(BytesElementReader); 37 DISALLOW_COPY_AND_ASSIGN(BytesElementReader);
36 }; 38 };
37 39
38 // A subclass of net::UploadFileElementReader which owns ResourceRequestBody. 40 // A subclass of net::UploadFileElementReader which owns ResourceRequestBody.
39 // This class is necessary to ensure the BlobData and any attached shareable 41 // This class is necessary to ensure the BlobData and any attached shareable
40 // files survive until upload completion. 42 // files survive until upload completion.
41 class FileElementReader : public net::UploadFileElementReader { 43 class FileElementReader : public net::UploadFileElementReader {
42 public: 44 public:
43 FileElementReader(ResourceRequestBody* resource_request_body, 45 FileElementReader(ResourceRequestBody* resource_request_body,
46 base::TaskRunner* task_runner,
44 const ResourceRequestBody::Element& element) 47 const ResourceRequestBody::Element& element)
45 : net::UploadFileElementReader(element.path(), 48 : net::UploadFileElementReader(task_runner,
49 element.path(),
46 element.offset(), 50 element.offset(),
47 element.length(), 51 element.length(),
48 element.expected_modification_time()), 52 element.expected_modification_time()),
49 resource_request_body_(resource_request_body) { 53 resource_request_body_(resource_request_body) {
50 DCHECK_EQ(ResourceRequestBody::Element::TYPE_FILE, element.type()); 54 DCHECK_EQ(ResourceRequestBody::Element::TYPE_FILE, element.type());
51 } 55 }
52 56
53 virtual ~FileElementReader() {} 57 virtual ~FileElementReader() {}
54 58
55 private: 59 private:
(...skipping 30 matching lines...) Expand all
86 void ResourceRequestBody::AppendFileSystemFileRange( 90 void ResourceRequestBody::AppendFileSystemFileRange(
87 const GURL& url, uint64 offset, uint64 length, 91 const GURL& url, uint64 offset, uint64 length,
88 const base::Time& expected_modification_time) { 92 const base::Time& expected_modification_time) {
89 elements_.push_back(Element()); 93 elements_.push_back(Element());
90 elements_.back().SetToFileSystemUrlRange(url, offset, length, 94 elements_.back().SetToFileSystemUrlRange(url, offset, length,
91 expected_modification_time); 95 expected_modification_time);
92 } 96 }
93 97
94 net::UploadDataStream* 98 net::UploadDataStream*
95 ResourceRequestBody::ResolveElementsAndCreateUploadDataStream( 99 ResourceRequestBody::ResolveElementsAndCreateUploadDataStream(
96 BlobStorageController* blob_controller) { 100 BlobStorageController* blob_controller,
101 fileapi::FileSystemContext* file_system_context) {
97 // Resolve all blob elements. 102 // Resolve all blob elements.
98 std::vector<const Element*> resolved_elements; 103 std::vector<const Element*> resolved_elements;
99 for (size_t i = 0; i < elements_.size(); ++i) { 104 for (size_t i = 0; i < elements_.size(); ++i) {
100 const Element& element = elements_[i]; 105 const Element& element = elements_[i];
101 if (element.type() == Element::TYPE_BLOB) { 106 if (element.type() == Element::TYPE_BLOB) {
102 ResolveBlobReference(blob_controller, element.url(), &resolved_elements); 107 ResolveBlobReference(blob_controller, element.url(), &resolved_elements);
103 } else { 108 } else {
104 // No need to resolve, just append the element. 109 // No need to resolve, just append the element.
105 resolved_elements.push_back(&element); 110 resolved_elements.push_back(&element);
106 } 111 }
107 } 112 }
108 113
109 ScopedVector<net::UploadElementReader> element_readers; 114 ScopedVector<net::UploadElementReader> element_readers;
110 for (size_t i = 0; i < resolved_elements.size(); ++i) { 115 for (size_t i = 0; i < resolved_elements.size(); ++i) {
111 const Element& element = *resolved_elements[i]; 116 const Element& element = *resolved_elements[i];
112 switch (element.type()) { 117 switch (element.type()) {
113 case Element::TYPE_BYTES: 118 case Element::TYPE_BYTES:
114 element_readers.push_back(new BytesElementReader(this, element)); 119 element_readers.push_back(new BytesElementReader(this, element));
115 break; 120 break;
116 case Element::TYPE_FILE: 121 case Element::TYPE_FILE:
117 element_readers.push_back(new FileElementReader(this, element)); 122 element_readers.push_back(new FileElementReader(
123 this,
124 file_system_context->task_runners()->file_task_runner(),
kinuko 2013/01/07 08:16:22 While I can see why you wanted to pass file_system
hashimoto 2013/01/07 09:12:33 Done. When we support Filesystem files, are we go
kinuko 2013/01/08 03:32:48 To me passing both sounds more reasonable, though
125 element));
118 break; 126 break;
119 case Element::TYPE_FILE_FILESYSTEM: 127 case Element::TYPE_FILE_FILESYSTEM:
120 // TODO(kinuko): Resolve FileSystemURL before creating UploadData. 128 // TODO(kinuko): Resolve FileSystemURL before creating UploadData.
121 NOTREACHED(); 129 NOTREACHED();
122 break; 130 break;
123 case Element::TYPE_BLOB: 131 case Element::TYPE_BLOB:
124 // Blob elements should be resolved beforehand. 132 // Blob elements should be resolved beforehand.
125 NOTREACHED(); 133 NOTREACHED();
126 break; 134 break;
127 case Element::TYPE_UNKNOWN: 135 case Element::TYPE_UNKNOWN:
(...skipping 26 matching lines...) Expand all
154 162
155 // Append the elements in the referred blob data. 163 // Append the elements in the referred blob data.
156 for (size_t i = 0; i < blob_data->items().size(); ++i) { 164 for (size_t i = 0; i < blob_data->items().size(); ++i) {
157 const BlobData::Item& item = blob_data->items().at(i); 165 const BlobData::Item& item = blob_data->items().at(i);
158 DCHECK_NE(BlobData::Item::TYPE_BLOB, item.type()); 166 DCHECK_NE(BlobData::Item::TYPE_BLOB, item.type());
159 resolved_elements->push_back(&item); 167 resolved_elements->push_back(&item);
160 } 168 }
161 } 169 }
162 170
163 } // namespace webkit_glue 171 } // namespace webkit_glue
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698