summaryrefslogtreecommitdiff
path: root/libopie2/opiebluez/obluetooth.cpp
authormickeyl <mickeyl>2005-07-14 14:17:46 (UTC)
committer mickeyl <mickeyl>2005-07-14 14:17:46 (UTC)
commit72224480ec012cf8d68608aea5a1b035f4d16895 (patch) (side-by-side diff)
tree104feb22de493fd96823b10e318f0160cc97e68f /libopie2/opiebluez/obluetooth.cpp
parent237cf3ec5134e299a9da0ce7deb533383f3d11f0 (diff)
downloadopie-72224480ec012cf8d68608aea5a1b035f4d16895.zip
opie-72224480ec012cf8d68608aea5a1b035f4d16895.tar.gz
opie-72224480ec012cf8d68608aea5a1b035f4d16895.tar.bz2
- add device class
- first bits at inquiry
Diffstat (limited to 'libopie2/opiebluez/obluetooth.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiebluez/obluetooth.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/libopie2/opiebluez/obluetooth.cpp b/libopie2/opiebluez/obluetooth.cpp
index c99a822..e0ba0ec 100644
--- a/libopie2/opiebluez/obluetooth.cpp
+++ b/libopie2/opiebluez/obluetooth.cpp
@@ -24,35 +24,37 @@
    --        :-=` this library; see the file COPYING.LIB.
If not, write to the Free Software Foundation,
Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA.
*/
#include "obluetooth.h"
/* OPIE */
#include <opie2/odebug.h>
using namespace Opie::Core;
/* STD */
#include <bluetooth/bluetooth.h>
#include <bluetooth/hci.h>
#include <bluetooth/hci_lib.h>
+#include <assert.h>
#include <errno.h>
#include <stdlib.h>
#include <string.h>
+#include <unistd.h>
#include <sys/ioctl.h>
#include <sys/types.h>
#include <sys/socket.h>
namespace Opie {
namespace Bluez {
/*======================================================================================
* OBluetooth
*======================================================================================*/
OBluetooth* OBluetooth::_instance = 0;
OBluetooth::OBluetooth()
{
synchronize();
@@ -176,19 +178,74 @@ bool OBluetoothInterface::setUp( bool b )
{
owarn << "OBluetoothInterface::setUp( " << b << " ) - couldn't change interface state (" << strerror( errno ) << ")" << oendl;
return false;
}
else
{
d->reloadInfo();
return true;
}
}
bool OBluetoothInterface::isUp() const
{
return hci_test_bit( HCI_UP, &d->devinfo.flags );
}
+OBluetoothInterface::DeviceIterator OBluetoothInterface::neighbourhood()
+{
+ _devices.clear();
+ struct hci_inquiry_req* ir;
+ int nrsp = 255;
+
+ char* mybuffer = static_cast<char*>( malloc( sizeof( *ir ) + ( sizeof( inquiry_info ) * (nrsp) ) ) );
+ assert( mybuffer );
+
+ ir = (struct hci_inquiry_req*) mybuffer;
+ memset( ir, 0, sizeof( *ir ) + ( sizeof( inquiry_info ) * (nrsp) ) );
+
+ ir->dev_id = d->devinfo.dev_id;
+ ir->num_rsp = nrsp;
+ ir->length = 8;
+ ir->flags = 0;
+ ir->lap[0] = 0x33;
+ ir->lap[1] = 0x8b;
+ ir->lap[2] = 0x9e;
+
+ int result = ::ioctl( d->ctlfd, HCIINQUIRY, mybuffer );
+ if ( result == -1 )
+ {
+ owarn << "OBluetoothInterface::neighbourhood() - can't issue HCIINQUIRY (" << strerror( errno ) << ")" << oendl;
+ return DeviceIterator( _devices );
+ }
+
+ for( int i = 0; i < ir->num_rsp; ++i )
+ {
+ odebug << "found a device" << oendl;
+ }
+
+ return DeviceIterator( _devices );
}
+
+
+/*======================================================================================
+ * OBluetoothDevice
+ *======================================================================================*/
+
+OBluetoothDevice::OBluetoothDevice( QObject* parent, const char* name )
+ :QObject( parent, name )
+{
+ odebug << "OBluetoothDevice::OBluetoothDevice() - '" << name << "'" << oendl;
+}
+
+OBluetoothDevice::~OBluetoothDevice()
+{
+ odebug << "OBluetoothDevice::~OBluetoothDevice()" << oendl;
}
+QString OBluetoothDevice::macAddress() const
+{
+ return "N/A";
+}
+
+}
+}