Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(464)

Side by Side Diff: net/disk_cache/storage_block-inl.h

Issue 15203004: Disk cache: Reference CL for the implementation of file format version 3. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: IndexTable review Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « net/disk_cache/storage_block.h ('k') | net/disk_cache/storage_block_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #ifndef NET_DISK_CACHE_STORAGE_BLOCK_INL_H_ 5 #ifndef NET_DISK_CACHE_STORAGE_BLOCK_INL_H_
6 #define NET_DISK_CACHE_STORAGE_BLOCK_INL_H_ 6 #define NET_DISK_CACHE_STORAGE_BLOCK_INL_H_
7 7
8 #include "net/disk_cache/storage_block.h" 8 #include "net/disk_cache/storage_block.h"
9 9
10 #include "base/hash.h" 10 #include "base/hash.h"
11 #include "base/logging.h" 11 #include "base/logging.h"
12 #include "net/disk_cache/trace.h" 12 #include "net/disk_cache/trace.h"
13 13
14 namespace disk_cache { 14 namespace disk_cache {
15 15
16 template<typename T> StorageBlock<T>::StorageBlock()
17 : data_(NULL),
18 file_(NULL),
19 modified_(false),
20 own_data_(false),
21 extended_(false) {
22 }
23
16 template<typename T> StorageBlock<T>::StorageBlock(MappedFile* file, 24 template<typename T> StorageBlock<T>::StorageBlock(MappedFile* file,
17 Addr address) 25 Addr address)
18 : data_(NULL), file_(file), address_(address), modified_(false), 26 : data_(NULL), file_(file), address_(address), modified_(false),
19 own_data_(false), extended_(false) { 27 own_data_(false), extended_(false) {
20 if (address.num_blocks() > 1) 28 if (address.num_blocks() > 1)
21 extended_ = true; 29 extended_ = true;
22 DCHECK(!address.is_initialized() || sizeof(*data_) == address.BlockSize()); 30 DCHECK(!address.is_initialized() || sizeof(*data_) == address.BlockSize());
23 } 31 }
24 32
25 template<typename T> StorageBlock<T>::~StorageBlock() { 33 template<typename T> StorageBlock<T>::~StorageBlock() {
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after
91 template<typename T> void StorageBlock<T>::clear_modified() { 99 template<typename T> void StorageBlock<T>::clear_modified() {
92 modified_ = false; 100 modified_ = false;
93 } 101 }
94 102
95 template<typename T> T* StorageBlock<T>::Data() { 103 template<typename T> T* StorageBlock<T>::Data() {
96 if (!data_) 104 if (!data_)
97 AllocateData(); 105 AllocateData();
98 return data_; 106 return data_;
99 } 107 }
100 108
109 template<typename T> T* StorageBlock<T>::ReleaseData() {
110 if (!own_data_ || !data_)
111 return NULL;
112
113 data_->self_hash = CalculateHash();
114 T* result = data_;
115 data_ = NULL;
116 own_data_ = false;
117 modified_ = false;
118 return result;
119 }
120
101 template<typename T> bool StorageBlock<T>::HasData() const { 121 template<typename T> bool StorageBlock<T>::HasData() const {
102 return (NULL != data_); 122 return (NULL != data_);
103 } 123 }
104 124
105 template<typename T> bool StorageBlock<T>::VerifyHash() const { 125 template<typename T> bool StorageBlock<T>::VerifyHash() const {
106 uint32 hash = CalculateHash(); 126 uint32 hash = CalculateHash();
107 return (!data_->self_hash || data_->self_hash == hash); 127 return (!data_->self_hash || data_->self_hash == hash);
108 } 128 }
109 129
130 template<typename T> void StorageBlock<T>::UpdateHash() {
131 data_->self_hash = CalculateHash();
132 }
133
110 template<typename T> bool StorageBlock<T>::own_data() const { 134 template<typename T> bool StorageBlock<T>::own_data() const {
111 return own_data_; 135 return own_data_;
112 } 136 }
113 137
114 template<typename T> const Addr StorageBlock<T>::address() const { 138 template<typename T> const Addr StorageBlock<T>::address() const {
115 return address_; 139 return address_;
116 } 140 }
117 141
118 template<typename T> bool StorageBlock<T>::Load() { 142 template<typename T> bool StorageBlock<T>::Load() {
119 if (file_) { 143 if (file_) {
(...skipping 16 matching lines...) Expand all
136 if (file_->Store(this)) { 160 if (file_->Store(this)) {
137 modified_ = false; 161 modified_ = false;
138 return true; 162 return true;
139 } 163 }
140 } 164 }
141 LOG(ERROR) << "Failed data store."; 165 LOG(ERROR) << "Failed data store.";
142 Trace("Failed data store."); 166 Trace("Failed data store.");
143 return false; 167 return false;
144 } 168 }
145 169
170 template<typename T> bool StorageBlock<T>::Load(FileIOCallback* callback,
171 bool* completed) {
172 if (file_) {
173 if (!data_)
174 AllocateData();
175
176 if (file_->Load(this, callback, completed)) {
177 modified_ = false;
178 return true;
179 }
180 }
181 LOG(WARNING) << "Failed data load.";
182 Trace("Failed data load.");
183 return false;
184 }
185
186 template<typename T> bool StorageBlock<T>::Store(FileIOCallback* callback,
187 bool* completed) {
188 if (file_ && data_) {
189 data_->self_hash = CalculateHash();
190 if (file_->Store(this, callback, completed)) {
191 modified_ = false;
192 return true;
193 }
194 }
195 LOG(ERROR) << "Failed data store.";
196 Trace("Failed data store.");
197 return false;
198 }
199
146 template<typename T> void StorageBlock<T>::AllocateData() { 200 template<typename T> void StorageBlock<T>::AllocateData() {
147 DCHECK(!data_); 201 DCHECK(!data_);
148 if (!extended_) { 202 if (!extended_) {
149 data_ = new T; 203 data_ = new T;
150 } else { 204 } else {
151 void* buffer = new char[address_.num_blocks() * sizeof(*data_)]; 205 void* buffer = new char[address_.num_blocks() * sizeof(*data_)];
152 data_ = new(buffer) T; 206 data_ = new(buffer) T;
153 } 207 }
154 own_data_ = true; 208 own_data_ = true;
155 } 209 }
(...skipping 10 matching lines...) Expand all
166 } 220 }
167 } 221 }
168 222
169 template<typename T> uint32 StorageBlock<T>::CalculateHash() const { 223 template<typename T> uint32 StorageBlock<T>::CalculateHash() const {
170 return base::Hash(reinterpret_cast<char*>(data_), offsetof(T, self_hash)); 224 return base::Hash(reinterpret_cast<char*>(data_), offsetof(T, self_hash));
171 } 225 }
172 226
173 } // namespace disk_cache 227 } // namespace disk_cache
174 228
175 #endif // NET_DISK_CACHE_STORAGE_BLOCK_INL_H_ 229 #endif // NET_DISK_CACHE_STORAGE_BLOCK_INL_H_
OLDNEW
« no previous file with comments | « net/disk_cache/storage_block.h ('k') | net/disk_cache/storage_block_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698