| 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 | 4 |
| 5 #include "chromeos/dbus/shill_client_helper.h" | 5 #include "chromeos/dbus/shill_client_helper.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/values.h" | 8 #include "base/values.h" |
| 9 #include "dbus/message.h" | 9 #include "dbus/message.h" |
| 10 #include "dbus/object_proxy.h" | 10 #include "dbus/object_proxy.h" |
| (...skipping 17 matching lines...) Expand all Loading... |
| 28 } | 28 } |
| 29 | 29 |
| 30 ShillClientHelper::~ShillClientHelper() { | 30 ShillClientHelper::~ShillClientHelper() { |
| 31 LOG_IF(ERROR, observer_list_.size() != 0u) | 31 LOG_IF(ERROR, observer_list_.size() != 0u) |
| 32 << "ShillClientHelper destroyed with active observers: " | 32 << "ShillClientHelper destroyed with active observers: " |
| 33 << observer_list_.size(); | 33 << observer_list_.size(); |
| 34 } | 34 } |
| 35 | 35 |
| 36 void ShillClientHelper::AddPropertyChangedObserver( | 36 void ShillClientHelper::AddPropertyChangedObserver( |
| 37 ShillPropertyChangedObserver* observer) { | 37 ShillPropertyChangedObserver* observer) { |
| 38 // Excecute all the pending MonitorPropertyChanged calls. |
| 39 for (size_t i = 0; i < interfaces_to_be_monitored_.size(); ++i) { |
| 40 MonitorPropertyChangedInternal(interfaces_to_be_monitored_[i]); |
| 41 } |
| 42 interfaces_to_be_monitored_.clear(); |
| 43 |
| 38 observer_list_.AddObserver(observer); | 44 observer_list_.AddObserver(observer); |
| 39 } | 45 } |
| 40 | 46 |
| 41 void ShillClientHelper::RemovePropertyChangedObserver( | 47 void ShillClientHelper::RemovePropertyChangedObserver( |
| 42 ShillPropertyChangedObserver* observer) { | 48 ShillPropertyChangedObserver* observer) { |
| 43 observer_list_.RemoveObserver(observer); | 49 observer_list_.RemoveObserver(observer); |
| 44 } | 50 } |
| 45 | 51 |
| 46 void ShillClientHelper::MonitorPropertyChanged( | 52 void ShillClientHelper::MonitorPropertyChanged( |
| 47 const std::string& interface_name) { | 53 const std::string& interface_name) { |
| 54 if (observer_list_.size() > 0) { |
| 55 // Effectively monitor the PropertyChanged now. |
| 56 MonitorPropertyChangedInternal(interface_name); |
| 57 } else { |
| 58 // Delay the ConnectToSignal until an observer is added. |
| 59 interfaces_to_be_monitored_.push_back(interface_name); |
| 60 } |
| 61 } |
| 62 |
| 63 void ShillClientHelper::MonitorPropertyChangedInternal( |
| 64 const std::string& interface_name) { |
| 48 // We are not using dbus::PropertySet to monitor PropertyChanged signal | 65 // We are not using dbus::PropertySet to monitor PropertyChanged signal |
| 49 // because the interface is not "org.freedesktop.DBus.Properties". | 66 // because the interface is not "org.freedesktop.DBus.Properties". |
| 50 proxy_->ConnectToSignal(interface_name, | 67 proxy_->ConnectToSignal(interface_name, |
| 51 flimflam::kMonitorPropertyChanged, | 68 flimflam::kMonitorPropertyChanged, |
| 52 base::Bind(&ShillClientHelper::OnPropertyChanged, | 69 base::Bind(&ShillClientHelper::OnPropertyChanged, |
| 53 weak_ptr_factory_.GetWeakPtr()), | 70 weak_ptr_factory_.GetWeakPtr()), |
| 54 base::Bind(&ShillClientHelper::OnSignalConnected, | 71 base::Bind(&ShillClientHelper::OnSignalConnected, |
| 55 weak_ptr_factory_.GetWeakPtr())); | 72 weak_ptr_factory_.GetWeakPtr())); |
| 56 } | 73 } |
| 57 | 74 |
| (...skipping 279 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 337 if (response) { | 354 if (response) { |
| 338 // Error message may contain the error message as string. | 355 // Error message may contain the error message as string. |
| 339 dbus::MessageReader reader(response); | 356 dbus::MessageReader reader(response); |
| 340 error_name = response->GetErrorName(); | 357 error_name = response->GetErrorName(); |
| 341 reader.PopString(&error_message); | 358 reader.PopString(&error_message); |
| 342 } | 359 } |
| 343 error_callback.Run(error_name, error_message); | 360 error_callback.Run(error_name, error_message); |
| 344 } | 361 } |
| 345 | 362 |
| 346 } // namespace chromeos | 363 } // namespace chromeos |
| OLD | NEW |