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

Side by Side Diff: third_party/libaddressinput/chromium/chrome_storage_impl.cc

Issue 298863012: Use upstream libaddressinput in Chrome. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressing comments. Created 6 years, 6 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 "third_party/libaddressinput/chromium/chrome_storage_impl.h" 5 #include "third_party/libaddressinput/chromium/chrome_storage_impl.h"
6 6
7 #include "base/memory/scoped_ptr.h"
7 #include "base/prefs/writeable_pref_store.h" 8 #include "base/prefs/writeable_pref_store.h"
8 #include "base/values.h" 9 #include "base/values.h"
10 #include "third_party/libaddressinput/chromium/fallback_data_store.h"
9 11
10 namespace autofill { 12 namespace autofill {
11 13
12 ChromeStorageImpl::ChromeStorageImpl(WriteablePrefStore* store) 14 ChromeStorageImpl::ChromeStorageImpl(WriteablePrefStore* store)
13 : backing_store_(store), 15 : backing_store_(store),
14 scoped_observer_(this) { 16 scoped_observer_(this) {
15 scoped_observer_.Add(backing_store_); 17 scoped_observer_.Add(backing_store_);
16 } 18 }
17 19
18 ChromeStorageImpl::~ChromeStorageImpl() {} 20 ChromeStorageImpl::~ChromeStorageImpl() {}
19 21
20 void ChromeStorageImpl::Put(const std::string& key, 22 void ChromeStorageImpl::Put(const std::string& key, const std::string& data) {
21 scoped_ptr<std::string> data) { 23 scoped_ptr<base::StringValue> string_value(new base::StringValue(data));
Evan Stade 2014/06/13 20:07:09 ...to copy
please use gerrit instead 2014/06/16 19:02:24 i18n team is changing this to scoped_ptr.
22 scoped_ptr<base::StringValue> string_value(
23 new base::StringValue(std::string()));
24 string_value->GetString()->swap(*data);
Evan Stade 2014/06/13 20:07:09 not a copy...
please use gerrit instead 2014/06/16 19:02:24 Now I see. Thank you for pointing it out.
25 backing_store_->SetValue(key, string_value.release()); 24 backing_store_->SetValue(key, string_value.release());
26 } 25 }
27 26
28 void ChromeStorageImpl::Get( 27 void ChromeStorageImpl::Get(const std::string& key,
29 const std::string& key, 28 const Storage::Callback& data_ready) const {
30 scoped_ptr<Storage::Callback> data_ready) const {
31 // |Get()| should not be const, so this is just a thunk that fixes that. 29 // |Get()| should not be const, so this is just a thunk that fixes that.
32 const_cast<ChromeStorageImpl*>(this)->DoGet(key, data_ready.Pass()); 30 const_cast<ChromeStorageImpl*>(this)->DoGet(key, data_ready);
33 } 31 }
34 32
35 void ChromeStorageImpl::OnPrefValueChanged(const std::string& key) {} 33 void ChromeStorageImpl::OnPrefValueChanged(const std::string& key) {}
36 34
37 void ChromeStorageImpl::OnInitializationCompleted(bool succeeded) { 35 void ChromeStorageImpl::OnInitializationCompleted(bool succeeded) {
38 for (std::vector<Request*>::iterator iter = 36 for (std::vector<Request*>::iterator iter = outstanding_requests_.begin();
39 outstanding_requests_.begin();
40 iter != outstanding_requests_.end(); ++iter) { 37 iter != outstanding_requests_.end(); ++iter) {
41 DoGet((*iter)->key, (*iter)->callback.Pass()); 38 DoGet((*iter)->key, (*iter)->callback);
42 } 39 }
43 40
44 outstanding_requests_.clear(); 41 outstanding_requests_.clear();
45 } 42 }
46 43
47 void ChromeStorageImpl::DoGet( 44 void ChromeStorageImpl::DoGet(const std::string& key,
48 const std::string& key, 45 const Storage::Callback& data_ready) {
49 scoped_ptr<Storage::Callback> data_ready) {
50 if (!backing_store_->IsInitializationComplete()) { 46 if (!backing_store_->IsInitializationComplete()) {
51 outstanding_requests_.push_back( 47 outstanding_requests_.push_back(new Request(key, data_ready));
52 new Request(key, data_ready.Pass()));
53 return; 48 return;
54 } 49 }
55 50
56 const base::Value* value = NULL; 51 const base::Value* value = NULL;
57 const base::StringValue* string_value = NULL; 52 const base::StringValue* string_value = NULL;
53 std::string fallback_data;
58 if (backing_store_->GetValue(key, &value) && 54 if (backing_store_->GetValue(key, &value) &&
59 value->GetAsString(&string_value)) { 55 value->GetAsString(&string_value)) {
60 (*data_ready)(true, key, string_value->GetString()); 56 data_ready(true, key, string_value->GetString());
57 } else if (FallbackDataStore::Get(key, &fallback_data)) {
58 data_ready(true, key, fallback_data);
61 } else { 59 } else {
62 (*data_ready)(false, key, std::string()); 60 data_ready(false, key, std::string());
63 } 61 }
64 } 62 }
65 63
66 ChromeStorageImpl::Request::Request(const std::string& key, 64 ChromeStorageImpl::Request::Request(const std::string& key,
67 scoped_ptr<Storage::Callback> callback) 65 const Callback& callback)
68 : key(key), 66 : key(key),
69 callback(callback.Pass()) {} 67 callback(callback) {}
70 68
71 } // namespace autofill 69 } // namespace autofill
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698