diff options
author | gdk@chromium.org <gdk@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-09-07 05:34:16 +0000 |
---|---|---|
committer | gdk@chromium.org <gdk@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-09-07 05:34:16 +0000 |
commit | 926957b72bee0ee2b268d946bc0ae25047e92539 (patch) | |
tree | 9ad6c5dec928ebdaf64299aeebecf0505c32df30 /chromeos/dbus/bluetooth_adapter_client.cc | |
parent | e94bbcbf1ed35d9636c59962acf7aa00d86fa181 (diff) | |
download | chromium_src-926957b72bee0ee2b268d946bc0ae25047e92539.zip chromium_src-926957b72bee0ee2b268d946bc0ae25047e92539.tar.gz chromium_src-926957b72bee0ee2b268d946bc0ae25047e92539.tar.bz2 |
Cleaning up weak_ptr_factory destruction order.
BUG=none
TEST=none
Review URL: https://chromiumcodereview.appspot.com/10917115
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@155319 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chromeos/dbus/bluetooth_adapter_client.cc')
-rw-r--r-- | chromeos/dbus/bluetooth_adapter_client.cc | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/chromeos/dbus/bluetooth_adapter_client.cc b/chromeos/dbus/bluetooth_adapter_client.cc index bfbe2a1..f6138f7 100644 --- a/chromeos/dbus/bluetooth_adapter_client.cc +++ b/chromeos/dbus/bluetooth_adapter_client.cc @@ -58,8 +58,8 @@ class BluetoothAdapterClientImpl: public BluetoothAdapterClient, public: explicit BluetoothAdapterClientImpl(dbus::Bus* bus, BluetoothManagerClient* manager_client) - : weak_ptr_factory_(this), - bus_(bus) { + : bus_(bus), + weak_ptr_factory_(this) { DVLOG(1) << "Creating BluetoothAdapterClientImpl"; DCHECK(manager_client); @@ -715,15 +715,17 @@ class BluetoothAdapterClientImpl: public BluetoothAdapterClient, callback.Run(object_path, response); } - // Weak pointer factory for generating 'this' pointers that might live longer - // than we do. - base::WeakPtrFactory<BluetoothAdapterClientImpl> weak_ptr_factory_; - dbus::Bus* bus_; // List of observers interested in event notifications from us. ObserverList<BluetoothAdapterClient::Observer> observers_; + // Weak pointer factory for generating 'this' pointers that might live longer + // than we do. + // Note: This should remain the last member so it'll be destroyed and + // invalidate its weak pointers before any other members are destroyed. + base::WeakPtrFactory<BluetoothAdapterClientImpl> weak_ptr_factory_; + DISALLOW_COPY_AND_ASSIGN(BluetoothAdapterClientImpl); }; |