| 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 #ifndef COMPONENTS_DRIVE_CHANGE_LIST_PROCESSOR_H_ | 5 #ifndef COMPONENTS_DRIVE_CHANGE_LIST_PROCESSOR_H_ |
| 6 #define COMPONENTS_DRIVE_CHANGE_LIST_PROCESSOR_H_ | 6 #define COMPONENTS_DRIVE_CHANGE_LIST_PROCESSOR_H_ |
| 7 | 7 |
| 8 #include <stdint.h> |
| 9 |
| 8 #include <map> | 10 #include <map> |
| 9 #include <set> | 11 #include <set> |
| 10 #include <string> | 12 #include <string> |
| 11 | 13 |
| 12 #include "base/files/file_path.h" | 14 #include "base/files/file_path.h" |
| 15 #include "base/macros.h" |
| 13 #include "base/memory/scoped_ptr.h" | 16 #include "base/memory/scoped_ptr.h" |
| 14 #include "base/memory/scoped_vector.h" | 17 #include "base/memory/scoped_vector.h" |
| 15 #include "components/drive/file_errors.h" | 18 #include "components/drive/file_errors.h" |
| 16 #include "components/drive/file_errors.h" | 19 #include "components/drive/file_errors.h" |
| 17 #include "url/gurl.h" | 20 #include "url/gurl.h" |
| 18 | 21 |
| 19 namespace base { | 22 namespace base { |
| 20 class CancellationFlag; | 23 class CancellationFlag; |
| 21 } // namespace base | 24 } // namespace base |
| 22 | 25 |
| (...skipping 12 matching lines...) Expand all Loading... |
| 35 | 38 |
| 36 class ResourceMetadata; | 39 class ResourceMetadata; |
| 37 | 40 |
| 38 // Holds information needed to fetch contents of a directory. | 41 // Holds information needed to fetch contents of a directory. |
| 39 // This object is copyable. | 42 // This object is copyable. |
| 40 class DirectoryFetchInfo { | 43 class DirectoryFetchInfo { |
| 41 public: | 44 public: |
| 42 DirectoryFetchInfo() : changestamp_(0) {} | 45 DirectoryFetchInfo() : changestamp_(0) {} |
| 43 DirectoryFetchInfo(const std::string& local_id, | 46 DirectoryFetchInfo(const std::string& local_id, |
| 44 const std::string& resource_id, | 47 const std::string& resource_id, |
| 45 int64 changestamp) | 48 int64_t changestamp) |
| 46 : local_id_(local_id), | 49 : local_id_(local_id), |
| 47 resource_id_(resource_id), | 50 resource_id_(resource_id), |
| 48 changestamp_(changestamp) { | 51 changestamp_(changestamp) {} |
| 49 } | |
| 50 | 52 |
| 51 // Returns true if the object is empty. | 53 // Returns true if the object is empty. |
| 52 bool empty() const { return local_id_.empty(); } | 54 bool empty() const { return local_id_.empty(); } |
| 53 | 55 |
| 54 // Local ID of the directory. | 56 // Local ID of the directory. |
| 55 const std::string& local_id() const { return local_id_; } | 57 const std::string& local_id() const { return local_id_; } |
| 56 | 58 |
| 57 // Resource ID of the directory. | 59 // Resource ID of the directory. |
| 58 const std::string& resource_id() const { return resource_id_; } | 60 const std::string& resource_id() const { return resource_id_; } |
| 59 | 61 |
| 60 // Changestamp of the directory. The changestamp is used to determine if | 62 // Changestamp of the directory. The changestamp is used to determine if |
| 61 // the directory contents should be fetched. | 63 // the directory contents should be fetched. |
| 62 int64 changestamp() const { return changestamp_; } | 64 int64_t changestamp() const { return changestamp_; } |
| 63 | 65 |
| 64 // Returns a string representation of this object. | 66 // Returns a string representation of this object. |
| 65 std::string ToString() const; | 67 std::string ToString() const; |
| 66 | 68 |
| 67 private: | 69 private: |
| 68 const std::string local_id_; | 70 const std::string local_id_; |
| 69 const std::string resource_id_; | 71 const std::string resource_id_; |
| 70 const int64 changestamp_; | 72 const int64_t changestamp_; |
| 71 }; | 73 }; |
| 72 | 74 |
| 73 // Class to represent a change list. | 75 // Class to represent a change list. |
| 74 class ChangeList { | 76 class ChangeList { |
| 75 public: | 77 public: |
| 76 ChangeList(); // For tests. | 78 ChangeList(); // For tests. |
| 77 explicit ChangeList(const google_apis::ChangeList& change_list); | 79 explicit ChangeList(const google_apis::ChangeList& change_list); |
| 78 explicit ChangeList(const google_apis::FileList& file_list); | 80 explicit ChangeList(const google_apis::FileList& file_list); |
| 79 ~ChangeList(); | 81 ~ChangeList(); |
| 80 | 82 |
| 81 const std::vector<ResourceEntry>& entries() const { return entries_; } | 83 const std::vector<ResourceEntry>& entries() const { return entries_; } |
| 82 std::vector<ResourceEntry>* mutable_entries() { return &entries_; } | 84 std::vector<ResourceEntry>* mutable_entries() { return &entries_; } |
| 83 const std::vector<std::string>& parent_resource_ids() const { | 85 const std::vector<std::string>& parent_resource_ids() const { |
| 84 return parent_resource_ids_; | 86 return parent_resource_ids_; |
| 85 } | 87 } |
| 86 std::vector<std::string>* mutable_parent_resource_ids() { | 88 std::vector<std::string>* mutable_parent_resource_ids() { |
| 87 return &parent_resource_ids_; | 89 return &parent_resource_ids_; |
| 88 } | 90 } |
| 89 const GURL& next_url() const { return next_url_; } | 91 const GURL& next_url() const { return next_url_; } |
| 90 int64 largest_changestamp() const { return largest_changestamp_; } | 92 int64_t largest_changestamp() const { return largest_changestamp_; } |
| 91 | 93 |
| 92 void set_largest_changestamp(int64 largest_changestamp) { | 94 void set_largest_changestamp(int64_t largest_changestamp) { |
| 93 largest_changestamp_ = largest_changestamp; | 95 largest_changestamp_ = largest_changestamp; |
| 94 } | 96 } |
| 95 | 97 |
| 96 private: | 98 private: |
| 97 std::vector<ResourceEntry> entries_; | 99 std::vector<ResourceEntry> entries_; |
| 98 std::vector<std::string> parent_resource_ids_; | 100 std::vector<std::string> parent_resource_ids_; |
| 99 GURL next_url_; | 101 GURL next_url_; |
| 100 int64 largest_changestamp_; | 102 int64_t largest_changestamp_; |
| 101 | 103 |
| 102 DISALLOW_COPY_AND_ASSIGN(ChangeList); | 104 DISALLOW_COPY_AND_ASSIGN(ChangeList); |
| 103 }; | 105 }; |
| 104 | 106 |
| 105 // ChangeListProcessor is used to process change lists, or full resource | 107 // ChangeListProcessor is used to process change lists, or full resource |
| 106 // lists from WAPI (codename for Documents List API) or Google Drive API, and | 108 // lists from WAPI (codename for Documents List API) or Google Drive API, and |
| 107 // updates the resource metadata stored locally. | 109 // updates the resource metadata stored locally. |
| 108 class ChangeListProcessor { | 110 class ChangeListProcessor { |
| 109 public: | 111 public: |
| 110 ChangeListProcessor(ResourceMetadata* resource_metadata, | 112 ChangeListProcessor(ResourceMetadata* resource_metadata, |
| (...skipping 28 matching lines...) Expand all Loading... |
| 139 | 141 |
| 140 private: | 142 private: |
| 141 typedef std::map<std::string /* resource_id */, ResourceEntry> | 143 typedef std::map<std::string /* resource_id */, ResourceEntry> |
| 142 ResourceEntryMap; | 144 ResourceEntryMap; |
| 143 typedef std::map<std::string /* resource_id */, | 145 typedef std::map<std::string /* resource_id */, |
| 144 std::string /* parent_resource_id*/> ParentResourceIdMap; | 146 std::string /* parent_resource_id*/> ParentResourceIdMap; |
| 145 | 147 |
| 146 // Applies the pre-processed metadata from entry_map_ onto the resource | 148 // Applies the pre-processed metadata from entry_map_ onto the resource |
| 147 // metadata. |about_resource| must not be null. | 149 // metadata. |about_resource| must not be null. |
| 148 FileError ApplyEntryMap( | 150 FileError ApplyEntryMap( |
| 149 int64 changestamp, | 151 int64_t changestamp, |
| 150 scoped_ptr<google_apis::AboutResource> about_resource); | 152 scoped_ptr<google_apis::AboutResource> about_resource); |
| 151 | 153 |
| 152 // Apply |entry| to resource_metadata_. | 154 // Apply |entry| to resource_metadata_. |
| 153 FileError ApplyEntry(const ResourceEntry& entry); | 155 FileError ApplyEntry(const ResourceEntry& entry); |
| 154 | 156 |
| 155 // Adds the directories changed by the update on |entry| to |changed_dirs_|. | 157 // Adds the directories changed by the update on |entry| to |changed_dirs_|. |
| 156 void UpdateChangedDirs(const ResourceEntry& entry); | 158 void UpdateChangedDirs(const ResourceEntry& entry); |
| 157 | 159 |
| 158 ResourceMetadata* resource_metadata_; // Not owned. | 160 ResourceMetadata* resource_metadata_; // Not owned. |
| 159 base::CancellationFlag* in_shutdown_; // Not owned. | 161 base::CancellationFlag* in_shutdown_; // Not owned. |
| 160 | 162 |
| 161 ResourceEntryMap entry_map_; | 163 ResourceEntryMap entry_map_; |
| 162 ParentResourceIdMap parent_resource_id_map_; | 164 ParentResourceIdMap parent_resource_id_map_; |
| 163 scoped_ptr<FileChange> changed_files_; | 165 scoped_ptr<FileChange> changed_files_; |
| 164 | 166 |
| 165 DISALLOW_COPY_AND_ASSIGN(ChangeListProcessor); | 167 DISALLOW_COPY_AND_ASSIGN(ChangeListProcessor); |
| 166 }; | 168 }; |
| 167 | 169 |
| 168 } // namespace internal | 170 } // namespace internal |
| 169 } // namespace drive | 171 } // namespace drive |
| 170 | 172 |
| 171 #endif // COMPONENTS_DRIVE_CHANGE_LIST_PROCESSOR_H_ | 173 #endif // COMPONENTS_DRIVE_CHANGE_LIST_PROCESSOR_H_ |
| OLD | NEW |