OLD | NEW |
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/prefs/pref_value_map.h" | 5 #include "chrome/browser/prefs/pref_value_map.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
10 #include "base/values.h" | 10 #include "base/values.h" |
(...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
134 ++other_pref; | 134 ++other_pref; |
135 } | 135 } |
136 } | 136 } |
137 | 137 |
138 // Add the remaining entries. | 138 // Add the remaining entries. |
139 for ( ; this_pref != prefs_.end(); ++this_pref) | 139 for ( ; this_pref != prefs_.end(); ++this_pref) |
140 differing_keys->push_back(this_pref->first); | 140 differing_keys->push_back(this_pref->first); |
141 for ( ; other_pref != other->prefs_.end(); ++other_pref) | 141 for ( ; other_pref != other->prefs_.end(); ++other_pref) |
142 differing_keys->push_back(other_pref->first); | 142 differing_keys->push_back(other_pref->first); |
143 } | 143 } |
| 144 |
| 145 void PrefValueMap::MergeFrom(const PrefValueMap* other) { |
| 146 Map::const_iterator other_pref(other->prefs_.begin()); |
| 147 for ( ; other_pref != other->prefs_.end(); ++other_pref) |
| 148 SetValue(other_pref->first, other_pref->second->DeepCopy()); |
| 149 } |
OLD | NEW |