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

Side by Side 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/sync_file_system/drive_backend/metadata_database.h" 5 #include "chrome/browser/sync_file_system/drive_backend/metadata_database.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <stack> 8 #include <stack>
9 9
10 #include "base/bind.h" 10 #include "base/bind.h"
(...skipping 1343 matching lines...) Expand 10 before | Expand all | Expand 10 after
1354 std::swap(*trackers_out, trackers); 1354 std::swap(*trackers_out, trackers);
1355 return true; 1355 return true;
1356 } 1356 }
1357 1357
1358 void MetadataDatabase::GetRegisteredAppIDs(std::vector<std::string>* app_ids) { 1358 void MetadataDatabase::GetRegisteredAppIDs(std::vector<std::string>* app_ids) {
1359 DCHECK(worker_sequence_checker_.CalledOnValidSequencedThread()); 1359 DCHECK(worker_sequence_checker_.CalledOnValidSequencedThread());
1360 DCHECK(app_ids); 1360 DCHECK(app_ids);
1361 *app_ids = index_->GetRegisteredAppIDs(); 1361 *app_ids = index_->GetRegisteredAppIDs();
1362 } 1362 }
1363 1363
1364 void MetadataDatabase::SweepDirtyTrackers(const SyncStatusCallback& callback) {
1365 DCHECK(worker_sequence_checker_.CalledOnValidSequencedThread());
1366
1367 std::vector<int64> tracker_ids;
1368 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.
1369 &MetadataDatabase::VisitTrackerToSweep, base::Unretained(this),
1370 &tracker_ids));
1371
1372 for (size_t i = 0; i < tracker_ids.size(); ++i) {
1373 scoped_ptr<FileTracker> tracker(new FileTracker);
1374 index_->GetFileTracker(tracker_ids[i], tracker.get());
1375 tracker->set_dirty(false);
1376 index_->StoreFileTracker(tracker.Pass());
1377 }
1378
1379 WriteToDatabase(callback);
1380 }
1381
1364 MetadataDatabase::MetadataDatabase( 1382 MetadataDatabase::MetadataDatabase(
1365 base::SequencedTaskRunner* worker_task_runner, 1383 base::SequencedTaskRunner* worker_task_runner,
1366 const base::FilePath& database_path, 1384 const base::FilePath& database_path,
1367 leveldb::Env* env_override) 1385 leveldb::Env* env_override)
1368 : worker_task_runner_(worker_task_runner), 1386 : worker_task_runner_(worker_task_runner),
1369 database_path_(database_path), 1387 database_path_(database_path),
1370 env_override_(env_override), 1388 env_override_(env_override),
1371 largest_known_change_id_(0), 1389 largest_known_change_id_(0),
1372 weak_ptr_factory_(this) { 1390 weak_ptr_factory_(this) {
1373 DCHECK(worker_task_runner); 1391 DCHECK(worker_task_runner);
(...skipping 501 matching lines...) Expand 10 before | Expand all | Expand 10 after
1875 *app_root_metadata); 1893 *app_root_metadata);
1876 1894
1877 index_->StoreFileMetadata(app_root_metadata.Pass()); 1895 index_->StoreFileMetadata(app_root_metadata.Pass());
1878 index_->StoreFileTracker(app_root_tracker.Pass()); 1896 index_->StoreFileTracker(app_root_tracker.Pass());
1879 } 1897 }
1880 1898
1881 void MetadataDatabase::DetachFromSequence() { 1899 void MetadataDatabase::DetachFromSequence() {
1882 worker_sequence_checker_.DetachFromSequence(); 1900 worker_sequence_checker_.DetachFromSequence();
1883 } 1901 }
1884 1902
1903 void MetadataDatabase::VisitTrackerToSweep(std::vector<int64>* tracker_ids,
1904 int64 tracker_id) {
1905 DCHECK(worker_sequence_checker_.CalledOnValidSequencedThread());
1906
1907 FileTracker tracker;
1908 if (!index_->GetFileTracker(tracker_id, &tracker)) {
1909 NOTREACHED();
1910 return;
1911 }
1912
1913 FileMetadata metadata;
1914 if (!index_->GetFileMetadata(tracker.file_id(), &metadata) ||
1915 !tracker.active() || !tracker.dirty() ||
1916 !tracker.has_synced_details() ||
1917 tracker.needs_folder_listing())
1918 return;
1919
1920 const FileDetails& remote_details = metadata.details();
1921 const FileDetails& synced_details = tracker.synced_details();
1922 if (remote_details.title() != synced_details.title() ||
1923 remote_details.md5() != synced_details.md5())
1924 return;
1925
1926 std::set<std::string> parents;
1927 for (int i = 0; i < remote_details.parent_folder_ids_size(); ++i)
1928 parents.insert(remote_details.parent_folder_ids(i));
1929
1930 for (int i = 0; i < synced_details.parent_folder_ids_size(); ++i)
1931 if (parents.erase(synced_details.parent_folder_ids(i)) != 1)
1932 return;
1933
1934 if (!parents.empty())
1935 return;
1936
1937 tracker_ids->push_back(tracker.tracker_id());
1938 }
1939
1885 } // namespace drive_backend 1940 } // namespace drive_backend
1886 } // namespace sync_file_system 1941 } // namespace sync_file_system
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698