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

Side by Side Diff: chrome/browser/extensions/settings/setting_sync_data.cc

Issue 9427001: Extend TwoClientExtensionSettingsSyncTest to test app settings. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: oops Created 8 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/extensions/settings/setting_sync_data.h" 5 #include "chrome/browser/extensions/settings/setting_sync_data.h"
6 6
7 #include "base/json/json_reader.h" 7 #include "base/json/json_reader.h"
8 #include "base/json/json_writer.h" 8 #include "base/json/json_writer.h"
9 #include "chrome/browser/sync/api/sync_data.h" 9 #include "chrome/browser/sync/api/sync_data.h"
10 #include "chrome/browser/sync/protocol/app_setting_specifics.pb.h"
10 #include "chrome/browser/sync/protocol/extension_setting_specifics.pb.h" 11 #include "chrome/browser/sync/protocol/extension_setting_specifics.pb.h"
12 #include "chrome/browser/sync/protocol/sync.pb.h"
11 13
12 namespace extensions { 14 namespace extensions {
13 15
14 SettingSyncData::SettingSyncData( 16 SettingSyncData::SettingSyncData(
15 const SyncChange& sync_change) { 17 const SyncChange& sync_change) {
16 Init(sync_change.change_type(), sync_change.sync_data()); 18 Init(sync_change.change_type(), sync_change.sync_data());
17 } 19 }
18 20
19 SettingSyncData::SettingSyncData( 21 SettingSyncData::SettingSyncData(
20 const SyncData& sync_data) { 22 const SyncData& sync_data) {
21 Init(SyncChange::ACTION_INVALID, sync_data); 23 Init(SyncChange::ACTION_INVALID, sync_data);
22 } 24 }
23 25
24 void SettingSyncData::Init( 26 void SettingSyncData::Init(
25 SyncChange::SyncChangeType change_type, const SyncData& sync_data) { 27 SyncChange::SyncChangeType change_type, const SyncData& sync_data) {
26 DCHECK(!internal_.get()); 28 DCHECK(!internal_.get());
27 sync_pb::ExtensionSettingSpecifics specifics = 29 sync_pb::EntitySpecifics specifics = sync_data.GetSpecifics();
28 sync_data.GetSpecifics().GetExtension(sync_pb::extension_setting); 30 // The data can only be either extension or app specfics. Assert this in
akalin 2012/02/27 23:42:10 can only be either -> must be either specfics -> s
not at google - send to devlin 2012/02/27 23:45:46 Done.
29 Value* value = 31 // debug mode.
30 base::JSONReader().JsonToValue(specifics.value(), false, false); 32 DCHECK_NE(specifics.HasExtension(sync_pb::extension_setting),
31 if (!value) { 33 specifics.HasExtension(sync_pb::app_setting));
34 if (specifics.HasExtension(sync_pb::extension_setting)) {
35 InitFromExtensionSettingSpecifics(
36 change_type,
37 specifics.GetExtension(sync_pb::extension_setting));
38 } else if (specifics.HasExtension(sync_pb::app_setting)) {
39 InitFromExtensionSettingSpecifics(
40 change_type,
41 specifics.GetExtension(sync_pb::app_setting).extension_setting());
42 }
43 }
44
45 void SettingSyncData::InitFromExtensionSettingSpecifics(
46 SyncChange::SyncChangeType change_type,
47 const sync_pb::ExtensionSettingSpecifics& specifics) {
48 DCHECK(!internal_.get());
49 scoped_ptr<Value> value(
50 base::JSONReader().JsonToValue(specifics.value(), false, false));
51 if (!value.get()) {
32 LOG(WARNING) << "Specifics for " << specifics.extension_id() << "/" << 52 LOG(WARNING) << "Specifics for " << specifics.extension_id() << "/" <<
33 specifics.key() << " had bad JSON for value: " << specifics.value(); 53 specifics.key() << " had bad JSON for value: " << specifics.value();
34 value = new DictionaryValue(); 54 value.reset(new DictionaryValue());
35 } 55 }
36 internal_ = new Internal( 56 internal_ = new Internal(
37 change_type, 57 change_type,
38 specifics.extension_id(), 58 specifics.extension_id(),
39 specifics.key(), 59 specifics.key(),
40 value); 60 value.Pass());
41 } 61 }
42 62
43 SettingSyncData::SettingSyncData( 63 SettingSyncData::SettingSyncData(
44 SyncChange::SyncChangeType change_type, 64 SyncChange::SyncChangeType change_type,
45 const std::string& extension_id, 65 const std::string& extension_id,
46 const std::string& key, 66 const std::string& key,
47 Value* value) 67 scoped_ptr<Value> value)
48 : internal_(new Internal(change_type, extension_id, key, value)) { 68 : internal_(new Internal(change_type, extension_id, key, value.Pass())) {}
49 CHECK(value);
50 }
51 69
52 SettingSyncData::~SettingSyncData() {} 70 SettingSyncData::~SettingSyncData() {}
53 71
54 SyncChange::SyncChangeType SettingSyncData::change_type() const { 72 SyncChange::SyncChangeType SettingSyncData::change_type() const {
55 return internal_->change_type_; 73 return internal_->change_type_;
56 } 74 }
57 75
58 const std::string& SettingSyncData::extension_id() const { 76 const std::string& SettingSyncData::extension_id() const {
59 return internal_->extension_id_; 77 return internal_->extension_id_;
60 } 78 }
61 79
62 const std::string& SettingSyncData::key() const { 80 const std::string& SettingSyncData::key() const {
63 return internal_->key_; 81 return internal_->key_;
64 } 82 }
65 83
66 const Value& SettingSyncData::value() const { 84 const Value& SettingSyncData::value() const {
67 return *internal_->value_; 85 return *internal_->value_;
68 } 86 }
69 87
70 SettingSyncData::Internal::Internal( 88 SettingSyncData::Internal::Internal(
71 SyncChange::SyncChangeType change_type, 89 SyncChange::SyncChangeType change_type,
72 const std::string& extension_id, 90 const std::string& extension_id,
73 const std::string& key, 91 const std::string& key,
74 Value* value) 92 scoped_ptr<Value> value)
75 : change_type_(change_type), 93 : change_type_(change_type),
76 extension_id_(extension_id), 94 extension_id_(extension_id),
77 key_(key), 95 key_(key),
78 value_(value) {} 96 value_(value.Pass()) {
97 DCHECK(value_.get());
98 }
79 99
80 SettingSyncData::Internal::~Internal() {} 100 SettingSyncData::Internal::~Internal() {}
81 101
82 } // namespace extensions 102 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698