diff options
author | yefim@chromium.org <yefim@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-02-12 21:16:40 +0000 |
---|---|---|
committer | yefim@chromium.org <yefim@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2014-02-12 21:16:40 +0000 |
commit | f93a6c6b376fe2ce3bb26698b6c4cb4cd0e36c28 (patch) | |
tree | d8ca4060b70c2d4fb5b7240e8c3f2daaef6938c6 /sync/internal_api | |
parent | 602f2dd4ad787a55009f32dd773d2b0d2b139a11 (diff) | |
download | chromium_src-f93a6c6b376fe2ce3bb26698b6c4cb4cd0e36c28.zip chromium_src-f93a6c6b376fe2ce3bb26698b6c4cb4cd0e36c28.tar.gz chromium_src-f93a6c6b376fe2ce3bb26698b6c4cb4cd0e36c28.tar.bz2 |
Enhanced bookmarks: added support for sync based experiment
BUG=321393
Review URL: https://codereview.chromium.org/156103002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@250792 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'sync/internal_api')
-rw-r--r-- | sync/internal_api/public/util/experiments.h | 21 | ||||
-rw-r--r-- | sync/internal_api/sync_manager_impl.cc | 17 |
2 files changed, 35 insertions, 3 deletions
diff --git a/sync/internal_api/public/util/experiments.h b/sync/internal_api/public/util/experiments.h index 4b89e43..18a0887 100644 --- a/sync/internal_api/public/util/experiments.h +++ b/sync/internal_api/public/util/experiments.h @@ -5,11 +5,16 @@ #ifndef SYNC_UTIL_EXPERIMENTS_ #define SYNC_UTIL_EXPERIMENTS_ +#include <string> + +#include "sync/internal_api/public/base/model_type.h" + namespace syncer { const char kFaviconSyncTag[] = "favicon_sync"; const char kPreCommitUpdateAvoidanceTag[] = "pre_commit_update_avoidance"; const char kGCMChannelTag[] = "gcm_channel"; +const char kEnhancedBookmarksTag[] = "enhanced_bookmarks"; // A structure to hold the enable status of experimental sync features. struct Experiments { @@ -19,12 +24,16 @@ struct Experiments { ENABLED, }; - Experiments() : favicon_sync_limit(200), - gcm_channel_state(UNSET) {} + Experiments() + : favicon_sync_limit(200), + gcm_channel_state(UNSET), + enhanced_bookmarks_enabled(false) {} bool Matches(const Experiments& rhs) { return (favicon_sync_limit == rhs.favicon_sync_limit && - gcm_channel_state == rhs.gcm_channel_state); + gcm_channel_state == rhs.gcm_channel_state && + enhanced_bookmarks_enabled == rhs.enhanced_bookmarks_enabled && + enhanced_bookmarks_ext_id == rhs.enhanced_bookmarks_ext_id); } // The number of favicons that a client is permitted to sync. @@ -32,6 +41,12 @@ struct Experiments { // Enable state of the GCM channel. GCMChannelState gcm_channel_state; + + // Enable the enhanced bookmarks sync datatype. + bool enhanced_bookmarks_enabled; + + // Enhanced bookmarks extension id. + std::string enhanced_bookmarks_ext_id; }; } // namespace syncer diff --git a/sync/internal_api/sync_manager_impl.cc b/sync/internal_api/sync_manager_impl.cc index e970b22..b2f1bdf 100644 --- a/sync/internal_api/sync_manager_impl.cc +++ b/sync/internal_api/sync_manager_impl.cc @@ -1221,6 +1221,23 @@ bool SyncManagerImpl::ReceivedExperiment(Experiments* experiments) { found_experiment = true; } + ReadNode enhanced_bookmarks_node(&trans); + if (enhanced_bookmarks_node.InitByClientTagLookup( + syncer::EXPERIMENTS, syncer::kEnhancedBookmarksTag) == + BaseNode::INIT_OK && + enhanced_bookmarks_node.GetExperimentsSpecifics() + .has_enhanced_bookmarks()) { + const sync_pb::EnhancedBookmarksFlags& enhanced_bookmarks = + enhanced_bookmarks_node.GetExperimentsSpecifics().enhanced_bookmarks(); + if (enhanced_bookmarks.has_enabled()) + experiments->enhanced_bookmarks_enabled = enhanced_bookmarks.enabled(); + if (enhanced_bookmarks.has_extension_id()) { + experiments->enhanced_bookmarks_ext_id = + enhanced_bookmarks.extension_id(); + } + found_experiment = true; + } + return found_experiment; } |