| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "chromeos/dbus/gsm_sms_client.h" | 4 #include "chromeos/dbus/gsm_sms_client.h" |
| 5 | 5 |
| 6 #include <map> | |
| 7 #include <utility> | 6 #include <utility> |
| 8 #include <vector> | 7 #include <vector> |
| 9 | 8 |
| 10 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/containers/scoped_ptr_map.h" |
| 11 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
| 12 #include "base/memory/weak_ptr.h" | 12 #include "base/memory/weak_ptr.h" |
| 13 #include "base/message_loop/message_loop.h" | 13 #include "base/message_loop/message_loop.h" |
| 14 #include "base/stl_util.h" | |
| 15 #include "base/strings/stringprintf.h" | 14 #include "base/strings/stringprintf.h" |
| 16 #include "base/values.h" | 15 #include "base/values.h" |
| 17 #include "dbus/bus.h" | 16 #include "dbus/bus.h" |
| 18 #include "dbus/message.h" | 17 #include "dbus/message.h" |
| 19 #include "dbus/object_proxy.h" | 18 #include "dbus/object_proxy.h" |
| 20 #include "dbus/values_util.h" | 19 #include "dbus/values_util.h" |
| 21 #include "third_party/cros_system_api/dbus/service_constants.h" | 20 #include "third_party/cros_system_api/dbus/service_constants.h" |
| 22 | 21 |
| 23 namespace chromeos { | 22 namespace chromeos { |
| 24 | 23 |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 155 // Note: This should remain the last member so it'll be destroyed and | 154 // Note: This should remain the last member so it'll be destroyed and |
| 156 // invalidate its weak pointers before any other members are destroyed. | 155 // invalidate its weak pointers before any other members are destroyed. |
| 157 base::WeakPtrFactory<SMSProxy> weak_ptr_factory_; | 156 base::WeakPtrFactory<SMSProxy> weak_ptr_factory_; |
| 158 | 157 |
| 159 DISALLOW_COPY_AND_ASSIGN(SMSProxy); | 158 DISALLOW_COPY_AND_ASSIGN(SMSProxy); |
| 160 }; | 159 }; |
| 161 | 160 |
| 162 // The GsmSMSClient implementation. | 161 // The GsmSMSClient implementation. |
| 163 class GsmSMSClientImpl : public GsmSMSClient { | 162 class GsmSMSClientImpl : public GsmSMSClient { |
| 164 public: | 163 public: |
| 165 GsmSMSClientImpl() : bus_(NULL), proxies_deleter_(&proxies_) {} | 164 GsmSMSClientImpl() : bus_(NULL) {} |
| 166 | 165 |
| 167 // GsmSMSClient override. | 166 // GsmSMSClient override. |
| 168 void SetSmsReceivedHandler(const std::string& service_name, | 167 void SetSmsReceivedHandler(const std::string& service_name, |
| 169 const dbus::ObjectPath& object_path, | 168 const dbus::ObjectPath& object_path, |
| 170 const SmsReceivedHandler& handler) override { | 169 const SmsReceivedHandler& handler) override { |
| 171 GetProxy(service_name, object_path)->SetSmsReceivedHandler(handler); | 170 GetProxy(service_name, object_path)->SetSmsReceivedHandler(handler); |
| 172 } | 171 } |
| 173 | 172 |
| 174 // GsmSMSClient override. | 173 // GsmSMSClient override. |
| 175 void ResetSmsReceivedHandler(const std::string& service_name, | 174 void ResetSmsReceivedHandler(const std::string& service_name, |
| (...skipping 25 matching lines...) Expand all Loading... |
| 201 } | 200 } |
| 202 | 201 |
| 203 // GsmSMSClient override. | 202 // GsmSMSClient override. |
| 204 void RequestUpdate(const std::string& service_name, | 203 void RequestUpdate(const std::string& service_name, |
| 205 const dbus::ObjectPath& object_path) override {} | 204 const dbus::ObjectPath& object_path) override {} |
| 206 | 205 |
| 207 protected: | 206 protected: |
| 208 void Init(dbus::Bus* bus) override { bus_ = bus; } | 207 void Init(dbus::Bus* bus) override { bus_ = bus; } |
| 209 | 208 |
| 210 private: | 209 private: |
| 211 typedef std::map<std::pair<std::string, std::string>, SMSProxy*> ProxyMap; | 210 typedef base::ScopedPtrMap<std::pair<std::string, std::string>, |
| 211 scoped_ptr<SMSProxy>> ProxyMap; |
| 212 | 212 |
| 213 // Returns a SMSProxy for the given service name and object path. | 213 // Returns a SMSProxy for the given service name and object path. |
| 214 SMSProxy* GetProxy(const std::string& service_name, | 214 SMSProxy* GetProxy(const std::string& service_name, |
| 215 const dbus::ObjectPath& object_path) { | 215 const dbus::ObjectPath& object_path) { |
| 216 const ProxyMap::key_type key(service_name, object_path.value()); | 216 const ProxyMap::key_type key(service_name, object_path.value()); |
| 217 ProxyMap::iterator it = proxies_.find(key); | 217 ProxyMap::const_iterator it = proxies_.find(key); |
| 218 if (it != proxies_.end()) | 218 if (it != proxies_.end()) |
| 219 return it->second; | 219 return it->second; |
| 220 | 220 |
| 221 // There is no proxy for the service_name and object_path, create it. | 221 // There is no proxy for the service_name and object_path, create it. |
| 222 SMSProxy* proxy = new SMSProxy(bus_, service_name, object_path); | 222 scoped_ptr<SMSProxy> proxy(new SMSProxy(bus_, service_name, object_path)); |
| 223 proxies_.insert(ProxyMap::value_type(key, proxy)); | 223 SMSProxy* proxy_ptr = proxy.get(); |
| 224 return proxy; | 224 proxies_.insert(key, proxy.Pass()); |
| 225 return proxy_ptr; |
| 225 } | 226 } |
| 226 | 227 |
| 227 dbus::Bus* bus_; | 228 dbus::Bus* bus_; |
| 228 ProxyMap proxies_; | 229 ProxyMap proxies_; |
| 229 STLValueDeleter<ProxyMap> proxies_deleter_; | |
| 230 | 230 |
| 231 DISALLOW_COPY_AND_ASSIGN(GsmSMSClientImpl); | 231 DISALLOW_COPY_AND_ASSIGN(GsmSMSClientImpl); |
| 232 }; | 232 }; |
| 233 | 233 |
| 234 } // namespace | 234 } // namespace |
| 235 | 235 |
| 236 //////////////////////////////////////////////////////////////////////////////// | 236 //////////////////////////////////////////////////////////////////////////////// |
| 237 // GsmSMSClient | 237 // GsmSMSClient |
| 238 | 238 |
| 239 GsmSMSClient::GsmSMSClient() {} | 239 GsmSMSClient::GsmSMSClient() {} |
| 240 | 240 |
| 241 GsmSMSClient::~GsmSMSClient() {} | 241 GsmSMSClient::~GsmSMSClient() {} |
| 242 | 242 |
| 243 // static | 243 // static |
| 244 GsmSMSClient* GsmSMSClient::Create() { | 244 GsmSMSClient* GsmSMSClient::Create() { |
| 245 return new GsmSMSClientImpl(); | 245 return new GsmSMSClientImpl(); |
| 246 } | 246 } |
| 247 | 247 |
| 248 } // namespace chromeos | 248 } // namespace chromeos |
| OLD | NEW |