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

Unified Diff: components/history/core/browser/typed_url_sync_bridge.h

Issue 2723953002: [sync] skeleton implementation of TypedURLSyncBridge (Closed)
Patch Set: rebase and address missing parts for bug 558320 Created 3 years, 10 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: components/history/core/browser/typed_url_sync_bridge.h
diff --git a/components/history/core/browser/typed_url_sync_bridge.h b/components/history/core/browser/typed_url_sync_bridge.h
new file mode 100644
index 0000000000000000000000000000000000000000..4b62e620ed5a2c70cee09da177f35b7c190cf68e
--- /dev/null
+++ b/components/history/core/browser/typed_url_sync_bridge.h
@@ -0,0 +1,67 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef COMPONENTS_HISTORY_CORE_BROWSER_TYPED_URL_SYNC_BRIDGE_H_
+#define COMPONENTS_HISTORY_CORE_BROWSER_TYPED_URL_SYNC_BRIDGE_H_
+
+#include "components/history/core/browser/history_backend_observer.h"
+#include "components/sync/model/metadata_change_list.h"
+#include "components/sync/model/model_type_sync_bridge.h"
+#include "components/sync/model/sync_error.h"
+
+namespace history {
+
+class TypedURLSyncBridge : public syncer::ModelTypeSyncBridge,
+ public history::HistoryBackendObserver {
+ public:
+ TypedURLSyncBridge(HistoryBackend* history_backend,
+ const ChangeProcessorFactory& change_processor_factory);
+ ~TypedURLSyncBridge() override;
+
+ // syncer::ModelTypeService implementation.
+ std::unique_ptr<syncer::MetadataChangeList> CreateMetadataChangeList()
+ override;
+ base::Optional<syncer::ModelError> MergeSyncData(
+ std::unique_ptr<syncer::MetadataChangeList> metadata_change_list,
+ syncer::EntityDataMap entity_data_map) override;
+ base::Optional<syncer::ModelError> ApplySyncChanges(
+ std::unique_ptr<syncer::MetadataChangeList> metadata_change_list,
+ syncer::EntityChangeList entity_changes) override;
+ void GetData(StorageKeyList storage_keys, DataCallback callback) override;
+ void GetAllData(DataCallback callback) override;
+ // Generate a tag that uniquely identifies |entity_data| across all data
+ // types. This is used to identify the entity on the server. The string will
+ // be the url (URLRow::url()::spec()).
skym 2017/03/07 18:08:04 I'm still finding these comments kind of odd. I sh
skym 2017/03/07 19:25:22 I just posted a CL to make autocomplete's comments
Gang Wu 2017/03/31 19:35:58 Done.
+ std::string GetClientTag(const syncer::EntityData& entity_data) override;
+ // Generate a string key uniquely identifying |entity_data| in the context of
skym 2017/03/07 18:08:04 Same as above, lets move to .cc, and what do you t
skym 2017/03/07 18:53:51 This returns a string right.. Are we representing
Gang Wu 2017/03/31 19:35:58 base-10
+ // local storage. The string will be the id in the “urls” table
+ // (URLRow::id()).
+ std::string GetStorageKey(const syncer::EntityData& entity_data) override;
+
+ // history::HistoryBackendObserver:
+ void OnURLVisited(history::HistoryBackend* history_backend,
+ ui::PageTransition transition,
+ const history::URLRow& row,
+ const history::RedirectList& redirects,
+ base::Time visit_time) override;
+ void OnURLsModified(history::HistoryBackend* history_backend,
+ const history::URLRows& changed_urls) override;
+ void OnURLsDeleted(history::HistoryBackend* history_backend,
+ bool all_history,
+ bool expired,
+ const history::URLRows& deleted_rows,
+ const std::set<GURL>& favicon_urls) override;
+
+ private:
+ // The backend we're syncing local changes from and sync changes to.
+ HistoryBackend* const history_backend_;
+
+ base::SequenceChecker sequence_checker_;
skym 2017/03/07 18:08:04 Can you add a comment about why we're using a sequ
Gang Wu 2017/03/31 19:35:58 comment added, more detail here. https://coderevie
+
+ DISALLOW_COPY_AND_ASSIGN(TypedURLSyncBridge);
+};
+
+} // namespace history
+
+#endif // COMPONENTS_HISTORY_CORE_BROWSER_TYPED_URL_SYNC_BRIDGE_H_

Powered by Google App Engine
This is Rietveld 408576698