Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 Loading... | |
| 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 Loading... | |
| 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 Loading... | |
| 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 |
| OLD | NEW |