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

Unified Diff: chrome/browser/sync_file_system/drive_backend/metadata_database_index_on_disk.cc

Issue 446793002: [SyncFS] Unconditionally demote remote file trackers on remote-to-local sync (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix Created 6 years, 4 months 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/sync_file_system/drive_backend/metadata_database_index_on_disk.cc
diff --git a/chrome/browser/sync_file_system/drive_backend/metadata_database_index_on_disk.cc b/chrome/browser/sync_file_system/drive_backend/metadata_database_index_on_disk.cc
index e82606179eadc6026dc811f3c7040ee153bbe418..a5b716308264727c8ebf618a94f3e8e35a0a6eda 100644
--- a/chrome/browser/sync_file_system/drive_backend/metadata_database_index_on_disk.cc
+++ b/chrome/browser/sync_file_system/drive_backend/metadata_database_index_on_disk.cc
@@ -528,7 +528,18 @@ bool MetadataDatabaseIndexOnDisk::HasDemotedDirtyTracker() const {
return StartsWithASCII(itr->key().ToString(), kDemotedDirtyIDKeyPrefix, true);
}
-void MetadataDatabaseIndexOnDisk::PromoteDemotedDirtyTrackers() {
+void MetadataDatabaseIndexOnDisk::PromoteDemotedDirtyTracker(int64 tracker_id) {
+ std::string demoted_key = GenerateDemotedDirtyIDKey(tracker_id);
+
+ std::string empty;
+ if (db_->Get(demoted_key, &empty).ok()) {
+ db_->Delete(demoted_key);
+ db_->Put(GenerateDirtyIDKey(tracker_id), std::string());
+ }
+}
+
+bool MetadataDatabaseIndexOnDisk::PromoteDemotedDirtyTrackers() {
+ bool promoted = false;
scoped_ptr<LevelDBWrapper::Iterator> itr(db_->NewIterator());
for (itr->Seek(kDirtyIDKeyPrefix); itr->Valid(); itr->Next()) {
std::string id_str;
@@ -541,7 +552,9 @@ void MetadataDatabaseIndexOnDisk::PromoteDemotedDirtyTrackers() {
db_->Delete(itr->key().ToString());
db_->Put(GenerateDemotedDirtyIDKey(tracker_id), std::string());
+ promoted = true;
}
+ return promoted;
}
size_t MetadataDatabaseIndexOnDisk::CountDirtyTracker() const {

Powered by Google App Engine
This is Rietveld 408576698