Chromium Code Reviews| 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 "chrome/browser/history/in_memory_url_index.h" | 5 #include "chrome/browser/history/in_memory_url_index.h" |
| 6 | 6 |
| 7 #include "base/debug/trace_event.h" | 7 #include "base/debug/trace_event.h" |
| 8 #include "base/files/file_util.h" | 8 #include "base/files/file_util.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
| 10 #include "chrome/browser/bookmarks/bookmark_model_factory.h" | 10 #include "chrome/browser/bookmarks/bookmark_model_factory.h" |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 96 : profile_(profile), | 96 : profile_(profile), |
| 97 history_service_(history_service), | 97 history_service_(history_service), |
| 98 history_client_(history_client), | 98 history_client_(history_client), |
| 99 history_dir_(history_dir), | 99 history_dir_(history_dir), |
| 100 languages_(languages), | 100 languages_(languages), |
| 101 private_data_(new URLIndexPrivateData), | 101 private_data_(new URLIndexPrivateData), |
| 102 restore_cache_observer_(NULL), | 102 restore_cache_observer_(NULL), |
| 103 save_cache_observer_(NULL), | 103 save_cache_observer_(NULL), |
| 104 shutdown_(false), | 104 shutdown_(false), |
| 105 restored_(false), | 105 restored_(false), |
| 106 needs_to_be_cached_(false) { | 106 needs_to_be_cached_(false), |
| 107 history_service_observer_(this) { | |
| 107 InitializeSchemeWhitelist(&scheme_whitelist_); | 108 InitializeSchemeWhitelist(&scheme_whitelist_); |
| 108 if (profile) { | 109 if (profile) { |
| 109 // TODO(mrossetti): Register for language change notifications. | 110 // TODO(mrossetti): Register for language change notifications. |
| 110 content::Source<Profile> source(profile); | 111 content::Source<Profile> source(profile); |
| 111 registrar_.Add(this, chrome::NOTIFICATION_HISTORY_URLS_MODIFIED, | 112 registrar_.Add(this, chrome::NOTIFICATION_HISTORY_URLS_MODIFIED, |
| 112 source); | 113 source); |
| 113 registrar_.Add(this, chrome::NOTIFICATION_HISTORY_URLS_DELETED, source); | 114 registrar_.Add(this, chrome::NOTIFICATION_HISTORY_URLS_DELETED, source); |
| 114 } | 115 } |
| 115 if (history_service_) | 116 if (history_service_) |
| 116 history_service_->AddObserver(this); | 117 history_service_observer_.Add(history_service_); |
| 117 } | 118 } |
| 118 | 119 |
| 119 // Called only by unit tests. | 120 // Called only by unit tests. |
| 120 InMemoryURLIndex::InMemoryURLIndex() | 121 InMemoryURLIndex::InMemoryURLIndex() |
| 121 : profile_(NULL), | 122 : profile_(NULL), |
| 122 history_service_(nullptr), | 123 history_service_(nullptr), |
| 123 history_client_(NULL), | 124 history_client_(NULL), |
| 124 private_data_(new URLIndexPrivateData), | 125 private_data_(new URLIndexPrivateData), |
| 125 restore_cache_observer_(NULL), | 126 restore_cache_observer_(NULL), |
| 126 save_cache_observer_(NULL), | 127 save_cache_observer_(NULL), |
| 127 shutdown_(false), | 128 shutdown_(false), |
| 128 restored_(false), | 129 restored_(false), |
| 129 needs_to_be_cached_(false) { | 130 needs_to_be_cached_(false), |
| 131 history_service_observer_(this) { | |
| 130 InitializeSchemeWhitelist(&scheme_whitelist_); | 132 InitializeSchemeWhitelist(&scheme_whitelist_); |
| 131 } | 133 } |
| 132 | 134 |
| 133 InMemoryURLIndex::~InMemoryURLIndex() { | 135 InMemoryURLIndex::~InMemoryURLIndex() { |
| 134 // If there was a history directory (which there won't be for some unit tests) | 136 // If there was a history directory (which there won't be for some unit tests) |
| 135 // then insure that the cache has already been saved. | 137 // then insure that the cache has already been saved. |
| 136 DCHECK(history_dir_.empty() || !needs_to_be_cached_); | 138 DCHECK(history_dir_.empty() || !needs_to_be_cached_); |
| 137 } | 139 } |
| 138 | 140 |
| 139 void InMemoryURLIndex::Init() { | 141 void InMemoryURLIndex::Init() { |
| 140 PostRestoreFromCacheFileTask(); | 142 PostRestoreFromCacheFileTask(); |
| 141 } | 143 } |
| 142 | 144 |
| 143 void InMemoryURLIndex::ShutDown() { | 145 void InMemoryURLIndex::ShutDown() { |
| 144 if (history_service_) | 146 history_service_observer_.RemoveAll(); |
| 145 history_service_->RemoveObserver(this); | |
| 146 registrar_.RemoveAll(); | 147 registrar_.RemoveAll(); |
| 147 cache_reader_tracker_.TryCancelAll(); | 148 cache_reader_tracker_.TryCancelAll(); |
| 148 shutdown_ = true; | 149 shutdown_ = true; |
| 149 base::FilePath path; | 150 base::FilePath path; |
| 150 if (!GetCacheFilePath(&path)) | 151 if (!GetCacheFilePath(&path)) |
| 151 return; | 152 return; |
| 152 private_data_tracker_.TryCancelAll(); | 153 private_data_tracker_.TryCancelAll(); |
| 153 URLIndexPrivateData::WritePrivateDataToCacheFileTask(private_data_, path); | 154 URLIndexPrivateData::WritePrivateDataToCacheFileTask(private_data_, path); |
| 154 needs_to_be_cached_ = false; | 155 needs_to_be_cached_ = false; |
| 155 } | 156 } |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 190 const content::NotificationDetails& details) { | 191 const content::NotificationDetails& details) { |
| 191 switch (notification_type) { | 192 switch (notification_type) { |
| 192 case chrome::NOTIFICATION_HISTORY_URLS_MODIFIED: | 193 case chrome::NOTIFICATION_HISTORY_URLS_MODIFIED: |
| 193 OnURLsModified( | 194 OnURLsModified( |
| 194 content::Details<history::URLsModifiedDetails>(details).ptr()); | 195 content::Details<history::URLsModifiedDetails>(details).ptr()); |
| 195 break; | 196 break; |
| 196 case chrome::NOTIFICATION_HISTORY_URLS_DELETED: | 197 case chrome::NOTIFICATION_HISTORY_URLS_DELETED: |
| 197 OnURLsDeleted( | 198 OnURLsDeleted( |
| 198 content::Details<history::URLsDeletedDetails>(details).ptr()); | 199 content::Details<history::URLsDeletedDetails>(details).ptr()); |
| 199 break; | 200 break; |
| 200 case chrome::NOTIFICATION_HISTORY_LOADED: | |
| 201 registrar_.Remove(this, chrome::NOTIFICATION_HISTORY_LOADED, | |
| 202 content::Source<Profile>(profile_)); | |
| 203 ScheduleRebuildFromHistory(); | |
| 204 break; | |
| 205 default: | 201 default: |
| 206 // For simplicity, the unit tests send us all notifications, even when | 202 // For simplicity, the unit tests send us all notifications, even when |
| 207 // we haven't registered for them, so don't assert here. | 203 // we haven't registered for them, so don't assert here. |
| 208 break; | 204 break; |
| 209 } | 205 } |
| 210 } | 206 } |
| 211 | 207 |
| 212 void InMemoryURLIndex::OnURLVisited(HistoryService* history_service, | 208 void InMemoryURLIndex::OnURLVisited(HistoryService* history_service, |
| 213 ui::PageTransition transition, | 209 ui::PageTransition transition, |
| 214 const URLRow& row, | 210 const URLRow& row, |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 297 // When unable to restore from the cache file delete the cache file, if | 293 // When unable to restore from the cache file delete the cache file, if |
| 298 // it exists, and then rebuild from the history database if it's available, | 294 // it exists, and then rebuild from the history database if it's available, |
| 299 // otherwise wait until the history database loaded and then rebuild. | 295 // otherwise wait until the history database loaded and then rebuild. |
| 300 base::FilePath path; | 296 base::FilePath path; |
| 301 if (!GetCacheFilePath(&path) || shutdown_) | 297 if (!GetCacheFilePath(&path) || shutdown_) |
| 302 return; | 298 return; |
| 303 content::BrowserThread::PostBlockingPoolTask( | 299 content::BrowserThread::PostBlockingPoolTask( |
| 304 FROM_HERE, base::Bind(DeleteCacheFile, path)); | 300 FROM_HERE, base::Bind(DeleteCacheFile, path)); |
| 305 HistoryService* service = | 301 HistoryService* service = |
| 306 HistoryServiceFactory::GetForProfileWithoutCreating(profile_); | 302 HistoryServiceFactory::GetForProfileWithoutCreating(profile_); |
| 307 if (service && service->backend_loaded()) { | 303 if (service) { |
| 308 ScheduleRebuildFromHistory(); | 304 if (!service->backend_loaded()) { |
| 309 } else { | 305 history_service_observer_.Add(service); |
|
sdefresne
2014/11/05 14:51:52
InMemoryURLIndex constructor already register 'thi
nshaik
2014/11/06 02:05:12
Done.
| |
| 310 registrar_.Add(this, chrome::NOTIFICATION_HISTORY_LOADED, | 306 } else { |
| 311 content::Source<Profile>(profile_)); | 307 ScheduleRebuildFromHistory(); |
| 308 } | |
| 312 } | 309 } |
| 313 } | 310 } |
| 314 } | 311 } |
| 315 | 312 |
| 316 // Restoring from the History DB ----------------------------------------------- | 313 // Restoring from the History DB ----------------------------------------------- |
| 317 | 314 |
| 318 void InMemoryURLIndex::ScheduleRebuildFromHistory() { | 315 void InMemoryURLIndex::ScheduleRebuildFromHistory() { |
| 319 HistoryService* service = | 316 HistoryService* service = |
| 320 HistoryServiceFactory::GetForProfile(profile_, | 317 HistoryServiceFactory::GetForProfile(profile_, |
| 321 Profile::EXPLICIT_ACCESS); | 318 Profile::EXPLICIT_ACCESS); |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 375 FROM_HERE, | 372 FROM_HERE, |
| 376 base::Bind(DeleteCacheFile, path)); | 373 base::Bind(DeleteCacheFile, path)); |
| 377 } | 374 } |
| 378 } | 375 } |
| 379 | 376 |
| 380 void InMemoryURLIndex::OnCacheSaveDone(bool succeeded) { | 377 void InMemoryURLIndex::OnCacheSaveDone(bool succeeded) { |
| 381 if (save_cache_observer_) | 378 if (save_cache_observer_) |
| 382 save_cache_observer_->OnCacheSaveFinished(succeeded); | 379 save_cache_observer_->OnCacheSaveFinished(succeeded); |
| 383 } | 380 } |
| 384 | 381 |
| 382 void InMemoryURLIndex::OnHistoryServiceLoaded(HistoryService* history_service) { | |
| 383 ScheduleRebuildFromHistory(); | |
| 384 history_service_observer_.Remove(history_service); | |
|
sdefresne
2014/11/05 14:51:52
Remove this line, otherwise InMemoryURLIndex::OnUR
nshaik
2014/11/06 02:05:12
My bad. fixed it.
| |
| 385 } | |
| 386 | |
| 385 } // namespace history | 387 } // namespace history |
| OLD | NEW |