summaryrefslogtreecommitdiff
path: root/core/applets/irdaapplet/irda.cpp
authorharlekin <harlekin>2002-06-14 10:17:34 (UTC)
committer harlekin <harlekin>2002-06-14 10:17:34 (UTC)
commitcf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad (patch) (unidiff)
tree42616657f00051e0a13e06f6d9fa07c5ba838bea /core/applets/irdaapplet/irda.cpp
parent1e09f5f7c691bff0d546dead1807a92c1a0b0303 (diff)
downloadopie-cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad.zip
opie-cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad.tar.gz
opie-cf54bc85d0e9846d64ca2a2af55fffc3d4e2f4ad.tar.bz2
show discovered device
Diffstat (limited to 'core/applets/irdaapplet/irda.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/irdaapplet/irda.cpp44
1 files changed, 40 insertions, 4 deletions
diff --git a/core/applets/irdaapplet/irda.cpp b/core/applets/irdaapplet/irda.cpp
index 28a79d1..e21f191 100644
--- a/core/applets/irdaapplet/irda.cpp
+++ b/core/applets/irdaapplet/irda.cpp
@@ -39,12 +39,13 @@
39#include <qlayout.h> 39#include <qlayout.h>
40#include <qframe.h> 40#include <qframe.h>
41#include <qpixmap.h> 41#include <qpixmap.h>
42#include <qstring.h> 42#include <qstring.h>
43#include <qfile.h> 43#include <qfile.h>
44#include <qtimer.h> 44#include <qtimer.h>
45#include <qtextstream.h>
45#include <qpopupmenu.h> 46#include <qpopupmenu.h>
46 47
47#include <net/if.h> 48#include <net/if.h>
48#include <netinet/in.h> 49#include <netinet/in.h>
49#include <sys/types.h> 50#include <sys/types.h>
50#include <sys/socket.h> 51#include <sys/socket.h>
@@ -125,30 +126,65 @@ int IrdaApplet::setIrdaDiscoveryStatus(int d) {
125 discovery.close(); 126 discovery.close();
126 127
127 return 0; 128 return 0;
128} 129}
129 130
130 131
132void IrdaApplet::showDiscovered() {
133 QFile discovery("/proc/net/irda/discovery");
134
135 if (discovery.open(IO_ReadOnly) ) {
136 QStringList list;
137 // since it is /proc we _must_ use QTextStream
138 QTextStream stream ( &discovery);
139 QString streamIn;
140 streamIn = stream.read();
141 list = QStringList::split("\n", streamIn);
142
143 for(QStringList::Iterator line=list.begin(); line!=list.end(); line++) {
144 if( (*line).startsWith("nickname:") ){
145 discoveredDevice = (*line).mid(((*line).find(':'))+1,(*line).find(',')-(*line).find(':')-1);
146 qDebug(discoveredDevice);
147 }
148 }
149 }
150
151}
152
131void IrdaApplet::mousePressEvent( QMouseEvent *) { 153void IrdaApplet::mousePressEvent( QMouseEvent *) {
132 QPopupMenu *menu = new QPopupMenu(); 154 QPopupMenu *menu = new QPopupMenu();
133 QString cmd; 155 QString cmd;
134 int ret=0; 156 int ret=0;
157 showDiscovered();
135 158
136 /* Refresh active state */ 159 /* Refresh active state */
137 timerEvent(NULL); 160 timerEvent(NULL);
138 161
139 //menu->insertItem( tr("More..."), 4 ); 162 //menu->insertItem( tr("More..."), 4 );
140 if (irdaactive) 163
164 menu->insertItem( tr("Discovered Device:"), 9);
165
166 if ( !discoveredDevice.isEmpty() ) {
167 menu->insertItem( discoveredDevice ,7 );
168 } else {
169 menu->insertItem( tr("None"), 8);
170 }
171
172 menu->insertSeparator();
173
174 if (irdaactive) {
141 menu->insertItem( tr("Disable IrDA"), 0 ); 175 menu->insertItem( tr("Disable IrDA"), 0 );
142 else 176 } else {
143 menu->insertItem( tr("Enable IrDA"), 1 ); 177 menu->insertItem( tr("Enable IrDA"), 1 );
178 }
144 179
145 if (irdaDiscoveryActive) 180 if (irdaDiscoveryActive) {
146 menu->insertItem( tr("Disable Discovery"), 2 ); 181 menu->insertItem( tr("Disable Discovery"), 2 );
147 else 182 } else {
148 menu->insertItem( tr("Enable Discovery"), 3 ); 183 menu->insertItem( tr("Enable Discovery"), 3 );
184 }
149 185
150 if( receiveActive ){ 186 if( receiveActive ){
151 menu->insertItem( tr("Disable Receive"), 5 ); 187 menu->insertItem( tr("Disable Receive"), 5 );
152 } else { 188 } else {
153 menu->insertItem( tr("Enable Receive"), 4 ); 189 menu->insertItem( tr("Enable Receive"), 4 );
154 } 190 }