Chromium Code Reviews| Index: content/browser/bluetooth/bluetooth_dispatcher_host.cc |
| diff --git a/content/browser/bluetooth/bluetooth_dispatcher_host.cc b/content/browser/bluetooth/bluetooth_dispatcher_host.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8f52f316a4af6147fc56678f9df6628ba5997e42 |
| --- /dev/null |
| +++ b/content/browser/bluetooth/bluetooth_dispatcher_host.cc |
| @@ -0,0 +1,69 @@ |
| +// Copyright 2014 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. |
| + |
| +#include "content/browser/bluetooth/bluetooth_dispatcher_host.h" |
| + |
| +#include "content/common/bluetooth/bluetooth_messages.h" |
| + |
| +namespace content { |
| + |
| +BluetoothDispatcherHost::BluetoothDispatcherHost() |
| + : BrowserMessageFilter(BluetoothMsgStart), |
| + bluetoothMockDataSet_(MockData::NOT_MOCKING), |
| + bluetoothRequestDeviceRejectType_(BluetoothError::NOT_FOUND) { |
| +} |
| + |
| +bool BluetoothDispatcherHost::OnMessageReceived(const IPC::Message& message) { |
| + bool handled = true; |
| + IPC_BEGIN_MESSAGE_MAP(BluetoothDispatcherHost, message) |
| + IPC_MESSAGE_HANDLER(BluetoothHostMsg_RequestDevice, OnRequestDevice) |
| + IPC_MESSAGE_HANDLER(BluetoothHostMsg_SetBluetoothMockDataSetForTesting, |
| + OnSetBluetoothMockDataSetForTesting) |
| + IPC_MESSAGE_UNHANDLED(handled = false) |
| + IPC_END_MESSAGE_MAP() |
| + return handled; |
| +} |
| + |
| +BluetoothDispatcherHost::~BluetoothDispatcherHost() { |
| +} |
| + |
| +void BluetoothDispatcherHost::OnRequestDevice(int thread_id, int request_id) { |
| + // Mock implementation util a more complete implementation is built out. |
| + switch (bluetoothMockDataSet_) { |
| + case MockData::NOT_MOCKING: { |
| + Send(new BluetoothMsg_RequestDeviceError(thread_id, request_id, |
| + BluetoothError::NOT_FOUND)); |
| + return; |
|
nasko
2014/11/25 00:57:23
No need to return here, just plain break would wor
Jeffrey Yasskin
2014/11/25 01:08:07
Using return here, and the NOTREACHED after the sw
scheib
2014/11/25 16:11:06
Yes, as Jeffrey said, I prefer compile failure whe
nasko
2014/11/25 23:27:01
Heh, I learn something new every day. Thanks for t
|
| + } |
| + case MockData::REJECT: { |
| + Send(new BluetoothMsg_RequestDeviceError( |
| + thread_id, request_id, bluetoothRequestDeviceRejectType_)); |
| + return; |
| + } |
| + case MockData::RESOLVE: { |
| + Send(new BluetoothMsg_RequestDeviceSuccess(thread_id, request_id, |
| + "Empty Mock deviceId")); |
| + return; |
| + } |
| + } |
| + NOTREACHED(); |
|
nasko
2014/11/25 00:57:23
This belongs in a default switch statement.
scheib
2014/11/25 16:11:05
Intended, see above re compile checking all enum c
|
| +} |
| + |
| +void BluetoothDispatcherHost::OnSetBluetoothMockDataSetForTesting( |
| + const std::string& name) { |
| + if (name == "RejectRequestDevice_NotFoundError") { |
| + bluetoothMockDataSet_ = MockData::REJECT; |
| + bluetoothRequestDeviceRejectType_ = BluetoothError::NOT_FOUND; |
| + } else if (name == "RejectRequestDevice_SecurityError") { |
| + bluetoothMockDataSet_ = MockData::REJECT; |
| + bluetoothRequestDeviceRejectType_ = BluetoothError::SECURITY; |
| + } else if (name == "ResolveRequestDevice_Empty" || // TODO Remove. |
|
Jeffrey Yasskin
2014/11/24 23:30:11
TODOs generally have a '(username):' after them: h
scheib
2014/11/25 16:11:05
Done.
|
| + name == "Single Empty Device") { |
| + bluetoothMockDataSet_ = MockData::RESOLVE; |
| + } else { |
| + bluetoothMockDataSet_ = MockData::NOT_MOCKING; |
| + } |
| +} |
| + |
| +} // namespace content |