summaryrefslogtreecommitdiff
authorzecke <zecke>2002-06-28 21:22:46 (UTC)
committer zecke <zecke>2002-06-28 21:22:46 (UTC)
commit26be5facf38c25f2b22b18a19ea7fa710f5e2236 (patch) (side-by-side diff)
treedc78f9e3b27968675f25f8613e23d9d08499d0e8
parent63c022af051f205c8080040bf60a9221e691304b (diff)
downloadopie-26be5facf38c25f2b22b18a19ea7fa710f5e2236.zip
opie-26be5facf38c25f2b22b18a19ea7fa710f5e2236.tar.gz
opie-26be5facf38c25f2b22b18a19ea7fa710f5e2236.tar.bz2
update the parser
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opietooth/lib/manager.cc12
1 files changed, 10 insertions, 2 deletions
diff --git a/noncore/net/opietooth/lib/manager.cc b/noncore/net/opietooth/lib/manager.cc
index 2234333..e07f9da 100644
--- a/noncore/net/opietooth/lib/manager.cc
+++ b/noncore/net/opietooth/lib/manager.cc
@@ -227,48 +227,48 @@ RemoteDevice::ValueList Manager::parseHCIOutput(const QString& output ) {
////// hcitool cc and hcitool con
/**
* Create it on the stack as don't care
* so we don't need to care for it
* cause hcitool gets reparented
*/
void Manager::connectTo( const QString& mac) {
OProcess proc;
proc << "hcitool";
proc << "cc";
- proc << "mac";
+ proc << mac;
proc.start(OProcess::DontCare); // the lib does not care at this point
}
void Manager::searchConnections() {
qWarning("searching connections?");
OProcess* proc = new OProcess();
m_hcitoolCon = QString::null;
connect(proc, SIGNAL(processExited(OProcess*) ),
this, SLOT(slotConnectionExited( OProcess*) ) );
connect(proc, SIGNAL(receivedStdout(OProcess*, char*, int) ),
this, SLOT(slotConnectionOutput(OProcess*, char*, int) ) );
*proc << "hcitool";
*proc << "con";
if (!proc->start(OProcess::NotifyOnExit, OProcess::AllOutput) ) {
Connection::ValueList list;
emit connections( list );
delete proc;
}
}
-void Manager::slotConnectionExited( OProcess* proc ) {
+void Manager::slotConnectionExited( OProcess* /*proc*/ ) {
qWarning("exited");
Connection::ValueList list;
list = parseConnections( m_hcitoolCon );
emit connections(list );
}
void Manager::slotConnectionOutput(OProcess* proc, char* cha, int len) {
QCString str(cha, len );
m_hcitoolCon.append( str );
delete proc;
}
Connection::ValueList Manager::parseConnections( const QString& out ) {
Connection::ValueList list2;
@@ -277,15 +277,23 @@ Connection::ValueList Manager::parseConnections( const QString& out ) {
for (it = list.begin(); it != list.end(); ++it ) {
QString row = (*it).stripWhiteSpace();
QStringList value = QStringList::split(' ', row );
qWarning("0: %s", value[0].latin1() );
qWarning("1: %s", value[1].latin1() );
qWarning("2: %s", value[2].latin1() );
qWarning("3: %s", value[3].latin1() );
qWarning("4: %s", value[4].latin1() );
qWarning("5: %s", value[5].latin1() );
qWarning("6: %s", value[6].latin1() );
qWarning("7: %s", value[7].latin1() );
qWarning("8: %s", value[8].latin1() );
+ Connection con;
+ con.setDirection( value[0] == QString::fromLatin1("<") ? Outgoing : Incoming );
+ con.setConnectionMode( value[1] );
+ con.setMac( value[2] );
+ con.setHandle( value[4].toInt() );
+ con.setState( value[6].toInt() );
+ con.setLinkMode( value[8] == QString::fromLatin1("MASTER") ? Master : Client );
+ list2.append( con );
}
return list2;
}