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

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

Issue 443793003: [SyncFS] Clear dirty flag on changelist application phase (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: 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.cc
diff --git a/chrome/browser/sync_file_system/drive_backend/metadata_database.cc b/chrome/browser/sync_file_system/drive_backend/metadata_database.cc
index 5c3bae8aa639b29ebb83b002a54c4fe09ab2de76..352e3fda05e374b5c479a08ba8e7f95f57c9c3c6 100644
--- a/chrome/browser/sync_file_system/drive_backend/metadata_database.cc
+++ b/chrome/browser/sync_file_system/drive_backend/metadata_database.cc
@@ -1361,6 +1361,24 @@ void MetadataDatabase::GetRegisteredAppIDs(std::vector<std::string>* app_ids) {
*app_ids = index_->GetRegisteredAppIDs();
}
+void MetadataDatabase::SweepDirtyTrackers(const SyncStatusCallback& callback) {
+ DCHECK(worker_sequence_checker_.CalledOnValidSequencedThread());
+
+ std::vector<int64> tracker_ids;
+ index_->EnumerateDirtyTrackers(base::Bind(
peria 2014/08/07 09:40:43 This code looks too complicated to me. Can't we do
tzik 2014/08/12 15:14:30 OK, revised.
+ &MetadataDatabase::VisitTrackerToSweep, base::Unretained(this),
+ &tracker_ids));
+
+ for (size_t i = 0; i < tracker_ids.size(); ++i) {
+ scoped_ptr<FileTracker> tracker(new FileTracker);
+ index_->GetFileTracker(tracker_ids[i], tracker.get());
+ tracker->set_dirty(false);
+ index_->StoreFileTracker(tracker.Pass());
+ }
+
+ WriteToDatabase(callback);
+}
+
MetadataDatabase::MetadataDatabase(
base::SequencedTaskRunner* worker_task_runner,
const base::FilePath& database_path,
@@ -1882,5 +1900,42 @@ void MetadataDatabase::DetachFromSequence() {
worker_sequence_checker_.DetachFromSequence();
}
+void MetadataDatabase::VisitTrackerToSweep(std::vector<int64>* tracker_ids,
+ int64 tracker_id) {
+ DCHECK(worker_sequence_checker_.CalledOnValidSequencedThread());
+
+ FileTracker tracker;
+ if (!index_->GetFileTracker(tracker_id, &tracker)) {
+ NOTREACHED();
+ return;
+ }
+
+ FileMetadata metadata;
+ if (!index_->GetFileMetadata(tracker.file_id(), &metadata) ||
+ !tracker.active() || !tracker.dirty() ||
+ !tracker.has_synced_details() ||
+ tracker.needs_folder_listing())
+ return;
+
+ const FileDetails& remote_details = metadata.details();
+ const FileDetails& synced_details = tracker.synced_details();
+ if (remote_details.title() != synced_details.title() ||
+ remote_details.md5() != synced_details.md5())
+ return;
+
+ std::set<std::string> parents;
+ for (int i = 0; i < remote_details.parent_folder_ids_size(); ++i)
+ parents.insert(remote_details.parent_folder_ids(i));
+
+ for (int i = 0; i < synced_details.parent_folder_ids_size(); ++i)
+ if (parents.erase(synced_details.parent_folder_ids(i)) != 1)
+ return;
+
+ if (!parents.empty())
+ return;
+
+ tracker_ids->push_back(tracker.tracker_id());
+}
+
} // namespace drive_backend
} // namespace sync_file_system

Powered by Google App Engine
This is Rietveld 408576698