OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 "net/disk_cache/simple/simple_synchronous_entry.h" | 5 #include "net/disk_cache/simple/simple_synchronous_entry.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <cstring> | 8 #include <cstring> |
9 #include <limits> | 9 #include <limits> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
13 #include "base/file_util.h" | 13 #include "base/file_util.h" |
14 #include "base/hash.h" | 14 #include "base/hash.h" |
15 #include "base/location.h" | 15 #include "base/location.h" |
16 #include "base/memory/scoped_ptr.h" | 16 #include "base/memory/scoped_ptr.h" |
17 #include "base/message_loop_proxy.h" | 17 #include "base/message_loop_proxy.h" |
18 #include "base/sha1.h" | 18 #include "base/sha1.h" |
19 #include "base/stringprintf.h" | 19 #include "base/stringprintf.h" |
20 #include "base/task_runner.h" | 20 #include "base/task_runner.h" |
21 #include "net/base/io_buffer.h" | 21 #include "net/base/io_buffer.h" |
22 #include "net/base/net_errors.h" | 22 #include "net/base/net_errors.h" |
23 #include "net/disk_cache/simple/simple_disk_format.h" | |
24 | 23 |
25 using base::ClosePlatformFile; | 24 using base::ClosePlatformFile; |
26 using base::FilePath; | 25 using base::FilePath; |
27 using base::GetPlatformFileInfo; | 26 using base::GetPlatformFileInfo; |
28 using base::PlatformFileError; | 27 using base::PlatformFileError; |
29 using base::PlatformFileInfo; | 28 using base::PlatformFileInfo; |
30 using base::PLATFORM_FILE_CREATE; | 29 using base::PLATFORM_FILE_CREATE; |
31 using base::PLATFORM_FILE_OK; | 30 using base::PLATFORM_FILE_OK; |
32 using base::PLATFORM_FILE_OPEN; | 31 using base::PLATFORM_FILE_OPEN; |
33 using base::PLATFORM_FILE_READ; | 32 using base::PLATFORM_FILE_READ; |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
97 } | 96 } |
98 callback_runner->PostTask(FROM_HERE, base::Bind(callback, sync_entry)); | 97 callback_runner->PostTask(FROM_HERE, base::Bind(callback, sync_entry)); |
99 } | 98 } |
100 | 99 |
101 // static | 100 // static |
102 void SimpleSynchronousEntry::DoomEntry( | 101 void SimpleSynchronousEntry::DoomEntry( |
103 const FilePath& path, | 102 const FilePath& path, |
104 const std::string& key, | 103 const std::string& key, |
105 scoped_refptr<TaskRunner> callback_runner, | 104 scoped_refptr<TaskRunner> callback_runner, |
106 const net::CompletionCallback& callback) { | 105 const net::CompletionCallback& callback) { |
107 for (int i = 0; i < kIndexCount; ++i) { | 106 for (int i = 0; i < kSimpleEntryFileCount; ++i) { |
108 FilePath to_delete = path.AppendASCII(GetFilenameForKeyAndIndex(key, i)); | 107 FilePath to_delete = path.AppendASCII(GetFilenameForKeyAndIndex(key, i)); |
109 bool ALLOW_UNUSED result = file_util::Delete(to_delete, false); | 108 bool ALLOW_UNUSED result = file_util::Delete(to_delete, false); |
110 DLOG_IF(ERROR, !result) << "Could not delete " << to_delete.MaybeAsASCII(); | 109 DLOG_IF(ERROR, !result) << "Could not delete " << to_delete.MaybeAsASCII(); |
111 } | 110 } |
112 if (!callback.is_null()) | 111 if (!callback.is_null()) |
113 callback_runner->PostTask(FROM_HERE, base::Bind(callback, net::OK)); | 112 callback_runner->PostTask(FROM_HERE, base::Bind(callback, net::OK)); |
114 } | 113 } |
115 | 114 |
116 void SimpleSynchronousEntry::DoomAndClose() { | 115 void SimpleSynchronousEntry::DoomAndClose() { |
117 scoped_refptr<TaskRunner> callback_runner = callback_runner_; | 116 scoped_refptr<TaskRunner> callback_runner = callback_runner_; |
118 FilePath path = path_; | 117 FilePath path = path_; |
119 std::string key = key_; | 118 std::string key = key_; |
120 | 119 |
121 Close(); | 120 Close(); |
122 // |this| is now deleted. | 121 // |this| is now deleted. |
123 | 122 |
124 DoomEntry(path, key, callback_runner, net::CompletionCallback()); | 123 DoomEntry(path, key, callback_runner, net::CompletionCallback()); |
125 } | 124 } |
126 | 125 |
127 void SimpleSynchronousEntry::Close() { | 126 void SimpleSynchronousEntry::Close() { |
128 for (int i = 0; i < kIndexCount; ++i) { | 127 for (int i = 0; i < kSimpleEntryFileCount; ++i) { |
129 bool ALLOW_UNUSED result = ClosePlatformFile(files_[i]); | 128 bool ALLOW_UNUSED result = ClosePlatformFile(files_[i]); |
130 DLOG_IF(INFO, !result) << "Could not Close() file."; | 129 DLOG_IF(INFO, !result) << "Could not Close() file."; |
131 } | 130 } |
132 delete this; | 131 delete this; |
133 } | 132 } |
134 | 133 |
135 void SimpleSynchronousEntry::ReadData( | 134 void SimpleSynchronousEntry::ReadData( |
136 int index, | 135 int index, |
137 int offset, | 136 int offset, |
138 net::IOBuffer* buf, | 137 net::IOBuffer* buf, |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
187 : callback_runner_(callback_runner), | 186 : callback_runner_(callback_runner), |
188 path_(path), | 187 path_(path), |
189 key_(key), | 188 key_(key), |
190 initialized_(false) { | 189 initialized_(false) { |
191 } | 190 } |
192 | 191 |
193 SimpleSynchronousEntry::~SimpleSynchronousEntry() { | 192 SimpleSynchronousEntry::~SimpleSynchronousEntry() { |
194 } | 193 } |
195 | 194 |
196 bool SimpleSynchronousEntry::OpenOrCreateFiles(bool create) { | 195 bool SimpleSynchronousEntry::OpenOrCreateFiles(bool create) { |
197 for (int i = 0; i < kIndexCount; ++i) { | 196 for (int i = 0; i < kSimpleEntryFileCount; ++i) { |
198 FilePath filename = path_.AppendASCII(GetFilenameForKeyAndIndex(key_, i)); | 197 FilePath filename = path_.AppendASCII(GetFilenameForKeyAndIndex(key_, i)); |
199 int flags = PLATFORM_FILE_READ | PLATFORM_FILE_WRITE; | 198 int flags = PLATFORM_FILE_READ | PLATFORM_FILE_WRITE; |
200 if (create) | 199 if (create) |
201 flags |= PLATFORM_FILE_CREATE; | 200 flags |= PLATFORM_FILE_CREATE; |
202 else | 201 else |
203 flags |= PLATFORM_FILE_OPEN; | 202 flags |= PLATFORM_FILE_OPEN; |
204 PlatformFileError error; | 203 PlatformFileError error; |
205 files_[i] = CreatePlatformFile(filename, flags, NULL, &error); | 204 files_[i] = CreatePlatformFile(filename, flags, NULL, &error); |
206 if (error != PLATFORM_FILE_OK) { | 205 if (error != PLATFORM_FILE_OK) { |
207 DVLOG(8) << "CreatePlatformFile error " << error << " while " | 206 DVLOG(8) << "CreatePlatformFile error " << error << " while " |
208 << (create ? "creating " : "opening ") | 207 << (create ? "creating " : "opening ") |
209 << filename.MaybeAsASCII(); | 208 << filename.MaybeAsASCII(); |
210 while (--i >= 0) { | 209 while (--i >= 0) { |
211 bool ALLOW_UNUSED did_close = ClosePlatformFile(files_[i]); | 210 bool ALLOW_UNUSED did_close = ClosePlatformFile(files_[i]); |
212 DLOG_IF(INFO, !did_close) << "Could not close file " | 211 DLOG_IF(INFO, !did_close) << "Could not close file " |
213 << filename.MaybeAsASCII(); | 212 << filename.MaybeAsASCII(); |
214 } | 213 } |
215 return false; | 214 return false; |
216 } | 215 } |
217 } | 216 } |
218 | 217 |
219 for (int i = 0; i < kIndexCount; ++i) { | 218 for (int i = 0; i < kSimpleEntryFileCount; ++i) { |
220 PlatformFileInfo file_info; | 219 PlatformFileInfo file_info; |
221 bool success = GetPlatformFileInfo(files_[i], &file_info); | 220 bool success = GetPlatformFileInfo(files_[i], &file_info); |
222 if (!success) { | 221 if (!success) { |
223 DLOG(WARNING) << "Could not get platform file info."; | 222 DLOG(WARNING) << "Could not get platform file info."; |
224 continue; | 223 continue; |
225 } | 224 } |
226 last_used_ = std::max(last_used_, file_info.last_accessed); | 225 last_used_ = std::max(last_used_, file_info.last_accessed); |
227 last_modified_ = std::max(last_modified_, file_info.last_modified); | 226 last_modified_ = std::max(last_modified_, file_info.last_modified); |
228 data_size_[i] = DataSizeFromKeyAndFileSize(key_.size(), file_info.size); | 227 data_size_[i] = DataSizeFromKeyAndFileSize(key_.size(), file_info.size); |
229 } | 228 } |
230 | 229 |
231 return true; | 230 return true; |
232 } | 231 } |
233 | 232 |
234 bool SimpleSynchronousEntry::InitializeForOpen() { | 233 bool SimpleSynchronousEntry::InitializeForOpen() { |
235 DCHECK(!initialized_); | 234 DCHECK(!initialized_); |
236 if (!OpenOrCreateFiles(false)) | 235 if (!OpenOrCreateFiles(false)) |
237 return false; | 236 return false; |
238 | 237 |
239 for (int i = 0; i < kIndexCount; ++i) { | 238 for (int i = 0; i < kSimpleEntryFileCount; ++i) { |
240 SimpleFileHeader header; | 239 SimpleFileHeader header; |
241 int header_read_result = | 240 int header_read_result = |
242 ReadPlatformFile(files_[i], 0, reinterpret_cast<char*>(&header), | 241 ReadPlatformFile(files_[i], 0, reinterpret_cast<char*>(&header), |
243 sizeof(header)); | 242 sizeof(header)); |
244 if (header_read_result != sizeof(header)) { | 243 if (header_read_result != sizeof(header)) { |
245 DLOG(WARNING) << "Cannot read header from entry."; | 244 DLOG(WARNING) << "Cannot read header from entry."; |
246 return false; | 245 return false; |
247 } | 246 } |
248 | 247 |
249 if (header.initial_magic_number != kSimpleInitialMagicNumber) { | 248 if (header.initial_magic_number != kSimpleInitialMagicNumber) { |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
285 return true; | 284 return true; |
286 } | 285 } |
287 | 286 |
288 bool SimpleSynchronousEntry::InitializeForCreate() { | 287 bool SimpleSynchronousEntry::InitializeForCreate() { |
289 DCHECK(!initialized_); | 288 DCHECK(!initialized_); |
290 if (!OpenOrCreateFiles(true)) { | 289 if (!OpenOrCreateFiles(true)) { |
291 DLOG(WARNING) << "Could not create platform files."; | 290 DLOG(WARNING) << "Could not create platform files."; |
292 return false; | 291 return false; |
293 } | 292 } |
294 | 293 |
295 for (int i = 0; i < kIndexCount; ++i) { | 294 for (int i = 0; i < kSimpleEntryFileCount; ++i) { |
296 SimpleFileHeader header; | 295 SimpleFileHeader header; |
297 header.initial_magic_number = kSimpleInitialMagicNumber; | 296 header.initial_magic_number = kSimpleInitialMagicNumber; |
298 header.version = kSimpleVersion; | 297 header.version = kSimpleVersion; |
299 | 298 |
300 header.key_length = key_.size(); | 299 header.key_length = key_.size(); |
301 header.key_hash = base::Hash(key_); | 300 header.key_hash = base::Hash(key_); |
302 | 301 |
303 if (WritePlatformFile(files_[i], 0, reinterpret_cast<char*>(&header), | 302 if (WritePlatformFile(files_[i], 0, reinterpret_cast<char*>(&header), |
304 sizeof(header)) != sizeof(header)) { | 303 sizeof(header)) != sizeof(header)) { |
305 // TODO(gavinp): Clean up created files. | 304 // TODO(gavinp): Clean up created files. |
306 DLOG(WARNING) << "Could not write headers to new cache entry."; | 305 DLOG(WARNING) << "Could not write headers to new cache entry."; |
307 return false; | 306 return false; |
308 } | 307 } |
309 | 308 |
310 if (WritePlatformFile(files_[i], sizeof(header), key_.data(), | 309 if (WritePlatformFile(files_[i], sizeof(header), key_.data(), |
311 key_.size()) != implicit_cast<int>(key_.size())) { | 310 key_.size()) != implicit_cast<int>(key_.size())) { |
312 // TODO(gavinp): Clean up created files. | 311 // TODO(gavinp): Clean up created files. |
313 DLOG(WARNING) << "Could not write keys to new cache entry."; | 312 DLOG(WARNING) << "Could not write keys to new cache entry."; |
314 return false; | 313 return false; |
315 } | 314 } |
316 } | 315 } |
317 | 316 |
318 initialized_ = true; | 317 initialized_ = true; |
319 return true; | 318 return true; |
320 } | 319 } |
321 | 320 |
322 } // namespace disk_cache | 321 } // namespace disk_cache |
OLD | NEW |