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 |