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

Unified Diff: chrome/browser/prefs/tracked/tracked_split_preference.cc

Issue 114223002: Multi-strategy based tracking. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: merge up to r248367 Created 6 years, 11 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
« no previous file with comments | « chrome/browser/prefs/tracked/tracked_split_preference.h ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/prefs/tracked/tracked_split_preference.cc
diff --git a/chrome/browser/prefs/tracked/tracked_split_preference.cc b/chrome/browser/prefs/tracked/tracked_split_preference.cc
new file mode 100644
index 0000000000000000000000000000000000000000..f78cdc9c130a1ea34e6f47880cdaaa26b74f6614
--- /dev/null
+++ b/chrome/browser/prefs/tracked/tracked_split_preference.cc
@@ -0,0 +1,75 @@
+// Copyright 2014 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.
+
+#include "chrome/browser/prefs/tracked/tracked_split_preference.h"
+
+#include <vector>
+
+#include "base/logging.h"
+#include "base/values.h"
+#include "chrome/browser/prefs/pref_hash_store.h"
+
+TrackedSplitPreference::TrackedSplitPreference(
+ const std::string& pref_path,
+ size_t reporting_id,
+ size_t reporting_ids_count,
+ PrefHashFilter::EnforcementLevel enforcement_level,
+ PrefHashStore* pref_hash_store)
+ : pref_path_(pref_path),
+ helper_(pref_path, reporting_id, reporting_ids_count, enforcement_level),
+ pref_hash_store_(pref_hash_store) {
+}
+
+void TrackedSplitPreference::OnNewValue(const base::Value* value) const {
+ const base::DictionaryValue* dict_value = NULL;
+ if (value && !value->GetAsDictionary(&dict_value)) {
+ NOTREACHED();
+ return;
+ }
+ pref_hash_store_->StoreSplitHash(pref_path_, dict_value);
+}
+
+void TrackedSplitPreference::EnforceAndReport(
+ base::DictionaryValue* pref_store_contents) const {
+ base::DictionaryValue* dict_value = NULL;
+ if (!pref_store_contents->GetDictionary(pref_path_, &dict_value) &&
+ pref_store_contents->Get(pref_path_, NULL)) {
+ // There should be a dictionary or nothing at |pref_path_|.
+ NOTREACHED();
+ return;
+ }
+
+ std::vector<std::string> invalid_keys;
+ PrefHashStore::ValueState value_state =
+ pref_hash_store_->CheckSplitValue(pref_path_, dict_value, &invalid_keys);
+
+ if (value_state == PrefHashStore::CHANGED)
+ helper_.ReportSplitPreferenceChangedCount(invalid_keys.size());
+
+ helper_.ReportValidationResult(value_state);
+
+ TrackedPreferenceHelper::ResetAction reset_action =
+ helper_.GetAction(value_state);
+ helper_.ReportAction(reset_action);
+
+ if (reset_action == TrackedPreferenceHelper::DO_RESET) {
+ if (value_state == PrefHashStore::CHANGED) {
+ DCHECK(!invalid_keys.empty());
+
+ for (std::vector<std::string>::const_iterator it =
+ invalid_keys.begin(); it != invalid_keys.end(); ++it) {
+ dict_value->Remove(*it, NULL);
+ }
+ } else {
+ pref_store_contents->RemovePath(pref_path_, NULL);
+ }
+ }
+
+ if (value_state != PrefHashStore::UNCHANGED) {
+ // Store the hash for the new value (whether it was reset or not).
+ const base::DictionaryValue* new_dict_value = NULL;
+ pref_store_contents->GetDictionary(pref_path_, &new_dict_value);
+ pref_hash_store_->StoreSplitHash(pref_path_, new_dict_value);
+ }
+}
« no previous file with comments | « chrome/browser/prefs/tracked/tracked_split_preference.h ('k') | chrome/chrome_browser.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698