author | zecke <zecke> | 2002-10-18 01:46:28 (UTC) |
---|---|---|
committer | zecke <zecke> | 2002-10-18 01:46:28 (UTC) |
commit | 218bc4583c545db50f3475930d61b1c76aca3fbd (patch) (unidiff) | |
tree | 5ddd0dbca5a42d3f00914968150147c85b4da837 | |
parent | 0457c48c165abef8afa2ac73c8f66d20e289681a (diff) | |
download | opie-218bc4583c545db50f3475930d61b1c76aca3fbd.zip opie-218bc4583c545db50f3475930d61b1c76aca3fbd.tar.gz opie-218bc4583c545db50f3475930d61b1c76aca3fbd.tar.bz2 |
Remove some more #ifdefs
-rw-r--r-- | core/launcher/desktop.cpp | 4 | ||||
-rw-r--r-- | core/launcher/launcher.cpp | 2 |
2 files changed, 1 insertions, 5 deletions
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index 1fd3f6a..3546e28 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp | |||
@@ -186,434 +186,430 @@ public: | |||
186 | { | 186 | { |
187 | switch ( level ) { | 187 | switch ( level ) { |
188 | case 0: | 188 | case 0: |
189 | if ( m_disable_suspend > 0 && m_enable_dim ) { | 189 | if ( m_disable_suspend > 0 && m_enable_dim ) { |
190 | if ( backlight() > 1 ) | 190 | if ( backlight() > 1 ) |
191 | setBacklight( 1 ); // lowest non-off | 191 | setBacklight( 1 ); // lowest non-off |
192 | } | 192 | } |
193 | return true; | 193 | return true; |
194 | break; | 194 | break; |
195 | case 1: | 195 | case 1: |
196 | if ( m_disable_suspend > 1 && m_enable_lightoff ) { | 196 | if ( m_disable_suspend > 1 && m_enable_lightoff ) { |
197 | setBacklight( 0 ); // off | 197 | setBacklight( 0 ); // off |
198 | } | 198 | } |
199 | return true; | 199 | return true; |
200 | break; | 200 | break; |
201 | case 2: | 201 | case 2: |
202 | if ( m_enable_onlylcdoff ) { | 202 | if ( m_enable_onlylcdoff ) { |
203 | ODevice::inst ( ) -> setDisplayStatus ( false ); | 203 | ODevice::inst ( ) -> setDisplayStatus ( false ); |
204 | m_lcd_status = false; | 204 | m_lcd_status = false; |
205 | return true; | 205 | return true; |
206 | } | 206 | } |
207 | else // We're going to suspend the whole machine | 207 | else // We're going to suspend the whole machine |
208 | { | 208 | { |
209 | if ( ( m_disable_suspend > 2 ) && | 209 | if ( ( m_disable_suspend > 2 ) && |
210 | ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && | 210 | ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && |
211 | ( !Network::networkOnline ( ) ) ) { | 211 | ( !Network::networkOnline ( ) ) ) { |
212 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); | 212 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); |
213 | return true; | 213 | return true; |
214 | } | 214 | } |
215 | } | 215 | } |
216 | break; | 216 | break; |
217 | } | 217 | } |
218 | return false; | 218 | return false; |
219 | } | 219 | } |
220 | 220 | ||
221 | private: | 221 | private: |
222 | static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def ) | 222 | static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def ) |
223 | { | 223 | { |
224 | if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) | 224 | if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) |
225 | return 0; | 225 | return 0; |
226 | 226 | ||
227 | if ( interval < 0 ) { | 227 | if ( interval < 0 ) { |
228 | // Restore screen blanking and power saving state | 228 | // Restore screen blanking and power saving state |
229 | interval = config.readNumEntry( value, def ); | 229 | interval = config.readNumEntry( value, def ); |
230 | } | 230 | } |
231 | return interval; | 231 | return interval; |
232 | } | 232 | } |
233 | 233 | ||
234 | public: | 234 | public: |
235 | void setIntervals( int i1, int i2, int i3 ) | 235 | void setIntervals( int i1, int i2, int i3 ) |
236 | { | 236 | { |
237 | Config config( "qpe" ); | 237 | Config config( "qpe" ); |
238 | config.setGroup( "Screensaver" ); | 238 | config.setGroup( "Screensaver" ); |
239 | 239 | ||
240 | int v[ 4 ]; | 240 | int v[ 4 ]; |
241 | i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 ); | 241 | i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 ); |
242 | i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 ); | 242 | i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 ); |
243 | i3 = ssi( i3, config, "", "Interval", 60 ); | 243 | i3 = ssi( i3, config, "", "Interval", 60 ); |
244 | 244 | ||
245 | //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); | 245 | //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); |
246 | 246 | ||
247 | v [ 0 ] = QMAX( 1000 * i1, 100 ); | 247 | v [ 0 ] = QMAX( 1000 * i1, 100 ); |
248 | v [ 1 ] = QMAX( 1000 * i2, 100 ); | 248 | v [ 1 ] = QMAX( 1000 * i2, 100 ); |
249 | v [ 2 ] = QMAX( 1000 * i3, 100 ); | 249 | v [ 2 ] = QMAX( 1000 * i3, 100 ); |
250 | v [ 3 ] = 0; | 250 | v [ 3 ] = 0; |
251 | m_enable_dim = ( ( i1 != 0 ) ? config. readNumEntry ( "Dim", 1 ) : false ); | 251 | m_enable_dim = ( ( i1 != 0 ) ? config. readNumEntry ( "Dim", 1 ) : false ); |
252 | m_enable_lightoff = ( ( i2 != 0 ) ? config. readNumEntry ( "LightOff", 1 ) : false ); | 252 | m_enable_lightoff = ( ( i2 != 0 ) ? config. readNumEntry ( "LightOff", 1 ) : false ); |
253 | m_enable_onlylcdoff = config. readNumEntry ( "LcdOffOnly", 0 ); | 253 | m_enable_onlylcdoff = config. readNumEntry ( "LcdOffOnly", 0 ); |
254 | 254 | ||
255 | if ( !i1 && !i2 && !i3 ) | 255 | if ( !i1 && !i2 && !i3 ) |
256 | QWSServer::setScreenSaverInterval( 0 ); | 256 | QWSServer::setScreenSaverInterval( 0 ); |
257 | else | 257 | else |
258 | QWSServer::setScreenSaverIntervals( v ); | 258 | QWSServer::setScreenSaverIntervals( v ); |
259 | } | 259 | } |
260 | 260 | ||
261 | void setInterval ( int interval ) | 261 | void setInterval ( int interval ) |
262 | { | 262 | { |
263 | setIntervals ( -1, -1, interval ); | 263 | setIntervals ( -1, -1, interval ); |
264 | } | 264 | } |
265 | 265 | ||
266 | void setMode ( int mode ) | 266 | void setMode ( int mode ) |
267 | { | 267 | { |
268 | if ( mode > m_disable_suspend ) | 268 | if ( mode > m_disable_suspend ) |
269 | setInterval( -1 ); | 269 | setInterval( -1 ); |
270 | m_disable_suspend = mode; | 270 | m_disable_suspend = mode; |
271 | } | 271 | } |
272 | 272 | ||
273 | int backlight ( ) | 273 | int backlight ( ) |
274 | { | 274 | { |
275 | if ( m_backlight_bright == -1 ) { | 275 | if ( m_backlight_bright == -1 ) { |
276 | // Read from config | 276 | // Read from config |
277 | Config config ( "qpe" ); | 277 | Config config ( "qpe" ); |
278 | config. setGroup ( "Screensaver" ); | 278 | config. setGroup ( "Screensaver" ); |
279 | m_backlight_bright = config. readNumEntry ( "Brightness", 255 ); | 279 | m_backlight_bright = config. readNumEntry ( "Brightness", 255 ); |
280 | } | 280 | } |
281 | return m_backlight_bright; | 281 | return m_backlight_bright; |
282 | } | 282 | } |
283 | 283 | ||
284 | void setBacklight ( int bright ) | 284 | void setBacklight ( int bright ) |
285 | { | 285 | { |
286 | if ( bright == -3 ) { | 286 | if ( bright == -3 ) { |
287 | // Forced on | 287 | // Forced on |
288 | m_backlight_forcedoff = false; | 288 | m_backlight_forcedoff = false; |
289 | bright = -1; | 289 | bright = -1; |
290 | } | 290 | } |
291 | if ( m_backlight_forcedoff && bright != -2 ) | 291 | if ( m_backlight_forcedoff && bright != -2 ) |
292 | return ; | 292 | return ; |
293 | if ( bright == -2 ) { | 293 | if ( bright == -2 ) { |
294 | // Toggle between off and on | 294 | // Toggle between off and on |
295 | bright = m_backlight_bright ? 0 : -1; | 295 | bright = m_backlight_bright ? 0 : -1; |
296 | m_backlight_forcedoff = !bright; | 296 | m_backlight_forcedoff = !bright; |
297 | } | 297 | } |
298 | 298 | ||
299 | m_backlight_bright = bright; | 299 | m_backlight_bright = bright; |
300 | 300 | ||
301 | bright = backlight ( ); | 301 | bright = backlight ( ); |
302 | ODevice::inst ( ) -> setDisplayBrightness ( bright ); | 302 | ODevice::inst ( ) -> setDisplayBrightness ( bright ); |
303 | 303 | ||
304 | m_backlight_bright = bright; | 304 | m_backlight_bright = bright; |
305 | } | 305 | } |
306 | 306 | ||
307 | void setDisplayState ( bool on ) | 307 | void setDisplayState ( bool on ) |
308 | { | 308 | { |
309 | if ( m_lcd_status != on ) { | 309 | if ( m_lcd_status != on ) { |
310 | ODevice::inst ( ) -> setDisplayStatus ( on ); | 310 | ODevice::inst ( ) -> setDisplayStatus ( on ); |
311 | m_lcd_status = on; | 311 | m_lcd_status = on; |
312 | } | 312 | } |
313 | } | 313 | } |
314 | 314 | ||
315 | private: | 315 | private: |
316 | int m_disable_suspend; | 316 | int m_disable_suspend; |
317 | bool m_enable_dim; | 317 | bool m_enable_dim; |
318 | bool m_enable_lightoff; | 318 | bool m_enable_lightoff; |
319 | bool m_enable_onlylcdoff; | 319 | bool m_enable_onlylcdoff; |
320 | 320 | ||
321 | bool m_lcd_status; | 321 | bool m_lcd_status; |
322 | 322 | ||
323 | int m_backlight_bright; | 323 | int m_backlight_bright; |
324 | bool m_backlight_forcedoff; | 324 | bool m_backlight_forcedoff; |
325 | }; | 325 | }; |
326 | 326 | ||
327 | void DesktopApplication::switchLCD ( bool on ) | 327 | void DesktopApplication::switchLCD ( bool on ) |
328 | { | 328 | { |
329 | if ( qApp ) { | 329 | if ( qApp ) { |
330 | DesktopApplication *dapp = (DesktopApplication *) qApp; | 330 | DesktopApplication *dapp = (DesktopApplication *) qApp; |
331 | 331 | ||
332 | if ( dapp-> m_screensaver ) { | 332 | if ( dapp-> m_screensaver ) { |
333 | if ( on ) { | 333 | if ( on ) { |
334 | dapp-> m_screensaver-> setDisplayState ( true ); | 334 | dapp-> m_screensaver-> setDisplayState ( true ); |
335 | dapp-> m_screensaver-> setBacklight ( -3 ); | 335 | dapp-> m_screensaver-> setBacklight ( -3 ); |
336 | } | 336 | } |
337 | else { | 337 | else { |
338 | dapp-> m_screensaver-> setDisplayState ( false ); | 338 | dapp-> m_screensaver-> setDisplayState ( false ); |
339 | } | 339 | } |
340 | } | 340 | } |
341 | } | 341 | } |
342 | } | 342 | } |
343 | 343 | ||
344 | 344 | ||
345 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) | 345 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) |
346 | : QPEApplication( argc, argv, appType ) | 346 | : QPEApplication( argc, argv, appType ) |
347 | { | 347 | { |
348 | 348 | ||
349 | QTimer * t = new QTimer( this ); | 349 | QTimer * t = new QTimer( this ); |
350 | connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); | 350 | connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); |
351 | t->start( 10000 ); | 351 | t->start( 10000 ); |
352 | ps = new PowerStatus; | 352 | ps = new PowerStatus; |
353 | pa = new DesktopPowerAlerter( 0 ); | 353 | pa = new DesktopPowerAlerter( 0 ); |
354 | 354 | ||
355 | channel = new QCopChannel( "QPE/Desktop", this ); | 355 | channel = new QCopChannel( "QPE/Desktop", this ); |
356 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 356 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
357 | this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); | 357 | this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); |
358 | 358 | ||
359 | channel = new QCopChannel( "QPE/System", this ); | 359 | channel = new QCopChannel( "QPE/System", this ); |
360 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 360 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
361 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); | 361 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); |
362 | 362 | ||
363 | m_screensaver = new QPEScreenSaver; | 363 | m_screensaver = new QPEScreenSaver; |
364 | 364 | ||
365 | m_screensaver-> setInterval ( -1 ); | 365 | m_screensaver-> setInterval ( -1 ); |
366 | QWSServer::setScreenSaver( m_screensaver ); | 366 | QWSServer::setScreenSaver( m_screensaver ); |
367 | } | 367 | } |
368 | 368 | ||
369 | 369 | ||
370 | DesktopApplication::~DesktopApplication() | 370 | DesktopApplication::~DesktopApplication() |
371 | { | 371 | { |
372 | delete ps; | 372 | delete ps; |
373 | delete pa; | 373 | delete pa; |
374 | } | 374 | } |
375 | 375 | ||
376 | void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) | 376 | void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) |
377 | { | 377 | { |
378 | #ifdef Q_WS_QWS | ||
379 | QDataStream stream( data, IO_ReadOnly ); | 378 | QDataStream stream( data, IO_ReadOnly ); |
380 | if ( msg == "keyRegister(int key, QString channel, QString message)" ) { | 379 | if ( msg == "keyRegister(int key, QString channel, QString message)" ) { |
381 | int k; | 380 | int k; |
382 | QString c, m; | 381 | QString c, m; |
383 | stream >> k; | 382 | stream >> k; |
384 | stream >> c; | 383 | stream >> c; |
385 | stream >> m; | 384 | stream >> m; |
386 | 385 | ||
387 | qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); | 386 | qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); |
388 | keyRegisterList.append( QCopKeyRegister( k, c, m ) ); | 387 | keyRegisterList.append( QCopKeyRegister( k, c, m ) ); |
389 | } | 388 | } |
390 | #endif | ||
391 | } | 389 | } |
392 | 390 | ||
393 | 391 | ||
394 | void DesktopApplication::systemMessage( const QCString & msg, const QByteArray & data ) | 392 | void DesktopApplication::systemMessage( const QCString & msg, const QByteArray & data ) |
395 | { | 393 | { |
396 | #ifdef Q_WS_QWS | ||
397 | QDataStream stream ( data, IO_ReadOnly ); | 394 | QDataStream stream ( data, IO_ReadOnly ); |
398 | 395 | ||
399 | if ( msg == "setScreenSaverInterval(int)" ) { | 396 | if ( msg == "setScreenSaverInterval(int)" ) { |
400 | int time; | 397 | int time; |
401 | stream >> time; | 398 | stream >> time; |
402 | m_screensaver-> setInterval( time ); | 399 | m_screensaver-> setInterval( time ); |
403 | } | 400 | } |
404 | else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { | 401 | else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { |
405 | int t1, t2, t3; | 402 | int t1, t2, t3; |
406 | stream >> t1 >> t2 >> t3; | 403 | stream >> t1 >> t2 >> t3; |
407 | m_screensaver-> setIntervals( t1, t2, t3 ); | 404 | m_screensaver-> setIntervals( t1, t2, t3 ); |
408 | } | 405 | } |
409 | else if ( msg == "setBacklight(int)" ) { | 406 | else if ( msg == "setBacklight(int)" ) { |
410 | int bright; | 407 | int bright; |
411 | stream >> bright; | 408 | stream >> bright; |
412 | m_screensaver-> setBacklight( bright ); | 409 | m_screensaver-> setBacklight( bright ); |
413 | } | 410 | } |
414 | else if ( msg == "setScreenSaverMode(int)" ) { | 411 | else if ( msg == "setScreenSaverMode(int)" ) { |
415 | int mode; | 412 | int mode; |
416 | stream >> mode; | 413 | stream >> mode; |
417 | m_screensaver-> setMode ( mode ); | 414 | m_screensaver-> setMode ( mode ); |
418 | } | 415 | } |
419 | else if ( msg == "setDisplayState(int)" ) { | 416 | else if ( msg == "setDisplayState(int)" ) { |
420 | int state; | 417 | int state; |
421 | stream >> state; | 418 | stream >> state; |
422 | m_screensaver-> setDisplayState ( state != 0 ); | 419 | m_screensaver-> setDisplayState ( state != 0 ); |
423 | } | 420 | } |
424 | else if ( msg == "suspend()" ) { | 421 | else if ( msg == "suspend()" ) { |
425 | emit power(); | 422 | emit power(); |
426 | } | 423 | } |
427 | #endif | ||
428 | } | 424 | } |
429 | 425 | ||
430 | enum MemState { Unknown, VeryLow, Low, Normal } memstate = Unknown; | 426 | enum MemState { Unknown, VeryLow, Low, Normal } memstate = Unknown; |
431 | 427 | ||
432 | #ifdef Q_WS_QWS | 428 | #ifdef Q_WS_QWS |
433 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) | 429 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) |
434 | { | 430 | { |
435 | qpedesktop->checkMemory(); | 431 | qpedesktop->checkMemory(); |
436 | 432 | ||
437 | if ( e->type == QWSEvent::Key ) { | 433 | if ( e->type == QWSEvent::Key ) { |
438 | QWSKeyEvent * ke = ( QWSKeyEvent * ) e; | 434 | QWSKeyEvent * ke = ( QWSKeyEvent * ) e; |
439 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) | 435 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) |
440 | return TRUE; | 436 | return TRUE; |
441 | bool press = ke->simpleData.is_press; | 437 | bool press = ke->simpleData.is_press; |
442 | bool autoRepeat = ke->simpleData.is_auto_repeat; | 438 | bool autoRepeat = ke->simpleData.is_auto_repeat; |
443 | 439 | ||
444 | /* | 440 | /* |
445 | app that registers key/message to be sent back to the app, when it doesn't have focus, | 441 | app that registers key/message to be sent back to the app, when it doesn't have focus, |
446 | when user presses key, unless keyboard has been requested from app. | 442 | when user presses key, unless keyboard has been requested from app. |
447 | will not send multiple repeats if user holds key | 443 | will not send multiple repeats if user holds key |
448 | i.e. one shot | 444 | i.e. one shot |
449 | */ | 445 | */ |
450 | if ( !keyRegisterList.isEmpty() && ke->simpleData.keycode !=0 && press) { | 446 | if ( !keyRegisterList.isEmpty() && ke->simpleData.keycode !=0 && press) { |
451 | // qDebug("<<<<<<<<<<<<<keycode %d", ke->simpleData.keycode); | 447 | // qDebug("<<<<<<<<<<<<<keycode %d", ke->simpleData.keycode); |
452 | KeyRegisterList::Iterator it; | 448 | KeyRegisterList::Iterator it; |
453 | for ( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { | 449 | for ( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { |
454 | if ( ( *it ).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() ) { | 450 | if ( ( *it ).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() ) { |
455 | if ( press ) | 451 | if ( press ) |
456 | qDebug( "press" ); | 452 | qDebug( "press" ); |
457 | else | 453 | else |
458 | qDebug( "release" ); | 454 | qDebug( "release" ); |
459 | QCopEnvelope( ( *it ).getChannel().utf8(), ( *it ).getMessage().utf8() ); | 455 | QCopEnvelope( ( *it ).getChannel().utf8(), ( *it ).getMessage().utf8() ); |
460 | } | 456 | } |
461 | } | 457 | } |
462 | } | 458 | } |
463 | 459 | ||
464 | if ( !keyboardGrabbed() ) { | 460 | if ( !keyboardGrabbed() ) { |
465 | if ( ke->simpleData.keycode == Key_F9 ) { | 461 | if ( ke->simpleData.keycode == Key_F9 ) { |
466 | if ( press ) | 462 | if ( press ) |
467 | emit datebook(); | 463 | emit datebook(); |
468 | return TRUE; | 464 | return TRUE; |
469 | } | 465 | } |
470 | if ( ke->simpleData.keycode == Key_F10 ) { | 466 | if ( ke->simpleData.keycode == Key_F10 ) { |
471 | if ( !press && cardSendTimer ) { | 467 | if ( !press && cardSendTimer ) { |
472 | emit contacts(); | 468 | emit contacts(); |
473 | delete cardSendTimer; | 469 | delete cardSendTimer; |
474 | } | 470 | } |
475 | else if ( press ) { | 471 | else if ( press ) { |
476 | cardSendTimer = new QTimer(); | 472 | cardSendTimer = new QTimer(); |
477 | cardSendTimer->start( 2000, TRUE ); | 473 | cardSendTimer->start( 2000, TRUE ); |
478 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); | 474 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); |
479 | } | 475 | } |
480 | return TRUE; | 476 | return TRUE; |
481 | } | 477 | } |
482 | /* menu key now opens application menu/toolbar | 478 | /* menu key now opens application menu/toolbar |
483 | if ( ke->simpleData.keycode == Key_F11 ) { | 479 | if ( ke->simpleData.keycode == Key_F11 ) { |
484 | if ( press ) emit menu(); | 480 | if ( press ) emit menu(); |
485 | return TRUE; | 481 | return TRUE; |
486 | } | 482 | } |
487 | */ | 483 | */ |
488 | if ( ke->simpleData.keycode == Key_F12 ) { | 484 | if ( ke->simpleData.keycode == Key_F12 ) { |
489 | while ( activePopupWidget() ) | 485 | while ( activePopupWidget() ) |
490 | activePopupWidget() ->close(); | 486 | activePopupWidget() ->close(); |
491 | if ( press ) | 487 | if ( press ) |
492 | emit launch(); | 488 | emit launch(); |
493 | return TRUE; | 489 | return TRUE; |
494 | } | 490 | } |
495 | if ( ke->simpleData.keycode == Key_F13 ) { | 491 | if ( ke->simpleData.keycode == Key_F13 ) { |
496 | if ( press ) | 492 | if ( press ) |
497 | emit email(); | 493 | emit email(); |
498 | return TRUE; | 494 | return TRUE; |
499 | } | 495 | } |
500 | } | 496 | } |
501 | 497 | ||
502 | if ( ke->simpleData.keycode == Key_F34 ) { | 498 | if ( ke->simpleData.keycode == Key_F34 ) { |
503 | if ( press ) | 499 | if ( press ) |
504 | emit power(); | 500 | emit power(); |
505 | return TRUE; | 501 | return TRUE; |
506 | } | 502 | } |
507 | // This was used for the iPAQ PowerButton | 503 | // This was used for the iPAQ PowerButton |
508 | // See main.cpp for new KeyboardFilter | 504 | // See main.cpp for new KeyboardFilter |
509 | // | 505 | // |
510 | // if ( ke->simpleData.keycode == Key_SysReq ) { | 506 | // if ( ke->simpleData.keycode == Key_SysReq ) { |
511 | // if ( press ) emit power(); | 507 | // if ( press ) emit power(); |
512 | // return TRUE; | 508 | // return TRUE; |
513 | // } | 509 | // } |
514 | if ( ke->simpleData.keycode == Key_F35 ) { | 510 | if ( ke->simpleData.keycode == Key_F35 ) { |
515 | if ( press ) | 511 | if ( press ) |
516 | emit backlight(); | 512 | emit backlight(); |
517 | return TRUE; | 513 | return TRUE; |
518 | } | 514 | } |
519 | if ( ke->simpleData.keycode == Key_F32 ) { | 515 | if ( ke->simpleData.keycode == Key_F32 ) { |
520 | if ( press ) | 516 | if ( press ) |
521 | QCopEnvelope e( "QPE/Desktop", "startSync()" ); | 517 | QCopEnvelope e( "QPE/Desktop", "startSync()" ); |
522 | return TRUE; | 518 | return TRUE; |
523 | } | 519 | } |
524 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { | 520 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { |
525 | if ( press ) | 521 | if ( press ) |
526 | emit symbol(); | 522 | emit symbol(); |
527 | return TRUE; | 523 | return TRUE; |
528 | } | 524 | } |
529 | if ( ke->simpleData.keycode == Key_NumLock ) { | 525 | if ( ke->simpleData.keycode == Key_NumLock ) { |
530 | if ( press ) | 526 | if ( press ) |
531 | emit numLockStateToggle(); | 527 | emit numLockStateToggle(); |
532 | } | 528 | } |
533 | if ( ke->simpleData.keycode == Key_CapsLock ) { | 529 | if ( ke->simpleData.keycode == Key_CapsLock ) { |
534 | if ( press ) | 530 | if ( press ) |
535 | emit capsLockStateToggle(); | 531 | emit capsLockStateToggle(); |
536 | } | 532 | } |
537 | if ( ( press && !autoRepeat ) || ( !press && autoRepeat ) ) | 533 | if ( ( press && !autoRepeat ) || ( !press && autoRepeat ) ) |
538 | qpedesktop->keyClick(); | 534 | qpedesktop->keyClick(); |
539 | } | 535 | } |
540 | else { | 536 | else { |
541 | if ( e->type == QWSEvent::Mouse ) { | 537 | if ( e->type == QWSEvent::Mouse ) { |
542 | QWSMouseEvent * me = ( QWSMouseEvent * ) e; | 538 | QWSMouseEvent * me = ( QWSMouseEvent * ) e; |
543 | static bool up = TRUE; | 539 | static bool up = TRUE; |
544 | if ( me->simpleData.state & LeftButton ) { | 540 | if ( me->simpleData.state & LeftButton ) { |
545 | if ( up ) { | 541 | if ( up ) { |
546 | up = FALSE; | 542 | up = FALSE; |
547 | qpedesktop->screenClick(); | 543 | qpedesktop->screenClick(); |
548 | } | 544 | } |
549 | } | 545 | } |
550 | else { | 546 | else { |
551 | up = TRUE; | 547 | up = TRUE; |
552 | } | 548 | } |
553 | } | 549 | } |
554 | } | 550 | } |
555 | 551 | ||
556 | return QPEApplication::qwsEventFilter( e ); | 552 | return QPEApplication::qwsEventFilter( e ); |
557 | } | 553 | } |
558 | #endif | 554 | #endif |
559 | 555 | ||
560 | void DesktopApplication::psTimeout() | 556 | void DesktopApplication::psTimeout() |
561 | { | 557 | { |
562 | qpedesktop->checkMemory(); // in case no events are being generated | 558 | qpedesktop->checkMemory(); // in case no events are being generated |
563 | 559 | ||
564 | *ps = PowerStatusManager::readStatus(); | 560 | *ps = PowerStatusManager::readStatus(); |
565 | 561 | ||
566 | if ( ( ps->batteryStatus() == PowerStatus::VeryLow ) ) { | 562 | if ( ( ps->batteryStatus() == PowerStatus::VeryLow ) ) { |
567 | pa->alert( tr( "Battery is running very low." ), 6 ); | 563 | pa->alert( tr( "Battery is running very low." ), 6 ); |
568 | } | 564 | } |
569 | 565 | ||
570 | if ( ps->batteryStatus() == PowerStatus::Critical ) { | 566 | if ( ps->batteryStatus() == PowerStatus::Critical ) { |
571 | pa->alert( tr( "Battery level is critical!\n" | 567 | pa->alert( tr( "Battery level is critical!\n" |
572 | "Keep power off until power restored!" ), 1 ); | 568 | "Keep power off until power restored!" ), 1 ); |
573 | } | 569 | } |
574 | 570 | ||
575 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { | 571 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { |
576 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); | 572 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); |
577 | } | 573 | } |
578 | } | 574 | } |
579 | 575 | ||
580 | 576 | ||
581 | void DesktopApplication::sendCard() | 577 | void DesktopApplication::sendCard() |
582 | { | 578 | { |
583 | delete cardSendTimer; | 579 | delete cardSendTimer; |
584 | cardSendTimer = 0; | 580 | cardSendTimer = 0; |
585 | QString card = getenv( "HOME" ); | 581 | QString card = getenv( "HOME" ); |
586 | card += "/Applications/addressbook/businesscard.vcf"; | 582 | card += "/Applications/addressbook/businesscard.vcf"; |
587 | 583 | ||
588 | if ( QFile::exists( card ) ) { | 584 | if ( QFile::exists( card ) ) { |
589 | QCopEnvelope e( "QPE/Obex", "send(QString,QString,QString)" ); | 585 | QCopEnvelope e( "QPE/Obex", "send(QString,QString,QString)" ); |
590 | QString mimetype = "text/x-vCard"; | 586 | QString mimetype = "text/x-vCard"; |
591 | e << tr( "business card" ) << card << mimetype; | 587 | e << tr( "business card" ) << card << mimetype; |
592 | } | 588 | } |
593 | } | 589 | } |
594 | 590 | ||
595 | #if defined(QPE_HAVE_MEMALERTER) | 591 | #if defined(QPE_HAVE_MEMALERTER) |
596 | QPE_MEMALERTER_IMPL | 592 | QPE_MEMALERTER_IMPL |
597 | #endif | 593 | #endif |
598 | 594 | ||
599 | //=========================================================================== | 595 | //=========================================================================== |
600 | 596 | ||
601 | Desktop::Desktop() : | 597 | Desktop::Desktop() : |
602 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), | 598 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), |
603 | qcopBridge( 0 ), | 599 | qcopBridge( 0 ), |
604 | transferServer( 0 ), | 600 | transferServer( 0 ), |
605 | packageSlave( 0 ) | 601 | packageSlave( 0 ) |
606 | { | 602 | { |
607 | qpedesktop = this; | 603 | qpedesktop = this; |
608 | 604 | ||
609 | // bg = new Info( this ); | 605 | // bg = new Info( this ); |
610 | tb = new TaskBar; | 606 | tb = new TaskBar; |
611 | 607 | ||
612 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); | 608 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); |
613 | 609 | ||
614 | connect( launcher, SIGNAL( busy() ), tb, SLOT( startWait() ) ); | 610 | connect( launcher, SIGNAL( busy() ), tb, SLOT( startWait() ) ); |
615 | connect( launcher, SIGNAL( notBusy( const QString& ) ), tb, SLOT( stopWait( const QString& ) ) ); | 611 | connect( launcher, SIGNAL( notBusy( const QString& ) ), tb, SLOT( stopWait( const QString& ) ) ); |
616 | 612 | ||
617 | int displayw = qApp->desktop() ->width(); | 613 | int displayw = qApp->desktop() ->width(); |
618 | int displayh = qApp->desktop() ->height(); | 614 | int displayh = qApp->desktop() ->height(); |
619 | 615 | ||
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp index a5955a4..5a9ee1b 100644 --- a/core/launcher/launcher.cpp +++ b/core/launcher/launcher.cpp | |||
@@ -435,385 +435,385 @@ void CategoryTabBar::layoutTabs() | |||
435 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 435 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
436 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 436 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
437 | } | 437 | } |
438 | int h = QMAX( fm.height(), ih ); | 438 | int h = QMAX( fm.height(), ih ); |
439 | h = QMAX( h, QApplication::globalStrut().height() ); | 439 | h = QMAX( h, QApplication::globalStrut().height() ); |
440 | 440 | ||
441 | h += vframe; | 441 | h += vframe; |
442 | w += hframe; | 442 | w += hframe; |
443 | 443 | ||
444 | QRect tr(x, 0, | 444 | QRect tr(x, 0, |
445 | mode == Even ? eventabwidth : w * (width()-1)/required, h); | 445 | mode == Even ? eventabwidth : w * (width()-1)/required, h); |
446 | t->setRect(tr); | 446 | t->setRect(tr); |
447 | x += tr.width() - overlap; | 447 | x += tr.width() - overlap; |
448 | r = r.unite(tr); | 448 | r = r.unite(tr); |
449 | } else if ( i != middleTab ) { | 449 | } else if ( i != middleTab ) { |
450 | int w = hiddenTabWidth; | 450 | int w = hiddenTabWidth; |
451 | int ih = 0; | 451 | int ih = 0; |
452 | if ( t->iconSet() != 0 ) { | 452 | if ( t->iconSet() != 0 ) { |
453 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 453 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
454 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 454 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
455 | } | 455 | } |
456 | int h = QMAX( fm.height(), ih ); | 456 | int h = QMAX( fm.height(), ih ); |
457 | h = QMAX( h, QApplication::globalStrut().height() ); | 457 | h = QMAX( h, QApplication::globalStrut().height() ); |
458 | 458 | ||
459 | h += vframe; | 459 | h += vframe; |
460 | w += hframe; | 460 | w += hframe; |
461 | 461 | ||
462 | t->setRect( QRect(x, 0, w, h) ); | 462 | t->setRect( QRect(x, 0, w, h) ); |
463 | x += t->rect().width() - overlap; | 463 | x += t->rect().width() - overlap; |
464 | r = r.unite( t->rect() ); | 464 | r = r.unite( t->rect() ); |
465 | } else { | 465 | } else { |
466 | int ih = 0; | 466 | int ih = 0; |
467 | if ( t->iconSet() != 0 ) { | 467 | if ( t->iconSet() != 0 ) { |
468 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 468 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
469 | } | 469 | } |
470 | int h = QMAX( fm.height(), ih ); | 470 | int h = QMAX( fm.height(), ih ); |
471 | h = QMAX( h, QApplication::globalStrut().height() ); | 471 | h = QMAX( h, QApplication::globalStrut().height() ); |
472 | 472 | ||
473 | h += vframe; | 473 | h += vframe; |
474 | 474 | ||
475 | t->setRect( QRect(x, 0, available, h) ); | 475 | t->setRect( QRect(x, 0, available, h) ); |
476 | x += t->rect().width() - overlap; | 476 | x += t->rect().width() - overlap; |
477 | r = r.unite( t->rect() ); | 477 | r = r.unite( t->rect() ); |
478 | } | 478 | } |
479 | } | 479 | } |
480 | 480 | ||
481 | QRect rr = tab(count()-1)->rect(); | 481 | QRect rr = tab(count()-1)->rect(); |
482 | rr.setRight(width()-1); | 482 | rr.setRight(width()-1); |
483 | tab(count()-1)->setRect( rr ); | 483 | tab(count()-1)->setRect( rr ); |
484 | 484 | ||
485 | for ( t = tabList()->first(); t; t = tabList()->next() ) { | 485 | for ( t = tabList()->first(); t; t = tabList()->next() ) { |
486 | QRect tr = t->rect(); | 486 | QRect tr = t->rect(); |
487 | tr.setHeight( r.height() ); | 487 | tr.setHeight( r.height() ); |
488 | t->setRect( tr ); | 488 | t->setRect( tr ); |
489 | } | 489 | } |
490 | 490 | ||
491 | update(); | 491 | update(); |
492 | } | 492 | } |
493 | 493 | ||
494 | 494 | ||
495 | void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const | 495 | void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const |
496 | { | 496 | { |
497 | CategoryTabBar *that = (CategoryTabBar *) this; | 497 | CategoryTabBar *that = (CategoryTabBar *) this; |
498 | CategoryTab *ct = (CategoryTab *)t; | 498 | CategoryTab *ct = (CategoryTab *)t; |
499 | QPalette pal = palette(); | 499 | QPalette pal = palette(); |
500 | bool setPal = FALSE; | 500 | bool setPal = FALSE; |
501 | if ( ct->bgColor.isValid() ) { | 501 | if ( ct->bgColor.isValid() ) { |
502 | pal.setColor( QPalette::Active, QColorGroup::Background, ct->bgColor ); | 502 | pal.setColor( QPalette::Active, QColorGroup::Background, ct->bgColor ); |
503 | pal.setColor( QPalette::Active, QColorGroup::Button, ct->bgColor ); | 503 | pal.setColor( QPalette::Active, QColorGroup::Button, ct->bgColor ); |
504 | pal.setColor( QPalette::Inactive, QColorGroup::Background, ct->bgColor ); | 504 | pal.setColor( QPalette::Inactive, QColorGroup::Background, ct->bgColor ); |
505 | pal.setColor( QPalette::Inactive, QColorGroup::Button, ct->bgColor ); | 505 | pal.setColor( QPalette::Inactive, QColorGroup::Button, ct->bgColor ); |
506 | that->setUpdatesEnabled( FALSE ); | 506 | that->setUpdatesEnabled( FALSE ); |
507 | that->setPalette( pal ); | 507 | that->setPalette( pal ); |
508 | setPal = TRUE; | 508 | setPal = TRUE; |
509 | } | 509 | } |
510 | #if QT_VERSION >= 300 | 510 | #if QT_VERSION >= 300 |
511 | QStyle::SFlags flags = QStyle::Style_Default; | 511 | QStyle::SFlags flags = QStyle::Style_Default; |
512 | if ( selected ) | 512 | if ( selected ) |
513 | flags |= QStyle::Style_Selected; | 513 | flags |= QStyle::Style_Selected; |
514 | style().drawControl( QStyle::CE_TabBarTab, p, this, t->rect(), | 514 | style().drawControl( QStyle::CE_TabBarTab, p, this, t->rect(), |
515 | colorGroup(), flags, QStyleOption(t) ); | 515 | colorGroup(), flags, QStyleOption(t) ); |
516 | #else | 516 | #else |
517 | style().drawTab( p, this, t, selected ); | 517 | style().drawTab( p, this, t, selected ); |
518 | #endif | 518 | #endif |
519 | 519 | ||
520 | QRect r( t->rect() ); | 520 | QRect r( t->rect() ); |
521 | QFont f( font() ); | 521 | QFont f( font() ); |
522 | if ( selected ) | 522 | if ( selected ) |
523 | f.setBold( TRUE ); | 523 | f.setBold( TRUE ); |
524 | p->setFont( f ); | 524 | p->setFont( f ); |
525 | 525 | ||
526 | if ( ct->fgColor.isValid() ) { | 526 | if ( ct->fgColor.isValid() ) { |
527 | pal.setColor( QPalette::Active, QColorGroup::Foreground, ct->fgColor ); | 527 | pal.setColor( QPalette::Active, QColorGroup::Foreground, ct->fgColor ); |
528 | pal.setColor( QPalette::Inactive, QColorGroup::Foreground, ct->fgColor ); | 528 | pal.setColor( QPalette::Inactive, QColorGroup::Foreground, ct->fgColor ); |
529 | that->setUpdatesEnabled( FALSE ); | 529 | that->setUpdatesEnabled( FALSE ); |
530 | that->setPalette( pal ); | 530 | that->setPalette( pal ); |
531 | setPal = TRUE; | 531 | setPal = TRUE; |
532 | } | 532 | } |
533 | int iw = 0; | 533 | int iw = 0; |
534 | int ih = 0; | 534 | int ih = 0; |
535 | if ( t->iconSet() != 0 ) { | 535 | if ( t->iconSet() != 0 ) { |
536 | iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; | 536 | iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; |
537 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 537 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
538 | } | 538 | } |
539 | int w = iw + p->fontMetrics().width( t->text() ) + 4; | 539 | int w = iw + p->fontMetrics().width( t->text() ) + 4; |
540 | int h = QMAX(p->fontMetrics().height() + 4, ih ); | 540 | int h = QMAX(p->fontMetrics().height() + 4, ih ); |
541 | paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, | 541 | paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, |
542 | r.top() + (r.height()-h)/2, w, h ), t, | 542 | r.top() + (r.height()-h)/2, w, h ), t, |
543 | #if QT_VERSION >= 300 | 543 | #if QT_VERSION >= 300 |
544 | t->identifier() == keyboardFocusTab() | 544 | t->identifier() == keyboardFocusTab() |
545 | #else | 545 | #else |
546 | t->identitifer() == keyboardFocusTab() | 546 | t->identitifer() == keyboardFocusTab() |
547 | #endif | 547 | #endif |
548 | ); | 548 | ); |
549 | if ( setPal ) { | 549 | if ( setPal ) { |
550 | that->unsetPalette(); | 550 | that->unsetPalette(); |
551 | that->setUpdatesEnabled( TRUE ); | 551 | that->setUpdatesEnabled( TRUE ); |
552 | } | 552 | } |
553 | } | 553 | } |
554 | 554 | ||
555 | 555 | ||
556 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, | 556 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, |
557 | QTab* t, bool has_focus ) const | 557 | QTab* t, bool has_focus ) const |
558 | { | 558 | { |
559 | QRect r = t->rect(); | 559 | QRect r = t->rect(); |
560 | // if ( t->id != currentTab() ) | 560 | // if ( t->id != currentTab() ) |
561 | //r.moveBy( 1, 1 ); | 561 | //r.moveBy( 1, 1 ); |
562 | // | 562 | // |
563 | if ( t->iconSet() ) { | 563 | if ( t->iconSet() ) { |
564 | // the tab has an iconset, draw it in the right mode | 564 | // the tab has an iconset, draw it in the right mode |
565 | QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; | 565 | QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; |
566 | if ( mode == QIconSet::Normal && has_focus ) | 566 | if ( mode == QIconSet::Normal && has_focus ) |
567 | mode = QIconSet::Active; | 567 | mode = QIconSet::Active; |
568 | QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); | 568 | QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); |
569 | int pixw = pixmap.width(); | 569 | int pixw = pixmap.width(); |
570 | int pixh = pixmap.height(); | 570 | int pixh = pixmap.height(); |
571 | p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); | 571 | p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); |
572 | r.setLeft( r.left() + pixw + 5 ); | 572 | r.setLeft( r.left() + pixw + 5 ); |
573 | } | 573 | } |
574 | 574 | ||
575 | QRect tr = r; | 575 | QRect tr = r; |
576 | 576 | ||
577 | if ( r.width() < 20 ) | 577 | if ( r.width() < 20 ) |
578 | return; | 578 | return; |
579 | 579 | ||
580 | if ( t->isEnabled() && isEnabled() ) { | 580 | if ( t->isEnabled() && isEnabled() ) { |
581 | #if defined(_WS_WIN32_) | 581 | #if defined(_WS_WIN32_) |
582 | if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) | 582 | if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) |
583 | p->setPen( colorGroup().buttonText() ); | 583 | p->setPen( colorGroup().buttonText() ); |
584 | else | 584 | else |
585 | p->setPen( colorGroup().foreground() ); | 585 | p->setPen( colorGroup().foreground() ); |
586 | #else | 586 | #else |
587 | p->setPen( colorGroup().foreground() ); | 587 | p->setPen( colorGroup().foreground() ); |
588 | #endif | 588 | #endif |
589 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); | 589 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); |
590 | } else { | 590 | } else { |
591 | p->setPen( palette().disabled().foreground() ); | 591 | p->setPen( palette().disabled().foreground() ); |
592 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); | 592 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); |
593 | } | 593 | } |
594 | } | 594 | } |
595 | 595 | ||
596 | //--------------------------------------------------------------------------- | 596 | //--------------------------------------------------------------------------- |
597 | 597 | ||
598 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) | 598 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) |
599 | : QMainWindow( parent, name, fl ) | 599 | : QMainWindow( parent, name, fl ) |
600 | { | 600 | { |
601 | setCaption( tr("Launcher") ); | 601 | setCaption( tr("Launcher") ); |
602 | 602 | ||
603 | syncDialog = 0; | 603 | syncDialog = 0; |
604 | 604 | ||
605 | // we have a pretty good idea how big we'll be | 605 | // we have a pretty good idea how big we'll be |
606 | setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); | 606 | setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); |
607 | 607 | ||
608 | tabs = 0; | 608 | tabs = 0; |
609 | rootFolder = 0; | 609 | rootFolder = 0; |
610 | docsFolder = 0; | 610 | docsFolder = 0; |
611 | 611 | ||
612 | int stamp = uidgen.generate(); // this is our timestamp to see which devices we know | 612 | int stamp = uidgen.generate(); // this is our timestamp to see which devices we know |
613 | //uidgen.store( stamp ); | 613 | //uidgen.store( stamp ); |
614 | m_timeStamp = QString::number( stamp ); | 614 | m_timeStamp = QString::number( stamp ); |
615 | 615 | ||
616 | tabs = new CategoryTabWidget( this ); | 616 | tabs = new CategoryTabWidget( this ); |
617 | tabs->setMaximumWidth( qApp->desktop()->width() ); | 617 | tabs->setMaximumWidth( qApp->desktop()->width() ); |
618 | setCentralWidget( tabs ); | 618 | setCentralWidget( tabs ); |
619 | 619 | ||
620 | connect( tabs, SIGNAL(selected(const QString&)), | 620 | connect( tabs, SIGNAL(selected(const QString&)), |
621 | this, SLOT(viewSelected(const QString&)) ); | 621 | this, SLOT(viewSelected(const QString&)) ); |
622 | connect( tabs, SIGNAL(clicked(const AppLnk*)), | 622 | connect( tabs, SIGNAL(clicked(const AppLnk*)), |
623 | this, SLOT(select(const AppLnk*))); | 623 | this, SLOT(select(const AppLnk*))); |
624 | connect( tabs, SIGNAL(rightPressed(AppLnk*)), | 624 | connect( tabs, SIGNAL(rightPressed(AppLnk*)), |
625 | this, SLOT(properties(AppLnk*))); | 625 | this, SLOT(properties(AppLnk*))); |
626 | 626 | ||
627 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 627 | #if !defined(QT_NO_COP) |
628 | QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); | 628 | QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); |
629 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 629 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
630 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); | 630 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); |
631 | QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); | 631 | QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); |
632 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 632 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
633 | this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); | 633 | this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); |
634 | #endif | 634 | #endif |
635 | 635 | ||
636 | storage = new StorageInfo( this ); | 636 | storage = new StorageInfo( this ); |
637 | connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); | 637 | connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); |
638 | 638 | ||
639 | updateTabs(); | 639 | updateTabs(); |
640 | 640 | ||
641 | preloadApps(); | 641 | preloadApps(); |
642 | 642 | ||
643 | in_lnk_props = FALSE; | 643 | in_lnk_props = FALSE; |
644 | got_lnk_change = FALSE; | 644 | got_lnk_change = FALSE; |
645 | } | 645 | } |
646 | 646 | ||
647 | Launcher::~Launcher() | 647 | Launcher::~Launcher() |
648 | { | 648 | { |
649 | delete rootFolder; | 649 | delete rootFolder; |
650 | delete docsFolder; | 650 | delete docsFolder; |
651 | } | 651 | } |
652 | 652 | ||
653 | static bool isVisibleWindow(int wid) | 653 | static bool isVisibleWindow(int wid) |
654 | { | 654 | { |
655 | #ifdef QWS | 655 | #ifdef QWS |
656 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 656 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
657 | QWSWindow* w; | 657 | QWSWindow* w; |
658 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { | 658 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { |
659 | if ( w->winId() == wid ) | 659 | if ( w->winId() == wid ) |
660 | return !w->isFullyObscured(); | 660 | return !w->isFullyObscured(); |
661 | } | 661 | } |
662 | #endif | 662 | #endif |
663 | return FALSE; | 663 | return FALSE; |
664 | } | 664 | } |
665 | 665 | ||
666 | void Launcher::showMaximized() | 666 | void Launcher::showMaximized() |
667 | { | 667 | { |
668 | if ( isVisibleWindow( winId() ) ) | 668 | if ( isVisibleWindow( winId() ) ) |
669 | doMaximize(); | 669 | doMaximize(); |
670 | else | 670 | else |
671 | QTimer::singleShot( 20, this, SLOT(doMaximize()) ); | 671 | QTimer::singleShot( 20, this, SLOT(doMaximize()) ); |
672 | } | 672 | } |
673 | 673 | ||
674 | void Launcher::doMaximize() | 674 | void Launcher::doMaximize() |
675 | { | 675 | { |
676 | QMainWindow::showMaximized(); | 676 | QMainWindow::showMaximized(); |
677 | } | 677 | } |
678 | 678 | ||
679 | void Launcher::updateMimeTypes() | 679 | void Launcher::updateMimeTypes() |
680 | { | 680 | { |
681 | MimeType::clear(); | 681 | MimeType::clear(); |
682 | updateMimeTypes(rootFolder); | 682 | updateMimeTypes(rootFolder); |
683 | } | 683 | } |
684 | 684 | ||
685 | void Launcher::updateMimeTypes(AppLnkSet* folder) | 685 | void Launcher::updateMimeTypes(AppLnkSet* folder) |
686 | { | 686 | { |
687 | for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { | 687 | for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { |
688 | AppLnk *app = it.current(); | 688 | AppLnk *app = it.current(); |
689 | if ( app->type() == "Folder" ) // No tr | 689 | if ( app->type() == "Folder" ) // No tr |
690 | updateMimeTypes((AppLnkSet *)app); | 690 | updateMimeTypes((AppLnkSet *)app); |
691 | else { | 691 | else { |
692 | MimeType::registerApp(*app); | 692 | MimeType::registerApp(*app); |
693 | } | 693 | } |
694 | } | 694 | } |
695 | } | 695 | } |
696 | 696 | ||
697 | /** This is a HACK.... | 697 | /** This is a HACK.... |
698 | * Reason: scanning huge mediums, microdirvers for examples | 698 | * Reason: scanning huge mediums, microdirvers for examples |
699 | * consomes time. To avoid that we invented the MediumMountCheck | 699 | * consomes time. To avoid that we invented the MediumMountCheck |
700 | * | 700 | * |
701 | * a) the user globally disabled medium checking. We can ignore | 701 | * a) the user globally disabled medium checking. We can ignore |
702 | * all removable medium | 702 | * all removable medium |
703 | * b) the user enabled medium checking globally and we need to use this mimefilter | 703 | * b) the user enabled medium checking globally and we need to use this mimefilter |
704 | * c) the user enabled medium checking on a per medium bases | 704 | * c) the user enabled medium checking on a per medium bases |
705 | * c1) we already checked and its not ask again turns | 705 | * c1) we already checked and its not ask again turns |
706 | * c2) we need to ask and then apply the mimefilter | 706 | * c2) we need to ask and then apply the mimefilter |
707 | */ | 707 | */ |
708 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: | 708 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: |
709 | { | 709 | { |
710 | delete docsFolder; | 710 | delete docsFolder; |
711 | docsFolder = new DocLnkSet; | 711 | docsFolder = new DocLnkSet; |
712 | 712 | ||
713 | DocLnkSet *tmp = 0; | 713 | DocLnkSet *tmp = 0; |
714 | QString home = QString(getenv("HOME")) + "/Documents"; | 714 | QString home = QString(getenv("HOME")) + "/Documents"; |
715 | tmp = new DocLnkSet( home , QString::null); | 715 | tmp = new DocLnkSet( home , QString::null); |
716 | docsFolder->appendFrom( *tmp ); | 716 | docsFolder->appendFrom( *tmp ); |
717 | delete tmp; | 717 | delete tmp; |
718 | 718 | ||
719 | // RAM documents | 719 | // RAM documents |
720 | StorageInfo storage; | 720 | StorageInfo storage; |
721 | const QList<FileSystem> &fileSystems = storage.fileSystems(); | 721 | const QList<FileSystem> &fileSystems = storage.fileSystems(); |
722 | QListIterator<FileSystem> it ( fileSystems ); | 722 | QListIterator<FileSystem> it ( fileSystems ); |
723 | 723 | ||
724 | for ( ; it.current(); ++it ) { | 724 | for ( ; it.current(); ++it ) { |
725 | if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { | 725 | if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { |
726 | tmp = new DocLnkSet( (*it)->path(), QString::null ); | 726 | tmp = new DocLnkSet( (*it)->path(), QString::null ); |
727 | docsFolder->appendFrom( *tmp ); | 727 | docsFolder->appendFrom( *tmp ); |
728 | delete tmp; | 728 | delete tmp; |
729 | } | 729 | } |
730 | } | 730 | } |
731 | 731 | ||
732 | Config mediumCfg( "medium"); | 732 | Config mediumCfg( "medium"); |
733 | mediumCfg.setGroup("main"); | 733 | mediumCfg.setGroup("main"); |
734 | // a) -zecke we don't want to check | 734 | // a) -zecke we don't want to check |
735 | if(!mediumCfg.readBoolEntry("use", true ) ) | 735 | if(!mediumCfg.readBoolEntry("use", true ) ) |
736 | return; | 736 | return; |
737 | 737 | ||
738 | // find out wich filesystems are new in this round | 738 | // find out wich filesystems are new in this round |
739 | // We will do this by having a timestamp inside each mountpoint | 739 | // We will do this by having a timestamp inside each mountpoint |
740 | // if the current timestamp doesn't match this is a new file system and | 740 | // if the current timestamp doesn't match this is a new file system and |
741 | // come up with our MediumMountGui :) let the hacking begin | 741 | // come up with our MediumMountGui :) let the hacking begin |
742 | int stamp = uidgen.generate(); | 742 | int stamp = uidgen.generate(); |
743 | 743 | ||
744 | QString newStamp = QString::number( stamp ); // generates newtime Stamp | 744 | QString newStamp = QString::number( stamp ); // generates newtime Stamp |
745 | 745 | ||
746 | // b) | 746 | // b) |
747 | if( mediumCfg.readBoolEntry("global", true ) ){ | 747 | if( mediumCfg.readBoolEntry("global", true ) ){ |
748 | QString mime = configToMime(&mediumCfg).join(";"); | 748 | QString mime = configToMime(&mediumCfg).join(";"); |
749 | for( it.toFirst(); it.current(); ++it ){ | 749 | for( it.toFirst(); it.current(); ++it ){ |
750 | if( (*it)->isRemovable() ){ | 750 | if( (*it)->isRemovable() ){ |
751 | tmp = new DocLnkSet( (*it)->path(), mime ); | 751 | tmp = new DocLnkSet( (*it)->path(), mime ); |
752 | docsFolder->appendFrom( *tmp ); | 752 | docsFolder->appendFrom( *tmp ); |
753 | delete tmp; | 753 | delete tmp; |
754 | } | 754 | } |
755 | } // done | 755 | } // done |
756 | return; // save the else | 756 | return; // save the else |
757 | } | 757 | } |
758 | // c) zecke | 758 | // c) zecke |
759 | for ( it.toFirst(); it.current(); ++it ) { | 759 | for ( it.toFirst(); it.current(); ++it ) { |
760 | if ( (*it)->isRemovable() ) { // let's find out if we should search on it | 760 | if ( (*it)->isRemovable() ) { // let's find out if we should search on it |
761 | Config cfg( (*it)->path() + "/.opiestorage.cf", Config::File); | 761 | Config cfg( (*it)->path() + "/.opiestorage.cf", Config::File); |
762 | cfg.setGroup("main"); | 762 | cfg.setGroup("main"); |
763 | QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); | 763 | QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); |
764 | /** This medium is uptodate | 764 | /** This medium is uptodate |
765 | */ | 765 | */ |
766 | if( stamp == m_timeStamp ){ // ok we know this card | 766 | if( stamp == m_timeStamp ){ // ok we know this card |
767 | cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp | 767 | cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp |
768 | // we need to scan the list now. Hopefully the cache will be there | 768 | // we need to scan the list now. Hopefully the cache will be there |
769 | // read the mimetypes from the config and search for documents | 769 | // read the mimetypes from the config and search for documents |
770 | QStringList mimetypes = configToMime( &cfg); | 770 | QStringList mimetypes = configToMime( &cfg); |
771 | tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); | 771 | tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); |
772 | docsFolder->appendFrom( *tmp ); | 772 | docsFolder->appendFrom( *tmp ); |
773 | delete tmp; | 773 | delete tmp; |
774 | 774 | ||
775 | }else{ // come up with the gui cause this a new card | 775 | }else{ // come up with the gui cause this a new card |
776 | MediumMountGui medium(&cfg, (*it)->path() ); | 776 | MediumMountGui medium(&cfg, (*it)->path() ); |
777 | if( medium.check() ){ // we did not ask before or ask again is off | 777 | if( medium.check() ){ // we did not ask before or ask again is off |
778 | /** c2) */ | 778 | /** c2) */ |
779 | if( medium.exec() ){ // he clicked yes so search it | 779 | if( medium.exec() ){ // he clicked yes so search it |
780 | // speicher | 780 | // speicher |
781 | //cfg.read(); // cause of a race we need to reread - fixed | 781 | //cfg.read(); // cause of a race we need to reread - fixed |
782 | cfg.setGroup("main"); | 782 | cfg.setGroup("main"); |
783 | cfg.writeEntry("timestamp", newStamp ); | 783 | cfg.writeEntry("timestamp", newStamp ); |
784 | cfg.write(); | 784 | cfg.write(); |
785 | tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); | 785 | tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); |
786 | docsFolder->appendFrom( *tmp ); | 786 | docsFolder->appendFrom( *tmp ); |
787 | delete tmp; | 787 | delete tmp; |
788 | }// no else | 788 | }// no else |
789 | /** c1) */ | 789 | /** c1) */ |
790 | }else{ // we checked | 790 | }else{ // we checked |
791 | // do something different see what we need to do | 791 | // do something different see what we need to do |
792 | // let's see if we should check the device | 792 | // let's see if we should check the device |
793 | cfg.setGroup("main" ); | 793 | cfg.setGroup("main" ); |
794 | bool check = cfg.readBoolEntry("autocheck", true ); | 794 | bool check = cfg.readBoolEntry("autocheck", true ); |
795 | if( check ){ // find the documents | 795 | if( check ){ // find the documents |
796 | tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); | 796 | tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); |
797 | docsFolder->appendFrom( *tmp ); | 797 | docsFolder->appendFrom( *tmp ); |
798 | delete tmp; | 798 | delete tmp; |
799 | } | 799 | } |
800 | } | 800 | } |
801 | } | 801 | } |
802 | } | 802 | } |
803 | } | 803 | } |
804 | m_timeStamp = newStamp; | 804 | m_timeStamp = newStamp; |
805 | } | 805 | } |
806 | 806 | ||
807 | void Launcher::updateTabs() | 807 | void Launcher::updateTabs() |
808 | { | 808 | { |
809 | MimeType::updateApplications(); // ### reads all applnks twice | 809 | MimeType::updateApplications(); // ### reads all applnks twice |
810 | 810 | ||
811 | delete rootFolder; | 811 | delete rootFolder; |
812 | rootFolder = new AppLnkSet( MimeType::appsFolderName() ); | 812 | rootFolder = new AppLnkSet( MimeType::appsFolderName() ); |
813 | 813 | ||
814 | loadDocs(); | 814 | loadDocs(); |
815 | 815 | ||
816 | tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); | 816 | tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); |
817 | } | 817 | } |
818 | 818 | ||
819 | void Launcher::updateDocs() | 819 | void Launcher::updateDocs() |