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/browser/blob/local_file_stream_reader.h" | 5 #include "storage/browser/blob/local_file_stream_reader.h" |
6 | 6 |
7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
8 #include "base/files/file_util_proxy.h" | 8 #include "base/files/file_util_proxy.h" |
9 #include "base/location.h" | 9 #include "base/location.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/task_runner.h" | 11 #include "base/task_runner.h" |
12 #include "net/base/file_stream.h" | 12 #include "net/base/file_stream.h" |
13 #include "net/base/io_buffer.h" | 13 #include "net/base/io_buffer.h" |
14 #include "net/base/net_errors.h" | 14 #include "net/base/net_errors.h" |
15 | 15 |
16 namespace webkit_blob { | 16 namespace storage { |
17 | 17 |
18 namespace { | 18 namespace { |
19 | 19 |
20 const int kOpenFlagsForRead = base::File::FLAG_OPEN | | 20 const int kOpenFlagsForRead = |
21 base::File::FLAG_READ | | 21 base::File::FLAG_OPEN | base::File::FLAG_READ | base::File::FLAG_ASYNC; |
22 base::File::FLAG_ASYNC; | |
23 | 22 |
24 } // namespace | 23 } // namespace |
25 | 24 |
26 FileStreamReader* FileStreamReader::CreateForLocalFile( | 25 FileStreamReader* FileStreamReader::CreateForLocalFile( |
27 base::TaskRunner* task_runner, | 26 base::TaskRunner* task_runner, |
28 const base::FilePath& file_path, | 27 const base::FilePath& file_path, |
29 int64 initial_offset, | 28 int64 initial_offset, |
30 const base::Time& expected_modification_time) { | 29 const base::Time& expected_modification_time) { |
31 return new LocalFileStreamReader(task_runner, file_path, initial_offset, | 30 return new LocalFileStreamReader( |
32 expected_modification_time); | 31 task_runner, file_path, initial_offset, expected_modification_time); |
33 } | 32 } |
34 | 33 |
35 LocalFileStreamReader::~LocalFileStreamReader() { | 34 LocalFileStreamReader::~LocalFileStreamReader() { |
36 } | 35 } |
37 | 36 |
38 int LocalFileStreamReader::Read(net::IOBuffer* buf, int buf_len, | 37 int LocalFileStreamReader::Read(net::IOBuffer* buf, |
39 const net::CompletionCallback& callback) { | 38 int buf_len, |
| 39 const net::CompletionCallback& callback) { |
40 DCHECK(!has_pending_open_); | 40 DCHECK(!has_pending_open_); |
41 if (stream_impl_) | 41 if (stream_impl_) |
42 return stream_impl_->Read(buf, buf_len, callback); | 42 return stream_impl_->Read(buf, buf_len, callback); |
43 return Open(base::Bind(&LocalFileStreamReader::DidOpenForRead, | 43 return Open(base::Bind(&LocalFileStreamReader::DidOpenForRead, |
44 weak_factory_.GetWeakPtr(), | 44 weak_factory_.GetWeakPtr(), |
45 make_scoped_refptr(buf), buf_len, callback)); | 45 make_scoped_refptr(buf), |
| 46 buf_len, |
| 47 callback)); |
46 } | 48 } |
47 | 49 |
48 int64 LocalFileStreamReader::GetLength( | 50 int64 LocalFileStreamReader::GetLength( |
49 const net::Int64CompletionCallback& callback) { | 51 const net::Int64CompletionCallback& callback) { |
50 const bool posted = base::FileUtilProxy::GetFileInfo( | 52 const bool posted = base::FileUtilProxy::GetFileInfo( |
51 task_runner_.get(), | 53 task_runner_.get(), |
52 file_path_, | 54 file_path_, |
53 base::Bind(&LocalFileStreamReader::DidGetFileInfoForGetLength, | 55 base::Bind(&LocalFileStreamReader::DidGetFileInfoForGetLength, |
54 weak_factory_.GetWeakPtr(), | 56 weak_factory_.GetWeakPtr(), |
55 callback)); | 57 callback)); |
56 DCHECK(posted); | 58 DCHECK(posted); |
57 return net::ERR_IO_PENDING; | 59 return net::ERR_IO_PENDING; |
58 } | 60 } |
59 | 61 |
60 LocalFileStreamReader::LocalFileStreamReader( | 62 LocalFileStreamReader::LocalFileStreamReader( |
61 base::TaskRunner* task_runner, | 63 base::TaskRunner* task_runner, |
62 const base::FilePath& file_path, | 64 const base::FilePath& file_path, |
63 int64 initial_offset, | 65 int64 initial_offset, |
64 const base::Time& expected_modification_time) | 66 const base::Time& expected_modification_time) |
65 : task_runner_(task_runner), | 67 : task_runner_(task_runner), |
66 file_path_(file_path), | 68 file_path_(file_path), |
67 initial_offset_(initial_offset), | 69 initial_offset_(initial_offset), |
68 expected_modification_time_(expected_modification_time), | 70 expected_modification_time_(expected_modification_time), |
69 has_pending_open_(false), | 71 has_pending_open_(false), |
70 weak_factory_(this) {} | 72 weak_factory_(this) { |
| 73 } |
71 | 74 |
72 int LocalFileStreamReader::Open(const net::CompletionCallback& callback) { | 75 int LocalFileStreamReader::Open(const net::CompletionCallback& callback) { |
73 DCHECK(!has_pending_open_); | 76 DCHECK(!has_pending_open_); |
74 DCHECK(!stream_impl_.get()); | 77 DCHECK(!stream_impl_.get()); |
75 has_pending_open_ = true; | 78 has_pending_open_ = true; |
76 | 79 |
77 // Call GetLength first to make it perform last-modified-time verification, | 80 // Call GetLength first to make it perform last-modified-time verification, |
78 // and then call DidVerifyForOpen for do the rest. | 81 // and then call DidVerifyForOpen for do the rest. |
79 return GetLength(base::Bind(&LocalFileStreamReader::DidVerifyForOpen, | 82 return GetLength(base::Bind(&LocalFileStreamReader::DidVerifyForOpen, |
80 weak_factory_.GetWeakPtr(), callback)); | 83 weak_factory_.GetWeakPtr(), |
| 84 callback)); |
81 } | 85 } |
82 | 86 |
83 void LocalFileStreamReader::DidVerifyForOpen( | 87 void LocalFileStreamReader::DidVerifyForOpen( |
84 const net::CompletionCallback& callback, | 88 const net::CompletionCallback& callback, |
85 int64 get_length_result) { | 89 int64 get_length_result) { |
86 if (get_length_result < 0) { | 90 if (get_length_result < 0) { |
87 callback.Run(static_cast<int>(get_length_result)); | 91 callback.Run(static_cast<int>(get_length_result)); |
88 return; | 92 return; |
89 } | 93 } |
90 | 94 |
91 stream_impl_.reset(new net::FileStream(task_runner_)); | 95 stream_impl_.reset(new net::FileStream(task_runner_)); |
92 const int result = stream_impl_->Open( | 96 const int result = |
93 file_path_, kOpenFlagsForRead, | 97 stream_impl_->Open(file_path_, |
94 base::Bind(&LocalFileStreamReader::DidOpenFileStream, | 98 kOpenFlagsForRead, |
95 weak_factory_.GetWeakPtr(), | 99 base::Bind(&LocalFileStreamReader::DidOpenFileStream, |
96 callback)); | 100 weak_factory_.GetWeakPtr(), |
| 101 callback)); |
97 if (result != net::ERR_IO_PENDING) | 102 if (result != net::ERR_IO_PENDING) |
98 callback.Run(result); | 103 callback.Run(result); |
99 } | 104 } |
100 | 105 |
101 void LocalFileStreamReader::DidOpenFileStream( | 106 void LocalFileStreamReader::DidOpenFileStream( |
102 const net::CompletionCallback& callback, | 107 const net::CompletionCallback& callback, |
103 int result) { | 108 int result) { |
104 if (result != net::OK) { | 109 if (result != net::OK) { |
105 callback.Run(result); | 110 callback.Run(result); |
106 return; | 111 return; |
107 } | 112 } |
108 result = stream_impl_->Seek( | 113 result = |
109 base::File::FROM_BEGIN, initial_offset_, | 114 stream_impl_->Seek(base::File::FROM_BEGIN, |
110 base::Bind(&LocalFileStreamReader::DidSeekFileStream, | 115 initial_offset_, |
111 weak_factory_.GetWeakPtr(), | 116 base::Bind(&LocalFileStreamReader::DidSeekFileStream, |
112 callback)); | 117 weak_factory_.GetWeakPtr(), |
| 118 callback)); |
113 if (result != net::ERR_IO_PENDING) { | 119 if (result != net::ERR_IO_PENDING) { |
114 callback.Run(result); | 120 callback.Run(result); |
115 } | 121 } |
116 } | 122 } |
117 | 123 |
118 void LocalFileStreamReader::DidSeekFileStream( | 124 void LocalFileStreamReader::DidSeekFileStream( |
119 const net::CompletionCallback& callback, | 125 const net::CompletionCallback& callback, |
120 int64 seek_result) { | 126 int64 seek_result) { |
121 if (seek_result < 0) { | 127 if (seek_result < 0) { |
122 callback.Run(static_cast<int>(seek_result)); | 128 callback.Run(static_cast<int>(seek_result)); |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
159 callback.Run(net::FileErrorToNetError(error)); | 165 callback.Run(net::FileErrorToNetError(error)); |
160 return; | 166 return; |
161 } | 167 } |
162 if (!VerifySnapshotTime(expected_modification_time_, file_info)) { | 168 if (!VerifySnapshotTime(expected_modification_time_, file_info)) { |
163 callback.Run(net::ERR_UPLOAD_FILE_CHANGED); | 169 callback.Run(net::ERR_UPLOAD_FILE_CHANGED); |
164 return; | 170 return; |
165 } | 171 } |
166 callback.Run(file_info.size); | 172 callback.Run(file_info.size); |
167 } | 173 } |
168 | 174 |
169 } // namespace webkit_blob | 175 } // namespace storage |
OLD | NEW |