| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/browser/fileapi/file_system_operation_runner.h" | 5 #include "webkit/browser/fileapi/file_system_operation_runner.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/message_loop/message_loop_proxy.h" | 8 #include "base/message_loop/message_loop_proxy.h" |
| 9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 10 #include "net/url_request/url_request_context.h" | 10 #include "net/url_request/url_request_context.h" |
| 11 #include "webkit/browser/blob/blob_url_request_job_factory.h" | 11 #include "webkit/browser/blob/blob_url_request_job_factory.h" |
| 12 #include "webkit/browser/fileapi/file_observers.h" | 12 #include "webkit/browser/fileapi/file_observers.h" |
| 13 #include "webkit/browser/fileapi/file_stream_writer.h" | 13 #include "webkit/browser/fileapi/file_stream_writer.h" |
| 14 #include "webkit/browser/fileapi/file_system_context.h" | 14 #include "webkit/browser/fileapi/file_system_context.h" |
| 15 #include "webkit/browser/fileapi/file_system_operation.h" | 15 #include "webkit/browser/fileapi/file_system_operation.h" |
| 16 #include "webkit/browser/fileapi/file_writer_delegate.h" | 16 #include "webkit/browser/fileapi/file_writer_delegate.h" |
| 17 #include "webkit/common/blob/shareable_file_reference.h" | 17 #include "webkit/common/blob/shareable_file_reference.h" |
| 18 | 18 |
| 19 namespace fileapi { | 19 namespace storage { |
| 20 | 20 |
| 21 typedef FileSystemOperationRunner::OperationID OperationID; | 21 typedef FileSystemOperationRunner::OperationID OperationID; |
| 22 | 22 |
| 23 class FileSystemOperationRunner::BeginOperationScoper | 23 class FileSystemOperationRunner::BeginOperationScoper |
| 24 : public base::SupportsWeakPtr< | 24 : public base::SupportsWeakPtr< |
| 25 FileSystemOperationRunner::BeginOperationScoper> { | 25 FileSystemOperationRunner::BeginOperationScoper> { |
| 26 public: | 26 public: |
| 27 BeginOperationScoper() {} | 27 BeginOperationScoper() {} |
| 28 private: | 28 private: |
| 29 DISALLOW_COPY_AND_ASSIGN(BeginOperationScoper); | 29 DISALLOW_COPY_AND_ASSIGN(BeginOperationScoper); |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 231 operation->Remove( | 231 operation->Remove( |
| 232 url, recursive, | 232 url, recursive, |
| 233 base::Bind(&FileSystemOperationRunner::DidFinish, AsWeakPtr(), | 233 base::Bind(&FileSystemOperationRunner::DidFinish, AsWeakPtr(), |
| 234 handle, callback)); | 234 handle, callback)); |
| 235 return handle.id; | 235 return handle.id; |
| 236 } | 236 } |
| 237 | 237 |
| 238 OperationID FileSystemOperationRunner::Write( | 238 OperationID FileSystemOperationRunner::Write( |
| 239 const net::URLRequestContext* url_request_context, | 239 const net::URLRequestContext* url_request_context, |
| 240 const FileSystemURL& url, | 240 const FileSystemURL& url, |
| 241 scoped_ptr<webkit_blob::BlobDataHandle> blob, | 241 scoped_ptr<storage::BlobDataHandle> blob, |
| 242 int64 offset, | 242 int64 offset, |
| 243 const WriteCallback& callback) { | 243 const WriteCallback& callback) { |
| 244 base::File::Error error = base::File::FILE_OK; | 244 base::File::Error error = base::File::FILE_OK; |
| 245 FileSystemOperation* operation = | 245 FileSystemOperation* operation = |
| 246 file_system_context_->CreateFileSystemOperation(url, &error); | 246 file_system_context_->CreateFileSystemOperation(url, &error); |
| 247 | 247 |
| 248 BeginOperationScoper scope; | 248 BeginOperationScoper scope; |
| 249 OperationHandle handle = BeginOperation(operation, scope.AsWeakPtr()); | 249 OperationHandle handle = BeginOperation(operation, scope.AsWeakPtr()); |
| 250 if (!operation) { | 250 if (!operation) { |
| 251 DidWrite(handle, callback, error, 0, true); | 251 DidWrite(handle, callback, error, 0, true); |
| 252 return handle.id; | 252 return handle.id; |
| 253 } | 253 } |
| 254 | 254 |
| 255 scoped_ptr<FileStreamWriter> writer( | 255 scoped_ptr<FileStreamWriter> writer( |
| 256 file_system_context_->CreateFileStreamWriter(url, offset)); | 256 file_system_context_->CreateFileStreamWriter(url, offset)); |
| 257 if (!writer) { | 257 if (!writer) { |
| 258 // Write is not supported. | 258 // Write is not supported. |
| 259 DidWrite(handle, callback, base::File::FILE_ERROR_SECURITY, 0, true); | 259 DidWrite(handle, callback, base::File::FILE_ERROR_SECURITY, 0, true); |
| 260 return handle.id; | 260 return handle.id; |
| 261 } | 261 } |
| 262 | 262 |
| 263 FileWriterDelegate::FlushPolicy flush_policy = | 263 FileWriterDelegate::FlushPolicy flush_policy = |
| 264 file_system_context_->ShouldFlushOnWriteCompletion(url.type()) | 264 file_system_context_->ShouldFlushOnWriteCompletion(url.type()) |
| 265 ? FileWriterDelegate::FLUSH_ON_COMPLETION | 265 ? FileWriterDelegate::FLUSH_ON_COMPLETION |
| 266 : FileWriterDelegate::NO_FLUSH_ON_COMPLETION; | 266 : FileWriterDelegate::NO_FLUSH_ON_COMPLETION; |
| 267 scoped_ptr<FileWriterDelegate> writer_delegate( | 267 scoped_ptr<FileWriterDelegate> writer_delegate( |
| 268 new FileWriterDelegate(writer.Pass(), flush_policy)); | 268 new FileWriterDelegate(writer.Pass(), flush_policy)); |
| 269 | 269 |
| 270 scoped_ptr<net::URLRequest> blob_request( | 270 scoped_ptr<net::URLRequest> blob_request( |
| 271 webkit_blob::BlobProtocolHandler::CreateBlobRequest( | 271 storage::BlobProtocolHandler::CreateBlobRequest( |
| 272 blob.Pass(), | 272 blob.Pass(), url_request_context, writer_delegate.get())); |
| 273 url_request_context, | |
| 274 writer_delegate.get())); | |
| 275 | 273 |
| 276 PrepareForWrite(handle.id, url); | 274 PrepareForWrite(handle.id, url); |
| 277 operation->Write( | 275 operation->Write( |
| 278 url, writer_delegate.Pass(), blob_request.Pass(), | 276 url, writer_delegate.Pass(), blob_request.Pass(), |
| 279 base::Bind(&FileSystemOperationRunner::DidWrite, AsWeakPtr(), | 277 base::Bind(&FileSystemOperationRunner::DidWrite, AsWeakPtr(), |
| 280 handle, callback)); | 278 handle, callback)); |
| 281 return handle.id; | 279 return handle.id; |
| 282 } | 280 } |
| 283 | 281 |
| 284 OperationID FileSystemOperationRunner::Truncate( | 282 OperationID FileSystemOperationRunner::Truncate( |
| (...skipping 306 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 591 callback.Run(file.Pass(), on_close_callback); | 589 callback.Run(file.Pass(), on_close_callback); |
| 592 FinishOperation(handle.id); | 590 FinishOperation(handle.id); |
| 593 } | 591 } |
| 594 | 592 |
| 595 void FileSystemOperationRunner::DidCreateSnapshot( | 593 void FileSystemOperationRunner::DidCreateSnapshot( |
| 596 const OperationHandle& handle, | 594 const OperationHandle& handle, |
| 597 const SnapshotFileCallback& callback, | 595 const SnapshotFileCallback& callback, |
| 598 base::File::Error rv, | 596 base::File::Error rv, |
| 599 const base::File::Info& file_info, | 597 const base::File::Info& file_info, |
| 600 const base::FilePath& platform_path, | 598 const base::FilePath& platform_path, |
| 601 const scoped_refptr<webkit_blob::ShareableFileReference>& file_ref) { | 599 const scoped_refptr<storage::ShareableFileReference>& file_ref) { |
| 602 if (handle.scope) { | 600 if (handle.scope) { |
| 603 finished_operations_.insert(handle.id); | 601 finished_operations_.insert(handle.id); |
| 604 base::MessageLoopProxy::current()->PostTask( | 602 base::MessageLoopProxy::current()->PostTask( |
| 605 FROM_HERE, base::Bind(&FileSystemOperationRunner::DidCreateSnapshot, | 603 FROM_HERE, base::Bind(&FileSystemOperationRunner::DidCreateSnapshot, |
| 606 AsWeakPtr(), handle, callback, rv, file_info, | 604 AsWeakPtr(), handle, callback, rv, file_info, |
| 607 platform_path, file_ref)); | 605 platform_path, file_ref)); |
| 608 return; | 606 return; |
| 609 } | 607 } |
| 610 callback.Run(rv, file_info, platform_path, file_ref); | 608 callback.Run(rv, file_info, platform_path, file_ref); |
| 611 FinishOperation(handle.id); | 609 FinishOperation(handle.id); |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 679 std::map<OperationID, StatusCallback>::iterator found_cancel = | 677 std::map<OperationID, StatusCallback>::iterator found_cancel = |
| 680 stray_cancel_callbacks_.find(id); | 678 stray_cancel_callbacks_.find(id); |
| 681 if (found_cancel != stray_cancel_callbacks_.end()) { | 679 if (found_cancel != stray_cancel_callbacks_.end()) { |
| 682 // This cancel has been requested after the operation has finished, | 680 // This cancel has been requested after the operation has finished, |
| 683 // so report that we failed to stop it. | 681 // so report that we failed to stop it. |
| 684 found_cancel->second.Run(base::File::FILE_ERROR_INVALID_OPERATION); | 682 found_cancel->second.Run(base::File::FILE_ERROR_INVALID_OPERATION); |
| 685 stray_cancel_callbacks_.erase(found_cancel); | 683 stray_cancel_callbacks_.erase(found_cancel); |
| 686 } | 684 } |
| 687 } | 685 } |
| 688 | 686 |
| 689 } // namespace fileapi | 687 } // namespace storage |
| OLD | NEW |