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 |