Update LocalDevice class with basic bluetooth_server comunication. Server code still to come. Nothing except the driver tested at the moment... I hope after these nothing is broken
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@23817 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
b06bf23fb5
commit
308050e89a
@ -52,7 +52,7 @@ DiscoveryListener::MessageReceived(BMessage* message)
|
||||
case B_BT_INQUIRY_DEVICE_MSG:
|
||||
|
||||
/* TODO: Extract info from BMessage to create a
|
||||
proper RemoteDevice, ¿¿¿message should be passed from Agent??? */
|
||||
proper RemoteDevice, message should be passed from Agent??? */
|
||||
|
||||
/* - Instance to be stored/Registered in the Agent? */
|
||||
//DeviceDiscovered( RemoteDevice(BString("00:00:00:00:00:00")), DeviceClass(0));
|
||||
|
@ -1,5 +1,7 @@
|
||||
SubDir HAIKU_TOP src kits bluetooth ;
|
||||
|
||||
UsePrivateHeaders bluetooth ;
|
||||
|
||||
SharedLibrary libbluetooth.so :
|
||||
LocalDevice.cpp
|
||||
DiscoveryListener.cpp
|
||||
|
@ -5,40 +5,112 @@
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#include <bluetooth/LocalDevice.h>
|
||||
#include <bluetooth/RemoteDevice.h>
|
||||
#include <bluetooth/DeviceClass.h>
|
||||
#include <bluetooth/DiscoveryAgent.h>
|
||||
#include <bluetooth/RemoteDevice.h>
|
||||
|
||||
#include <bluetooth/bdaddrUtils.h>
|
||||
|
||||
#include "bluetoothserver_p.h"
|
||||
|
||||
namespace Bluetooth {
|
||||
|
||||
BMessenger* LocalDevice::sfMessenger = NULL;
|
||||
|
||||
status_t
|
||||
LocalDevice::SRetrieveBluetoothMessenger(void)
|
||||
{
|
||||
if (sfMessenger == NULL || !sfMessenger->IsValid() )
|
||||
sfMessenger = new BMessenger();
|
||||
|
||||
return (sfMessenger != NULL)?B_OK:B_ERROR;
|
||||
}
|
||||
|
||||
status_t LocalDevice::RetrieveBluetoothMessenger(void)
|
||||
{
|
||||
if (fMessenger == NULL || !fMessenger->IsValid())
|
||||
fMessenger = new BMessenger();
|
||||
|
||||
return (fMessenger != NULL)?B_OK:B_ERROR;
|
||||
}
|
||||
|
||||
LocalDevice*
|
||||
LocalDevice::GetLocalDevice()
|
||||
LocalDevice::RequestLocalDeviceID(BMessage* request)
|
||||
{
|
||||
BMessage reply;
|
||||
hci_id hid;
|
||||
|
||||
if (sfMessenger->SendMessage(request, &reply) == B_OK &&
|
||||
reply.FindInt32("hci_id", &hid) == B_OK ){
|
||||
|
||||
if (hid > 0)
|
||||
return new LocalDevice(hid);
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
LocalDevice*
|
||||
LocalDevice::GetLocalDevice(uint8 dev)
|
||||
{
|
||||
#if 0
|
||||
#pragma -
|
||||
#endif
|
||||
|
||||
|
||||
LocalDevice*
|
||||
LocalDevice::GetLocalDevice()
|
||||
{
|
||||
if (SRetrieveBluetoothMessenger() != B_OK)
|
||||
return NULL;
|
||||
|
||||
BMessage request(BT_MSG_ADQUIRE_LOCAL_DEVICE);
|
||||
|
||||
return RequestLocalDeviceID(&request);
|
||||
}
|
||||
|
||||
|
||||
LocalDevice*
|
||||
LocalDevice::GetLocalDevice(hci_id hid)
|
||||
{
|
||||
if (SRetrieveBluetoothMessenger() != B_OK)
|
||||
return NULL;
|
||||
|
||||
BMessage request(BT_MSG_ADQUIRE_LOCAL_DEVICE);
|
||||
request.AddInt32("hci_id", hid);
|
||||
|
||||
return RequestLocalDeviceID(&request);
|
||||
|
||||
}
|
||||
|
||||
|
||||
LocalDevice*
|
||||
LocalDevice::GetLocalDevice(bdaddr_t bdaddr)
|
||||
{
|
||||
|
||||
if (SRetrieveBluetoothMessenger() != B_OK)
|
||||
return NULL;
|
||||
|
||||
BMessage request(BT_MSG_ADQUIRE_LOCAL_DEVICE);
|
||||
request.AddData("bdaddr", B_ANY_TYPE, &bdaddr, sizeof(bdaddr_t));
|
||||
|
||||
|
||||
return RequestLocalDeviceID(&request);
|
||||
}
|
||||
|
||||
|
||||
uint32
|
||||
LocalDevice::GetLocalDeviceCount()
|
||||
{
|
||||
if (SRetrieveBluetoothMessenger() != B_OK)
|
||||
return NULL;
|
||||
|
||||
BMessage request(BT_MSG_COUNT_LOCAL_DEVICES);
|
||||
BMessage reply;
|
||||
|
||||
if (sfMessenger->SendMessage(&request, &reply) == B_OK)
|
||||
return reply.FindInt32("count");
|
||||
else
|
||||
return B_ERROR;
|
||||
|
||||
}
|
||||
|
||||
|
||||
@ -53,8 +125,23 @@ namespace Bluetooth {
|
||||
BString
|
||||
LocalDevice::GetFriendlyName()
|
||||
{
|
||||
|
||||
if (RetrieveBluetoothMessenger() != B_OK)
|
||||
return NULL;
|
||||
|
||||
BString friendlyname;
|
||||
BMessage request(BT_MSG_GET_FRIENDLY_NAME);
|
||||
BMessage reply;
|
||||
|
||||
/* ADD ID */
|
||||
request.AddInt32("hci_id", hid);
|
||||
|
||||
if (fMessenger->SendMessage(&request, &reply) == B_OK &&
|
||||
reply.FindString("friendlyname", &friendlyname) == B_OK ){
|
||||
|
||||
return friendlyname;
|
||||
}
|
||||
|
||||
return BString("Unknown");
|
||||
}
|
||||
|
||||
|
||||
@ -99,11 +186,26 @@ namespace Bluetooth {
|
||||
}
|
||||
|
||||
|
||||
BString
|
||||
bdaddr_t
|
||||
LocalDevice::GetBluetoothAddress()
|
||||
{
|
||||
if (RetrieveBluetoothMessenger() != B_OK)
|
||||
return bdaddrUtils::NullAddress();
|
||||
|
||||
return NULL;
|
||||
bdaddr_t bdaddr;
|
||||
BMessage request(BT_MSG_GET_ADDRESS);
|
||||
BMessage reply;
|
||||
ssize_t size;
|
||||
/* ADD ID */
|
||||
request.AddInt32("hci_id", hid);
|
||||
|
||||
if (fMessenger->SendMessage(&request, &reply) == B_OK &&
|
||||
reply.FindData("bdaddr", B_ANY_TYPE, 0, (const void**)&bdaddr, &size) == B_OK ){
|
||||
|
||||
return bdaddr;
|
||||
}
|
||||
|
||||
return bdaddrUtils::NullAddress();
|
||||
}
|
||||
|
||||
|
||||
@ -118,7 +220,7 @@ namespace Bluetooth {
|
||||
|
||||
}
|
||||
*/
|
||||
LocalDevice::LocalDevice()
|
||||
LocalDevice::LocalDevice(hci_id hid) : hid(hid)
|
||||
{
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user