| 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/fileapi/file_system_file_reader.h" | 5 #include "webkit/fileapi/file_system_file_reader.h" |
| 6 | 6 |
| 7 #include "base/file_util_proxy.h" | 7 #include "base/file_util_proxy.h" |
| 8 #include "base/message_loop_proxy.h" | |
| 9 #include "base/platform_file.h" | 8 #include "base/platform_file.h" |
| 9 #include "base/sequenced_task_runner.h" |
| 10 #include "net/base/file_stream.h" | 10 #include "net/base/file_stream.h" |
| 11 #include "net/base/io_buffer.h" | 11 #include "net/base/io_buffer.h" |
| 12 #include "net/base/net_errors.h" | 12 #include "net/base/net_errors.h" |
| 13 #include "webkit/blob/local_file_reader.h" | 13 #include "webkit/blob/local_file_reader.h" |
| 14 #include "webkit/fileapi/file_system_context.h" | 14 #include "webkit/fileapi/file_system_context.h" |
| 15 #include "webkit/fileapi/file_system_operation_interface.h" | 15 #include "webkit/fileapi/file_system_operation_interface.h" |
| 16 | 16 |
| 17 using webkit_blob::LocalFileReader; | 17 using webkit_blob::LocalFileReader; |
| 18 | 18 |
| 19 namespace fileapi { | 19 namespace fileapi { |
| 20 | 20 |
| 21 namespace { | 21 namespace { |
| 22 | 22 |
| 23 void ReadAdapter(base::WeakPtr<FileSystemFileReader> reader, | 23 void ReadAdapter(base::WeakPtr<FileSystemFileReader> reader, |
| 24 net::IOBuffer* buf, int buf_len, | 24 net::IOBuffer* buf, int buf_len, |
| 25 const net::CompletionCallback& callback) { | 25 const net::CompletionCallback& callback) { |
| 26 if (!reader.get()) | 26 if (!reader.get()) |
| 27 return; | 27 return; |
| 28 int rv = reader->Read(buf, buf_len, callback); | 28 int rv = reader->Read(buf, buf_len, callback); |
| 29 if (rv != net::ERR_IO_PENDING) | 29 if (rv != net::ERR_IO_PENDING) |
| 30 callback.Run(rv); | 30 callback.Run(rv); |
| 31 } | 31 } |
| 32 | 32 |
| 33 } | 33 } |
| 34 | 34 |
| 35 FileSystemFileReader::FileSystemFileReader( | 35 FileSystemFileReader::FileSystemFileReader( |
| 36 base::MessageLoopProxy* file_thread_proxy, | |
| 37 FileSystemContext* file_system_context, | 36 FileSystemContext* file_system_context, |
| 38 const GURL& url, | 37 const GURL& url, |
| 39 int64 initial_offset) | 38 int64 initial_offset) |
| 40 : file_thread_proxy_(file_thread_proxy), | 39 : file_system_context_(file_system_context), |
| 41 file_system_context_(file_system_context), | |
| 42 url_(url), | 40 url_(url), |
| 43 initial_offset_(initial_offset), | 41 initial_offset_(initial_offset), |
| 44 has_pending_create_snapshot_(false), | 42 has_pending_create_snapshot_(false), |
| 45 weak_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) { | 43 weak_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)) { |
| 46 } | 44 } |
| 47 | 45 |
| 48 FileSystemFileReader::~FileSystemFileReader() { | 46 FileSystemFileReader::~FileSystemFileReader() { |
| 49 } | 47 } |
| 50 | 48 |
| 51 int FileSystemFileReader::Read( | 49 int FileSystemFileReader::Read( |
| 52 net::IOBuffer* buf, int buf_len, | 50 net::IOBuffer* buf, int buf_len, |
| 53 const net::CompletionCallback& callback) { | 51 const net::CompletionCallback& callback) { |
| 54 if (local_file_reader_.get()) | 52 if (local_file_reader_.get()) |
| 55 return local_file_reader_->Read(buf, buf_len, callback); | 53 return local_file_reader_->Read(buf, buf_len, callback); |
| 56 DCHECK(!has_pending_create_snapshot_); | 54 DCHECK(!has_pending_create_snapshot_); |
| 57 FileSystemOperationInterface* operation = | 55 FileSystemOperationInterface* operation = |
| 58 file_system_context_->CreateFileSystemOperation( | 56 file_system_context_->CreateFileSystemOperation(url_); |
| 59 url_, file_thread_proxy_); | |
| 60 if (!operation) | 57 if (!operation) |
| 61 return net::ERR_INVALID_URL; | 58 return net::ERR_INVALID_URL; |
| 62 has_pending_create_snapshot_ = true; | 59 has_pending_create_snapshot_ = true; |
| 63 operation->CreateSnapshotFile( | 60 operation->CreateSnapshotFile( |
| 64 url_, | 61 url_, |
| 65 base::Bind(&FileSystemFileReader::DidCreateSnapshot, | 62 base::Bind(&FileSystemFileReader::DidCreateSnapshot, |
| 66 weak_factory_.GetWeakPtr(), | 63 weak_factory_.GetWeakPtr(), |
| 67 base::Bind(&ReadAdapter, weak_factory_.GetWeakPtr(), | 64 base::Bind(&ReadAdapter, weak_factory_.GetWeakPtr(), |
| 68 make_scoped_refptr(buf), buf_len, callback), | 65 make_scoped_refptr(buf), buf_len, callback), |
| 69 callback)); | 66 callback)); |
| (...skipping 13 matching lines...) Expand all Loading... |
| 83 | 80 |
| 84 if (file_error != base::PLATFORM_FILE_OK) { | 81 if (file_error != base::PLATFORM_FILE_OK) { |
| 85 callback.Run(LocalFileReader::PlatformFileErrorToNetError(file_error)); | 82 callback.Run(LocalFileReader::PlatformFileErrorToNetError(file_error)); |
| 86 return; | 83 return; |
| 87 } | 84 } |
| 88 | 85 |
| 89 // Keep the reference (if it's non-null) so that the file won't go away. | 86 // Keep the reference (if it's non-null) so that the file won't go away. |
| 90 snapshot_ref_ = file_ref; | 87 snapshot_ref_ = file_ref; |
| 91 | 88 |
| 92 local_file_reader_.reset( | 89 local_file_reader_.reset( |
| 93 new LocalFileReader(file_thread_proxy_, | 90 new LocalFileReader(file_system_context_->file_task_runner(), |
| 94 platform_path, | 91 platform_path, |
| 95 initial_offset_, | 92 initial_offset_, |
| 96 base::Time())); | 93 base::Time())); |
| 97 | 94 |
| 98 read_closure.Run(); | 95 read_closure.Run(); |
| 99 } | 96 } |
| 100 | 97 |
| 101 } // namespace fileapi | 98 } // namespace fileapi |
| OLD | NEW |