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

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: fix compile 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
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..75ecdd3592a9a5ce318990303439a31367ad9b8d
--- /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"
+
+TrackedSplitPreference::TrackedSplitPreference(
+ const std::string& pref_path,
+ size_t reporting_id,
+ size_t reporting_ids_count,
+ PrefHashFilter::EnforcementLevel enforcement_level)
+ : pref_path_(pref_path),
+ helper_(pref_path, reporting_id, reporting_ids_count, enforcement_level) {
+}
+
+void TrackedSplitPreference::OnValueChanged(
+ const base::Value* value,
+ PrefHashStore* pref_hash_store) const {
+ const base::DictionaryValue* dict_value = NULL;
+ if (value && !value->GetAsDictionary(&dict_value)) {
+ NOTREACHED();
+ return;
+ }
+ pref_hash_store->StoreSplitHash(pref_path_, dict_value);
erikwright (departed) 2014/01/21 18:44:45 pref_hash_store.h
gab 2014/01/21 20:51:42 Done.
+}
+
+void TrackedSplitPreference::EnforceAndReport(
+ PrefHashStore* pref_hash_store,
+ 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);
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698