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

Unified Diff: device/bluetooth/bluetooth_polling_thread_win.h

Issue 11411130: Implemented BluetoothTaskManagerWin class. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Renamed properties to adapter state Created 8 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: device/bluetooth/bluetooth_polling_thread_win.h
diff --git a/device/bluetooth/bluetooth_polling_thread_win.h b/device/bluetooth/bluetooth_polling_thread_win.h
new file mode 100644
index 0000000000000000000000000000000000000000..94eb98d172c57889532f47d406241eb13f584eaf
--- /dev/null
+++ b/device/bluetooth/bluetooth_polling_thread_win.h
@@ -0,0 +1,76 @@
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef DEVICE_BLUETOOTH_BLUETOOTH_POLLING_THREAD_WIN_H_
+#define DEVICE_BLUETOOTH_BLUETOOTH_POLLING_THREAD_WIN_H_
+
+#include "base/memory/scoped_ptr.h"
+#include "base/threading/thread.h"
+
+namespace base {
+
+class CancellationFlag;
+class ThreadChecker;
+
+} // namespace base
+
+namespace device {
+
+// A thread dedicated to perform blocking bluetooth APIs on Windows.
+class BluetoothPollingThreadWin : public base::Thread {
+ public:
+ struct AdapterState {
+ std::string name;
+ std::string address;
+ bool powered;
+ };
+
+ class Observer {
+ public:
+ virtual ~Observer() {}
+
+ // This will always be called on the UI thread.
+ virtual void AdapterStateChanged(const AdapterState& state) {}
+ };
+
+ BluetoothPollingThreadWin();
+ virtual ~BluetoothPollingThreadWin();
+
+ void AddObserver(Observer* observer);
+ void RemoveObserver(Observer* observer);
+
+ void Init();
+
+ private:
+ // Populates bluetooth adapter state using adapter_handle.
+ static void GetAdapterState(const HANDLE adapter_handle,
+ AdapterState* state);
+
+ // Polls Windows Bluetooth API on BluetoothPollingThread.
+ void PollAdapter(base::WeakPtr<BluetoothPollingThreadWin> weak_ptr);
+
+ // Callback to be run on the UI thread.
+ void OnAdapterStateChanged(const AdapterState* state);
+
+ static const int kPollIntervalMs;
+
+ // Polling will be canceled when BluetoothPollingThread terminates.
+ scoped_ptr<base::CancellationFlag> cancellation_flag_;
bryeung 2012/11/27 20:37:04 why a pointer?
youngki 2012/11/27 21:43:34 I want to forward-declare it instead of adding hea
+
+ // Checks that PollAdapter runs on BluetoothPollingThread.
+ scoped_ptr<base::ThreadChecker> thread_checker_;
+
+ // List of observers interested in event notifications from us.
+ ObserverList<Observer> observers_;
+
+ // 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<BluetoothPollingThreadWin> weak_ptr_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(BluetoothPollingThreadWin);
+};
+
+} // namespace device
+
+#endif // DEVICE_BLUETOOTH_BLUETOOTH_POLLING_THREAD_WIN_H_

Powered by Google App Engine
This is Rietveld 408576698