| 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/dom_storage/dom_storage_area.h" | 5 #include "webkit/dom_storage/dom_storage_area.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/file_util.h" | 8 #include "base/file_util.h" |
| 9 #include "base/location.h" | 9 #include "base/location.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 51 name.BaseName().RemoveExtension()); | 51 name.BaseName().RemoveExtension()); |
| 52 return DatabaseUtil::GetOriginFromIdentifier(origin_id); | 52 return DatabaseUtil::GetOriginFromIdentifier(origin_id); |
| 53 } | 53 } |
| 54 | 54 |
| 55 DomStorageArea::DomStorageArea( | 55 DomStorageArea::DomStorageArea( |
| 56 int64 namespace_id, const GURL& origin, | 56 int64 namespace_id, const GURL& origin, |
| 57 const FilePath& directory, DomStorageTaskRunner* task_runner) | 57 const FilePath& directory, DomStorageTaskRunner* task_runner) |
| 58 : namespace_id_(namespace_id), origin_(origin), | 58 : namespace_id_(namespace_id), origin_(origin), |
| 59 directory_(directory), | 59 directory_(directory), |
| 60 task_runner_(task_runner), | 60 task_runner_(task_runner), |
| 61 map_(new DomStorageMap(kPerAreaQuota)), | 61 map_(new DomStorageMap(kPerAreaQuota + kPerAreaOverQuotaAllowance)), |
| 62 is_initial_import_done_(true), | 62 is_initial_import_done_(true), |
| 63 is_shutdown_(false), | 63 is_shutdown_(false), |
| 64 commit_batches_in_flight_(0) { | 64 commit_batches_in_flight_(0) { |
| 65 if (namespace_id == kLocalStorageNamespaceId && !directory.empty()) { | 65 if (namespace_id == kLocalStorageNamespaceId && !directory.empty()) { |
| 66 FilePath path = directory.Append(DatabaseFileNameFromOrigin(origin_)); | 66 FilePath path = directory.Append(DatabaseFileNameFromOrigin(origin_)); |
| 67 backing_.reset(new DomStorageDatabase(path)); | 67 backing_.reset(new DomStorageDatabase(path)); |
| 68 is_initial_import_done_ = false; | 68 is_initial_import_done_ = false; |
| 69 } | 69 } |
| 70 } | 70 } |
| 71 | 71 |
| (...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 130 return success; | 130 return success; |
| 131 } | 131 } |
| 132 | 132 |
| 133 bool DomStorageArea::Clear() { | 133 bool DomStorageArea::Clear() { |
| 134 if (is_shutdown_) | 134 if (is_shutdown_) |
| 135 return false; | 135 return false; |
| 136 InitialImportIfNeeded(); | 136 InitialImportIfNeeded(); |
| 137 if (map_->Length() == 0) | 137 if (map_->Length() == 0) |
| 138 return false; | 138 return false; |
| 139 | 139 |
| 140 map_ = new DomStorageMap(kPerAreaQuota); | 140 map_ = new DomStorageMap(kPerAreaQuota + kPerAreaOverQuotaAllowance); |
| 141 | 141 |
| 142 if (backing_.get()) { | 142 if (backing_.get()) { |
| 143 CommitBatch* commit_batch = CreateCommitBatchIfNeeded(); | 143 CommitBatch* commit_batch = CreateCommitBatchIfNeeded(); |
| 144 commit_batch->clear_all_first = true; | 144 commit_batch->clear_all_first = true; |
| 145 commit_batch->changed_values.clear(); | 145 commit_batch->changed_values.clear(); |
| 146 } | 146 } |
| 147 | 147 |
| 148 return true; | 148 return true; |
| 149 } | 149 } |
| 150 | 150 |
| (...skipping 18 matching lines...) Expand all Loading... |
| 169 DCHECK(!is_shutdown_); | 169 DCHECK(!is_shutdown_); |
| 170 if (HasUncommittedChanges()) { | 170 if (HasUncommittedChanges()) { |
| 171 // TODO(michaeln): This logically deletes the data immediately, | 171 // TODO(michaeln): This logically deletes the data immediately, |
| 172 // and in a matter of a second, deletes the rows from the backing | 172 // and in a matter of a second, deletes the rows from the backing |
| 173 // database file, but the file itself will linger until shutdown | 173 // database file, but the file itself will linger until shutdown |
| 174 // or purge time. Ideally, this should delete the file more | 174 // or purge time. Ideally, this should delete the file more |
| 175 // quickly. | 175 // quickly. |
| 176 Clear(); | 176 Clear(); |
| 177 return; | 177 return; |
| 178 } | 178 } |
| 179 map_ = new DomStorageMap(kPerAreaQuota); | 179 map_ = new DomStorageMap(kPerAreaQuota + kPerAreaOverQuotaAllowance); |
| 180 if (backing_.get()) { | 180 if (backing_.get()) { |
| 181 is_initial_import_done_ = false; | 181 is_initial_import_done_ = false; |
| 182 backing_.reset(new DomStorageDatabase(backing_->file_path())); | 182 backing_.reset(new DomStorageDatabase(backing_->file_path())); |
| 183 file_util::Delete(backing_->file_path(), false); | 183 file_util::Delete(backing_->file_path(), false); |
| 184 file_util::Delete( | 184 file_util::Delete( |
| 185 DomStorageDatabase::GetJournalFilePath(backing_->file_path()), false); | 185 DomStorageDatabase::GetJournalFilePath(backing_->file_path()), false); |
| 186 } | 186 } |
| 187 } | 187 } |
| 188 | 188 |
| 189 void DomStorageArea::PurgeMemory() { | 189 void DomStorageArea::PurgeMemory() { |
| 190 DCHECK(!is_shutdown_); | 190 DCHECK(!is_shutdown_); |
| 191 if (!is_initial_import_done_ || // We're not using any memory. | 191 if (!is_initial_import_done_ || // We're not using any memory. |
| 192 !backing_.get() || // We can't purge anything. | 192 !backing_.get() || // We can't purge anything. |
| 193 HasUncommittedChanges()) // We leave things alone with changes pending. | 193 HasUncommittedChanges()) // We leave things alone with changes pending. |
| 194 return; | 194 return; |
| 195 | 195 |
| 196 // Drop the in memory cache, we'll reload when needed. | 196 // Drop the in memory cache, we'll reload when needed. |
| 197 is_initial_import_done_ = false; | 197 is_initial_import_done_ = false; |
| 198 map_ = new DomStorageMap(kPerAreaQuota); | 198 map_ = new DomStorageMap(kPerAreaQuota + kPerAreaOverQuotaAllowance); |
| 199 | 199 |
| 200 // Recreate the database object, this frees up the open sqlite connection | 200 // Recreate the database object, this frees up the open sqlite connection |
| 201 // and its page cache. | 201 // and its page cache. |
| 202 backing_.reset(new DomStorageDatabase(backing_->file_path())); | 202 backing_.reset(new DomStorageDatabase(backing_->file_path())); |
| 203 } | 203 } |
| 204 | 204 |
| 205 void DomStorageArea::Shutdown() { | 205 void DomStorageArea::Shutdown() { |
| 206 DCHECK(!is_shutdown_); | 206 DCHECK(!is_shutdown_); |
| 207 is_shutdown_ = true; | 207 is_shutdown_ = true; |
| 208 map_ = NULL; | 208 map_ = NULL; |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 303 bool success = backing_->CommitChanges( | 303 bool success = backing_->CommitChanges( |
| 304 commit_batch_->clear_all_first, | 304 commit_batch_->clear_all_first, |
| 305 commit_batch_->changed_values); | 305 commit_batch_->changed_values); |
| 306 DCHECK(success); | 306 DCHECK(success); |
| 307 } | 307 } |
| 308 commit_batch_.reset(); | 308 commit_batch_.reset(); |
| 309 backing_.reset(); | 309 backing_.reset(); |
| 310 } | 310 } |
| 311 | 311 |
| 312 } // namespace dom_storage | 312 } // namespace dom_storage |
| OLD | NEW |