OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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_index.
h" | 5 #include "chrome/browser/sync_file_system/drive_backend/metadata_database_index.
h" |
6 | 6 |
7 #include "base/metrics/histogram.h" | 7 #include "base/metrics/histogram.h" |
8 #include "base/strings/string_number_conversions.h" | 8 #include "base/strings/string_number_conversions.h" |
9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
10 #include "chrome/browser/sync_file_system/drive_backend/drive_backend_constants.
h" | 10 #include "chrome/browser/sync_file_system/drive_backend/drive_backend_constants.
h" |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
78 void ReadDatabaseContents(leveldb::DB* db, | 78 void ReadDatabaseContents(leveldb::DB* db, |
79 DatabaseContents* contents) { | 79 DatabaseContents* contents) { |
80 DCHECK(db); | 80 DCHECK(db); |
81 DCHECK(contents); | 81 DCHECK(contents); |
82 | 82 |
83 scoped_ptr<leveldb::Iterator> itr(db->NewIterator(leveldb::ReadOptions())); | 83 scoped_ptr<leveldb::Iterator> itr(db->NewIterator(leveldb::ReadOptions())); |
84 for (itr->SeekToFirst(); itr->Valid(); itr->Next()) { | 84 for (itr->SeekToFirst(); itr->Valid(); itr->Next()) { |
85 std::string key = itr->key().ToString(); | 85 std::string key = itr->key().ToString(); |
86 std::string value = itr->value().ToString(); | 86 std::string value = itr->value().ToString(); |
87 | 87 |
88 if (StartsWithASCII(key, kFileMetadataKeyPrefix, true)) { | 88 std::string file_id; |
89 std::string file_id = RemovePrefix(key, kFileMetadataKeyPrefix); | 89 if (RemovePrefix(key, kFileMetadataKeyPrefix, &file_id)) { |
90 | |
91 scoped_ptr<FileMetadata> metadata(new FileMetadata); | 90 scoped_ptr<FileMetadata> metadata(new FileMetadata); |
92 if (!metadata->ParseFromString(itr->value().ToString())) { | 91 if (!metadata->ParseFromString(itr->value().ToString())) { |
93 util::Log(logging::LOG_WARNING, FROM_HERE, | 92 util::Log(logging::LOG_WARNING, FROM_HERE, |
94 "Failed to parse a FileMetadata"); | 93 "Failed to parse a FileMetadata"); |
95 continue; | 94 continue; |
96 } | 95 } |
97 | 96 |
98 contents->file_metadata.push_back(metadata.release()); | 97 contents->file_metadata.push_back(metadata.release()); |
99 continue; | 98 continue; |
100 } | 99 } |
101 | 100 |
102 if (StartsWithASCII(key, kFileTrackerKeyPrefix, true)) { | 101 std::string tracker_id_str; |
| 102 if (RemovePrefix(key, kFileTrackerKeyPrefix, &tracker_id_str)) { |
103 int64 tracker_id = 0; | 103 int64 tracker_id = 0; |
104 if (!base::StringToInt64(RemovePrefix(key, kFileTrackerKeyPrefix), | 104 if (!base::StringToInt64(tracker_id_str, &tracker_id)) { |
105 &tracker_id)) { | |
106 util::Log(logging::LOG_WARNING, FROM_HERE, | 105 util::Log(logging::LOG_WARNING, FROM_HERE, |
107 "Failed to parse TrackerID"); | 106 "Failed to parse TrackerID"); |
108 continue; | 107 continue; |
109 } | 108 } |
110 | 109 |
111 scoped_ptr<FileTracker> tracker(new FileTracker); | 110 scoped_ptr<FileTracker> tracker(new FileTracker); |
112 if (!tracker->ParseFromString(itr->value().ToString())) { | 111 if (!tracker->ParseFromString(itr->value().ToString())) { |
113 util::Log(logging::LOG_WARNING, FROM_HERE, | 112 util::Log(logging::LOG_WARNING, FROM_HERE, |
114 "Failed to parse a Tracker"); | 113 "Failed to parse a Tracker"); |
115 continue; | 114 continue; |
(...skipping 574 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
690 | 689 |
691 DVLOG(3) << " Remove from dirty_trackers_: " << tracker_id; | 690 DVLOG(3) << " Remove from dirty_trackers_: " << tracker_id; |
692 dirty_trackers_.erase(tracker_id); | 691 dirty_trackers_.erase(tracker_id); |
693 | 692 |
694 demoted_dirty_trackers_.erase(tracker_id); | 693 demoted_dirty_trackers_.erase(tracker_id); |
695 } | 694 } |
696 } | 695 } |
697 | 696 |
698 } // namespace drive_backend | 697 } // namespace drive_backend |
699 } // namespace sync_file_system | 698 } // namespace sync_file_system |
OLD | NEW |