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

Unified Diff: chrome/browser/net/sdch_owner_pref_storage.cc

Issue 1634653003: Abstract pref storage from net::SdchOwner (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@net_prefs
Patch Set: Review comments Created 4 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/net/sdch_owner_pref_storage.cc
diff --git a/chrome/browser/net/sdch_owner_pref_storage.cc b/chrome/browser/net/sdch_owner_pref_storage.cc
new file mode 100644
index 0000000000000000000000000000000000000000..b73b9763cdabd40ada63f8b37c1ffe56dfbb167c
--- /dev/null
+++ b/chrome/browser/net/sdch_owner_pref_storage.cc
@@ -0,0 +1,111 @@
+// Copyright 2015 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/net/sdch_owner_pref_storage.h"
+
+#include "base/prefs/persistent_pref_store.h"
+#include "base/values.h"
+
+namespace chrome_browser_net {
+
+namespace {
+
+static const char kStorageKey[] = "SDCH";
+
+} // namespace
+
+SdchOwnerPrefStorage::SdchOwnerPrefStorage(PersistentPrefStore* storage)
+ : storage_(storage),
+ storage_key_(KStorageKey),
+ init_observer_(nullptr) {
+}
+
+SdchOwnerPrefStorage::~SdchOwnerPrefStorage() {
+ if (init_observer_)
+ storage_->RemoveObserver(this);
+}
+
+net::SdchOwner::PrefStorage::ReadError
+SdchOwnerPrefStorage::GetReadError() const {
+ PersistentPrefStore::PrefReadError error = storage_->GetReadError();
+
+ DCHECK_NE(error,
+ PersistentPrefStore::PREF_READ_ERROR_ASYNCHRONOUS_TASK_INCOMPLETE);
+ DCHECK_NE(error, PersistentPrefStore::PREF_READ_ERROR_MAX_ENUM);
+
+ switch (error) {
+ case PersistentPrefStore::PREF_READ_ERROR_NONE:
+ return PERSISTENCE_FAILURE_NONE;
+
+ case PersistentPrefStore::PREF_READ_ERROR_NO_FILE:
+ return PERSISTENCE_FAILURE_REASON_NO_FILE;
+
+ case PersistentPrefStore::PREF_READ_ERROR_JSON_PARSE:
+ case PersistentPrefStore::PREF_READ_ERROR_JSON_TYPE:
+ case PersistentPrefStore::PREF_READ_ERROR_FILE_OTHER:
+ case PersistentPrefStore::PREF_READ_ERROR_FILE_LOCKED:
+ case PersistentPrefStore::PREF_READ_ERROR_JSON_REPEAT:
+ return PERSISTENCE_FAILURE_REASON_READ_FAILED;
+
+ case PersistentPrefStore::PREF_READ_ERROR_ACCESS_DENIED:
+ case PersistentPrefStore::PREF_READ_ERROR_FILE_NOT_SPECIFIED:
+ case PersistentPrefStore::PREF_READ_ERROR_ASYNCHRONOUS_TASK_INCOMPLETE:
+ case PersistentPrefStore::PREF_READ_ERROR_MAX_ENUM:
+ default:
+ // We don't expect these other failures given our usage of prefs.
+ NOTREACHED();
+ return PERSISTENCE_FAILURE_OTHER;
+ }
+}
+
+bool SdchOwnerPrefStorage::GetValue(
+ const base::DictionaryValue** result) const {
+ const base::Value* result_value = nullptr;
+ if (!storage_->GetValue(storage_key_, &result_value))
+ return false;
+ return result_value->GetAsDictionary(result);
+}
+
+bool SdchOwnerPrefStorage::GetMutableValue(base::DictionaryValue** result) {
+ base::Value* result_value = nullptr;
+ if (!storage_->GetMutableValue(storage_key_, &result_value))
+ return false;
+ return result_value->GetAsDictionary(result);
+}
+
+void SdchOwnerPrefStorage::SetValue(scoped_ptr<base::DictionaryValue> value) {
+ storage_->SetValue(storage_key_, std::move(value),
+ WriteablePrefStore::DEFAULT_PREF_WRITE_FLAGS);
+}
+
+void SdchOwnerPrefStorage::ReportValueChanged() {
+ storage_->ReportValueChanged(storage_key_,
+ WriteablePrefStore::DEFAULT_PREF_WRITE_FLAGS);
+}
+
+bool SdchOwnerPrefStorage::IsInitializationComplete() {
+ return storage_->IsInitializationComplete();
+}
+
+void SdchOwnerPrefStorage::StartObservingInit(net::SdchOwner* observer) {
+ DCHECK(!init_observer_);
+ init_observer_ = observer;
+ storage_->AddObserver(this);
+}
+
+void SdchOwnerPrefStorage::StopObservingInit() {
+ DCHECK(init_observer_);
+ init_observer_ = nullptr;
+ storage_->RemoveObserver(this);
+}
+
+void SdchOwnerPrefStorage::OnPrefValueChanged(const std::string& key) {
+}
+
+void SdchOwnerPrefStorage::OnInitializationCompleted(bool succeeded) {
+ DCHECK(init_observer_);
+ init_observer_->OnPrefStorageInitializationComplete(succeeded);
+}
+
+} // namespace chrome_browser_net

Powered by Google App Engine
This is Rietveld 408576698