diff options
author | Andrzej J.R. Hunt <andrzej@ahunt.org> | 2012-09-03 12:34:31 +0200 |
---|---|---|
committer | Andrzej J.R. Hunt <andrzej@ahunt.org> | 2012-09-03 12:35:26 +0200 |
commit | d1cc631c0d1f7774003d550fac0711819f2fd782 (patch) | |
tree | 6bd8a38b563b1e4e78a2956d26c624999b806e06 /sd/source/ui | |
parent | d6dceb2bb0bf30e5a9362705156afd5339863db8 (diff) |
Some error handling for dbus / bluetooth.
Change-Id: Ib06f1deb620140e215411650132aefa6b76dbfbe
Diffstat (limited to 'sd/source/ui')
-rw-r--r-- | sd/source/ui/remotecontrol/BluetoothServer.cxx | 112 | ||||
-rw-r--r-- | sd/source/ui/remotecontrol/DiscoveryService.cxx | 4 |
2 files changed, 29 insertions, 87 deletions
diff --git a/sd/source/ui/remotecontrol/BluetoothServer.cxx b/sd/source/ui/remotecontrol/BluetoothServer.cxx index 0fc4624e0de1..2a4e95a24910 100644 --- a/sd/source/ui/remotecontrol/BluetoothServer.cxx +++ b/sd/source/ui/remotecontrol/BluetoothServer.cxx @@ -57,10 +57,12 @@ void BluetoothServer::execute() #ifdef GLIB_VERSION_2_26 g_type_init(); GError* aError = NULL; + GDBusConnection* aConnection = g_bus_get_sync( G_BUS_TYPE_SYSTEM, NULL, &aError ); if ( aError ) { g_error_free( aError ); + return; // We can't get a dbus connection } GVariant *aAdapter = g_dbus_connection_call_sync( aConnection, @@ -68,22 +70,13 @@ void BluetoothServer::execute() "DefaultAdapter", NULL, G_VARIANT_TYPE_TUPLE, G_DBUS_CALL_FLAGS_NONE, -1, NULL, &aError); - GVariant *aAdapterName = g_variant_get_child_value( aAdapter, 0 ); if ( aError ) { g_error_free( aError ); + g_object_unref( aConnection ); + return; // We can't get an adapter -- no bluetooth possible } -// fprintf( stderr, (const char*) g_variant_get_string( aAdapterName, NULL ) ); - - -// GDBusObjectManager* aManager = g_dbus_object_manager_client_new_sync( aConnection, -// G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE, "org.bluez.Manager", "/org/bluez", -// NULL, NULL, NULL, NULL, &aError ); -// if ( aError ) -// { -// fprintf( stderr, aError->message ); -// g_error_free( aError ); -// } + GVariant *aAdapterName = g_variant_get_child_value( aAdapter, 0 ); GVariant *aRecordHandle = g_dbus_connection_call_sync( aConnection, "org.bluez", g_variant_get_string( aAdapterName, NULL ), "org.bluez.Service", @@ -92,77 +85,30 @@ void BluetoothServer::execute() "<?xml version='1.0' encoding= 'UTF-8' ?><record><attribute id='0x0001'><sequence><uuid value='0x1101' /></sequence></attribute><attribute id='0x0004'><sequence><sequence><uuid value='0x0100' /></sequence><sequence><uuid value='0x0003' /><uint8 value='0x05' /></sequence></sequence></attribute><attribute id='0x0005'><sequence><uuid value='0x1002' /></sequence></attribute><attribute id='0x0006'><sequence><uint16 value='0x656e' /><uint16 value='0x006a' /><uint16 value='0x0100' /></sequence></attribute><attribute id='0x0009'><sequence><sequence><uuid value='0x1101' /><uint16 value='0x0100' /></sequence></sequence></attribute><attribute id='0x0100'><text value='Serial Port' /></attribute><attribute id='0x0101'><text value='COM Port' /></attribute></record>"), G_VARIANT_TYPE_TUPLE, G_DBUS_CALL_FLAGS_NONE, -1, NULL, &aError); + + g_variant_unref( aAdapter ); + g_object_unref( aConnection ); + if ( aError ) { - g_error_free( aError ); + g_object_unref( aAdapter ); + return; // Couldn't set up the service. } - (void) aRecordHandle; - // Remove handle again at some point -// g_variant_unref( aRet ); -// fprintf( stderr, "Manager gotten\n" ); -// -// // Name for default adapter -// GVariant *aAdapter = g_dbus_connection_call_sync( aConnection, -// "org.bluez", "/", "org.bluez.Manager", -// "DefaultAdapter", NULL, -// G_VARIANT_TYPE_TUPLE, -// G_DBUS_CALL_FLAGS_NONE, -1, NULL, &aError); -// GVariant *aAdapterName = g_variant_get_child_value( aAdapter, 0 ); -// if ( aError ) -// { -// fprintf( stderr, aError->message ); -// g_error_free( aError ); -// } -// fprintf( stderr, (const char*) g_variant_get_string( aAdapterName, NULL ) ); - - - - -// g_type_init(); -// GError* aError = NULL; -// GDBusConnection* aConnection = g_bus_get_sync( G_BUS_TYPE_SYSTEM, NULL, &aError ); -// fprintf( stderr, "Connection gotten\n" ); -// if ( aError ) -// { -// fprintf( stderr, aError->message ); -// g_error_free( aError ); -// } -// // GDBusObjectManager* aManager = g_dbus_object_manager_client_new_sync( aConnection, -// // G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE, "org.bluez.Manager", "/org/bluez", -// // NULL, NULL, NULL, NULL, &aError ); -// // if ( aError ) -// // { -// // fprintf( stderr, aError->message ); -// // g_error_free( aError ); -// // } -// fprintf( stderr, "Manager gotten\n" ); -// -// // Name for default adapter -// GVariant *aAdapter = g_dbus_connection_call_sync( aConnection, -// "org.bluez", "/", "org.bluez.Manager", -// "DefaultAdapter", NULL, -// G_VARIANT_TYPE_TUPLE, -// G_DBUS_CALL_FLAGS_NONE, -1, NULL, &aError); -// GVariant *aAdapterName = g_variant_get_child_value( aAdapter, 0 ); -// if ( aError ) -// { -// fprintf( stderr, aError->message ); -// g_error_free( aError ); -// } -// fprintf( stderr, (const char*) g_variant_get_string( aAdapterName, NULL ) ); - - - // ---------------- DEVICE ADDRESS + g_variant_unref( aRecordHandle ); // We don't need the handle + // as the service is automatically + // deregistered on exit. + + + // ---------------- Socket code int aSocket; if ( (aSocket = socket( AF_BLUETOOTH, SOCK_STREAM, BTPROTO_RFCOMM )) < 0 ) { - // Error return; } sockaddr_rc aAddr; aAddr.rc_family = AF_BLUETOOTH; -// aAddr.rc_bdaddr = {{0, 0, 0, 0, 0, 0}}; // BDADDR_ANY is broken + // BDADDR_ANY is broken, so use memset to set to 0. memset( &aAddr.rc_bdaddr, 0, sizeof( aAddr.rc_bdaddr ) ); aAddr.rc_channel = 5; @@ -179,18 +125,18 @@ void BluetoothServer::execute() sockaddr_rc aRemoteAddr; socklen_t aRemoteAddrLen = sizeof(aRemoteAddr); - int bSocket; - if ( (bSocket = accept(aSocket, (sockaddr*) &aRemoteAddr, &aRemoteAddrLen)) < 0 ) + while ( true ) { - close( aSocket ); - return; - } else { -// fprintf( stderr, "Accepted Bluetooth\n" ); - - Communicator* pCommunicator = new Communicator( new BufferedStreamSocket( bSocket) ); - mpCommunicators->push_back( pCommunicator ); - pCommunicator->launch(); - + int bSocket; + if ( (bSocket = accept(aSocket, (sockaddr*) &aRemoteAddr, &aRemoteAddrLen)) < 0 ) + { + close( aSocket ); + return; + } else { + Communicator* pCommunicator = new Communicator( new BufferedStreamSocket( bSocket) ); + mpCommunicators->push_back( pCommunicator ); + pCommunicator->launch(); + } } #endif // GLIB_VERSION_2_26 diff --git a/sd/source/ui/remotecontrol/DiscoveryService.cxx b/sd/source/ui/remotecontrol/DiscoveryService.cxx index 69e88545745f..53e649c64b79 100644 --- a/sd/source/ui/remotecontrol/DiscoveryService.cxx +++ b/sd/source/ui/remotecontrol/DiscoveryService.cxx @@ -64,8 +64,6 @@ DiscoveryService::~DiscoveryService() void DiscoveryService::execute() { - fprintf( stderr, "Discovery service is listening\n" );; - char aBuffer[BUFFER_SIZE]; while ( true ) @@ -73,9 +71,7 @@ void DiscoveryService::execute() memset( aBuffer, 0, sizeof(char) * BUFFER_SIZE ); sockaddr_in aAddr; socklen_t aLen = sizeof( aAddr ); - fprintf( stderr, "DiscoveryService waiting for packet\n" ); recvfrom( mSocket, aBuffer, BUFFER_SIZE, 0, (sockaddr*) &aAddr, &aLen ); - fprintf( stderr, "DiscoveryService received a packet.\n" ); OString aString( aBuffer, strlen( "LOREMOTE_SEARCH" ) ); if ( aString.compareTo( "LOREMOTE_SEARCH" ) == 0 ) |