summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/irdaapplet/irda.cpp44
-rw-r--r--core/applets/irdaapplet/irda.h2
2 files changed, 42 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
@@ -43,4 +43,5 @@
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
@@ -129,8 +130,30 @@ int IrdaApplet::setIrdaDiscoveryStatus(int d) {
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 */
@@ -138,13 +161,26 @@ void IrdaApplet::mousePressEvent( QMouseEvent *) {
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 ){
diff --git a/core/applets/irdaapplet/irda.h b/core/applets/irdaapplet/irda.h
index 002d295..5822afe 100644
--- a/core/applets/irdaapplet/irda.h
+++ b/core/applets/irdaapplet/irda.h
@@ -43,4 +43,5 @@ private:
43 int checkIrdaDiscoveryStatus(); 43 int checkIrdaDiscoveryStatus();
44 int setIrdaDiscoveryStatus(int); 44 int setIrdaDiscoveryStatus(int);
45 void showDiscovered();
45 int sockfd; 46 int sockfd;
46 47
@@ -50,4 +51,5 @@ private:
50 QPixmap irdaDiscoveryOnPixmap; 51 QPixmap irdaDiscoveryOnPixmap;
51 QPixmap receiveActivePixmap; 52 QPixmap receiveActivePixmap;
53 QString discoveredDevice;
52 int irdaactive; // bool and bitfields later bool irdaactive :1 ; 54 int irdaactive; // bool and bitfields later bool irdaactive :1 ;
53 int irdaDiscoveryActive; 55 int irdaDiscoveryActive;