Chromium Code Reviews| 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_index.h" | 5 #include "net/disk_cache/simple/simple_index.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 70 } | 70 } |
| 71 | 71 |
| 72 SimpleIndex::SimpleIndex( | 72 SimpleIndex::SimpleIndex( |
| 73 const scoped_refptr<base::TaskRunner>& cache_thread, | 73 const scoped_refptr<base::TaskRunner>& cache_thread, |
| 74 const scoped_refptr<base::TaskRunner>& io_thread, | 74 const scoped_refptr<base::TaskRunner>& io_thread, |
| 75 const base::FilePath& path) | 75 const base::FilePath& path) |
| 76 : cache_size_(0), | 76 : cache_size_(0), |
| 77 initialized_(false), | 77 initialized_(false), |
| 78 index_filename_(path.AppendASCII("simple-index")), | 78 index_filename_(path.AppendASCII("simple-index")), |
| 79 cache_thread_(cache_thread), | 79 cache_thread_(cache_thread), |
| 80 io_thread_(io_thread) {} | 80 io_thread_(io_thread) { |
| 81 } | |
| 81 | 82 |
| 82 SimpleIndex::~SimpleIndex() { | 83 SimpleIndex::~SimpleIndex() { |
| 83 DCHECK(io_thread_checker_.CalledOnValidThread()); | 84 DCHECK(io_thread_checker_.CalledOnValidThread()); |
| 85 | |
| 86 // Fail all callbacks waiting for the index to come up. | |
| 87 for (CallbackList::iterator it = to_run_when_initialized_.begin(), | |
| 88 end = to_run_when_initialized_.end(); it != end; ++it) | |
|
gavinp
2013/04/18 06:11:35
This for loop needs braces.
pasko-google - do not use
2013/04/18 09:29:54
Not required though. And I had an impression that
| |
| 89 it->Run(net::ERR_ABORTED); | |
| 84 } | 90 } |
| 85 | 91 |
| 86 void SimpleIndex::Initialize() { | 92 void SimpleIndex::Initialize() { |
| 87 DCHECK(io_thread_checker_.CalledOnValidThread()); | 93 DCHECK(io_thread_checker_.CalledOnValidThread()); |
| 88 IndexCompletionCallback merge_callback = | 94 IndexCompletionCallback merge_callback = |
| 89 base::Bind(&SimpleIndex::MergeInitializingSet, this); | 95 base::Bind(&SimpleIndex::MergeInitializingSet, this); |
| 90 base::WorkerPool::PostTask(FROM_HERE, | 96 base::WorkerPool::PostTask(FROM_HERE, |
| 91 base::Bind(&SimpleIndex::LoadFromDisk, | 97 base::Bind(&SimpleIndex::LoadFromDisk, |
| 92 index_filename_, | 98 index_filename_, |
| 93 io_thread_, | 99 io_thread_, |
| 94 merge_callback), | 100 merge_callback), |
| 95 true); | 101 true); |
| 96 } | 102 } |
| 97 | 103 |
| 104 int SimpleIndex::ExecuteWhenReady(const net::CompletionCallback& task) { | |
| 105 DCHECK(io_thread_checker_.CalledOnValidThread()); | |
| 106 if (initialized_) | |
| 107 io_thread_->PostTask(FROM_HERE, base::Bind(task, net::OK)); | |
| 108 else | |
| 109 to_run_when_initialized_.push_back(task); | |
| 110 return net::ERR_IO_PENDING; | |
| 111 } | |
| 112 | |
| 113 std::set<uint64>* SimpleIndex::ExtractEntriesBetween( | |
| 114 const base::Time initial_time, const base::Time end_time) { | |
| 115 DCHECK_EQ(true, initialized_); | |
| 116 const base::Time extended_end_time = | |
| 117 end_time.is_null() ? base::Time::Max() : end_time; | |
| 118 DCHECK(extended_end_time >= initial_time); | |
| 119 std::set<uint64>* ret_hashes = new std::set<uint64>(); | |
|
gavinp
2013/04/18 06:11:35
Can we make ret_hashes a scoped_ptr?
And it might
pasko-google - do not use
2013/04/18 09:29:54
Sure, I understand it may feel more cozy. Done.
| |
| 120 for (EntrySet::iterator it = entries_set_.begin(), end = entries_set_.end(); | |
| 121 it != end;) { | |
| 122 EntryMetadata metadata = it->second; | |
| 123 base::Time entry_time = metadata.GetLastUsedTime(); | |
| 124 if (initial_time <= entry_time && entry_time < extended_end_time) { | |
| 125 ret_hashes->insert(metadata.GetHashKey()); | |
| 126 entries_set_.erase(it++); | |
| 127 } else { | |
| 128 it++; | |
| 129 } | |
| 130 } | |
| 131 return ret_hashes; | |
| 132 } | |
| 133 | |
| 134 int32 SimpleIndex::GetEntryCount() const { | |
| 135 // TODO(pasko): return a meaningful initial estimate before initialized. | |
| 136 return entries_set_.size(); | |
| 137 } | |
| 138 | |
| 98 void SimpleIndex::Insert(const std::string& key) { | 139 void SimpleIndex::Insert(const std::string& key) { |
| 99 DCHECK(io_thread_checker_.CalledOnValidThread()); | 140 DCHECK(io_thread_checker_.CalledOnValidThread()); |
| 100 // Upon insert we don't know yet the size of the entry. | 141 // Upon insert we don't know yet the size of the entry. |
| 101 // It will be updated later when the SimpleEntryImpl finishes opening or | 142 // It will be updated later when the SimpleEntryImpl finishes opening or |
| 102 // creating the new entry, and then UpdateEntrySize will be called. | 143 // creating the new entry, and then UpdateEntrySize will be called. |
| 103 const uint64 hash_key = simple_util::GetEntryHashKey(key); | 144 const uint64 hash_key = simple_util::GetEntryHashKey(key); |
| 104 InsertInEntrySet(EntryMetadata(hash_key, base::Time::Now(), 0), | 145 InsertInEntrySet(EntryMetadata(hash_key, base::Time::Now(), 0), |
| 105 &entries_set_); | 146 &entries_set_); |
| 106 if (!initialized_) | 147 if (!initialized_) |
| 107 removed_entries_.erase(hash_key); | 148 removed_entries_.erase(hash_key); |
| (...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 264 // When Merging, existing valid data in the |current_entry| will prevail. | 305 // When Merging, existing valid data in the |current_entry| will prevail. |
| 265 current_entry->second.MergeWith(it->second); | 306 current_entry->second.MergeWith(it->second); |
| 266 cache_size_ += current_entry->second.GetEntrySize(); | 307 cache_size_ += current_entry->second.GetEntrySize(); |
| 267 } else { | 308 } else { |
| 268 InsertInEntrySet(it->second, &entries_set_); | 309 InsertInEntrySet(it->second, &entries_set_); |
| 269 cache_size_ += it->second.GetEntrySize(); | 310 cache_size_ += it->second.GetEntrySize(); |
| 270 } | 311 } |
| 271 } | 312 } |
| 272 | 313 |
| 273 initialized_ = true; | 314 initialized_ = true; |
| 315 | |
| 316 // Run all callbacks waiting for the index to come up. | |
| 317 for (CallbackList::iterator it = to_run_when_initialized_.begin(), | |
| 318 end = to_run_when_initialized_.end(); it != end; ++it) { | |
| 319 io_thread_->PostTask(FROM_HERE, base::Bind((*it), net::OK)); | |
| 320 } | |
| 321 to_run_when_initialized_.clear(); | |
| 274 } | 322 } |
| 275 | 323 |
| 276 void SimpleIndex::WriteToDisk() { | 324 void SimpleIndex::WriteToDisk() { |
| 277 DCHECK(io_thread_checker_.CalledOnValidThread()); | 325 DCHECK(io_thread_checker_.CalledOnValidThread()); |
| 278 SimpleIndexFile::IndexMetadata index_metadata(entries_set_.size(), | 326 SimpleIndexFile::IndexMetadata index_metadata(entries_set_.size(), |
| 279 cache_size_); | 327 cache_size_); |
| 280 scoped_ptr<Pickle> pickle = SimpleIndexFile::Serialize(index_metadata, | 328 scoped_ptr<Pickle> pickle = SimpleIndexFile::Serialize(index_metadata, |
| 281 entries_set_); | 329 entries_set_); |
| 282 cache_thread_->PostTask(FROM_HERE, base::Bind( | 330 cache_thread_->PostTask(FROM_HERE, base::Bind( |
| 283 &SimpleIndex::WriteToDiskInternal, | 331 &SimpleIndex::WriteToDiskInternal, |
| 284 index_filename_, | 332 index_filename_, |
| 285 base::Passed(&pickle))); | 333 base::Passed(&pickle))); |
| 286 } | 334 } |
| 287 | 335 |
| 288 } // namespace disk_cache | 336 } // namespace disk_cache |
| OLD | NEW |