-rw-r--r-- | core/applets/irdaapplet/irda.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/core/applets/irdaapplet/irda.cpp b/core/applets/irdaapplet/irda.cpp index 5b23330..d986df4 100644 --- a/core/applets/irdaapplet/irda.cpp +++ b/core/applets/irdaapplet/irda.cpp | |||
@@ -102,180 +102,183 @@ int IrdaApplet::setIrdaStatus(int c) { | |||
102 | return 0; | 102 | return 0; |
103 | } | 103 | } |
104 | 104 | ||
105 | int IrdaApplet::checkIrdaDiscoveryStatus() { | 105 | int IrdaApplet::checkIrdaDiscoveryStatus() { |
106 | 106 | ||
107 | QFile discovery("/proc/sys/net/irda/discovery"); | 107 | QFile discovery("/proc/sys/net/irda/discovery"); |
108 | 108 | ||
109 | QString streamIn = "0"; | 109 | QString streamIn = "0"; |
110 | 110 | ||
111 | if (discovery.open(IO_ReadOnly) ) { | 111 | if (discovery.open(IO_ReadOnly) ) { |
112 | QTextStream stream ( &discovery ); | 112 | QTextStream stream ( &discovery ); |
113 | streamIn = stream.read(); | 113 | streamIn = stream.read(); |
114 | } | 114 | } |
115 | 115 | ||
116 | discovery.close(); | 116 | discovery.close(); |
117 | 117 | ||
118 | return( streamIn.toInt() ); | 118 | return( streamIn.toInt() ); |
119 | } | 119 | } |
120 | 120 | ||
121 | 121 | ||
122 | int IrdaApplet::setIrdaDiscoveryStatus(int d) { | 122 | int IrdaApplet::setIrdaDiscoveryStatus(int d) { |
123 | QFile discovery("/proc/sys/net/irda/discovery"); | 123 | QFile discovery("/proc/sys/net/irda/discovery"); |
124 | 124 | ||
125 | discovery.open( IO_WriteOnly|IO_Raw ); | 125 | discovery.open( IO_WriteOnly|IO_Raw ); |
126 | 126 | ||
127 | if (d) | 127 | if (d) |
128 | discovery.putch('1'); | 128 | discovery.putch('1'); |
129 | else | 129 | else |
130 | discovery.putch('0'); | 130 | discovery.putch('0'); |
131 | 131 | ||
132 | discovery.close(); | 132 | discovery.close(); |
133 | 133 | ||
134 | return 0; | 134 | return 0; |
135 | } | 135 | } |
136 | 136 | ||
137 | 137 | ||
138 | void IrdaApplet::showDiscovered() { | 138 | void IrdaApplet::showDiscovered() { |
139 | QFile discovery("/proc/net/irda/discovery"); | 139 | QFile discovery("/proc/net/irda/discovery"); |
140 | 140 | ||
141 | if (discovery.open(IO_ReadOnly) ) { | 141 | if (discovery.open(IO_ReadOnly) ) { |
142 | QStringList list; | 142 | QStringList list; |
143 | // since it is /proc we _must_ use QTextStream | 143 | // since it is /proc we _must_ use QTextStream |
144 | QTextStream stream ( &discovery); | 144 | QTextStream stream ( &discovery); |
145 | QString streamIn; | 145 | QString streamIn; |
146 | streamIn = stream.read(); | 146 | streamIn = stream.read(); |
147 | list = QStringList::split("\n", streamIn); | 147 | list = QStringList::split("\n", streamIn); |
148 | 148 | ||
149 | for(QStringList::Iterator line=list.begin(); line!=list.end(); line++) { | 149 | for(QStringList::Iterator line=list.begin(); line!=list.end(); line++) { |
150 | if( (*line).startsWith("nickname:") ){ | 150 | if( (*line).startsWith("nickname:") ){ |
151 | discoveredDevice = (*line).mid(((*line).find(':'))+1,(*line).find(',')-(*line).find(':')-1); | 151 | discoveredDevice = (*line).mid(((*line).find(':'))+1,(*line).find(',')-(*line).find(':')-1); |
152 | qDebug(discoveredDevice); | 152 | qDebug(discoveredDevice); |
153 | } | 153 | } |
154 | } | 154 | } |
155 | } | 155 | } |
156 | 156 | ||
157 | } | 157 | } |
158 | 158 | ||
159 | void IrdaApplet::mousePressEvent( QMouseEvent *) { | 159 | void IrdaApplet::mousePressEvent( QMouseEvent *) { |
160 | QPopupMenu *menu = new QPopupMenu(); | 160 | QPopupMenu *menu = new QPopupMenu(); |
161 | QString cmd; | 161 | QString cmd; |
162 | int ret=0; | 162 | int ret=0; |
163 | showDiscovered(); | 163 | showDiscovered(); |
164 | 164 | ||
165 | /* Refresh active state */ | 165 | /* Refresh active state */ |
166 | timerEvent(NULL); | 166 | timerEvent(NULL); |
167 | 167 | ||
168 | //menu->insertItem( tr("More..."), 4 ); | 168 | //menu->insertItem( tr("More..."), 4 ); |
169 | 169 | ||
170 | menu->insertItem( tr("Discovered Device:"), 9); | 170 | menu->insertItem( tr("Discovered Device:"), 9); |
171 | 171 | ||
172 | if ( !discoveredDevice.isEmpty() ) { | 172 | if ( !discoveredDevice.isEmpty() ) { |
173 | menu->insertItem( discoveredDevice ,7 ); | 173 | menu->insertItem( discoveredDevice ,7 ); |
174 | } else { | 174 | } else { |
175 | menu->insertItem( tr("None"), 8); | 175 | menu->insertItem( tr("None"), 8); |
176 | } | 176 | } |
177 | 177 | ||
178 | menu->insertSeparator(); | 178 | menu->insertSeparator(); |
179 | 179 | ||
180 | if (irdaactive) { | 180 | if (irdaactive) { |
181 | menu->insertItem( tr("Disable IrDA"), 0 ); | 181 | menu->insertItem( tr("Disable IrDA"), 0 ); |
182 | } else { | 182 | } else { |
183 | menu->insertItem( tr("Enable IrDA"), 1 ); | 183 | menu->insertItem( tr("Enable IrDA"), 1 ); |
184 | } | 184 | } |
185 | 185 | ||
186 | if (irdaDiscoveryActive) { | 186 | if (irdaDiscoveryActive) { |
187 | menu->insertItem( tr("Disable Discovery"), 2 ); | 187 | menu->insertItem( tr("Disable Discovery"), 2 ); |
188 | } else { | 188 | } else { |
189 | menu->insertItem( tr("Enable Discovery"), 3 ); | 189 | menu->insertItem( tr("Enable Discovery"), 3 ); |
190 | } | 190 | } |
191 | 191 | ||
192 | if( receiveActive ){ | 192 | if( receiveActive ){ |
193 | menu->insertItem( tr("Disable Receive"), 5 ); | 193 | menu->insertItem( tr("Disable Receive"), 5 ); |
194 | } else { | 194 | } else { |
195 | menu->insertItem( tr("Enable Receive"), 4 ); | 195 | menu->insertItem( tr("Enable Receive"), 4 ); |
196 | } | 196 | } |
197 | 197 | ||
198 | QPoint p = mapToGlobal( QPoint(1, menu->sizeHint().height()-1) ); | 198 | QPoint p = mapToGlobal ( QPoint ( 0, 0 )); |
199 | ret = menu->exec(p, 2); | 199 | QSize s = menu-> sizeHint ( ); |
200 | ret = menu->exec( QPoint ( | ||
201 | p. x ( ) + ( width ( ) / 2 ) - ( s. width ( ) / 2 ), | ||
202 | p. y ( ) - s. height ( ) ), 0); | ||
200 | 203 | ||
201 | qDebug("ret was %d\n", ret); | 204 | qDebug("ret was %d\n", ret); |
202 | 205 | ||
203 | switch(ret) { | 206 | switch(ret) { |
204 | case 0: | 207 | case 0: |
205 | setIrdaStatus(0); | 208 | setIrdaStatus(0); |
206 | timerEvent(NULL); | 209 | timerEvent(NULL); |
207 | break; | 210 | break; |
208 | case 1: | 211 | case 1: |
209 | setIrdaStatus(1); | 212 | setIrdaStatus(1); |
210 | timerEvent(NULL); | 213 | timerEvent(NULL); |
211 | break; | 214 | break; |
212 | case 2: | 215 | case 2: |
213 | setIrdaDiscoveryStatus(0); | 216 | setIrdaDiscoveryStatus(0); |
214 | timerEvent(NULL); | 217 | timerEvent(NULL); |
215 | break; | 218 | break; |
216 | case 3: | 219 | case 3: |
217 | setIrdaDiscoveryStatus(1); | 220 | setIrdaDiscoveryStatus(1); |
218 | timerEvent(NULL); // NULL is undefined in c++ use 0 or 0l | 221 | timerEvent(NULL); // NULL is undefined in c++ use 0 or 0l |
219 | break; | 222 | break; |
220 | case 4: { // enable receive | 223 | case 4: { // enable receive |
221 | qWarning("Enable receive" ); | 224 | qWarning("Enable receive" ); |
222 | QCopEnvelope e("QPE/Obex", "receive(int)" ); | 225 | QCopEnvelope e("QPE/Obex", "receive(int)" ); |
223 | e << 1; | 226 | e << 1; |
224 | receiveActive = true; | 227 | receiveActive = true; |
225 | receiveStateChanged = true; | 228 | receiveStateChanged = true; |
226 | timerEvent(NULL); | 229 | timerEvent(NULL); |
227 | break; | 230 | break; |
228 | } | 231 | } |
229 | case 5: { // disable receive | 232 | case 5: { // disable receive |
230 | qWarning("Disable receive" ); | 233 | qWarning("Disable receive" ); |
231 | QCopEnvelope e("QPE/Obex", "receive(int)" ); | 234 | QCopEnvelope e("QPE/Obex", "receive(int)" ); |
232 | e << 0; | 235 | e << 0; |
233 | receiveActive = false; | 236 | receiveActive = false; |
234 | receiveStateChanged = true; | 237 | receiveStateChanged = true; |
235 | timerEvent(NULL); | 238 | timerEvent(NULL); |
236 | break; | 239 | break; |
237 | } | 240 | } |
238 | case 6: | 241 | case 6: |
239 | qDebug("FIXME: Bring up pretty menu...\n"); | 242 | qDebug("FIXME: Bring up pretty menu...\n"); |
240 | // With table of currently-detected devices. | 243 | // With table of currently-detected devices. |
241 | } | 244 | } |
242 | delete menu; // Can somebody explain why use a QPopupMenu* and not QPopupMenu nor QAction. with out delete we will leak cause QPopupMenu doesn't have a parent in this case | 245 | delete menu; // Can somebody explain why use a QPopupMenu* and not QPopupMenu nor QAction. with out delete we will leak cause QPopupMenu doesn't have a parent in this case |
243 | } | 246 | } |
244 | 247 | ||
245 | void IrdaApplet::timerEvent( QTimerEvent * ) { | 248 | void IrdaApplet::timerEvent( QTimerEvent * ) { |
246 | int oldactive = irdaactive; | 249 | int oldactive = irdaactive; |
247 | int olddiscovery = irdaDiscoveryActive; | 250 | int olddiscovery = irdaDiscoveryActive; |
248 | bool receiveUpdate = false; | 251 | bool receiveUpdate = false; |
249 | 252 | ||
250 | if (receiveStateChanged) { | 253 | if (receiveStateChanged) { |
251 | receiveUpdate = true; | 254 | receiveUpdate = true; |
252 | receiveStateChanged = false; | 255 | receiveStateChanged = false; |
253 | } | 256 | } |
254 | 257 | ||
255 | irdaactive = checkIrdaStatus(); | 258 | irdaactive = checkIrdaStatus(); |
256 | irdaDiscoveryActive = checkIrdaDiscoveryStatus(); | 259 | irdaDiscoveryActive = checkIrdaDiscoveryStatus(); |
257 | 260 | ||
258 | if ((irdaactive != oldactive) || (irdaDiscoveryActive != olddiscovery) || receiveUpdate ) { | 261 | if ((irdaactive != oldactive) || (irdaDiscoveryActive != olddiscovery) || receiveUpdate ) { |
259 | paintEvent(NULL); | 262 | paintEvent(NULL); |
260 | } | 263 | } |
261 | 264 | ||
262 | } | 265 | } |
263 | 266 | ||
264 | void IrdaApplet::paintEvent( QPaintEvent* ) { | 267 | void IrdaApplet::paintEvent( QPaintEvent* ) { |
265 | QPainter p(this); | 268 | QPainter p(this); |
266 | qDebug("paint irda pixmap"); | 269 | qDebug("paint irda pixmap"); |
267 | 270 | ||
268 | p.eraseRect ( 0, 0, this->width(), this->height() ); | 271 | p.eraseRect ( 0, 0, this->width(), this->height() ); |
269 | if (irdaactive > 0) { | 272 | if (irdaactive > 0) { |
270 | p.drawPixmap( 0, 1, irdaOnPixmap ); | 273 | p.drawPixmap( 0, 1, irdaOnPixmap ); |
271 | } else { | 274 | } else { |
272 | p.drawPixmap( 0, 1, irdaOffPixmap ); | 275 | p.drawPixmap( 0, 1, irdaOffPixmap ); |
273 | } | 276 | } |
274 | 277 | ||
275 | if (irdaDiscoveryActive > 0) { | 278 | if (irdaDiscoveryActive > 0) { |
276 | p.drawPixmap( 0, 1, irdaDiscoveryOnPixmap ); | 279 | p.drawPixmap( 0, 1, irdaDiscoveryOnPixmap ); |
277 | } | 280 | } |
278 | if (receiveActive) { | 281 | if (receiveActive) { |
279 | p.drawPixmap( 0, 1, receiveActivePixmap); | 282 | p.drawPixmap( 0, 1, receiveActivePixmap); |
280 | } | 283 | } |
281 | } | 284 | } |