summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--library/qpeapplication.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/library/qpeapplication.cpp b/library/qpeapplication.cpp
index 1534b0b..87a9739 100644
--- a/library/qpeapplication.cpp
+++ b/library/qpeapplication.cpp
@@ -224,772 +224,772 @@ int qpe_sysBrightnessSteps()
224 224
225static int& hack(int& i) 225static int& hack(int& i)
226{ 226{
227#if QT_VERSION <= 230 && defined(QT_NO_CODECS) 227#if QT_VERSION <= 230 && defined(QT_NO_CODECS)
228 // These should be created, but aren't in Qt 2.3.0 228 // These should be created, but aren't in Qt 2.3.0
229 (void)new QUtf8Codec; 229 (void)new QUtf8Codec;
230 (void)new QUtf16Codec; 230 (void)new QUtf16Codec;
231#endif 231#endif
232 return i; 232 return i;
233} 233}
234 234
235static bool forced_off = FALSE; 235static bool forced_off = FALSE;
236static int curbl=-1; 236static int curbl=-1;
237 237
238static int backlight() 238static int backlight()
239{ 239{
240 if ( curbl == -1 ) { 240 if ( curbl == -1 ) {
241 // Read from config 241 // Read from config
242 Config config( "qpe" ); 242 Config config( "qpe" );
243 config.setGroup( "Screensaver" ); 243 config.setGroup( "Screensaver" );
244 curbl = config.readNumEntry("Brightness",255); 244 curbl = config.readNumEntry("Brightness",255);
245 } 245 }
246 return curbl; 246 return curbl;
247} 247}
248 248
249static void setBacklight(int bright) 249static void setBacklight(int bright)
250{ 250{
251 if ( bright == -3 ) { 251 if ( bright == -3 ) {
252 // Forced on 252 // Forced on
253 forced_off = FALSE; 253 forced_off = FALSE;
254 bright = -1; 254 bright = -1;
255 } 255 }
256 if ( forced_off && bright != -2 ) 256 if ( forced_off && bright != -2 )
257 return; 257 return;
258 if ( bright == -2 ) { 258 if ( bright == -2 ) {
259 // Toggle between off and on 259 // Toggle between off and on
260 bright = curbl ? 0 : -1; 260 bright = curbl ? 0 : -1;
261 forced_off = !bright; 261 forced_off = !bright;
262 } 262 }
263 if ( bright == -1 ) { 263 if ( bright == -1 ) {
264 // Read from config 264 // Read from config
265 Config config( "qpe" ); 265 Config config( "qpe" );
266 config.setGroup( "Screensaver" ); 266 config.setGroup( "Screensaver" );
267 bright = config.readNumEntry("Brightness",255); 267 bright = config.readNumEntry("Brightness",255);
268 } 268 }
269#if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) 269#if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX)
270 if ( QFile::exists("/usr/bin/bl") ) { 270 if ( QFile::exists("/usr/bin/bl") ) {
271 QString cmd = "/usr/bin/bl 1 "; 271 QString cmd = "/usr/bin/bl 1 ";
272 cmd += bright<=0 ? "0 " : "1 "; 272 cmd += bright<=0 ? "0 " : "1 ";
273 cmd += QString::number(bright); 273 cmd += QString::number(bright);
274 system(cmd.latin1()); 274 system(cmd.latin1());
275#if defined(QT_QWS_EBX) 275#if defined(QT_QWS_EBX)
276 } else if ( QFile::exists("/dev/fl") ) { 276 } else if ( QFile::exists("/dev/fl") ) {
277#define FL_IOCTL_STEP_CONTRAST 100 277#define FL_IOCTL_STEP_CONTRAST 100
278 int fd = open("/dev/fl", O_WRONLY); 278 int fd = open("/dev/fl", O_WRONLY);
279 if (fd >= 0 ) { 279 if (fd >= 0 ) {
280 int steps = qpe_sysBrightnessSteps(); 280 int steps = qpe_sysBrightnessSteps();
281 int bl = ( bright * steps + 127 ) / 255; 281 int bl = ( bright * steps + 127 ) / 255;
282 if ( bright && !bl ) bl = 1; 282 if ( bright && !bl ) bl = 1;
283 bl = ioctl(fd, FL_IOCTL_STEP_CONTRAST, bl); 283 bl = ioctl(fd, FL_IOCTL_STEP_CONTRAST, bl);
284 close(fd); 284 close(fd);
285 } 285 }
286 } 286 }
287#elif defined(QT_QWS_IPAQ) 287#elif defined(QT_QWS_IPAQ)
288 } else if ( QFile::exists("/dev/ts") || QFile::exists("/dev/h3600_ts") ) { 288 } else if ( QFile::exists("/dev/ts") || QFile::exists("/dev/h3600_ts") ) {
289 typedef struct { 289 typedef struct {
290 unsigned char mode; 290 unsigned char mode;
291 unsigned char pwr; 291 unsigned char pwr;
292 unsigned char brightness; 292 unsigned char brightness;
293 } FLITE_IN; 293 } FLITE_IN;
294# ifndef FLITE_ON 294# ifndef FLITE_ON
295# ifndef _LINUX_IOCTL_H 295# ifndef _LINUX_IOCTL_H
296# include <linux/ioctl.h> 296# include <linux/ioctl.h>
297# endif 297# endif
298# define FLITE_ON _IOW('f', 7, FLITE_IN) 298# define FLITE_ON _IOW('f', 7, FLITE_IN)
299# endif 299# endif
300 int fd; 300 int fd;
301 if ( QFile::exists("/dev/ts") ) 301 if ( QFile::exists("/dev/ts") )
302 fd = open("/dev/ts", O_WRONLY); 302 fd = open("/dev/ts", O_WRONLY);
303 else 303 else
304 fd = open("/dev/h3600_ts", O_WRONLY); 304 fd = open("/dev/h3600_ts", O_WRONLY);
305 if (fd >= 0 ) { 305 if (fd >= 0 ) {
306 FLITE_IN bl; 306 FLITE_IN bl;
307 bl.mode = 1; 307 bl.mode = 1;
308 bl.pwr = bright ? 1 : 0; 308 bl.pwr = bright ? 1 : 0;
309 bl.brightness = bright; 309 bl.brightness = bright;
310 ioctl(fd, FLITE_ON, &bl); 310 ioctl(fd, FLITE_ON, &bl);
311 close(fd); 311 close(fd);
312 } 312 }
313 } 313 }
314#endif 314#endif
315#endif 315#endif
316 curbl = bright; 316 curbl = bright;
317} 317}
318 318
319void qpe_setBacklight(int bright) { setBacklight(bright); } 319void qpe_setBacklight(int bright) { setBacklight(bright); }
320 320
321static bool dim_on = FALSE; 321static bool dim_on = FALSE;
322static bool lightoff_on = FALSE; 322static bool lightoff_on = FALSE;
323static int disable_suspend = 100; 323static int disable_suspend = 100;
324 324
325static bool powerOnline() 325static bool powerOnline()
326{ 326{
327 return PowerStatusManager::readStatus().acStatus() == PowerStatus::Online; 327 return PowerStatusManager::readStatus().acStatus() == PowerStatus::Online;
328} 328}
329 329
330static bool networkOnline() 330static bool networkOnline()
331{ 331{
332 return Network::networkOnline(); 332 return Network::networkOnline();
333} 333}
334 334
335class QPEScreenSaver : public QWSScreenSaver 335class QPEScreenSaver : public QWSScreenSaver
336{ 336{
337private: 337private:
338 int LcdOn; 338 int LcdOn;
339 339
340public: 340public:
341 QPEScreenSaver() 341 QPEScreenSaver()
342 { 342 {
343 int fd; 343 int fd;
344 344
345 LcdOn = TRUE; 345 LcdOn = TRUE;
346 // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off) 346 // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off)
347 fd=open("/dev/fb0",O_RDWR); 347 fd=open("/dev/fb0",O_RDWR);
348 if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_NO_BLANKING); close(fd); } 348 if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_NO_BLANKING); close(fd); }
349 } 349 }
350 void restore() 350 void restore()
351 { 351 {
352 if (!LcdOn) // We must have turned it off 352 if (!LcdOn) // We must have turned it off
353 { 353 {
354 int fd; 354 int fd;
355 fd=open("/dev/fb0",O_RDWR); 355 fd=open("/dev/fb0",O_RDWR);
356 if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_NO_BLANKING); close(fd); } 356 if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_NO_BLANKING); close(fd); }
357 } 357 }
358 setBacklight(-1); 358 setBacklight(-1);
359 } 359 }
360 bool save(int level) 360 bool save(int level)
361 { 361 {
362 int fd; 362 int fd;
363 363
364 switch ( level ) { 364 switch ( level ) {
365 case 0: 365 case 0:
366 if ( disable_suspend > 0 && dim_on ) { 366 if ( disable_suspend > 0 && dim_on ) {
367 if (backlight() > 1) 367 if (backlight() > 1)
368 setBacklight(1); // lowest non-off 368 setBacklight(1); // lowest non-off
369 } 369 }
370 return TRUE; 370 return TRUE;
371 break; 371 break;
372 case 1: 372 case 1:
373 if ( disable_suspend > 1 && lightoff_on ) { 373 if ( disable_suspend > 1 && lightoff_on ) {
374 setBacklight(0); // off 374 setBacklight(0); // off
375 } 375 }
376 return TRUE; 376 return TRUE;
377 break; 377 break;
378 case 2: 378 case 2:
379 Config config( "qpe" ); 379 Config config( "qpe" );
380 config.setGroup( "Screensaver" ); 380 config.setGroup( "Screensaver" );
381 if (config.readNumEntry("LcdOffOnly",0) != 0) // We're only turning off the LCD 381 if (config.readNumEntry("LcdOffOnly",0) != 0) // We're only turning off the LCD
382 { 382 {
383 fd=open("/dev/fb0",O_RDWR); 383 fd=open("/dev/fb0",O_RDWR);
384 if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_POWERDOWN); close(fd); } 384 if (fd != -1) { ioctl(fd,FBIOBLANK,VESA_POWERDOWN); close(fd); }
385 LcdOn = FALSE; 385 LcdOn = FALSE;
386 } 386 }
387 else // We're going to suspend the whole machine 387 else // We're going to suspend the whole machine
388 { 388 {
389 if ( disable_suspend > 2 && !powerOnline() && !networkOnline() ) { 389 if ( disable_suspend > 2 && !powerOnline() && !networkOnline() ) {
390 QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); 390 QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE );
391 return TRUE; 391 return TRUE;
392 } 392 }
393 } 393 }
394 break; 394 break;
395 } 395 }
396 return FALSE; 396 return FALSE;
397 } 397 }
398}; 398};
399 399
400static int ssi(int interval, Config &config, const QString &enable, const QString& value, int def) 400static int ssi(int interval, Config &config, const QString &enable, const QString& value, int def)
401{ 401{
402 if ( !enable.isEmpty() && config.readNumEntry(enable,0) == 0 ) 402 if ( !enable.isEmpty() && config.readNumEntry(enable,0) == 0 )
403 return 0; 403 return 0;
404 404
405 if ( interval < 0 ) { 405 if ( interval < 0 ) {
406 // Restore screen blanking and power saving state 406 // Restore screen blanking and power saving state
407 interval = config.readNumEntry( value, def ); 407 interval = config.readNumEntry( value, def );
408 } 408 }
409 return interval; 409 return interval;
410} 410}
411 411
412static void setScreenSaverIntervals(int i1, int i2, int i3) 412static void setScreenSaverIntervals(int i1, int i2, int i3)
413{ 413{
414 Config config( "qpe" ); 414 Config config( "qpe" );
415 config.setGroup( "Screensaver" ); 415 config.setGroup( "Screensaver" );
416 416
417 int v[4]; 417 int v[4];
418 i1 = ssi(i1, config, "Dim","Interval_Dim", 30); 418 i1 = ssi(i1, config, "Dim","Interval_Dim", 30);
419 i2 = ssi(i2, config, "LightOff","Interval_LightOff", 20); 419 i2 = ssi(i2, config, "LightOff","Interval_LightOff", 20);
420 i3 = ssi(i3, config, "","Interval", 60); 420 i3 = ssi(i3, config, "","Interval", 60);
421 421
422 //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); 422 //qDebug("screen saver intervals: %d %d %d", i1, i2, i3);
423 423
424 v[0] = QMAX( 1000*i1, 100); 424 v[0] = QMAX( 1000*i1, 100);
425 v[1] = QMAX( 1000*i2, 100); 425 v[1] = QMAX( 1000*i2, 100);
426 v[2] = QMAX( 1000*i3, 100); 426 v[2] = QMAX( 1000*i3, 100);
427 v[3] = 0; 427 v[3] = 0;
428 dim_on = ( (i1 != 0) ? config.readNumEntry("Dim",1) : FALSE ); 428 dim_on = ( (i1 != 0) ? config.readNumEntry("Dim",1) : FALSE );
429 lightoff_on = ( (i2 != 0 ) ? config.readNumEntry("LightOff",1) : FALSE ); 429 lightoff_on = ( (i2 != 0 ) ? config.readNumEntry("LightOff",1) : FALSE );
430 if ( !i1 && !i2 && !i3 ) 430 if ( !i1 && !i2 && !i3 )
431 QWSServer::setScreenSaverInterval(0); 431 QWSServer::setScreenSaverInterval(0);
432 else 432 else
433 QWSServer::setScreenSaverIntervals(v); 433 QWSServer::setScreenSaverIntervals(v);
434} 434}
435 435
436static void setScreenSaverInterval(int interval) 436static void setScreenSaverInterval(int interval)
437{ 437{
438 setScreenSaverIntervals(-1,-1,interval); 438 setScreenSaverIntervals(-1,-1,interval);
439} 439}
440 440
441 441
442/*! 442/*!
443 \class QPEApplication qpeapplication.h 443 \class QPEApplication qpeapplication.h
444 \brief The QPEApplication class implements various system services 444 \brief The QPEApplication class implements various system services
445 that are available to all Qtopia applications. 445 that are available to all Qtopia applications.
446 446
447 Simply by using QPEApplication instead of QApplication, a plain Qt 447 Simply by using QPEApplication instead of QApplication, a plain Qt
448 application becomes a Qtopia application. It automatically follows 448 application becomes a Qtopia application. It automatically follows
449 style changes, quits and raises, and in the 449 style changes, quits and raises, and in the
450 case of \link docwidget.html document-oriented\endlink applications, 450 case of \link docwidget.html document-oriented\endlink applications,
451 changes the current displayed document in response to the environment. 451 changes the current displayed document in response to the environment.
452*/ 452*/
453 453
454/*! 454/*!
455 \fn void QPEApplication::clientMoused() 455 \fn void QPEApplication::clientMoused()
456 456
457 \internal 457 \internal
458*/ 458*/
459 459
460/*! 460/*!
461 \fn void QPEApplication::timeChanged(); 461 \fn void QPEApplication::timeChanged();
462 462
463 This signal is emitted when the time jumps forward or backwards 463 This signal is emitted when the time jumps forward or backwards
464 by more than the normal passage of time. 464 by more than the normal passage of time.
465*/ 465*/
466 466
467/*! 467/*!
468 \fn void QPEApplication::clockChanged( bool ampm ); 468 \fn void QPEApplication::clockChanged( bool ampm );
469 469
470 This signal is emitted when the user changes the style 470 This signal is emitted when the user changes the style
471 of clock. If \a ampm is TRUE, the user wants a 12-hour 471 of clock. If \a ampm is TRUE, the user wants a 12-hour
472 AM/PM close, otherwise, they want a 24-hour clock. 472 AM/PM close, otherwise, they want a 24-hour clock.
473*/ 473*/
474 474
475/*! 475/*!
476 \fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data ) 476 \fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data )
477 477
478 This signal is emitted when a message is received on the 478 This signal is emitted when a message is received on the
479 QPE/Application/<i>appname</i> QCop channel for this application. 479 QPE/Application/<i>appname</i> QCop channel for this application.
480 480
481 The slot to which you connect this signal uses \a msg and \a data 481 The slot to which you connect this signal uses \a msg and \a data
482 in the following way: 482 in the following way:
483 483
484\code 484\code
485 void MyWidget::receive( const QCString& msg, const QByteArray& data ) 485 void MyWidget::receive( const QCString& msg, const QByteArray& data )
486 { 486 {
487 QDataStream stream( data, IO_ReadOnly ); 487 QDataStream stream( data, IO_ReadOnly );
488 if ( msg == "someMessage(int,int,int)" ) { 488 if ( msg == "someMessage(int,int,int)" ) {
489 int a,b,c; 489 int a,b,c;
490 stream >> a >> b >> c; 490 stream >> a >> b >> c;
491 ... 491 ...
492 } else if ( msg == "otherMessage(QString)" ) { 492 } else if ( msg == "otherMessage(QString)" ) {
493 ... 493 ...
494 } 494 }
495 } 495 }
496\endcode 496\endcode
497 497
498 \sa qcop.html 498 \sa qcop.html
499*/ 499*/
500 500
501/*! 501/*!
502 Constructs a QPEApplication just as you would construct 502 Constructs a QPEApplication just as you would construct
503 a QApplication, passing \a argc, \a argv, and \a t. 503 a QApplication, passing \a argc, \a argv, and \a t.
504*/ 504*/
505QPEApplication::QPEApplication( int& argc, char **argv, Type t ) 505QPEApplication::QPEApplication( int& argc, char **argv, Type t )
506 : QApplication( hack(argc), argv, t ) 506 : QApplication( hack(argc), argv, t )
507{ 507{
508 int dw = desktop()->width(); 508 int dw = desktop()->width();
509 if ( dw < 200 ) { 509 if ( dw < 200 ) {
510// setFont( QFont( "helvetica", 8 ) ); 510// setFont( QFont( "helvetica", 8 ) );
511 AppLnk::setSmallIconSize(10); 511 AppLnk::setSmallIconSize(10);
512 AppLnk::setBigIconSize(28); 512 AppLnk::setBigIconSize(28);
513 } 513 }
514 514
515 d = new QPEApplicationData; 515 d = new QPEApplicationData;
516 QMimeSourceFactory::setDefaultFactory(new ResourceMimeFactory); 516 QMimeSourceFactory::setDefaultFactory(new ResourceMimeFactory);
517 517
518 connect(this, SIGNAL(lastWindowClosed()), this, SLOT(hideOrQuit())); 518 connect(this, SIGNAL(lastWindowClosed()), this, SLOT(hideOrQuit()));
519#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 519#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
520 520
521 QString qcopfn("/tmp/qcop-msg-"); 521 QString qcopfn("/tmp/qcop-msg-");
522 qcopfn += QString(argv[0]); // append command name 522 qcopfn += QString(argv[0]); // append command name
523 523
524 QFile f(qcopfn); 524 QFile f(qcopfn);
525 if ( f.open(IO_ReadOnly) ) { 525 if ( f.open(IO_ReadOnly) ) {
526 flock(f.handle(), LOCK_EX); 526 flock(f.handle(), LOCK_EX);
527 } 527 }
528 528
529 sysChannel = new QCopChannel( "QPE/System", this ); 529 sysChannel = new QCopChannel( "QPE/System", this );
530 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), 530 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)),
531 this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); 531 this, SLOT(systemMessage( const QCString &, const QByteArray &)) );
532 532
533 QCString channel = QCString(argv[0]); 533 QCString channel = QCString(argv[0]);
534 channel.replace(QRegExp(".*/"),""); 534 channel.replace(QRegExp(".*/"),"");
535 d->appName = channel; 535 d->appName = channel;
536 channel = "QPE/Application/" + channel; 536 channel = "QPE/Application/" + channel;
537 pidChannel = new QCopChannel( channel, this); 537 pidChannel = new QCopChannel( channel, this);
538 connect( pidChannel, SIGNAL(received(const QCString &, const QByteArray &)), 538 connect( pidChannel, SIGNAL(received(const QCString &, const QByteArray &)),
539 this, SLOT(pidMessage(const QCString &, const QByteArray &))); 539 this, SLOT(pidMessage(const QCString &, const QByteArray &)));
540 540
541 if ( f.isOpen() ) { 541 if ( f.isOpen() ) {
542 d->keep_running = FALSE; 542 d->keep_running = FALSE;
543 QDataStream ds(&f); 543 QDataStream ds(&f);
544 QCString channel, message; 544 QCString channel, message;
545 QByteArray data; 545 QByteArray data;
546 while(!ds.atEnd()) { 546 while(!ds.atEnd()) {
547 ds >> channel >> message >> data; 547 ds >> channel >> message >> data;
548 d->enqueueQCop(channel,message,data); 548 d->enqueueQCop(channel,message,data);
549 } 549 }
550 550
551 flock(f.handle(), LOCK_UN); 551 flock(f.handle(), LOCK_UN);
552 f.close(); 552 f.close();
553 f.remove(); 553 f.remove();
554 } 554 }
555 555
556 for (int a=0; a<argc; a++) { 556 for (int a=0; a<argc; a++) {
557 if ( qstrcmp(argv[a],"-preload")==0 ) { 557 if ( qstrcmp(argv[a],"-preload")==0 ) {
558 argv[a] = argv[a+1]; 558 argv[a] = argv[a+1];
559 a++; 559 a++;
560 d->preloaded = TRUE; 560 d->preloaded = TRUE;
561 argc-=1; 561 argc-=1;
562 } else if ( qstrcmp(argv[a],"-preload-show")==0 ) { 562 } else if ( qstrcmp(argv[a],"-preload-show")==0 ) {
563 argv[a] = argv[a+1]; 563 argv[a] = argv[a+1];
564 a++; 564 a++;
565 d->preloaded = TRUE; 565 d->preloaded = TRUE;
566 d->forceshow = TRUE; 566 d->forceshow = TRUE;
567 argc-=1; 567 argc-=1;
568 } 568 }
569 } 569 }
570 570
571 /* overide stored arguments */ 571 /* overide stored arguments */
572 setArgs(argc, argv); 572 setArgs(argc, argv);
573 573
574#endif 574#endif
575 575
576 qwsSetDecoration( new QPEDecoration() ); 576 qwsSetDecoration( new QPEDecoration() );
577 577
578#ifndef QT_NO_TRANSLATION 578#ifndef QT_NO_TRANSLATION
579 QStringList langs = Global::languageList(); 579 QStringList langs = Global::languageList();
580 for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) { 580 for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) {
581 QString lang = *it; 581 QString lang = *it;
582 582
583 QTranslator * trans; 583 QTranslator * trans;
584 QString tfn; 584 QString tfn;
585 585
586 trans = new QTranslator(this); 586 trans = new QTranslator(this);
587 tfn = qpeDir()+"/i18n/"+lang+"/libqpe.qm"; 587 tfn = qpeDir()+"/i18n/"+lang+"/libqpe.qm";
588 if ( trans->load( tfn )) 588 if ( trans->load( tfn ))
589 installTranslator( trans ); 589 installTranslator( trans );
590 else 590 else
591 delete trans; 591 delete trans;
592 592
593 trans = new QTranslator(this); 593 trans = new QTranslator(this);
594 tfn = qpeDir()+"/i18n/"+lang+"/"+d->appName+".qm"; 594 tfn = qpeDir()+"/i18n/"+lang+"/"+d->appName+".qm";
595 if ( trans->load( tfn )) 595 if ( trans->load( tfn ))
596 installTranslator( trans ); 596 installTranslator( trans );
597 else 597 else
598 delete trans; 598 delete trans;
599 599
600 //###language/font hack; should look it up somewhere 600 //###language/font hack; should look it up somewhere
601 if ( lang == "ja" || lang == "zh_CN" || lang == "zh_TW" || lang == "ko" ) { 601 if ( lang == "ja" || lang == "zh_CN" || lang == "zh_TW" || lang == "ko" ) {
602 QFont fn = FontManager::unicodeFont( FontManager::Proportional ); 602 QFont fn = FontManager::unicodeFont( FontManager::Proportional );
603 setFont( fn ); 603 setFont( fn );
604 } 604 }
605 else { 605 else {
606 Config config( "qpe" ); 606 Config config( "qpe" );
607 config.setGroup( "Appearance" ); 607 config.setGroup( "Appearance" );
608 QString familyStr = config.readEntry( "FontFamily", "fixed" ); 608 QString familyStr = config.readEntry( "FontFamily", "helvetica" );
609 QString styleStr = config.readEntry( "FontStyle", "Regular" ); 609 QString styleStr = config.readEntry( "FontStyle", "Regular" );
610 QString sizeStr = config.readEntry( "FontSize", "10" ); 610 QString sizeStr = config.readEntry( "FontSize", "10" );
611 QString charSetStr = config.readEntry( "FontCharSet", "iso10646-1" ); 611 QString charSetStr = config.readEntry( "FontCharSet", QString::null );
612 bool ok; 612 bool ok;
613 int i_size = sizeStr.toInt( &ok, 10 ); 613 int i_size = sizeStr.toInt( &ok, 10 );
614 FontDatabase fdb; 614 FontDatabase fdb;
615 QFont selectedFont = fdb.font( familyStr, styleStr, i_size, charSetStr ); 615 QFont selectedFont = fdb.font( familyStr, styleStr, i_size, charSetStr );
616 setFont( selectedFont ); 616 setFont( selectedFont );
617 } 617 }
618 } 618 }
619 619
620#endif 620#endif
621 621
622 applyStyle(); 622 applyStyle();
623 623
624 if ( type() == GuiServer ) { 624 if ( type() == GuiServer ) {
625 setScreenSaverInterval(-1); 625 setScreenSaverInterval(-1);
626 setVolume(); 626 setVolume();
627 QWSServer::setScreenSaver(new QPEScreenSaver); 627 QWSServer::setScreenSaver(new QPEScreenSaver);
628 } 628 }
629 629
630 installEventFilter( this ); 630 installEventFilter( this );
631 631
632 QPEMenuToolFocusManager::initialize(); 632 QPEMenuToolFocusManager::initialize();
633 633
634#ifdef QT_NO_QWS_CURSOR 634#ifdef QT_NO_QWS_CURSOR
635 // if we have no cursor, probably don't want tooltips 635 // if we have no cursor, probably don't want tooltips
636 QToolTip::setEnabled( FALSE ); 636 QToolTip::setEnabled( FALSE );
637#endif 637#endif
638} 638}
639 639
640static QPtrDict<void>* inputMethodDict=0; 640static QPtrDict<void>* inputMethodDict=0;
641static void createInputMethodDict() 641static void createInputMethodDict()
642{ 642{
643 if ( !inputMethodDict ) 643 if ( !inputMethodDict )
644 inputMethodDict = new QPtrDict<void>; 644 inputMethodDict = new QPtrDict<void>;
645} 645}
646 646
647/*! 647/*!
648 Returns the currently set hint to the system as to whether 648 Returns the currently set hint to the system as to whether
649 \a w has any use for text input methods. 649 \a w has any use for text input methods.
650 650
651 \sa setInputMethodHint() 651 \sa setInputMethodHint()
652*/ 652*/
653QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w ) 653QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w )
654{ 654{
655 if ( inputMethodDict && w ) 655 if ( inputMethodDict && w )
656 return (InputMethodHint)(int)inputMethodDict->find(w); 656 return (InputMethodHint)(int)inputMethodDict->find(w);
657 return Normal; 657 return Normal;
658} 658}
659 659
660/*! 660/*!
661 \enum QPEApplication::InputMethodHint 661 \enum QPEApplication::InputMethodHint
662 662
663 \value Normal the application sometimes needs text input (the default). 663 \value Normal the application sometimes needs text input (the default).
664 \value AlwaysOff the application never needs text input. 664 \value AlwaysOff the application never needs text input.
665 \value AlwaysOn the application always needs text input. 665 \value AlwaysOn the application always needs text input.
666*/ 666*/
667 667
668/*! 668/*!
669 Hints to the system that \a w has use for text input methods 669 Hints to the system that \a w has use for text input methods
670 as specified by \a mode. 670 as specified by \a mode.
671 671
672 \sa inputMethodHint() 672 \sa inputMethodHint()
673*/ 673*/
674void QPEApplication::setInputMethodHint( QWidget* w, InputMethodHint mode ) 674void QPEApplication::setInputMethodHint( QWidget* w, InputMethodHint mode )
675{ 675{
676 createInputMethodDict(); 676 createInputMethodDict();
677 if ( mode == Normal ) { 677 if ( mode == Normal ) {
678 inputMethodDict->remove(w); 678 inputMethodDict->remove(w);
679 } else { 679 } else {
680 inputMethodDict->insert(w,(void*)mode); 680 inputMethodDict->insert(w,(void*)mode);
681 } 681 }
682} 682}
683 683
684class HackDialog : public QDialog 684class HackDialog : public QDialog
685{ 685{
686public: 686public:
687 void acceptIt() { accept(); } 687 void acceptIt() { accept(); }
688 void rejectIt() { reject(); } 688 void rejectIt() { reject(); }
689}; 689};
690 690
691 691
692void QPEApplication::mapToDefaultAction( QWSKeyEvent *ke, int key ) 692void QPEApplication::mapToDefaultAction( QWSKeyEvent *ke, int key )
693{ 693{
694 // specialised actions for certain widgets. May want to 694 // specialised actions for certain widgets. May want to
695 // add more stuff here. 695 // add more stuff here.
696 if ( activePopupWidget() && activePopupWidget()->inherits( "QListBox" ) 696 if ( activePopupWidget() && activePopupWidget()->inherits( "QListBox" )
697 && activePopupWidget()->parentWidget() 697 && activePopupWidget()->parentWidget()
698 && activePopupWidget()->parentWidget()->inherits( "QComboBox" ) ) 698 && activePopupWidget()->parentWidget()->inherits( "QComboBox" ) )
699 key = Qt::Key_Return; 699 key = Qt::Key_Return;
700 700
701 if ( activePopupWidget() && activePopupWidget()->inherits( "QPopupMenu" ) ) 701 if ( activePopupWidget() && activePopupWidget()->inherits( "QPopupMenu" ) )
702 key = Qt::Key_Return; 702 key = Qt::Key_Return;
703 703
704 ke->simpleData.keycode = key; 704 ke->simpleData.keycode = key;
705} 705}
706 706
707class HackWidget : public QWidget 707class HackWidget : public QWidget
708{ 708{
709public: 709public:
710 bool needsOk() 710 bool needsOk()
711 { return (getWState() & WState_Reserved1 ); } 711 { return (getWState() & WState_Reserved1 ); }
712}; 712};
713 713
714/*! 714/*!
715 \internal 715 \internal
716*/ 716*/
717bool QPEApplication::qwsEventFilter( QWSEvent *e ) 717bool QPEApplication::qwsEventFilter( QWSEvent *e )
718{ 718{
719 if ( !d->notbusysent && e->type == QWSEvent::Focus ) { 719 if ( !d->notbusysent && e->type == QWSEvent::Focus ) {
720 if ( qApp->type() != QApplication::GuiServer ) { 720 if ( qApp->type() != QApplication::GuiServer ) {
721 QCopEnvelope e("QPE/System", "notBusy(QString)" ); 721 QCopEnvelope e("QPE/System", "notBusy(QString)" );
722 e << d->appName; 722 e << d->appName;
723 } 723 }
724 d->notbusysent=TRUE; 724 d->notbusysent=TRUE;
725 } 725 }
726 if ( type() == GuiServer ) { 726 if ( type() == GuiServer ) {
727 switch ( e->type ) { 727 switch ( e->type ) {
728 case QWSEvent::Mouse: 728 case QWSEvent::Mouse:
729 if ( e->asMouse()->simpleData.state && !QWidget::find(e->window()) ) 729 if ( e->asMouse()->simpleData.state && !QWidget::find(e->window()) )
730 emit clientMoused(); 730 emit clientMoused();
731 } 731 }
732 } 732 }
733 if ( e->type == QWSEvent::Key ) { 733 if ( e->type == QWSEvent::Key ) {
734 if ( d->kbgrabber == 1 ) 734 if ( d->kbgrabber == 1 )
735 return TRUE; 735 return TRUE;
736 QWSKeyEvent *ke = (QWSKeyEvent *)e; 736 QWSKeyEvent *ke = (QWSKeyEvent *)e;
737 if ( ke->simpleData.keycode == Qt::Key_F33 ) { 737 if ( ke->simpleData.keycode == Qt::Key_F33 ) {
738 // Use special "OK" key to press "OK" on top level widgets 738 // Use special "OK" key to press "OK" on top level widgets
739 QWidget *active = activeWindow(); 739 QWidget *active = activeWindow();
740 QWidget *popup = 0; 740 QWidget *popup = 0;
741 if ( active && active->isPopup() ) { 741 if ( active && active->isPopup() ) {
742 popup = active; 742 popup = active;
743 active = active->parentWidget(); 743 active = active->parentWidget();
744 } 744 }
745 if ( active && (int)active->winId() == ke->simpleData.window && 745 if ( active && (int)active->winId() == ke->simpleData.window &&
746 !active->testWFlags( WStyle_Customize|WType_Popup|WType_Desktop )) { 746 !active->testWFlags( WStyle_Customize|WType_Popup|WType_Desktop )) {
747 if ( ke->simpleData.is_press ) { 747 if ( ke->simpleData.is_press ) {
748 if ( popup ) 748 if ( popup )
749 popup->close(); 749 popup->close();
750 if ( active->inherits( "QDialog" ) ) { 750 if ( active->inherits( "QDialog" ) ) {
751 HackDialog *d = (HackDialog *)active; 751 HackDialog *d = (HackDialog *)active;
752 d->acceptIt(); 752 d->acceptIt();
753 return TRUE; 753 return TRUE;
754 } else if ( ((HackWidget *)active)->needsOk() ) { 754 } else if ( ((HackWidget *)active)->needsOk() ) {
755 QSignal s; 755 QSignal s;
756 s.connect( active, SLOT( accept() ) ); 756 s.connect( active, SLOT( accept() ) );
757 s.activate(); 757 s.activate();
758 } else { 758 } else {
759 // do the same as with the select key: Map to the default action of the widget: 759 // do the same as with the select key: Map to the default action of the widget:
760 mapToDefaultAction( ke, Qt::Key_Return ); 760 mapToDefaultAction( ke, Qt::Key_Return );
761 } 761 }
762 } 762 }
763 } 763 }
764 } else if ( ke->simpleData.keycode == Qt::Key_F30 ) { 764 } else if ( ke->simpleData.keycode == Qt::Key_F30 ) {
765 // Use special "select" key to do whatever default action a widget has 765 // Use special "select" key to do whatever default action a widget has
766 mapToDefaultAction( ke, Qt::Key_Space ); 766 mapToDefaultAction( ke, Qt::Key_Space );
767 } else if ( ke->simpleData.keycode == Qt::Key_Escape && 767 } else if ( ke->simpleData.keycode == Qt::Key_Escape &&
768 ke->simpleData.is_press ) { 768 ke->simpleData.is_press ) {
769 // Escape key closes app if focus on toplevel 769 // Escape key closes app if focus on toplevel
770 QWidget *active = activeWindow(); 770 QWidget *active = activeWindow();
771 if ( active && active->testWFlags( WType_TopLevel ) && 771 if ( active && active->testWFlags( WType_TopLevel ) &&
772 (int)active->winId() == ke->simpleData.window && 772 (int)active->winId() == ke->simpleData.window &&
773 !active->testWFlags( WStyle_Dialog|WStyle_Customize|WType_Popup|WType_Desktop )) { 773 !active->testWFlags( WStyle_Dialog|WStyle_Customize|WType_Popup|WType_Desktop )) {
774 if ( active->inherits( "QDialog" ) ) { 774 if ( active->inherits( "QDialog" ) ) {
775 HackDialog *d = (HackDialog *)active; 775 HackDialog *d = (HackDialog *)active;
776 d->rejectIt(); 776 d->rejectIt();
777 return TRUE; 777 return TRUE;
778 } else if ( strcmp( argv()[0], "embeddedkonsole") != 0 ) { 778 } else if ( strcmp( argv()[0], "embeddedkonsole") != 0 ) {
779 active->close(); 779 active->close();
780 } 780 }
781 } 781 }
782 } 782 }
783 783
784#if QT_VERSION < 231 784#if QT_VERSION < 231
785 // Filter out the F4/Launcher key from apps 785 // Filter out the F4/Launcher key from apps
786 // ### The launcher key may not always be F4 on all devices 786 // ### The launcher key may not always be F4 on all devices
787 if ( ((QWSKeyEvent *)e)->simpleData.keycode == Qt::Key_F4 ) 787 if ( ((QWSKeyEvent *)e)->simpleData.keycode == Qt::Key_F4 )
788 return TRUE; 788 return TRUE;
789#endif 789#endif
790 } 790 }
791 if ( e->type == QWSEvent::Focus ) { 791 if ( e->type == QWSEvent::Focus ) {
792 QWSFocusEvent *fe = (QWSFocusEvent*)e; 792 QWSFocusEvent *fe = (QWSFocusEvent*)e;
793 QWidget* nfw = QWidget::find(e->window()); 793 QWidget* nfw = QWidget::find(e->window());
794 if ( !fe->simpleData.get_focus ) { 794 if ( !fe->simpleData.get_focus ) {
795 QWidget *active = activeWindow(); 795 QWidget *active = activeWindow();
796 while ( active && active->isPopup() ) { 796 while ( active && active->isPopup() ) {
797 active->close(); 797 active->close();
798 active = activeWindow(); 798 active = activeWindow();
799 } 799 }
800 if ( !nfw && d->kbgrabber == 2 ) { 800 if ( !nfw && d->kbgrabber == 2 ) {
801 ungrabKeyboard(); 801 ungrabKeyboard();
802 d->kbregrab = TRUE; // want kb back when we're active 802 d->kbregrab = TRUE; // want kb back when we're active
803 } 803 }
804 } else { 804 } else {
805 // make sure our modal widget is ALWAYS on top 805 // make sure our modal widget is ALWAYS on top
806 QWidget *topm = activeModalWidget(); 806 QWidget *topm = activeModalWidget();
807 if ( topm ) { 807 if ( topm ) {
808 topm->raise(); 808 topm->raise();
809 } 809 }
810 if ( d->kbregrab ) { 810 if ( d->kbregrab ) {
811 grabKeyboard(); 811 grabKeyboard();
812 d->kbregrab = FALSE; 812 d->kbregrab = FALSE;
813 } 813 }
814 } 814 }
815 if ( fe->simpleData.get_focus && inputMethodDict ) { 815 if ( fe->simpleData.get_focus && inputMethodDict ) {
816 InputMethodHint m = inputMethodHint( QWidget::find(e->window()) ); 816 InputMethodHint m = inputMethodHint( QWidget::find(e->window()) );
817 if ( m == AlwaysOff ) 817 if ( m == AlwaysOff )
818 Global::hideInputMethod(); 818 Global::hideInputMethod();
819 if ( m == AlwaysOn ) 819 if ( m == AlwaysOn )
820 Global::showInputMethod(); 820 Global::showInputMethod();
821 } 821 }
822 } 822 }
823 return QApplication::qwsEventFilter( e ); 823 return QApplication::qwsEventFilter( e );
824} 824}
825 825
826/*! 826/*!
827 Destroys the QPEApplication. 827 Destroys the QPEApplication.
828*/ 828*/
829QPEApplication::~QPEApplication() 829QPEApplication::~QPEApplication()
830{ 830{
831 ungrabKeyboard(); 831 ungrabKeyboard();
832#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 832#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
833 // Need to delete QCopChannels early, since the display will 833 // Need to delete QCopChannels early, since the display will
834 // be gone by the time we get to ~QObject(). 834 // be gone by the time we get to ~QObject().
835 delete sysChannel; 835 delete sysChannel;
836 delete pidChannel; 836 delete pidChannel;
837#endif 837#endif
838 delete d; 838 delete d;
839} 839}
840 840
841/*! 841/*!
842 Returns <tt>$OPIEDIR/</tt>. 842 Returns <tt>$OPIEDIR/</tt>.
843*/ 843*/
844QString QPEApplication::qpeDir() 844QString QPEApplication::qpeDir()
845{ 845{
846 const char *base = getenv( "OPIEDIR" ); 846 const char *base = getenv( "OPIEDIR" );
847 if ( base ) 847 if ( base )
848 return QString( base ) + "/"; 848 return QString( base ) + "/";
849 849
850 return QString( "../" ); 850 return QString( "../" );
851} 851}
852 852
853/*! 853/*!
854 Returns the user's current Document directory. There is a trailing "/". 854 Returns the user's current Document directory. There is a trailing "/".
855*/ 855*/
856QString QPEApplication::documentDir() 856QString QPEApplication::documentDir()
857{ 857{
858 const char *base = getenv( "HOME" ); 858 const char *base = getenv( "HOME" );
859 if ( base ) 859 if ( base )
860 return QString( base ) + "/Documents/"; 860 return QString( base ) + "/Documents/";
861 861
862 return QString( "../Documents/" ); 862 return QString( "../Documents/" );
863} 863}
864 864
865static int deforient=-1; 865static int deforient=-1;
866 866
867/*! 867/*!
868 \internal 868 \internal
869*/ 869*/
870int QPEApplication::defaultRotation() 870int QPEApplication::defaultRotation()
871{ 871{
872 if ( deforient < 0 ) { 872 if ( deforient < 0 ) {
873 QString d = getenv("QWS_DISPLAY"); 873 QString d = getenv("QWS_DISPLAY");
874 if ( d.contains("Rot90") ) { 874 if ( d.contains("Rot90") ) {
875 deforient = 90; 875 deforient = 90;
876 } else if ( d.contains("Rot180") ) { 876 } else if ( d.contains("Rot180") ) {
877 deforient = 180; 877 deforient = 180;
878 } else if ( d.contains("Rot270") ) { 878 } else if ( d.contains("Rot270") ) {
879 deforient = 270; 879 deforient = 270;
880 } else { 880 } else {
881 deforient=0; 881 deforient=0;
882 } 882 }
883 } 883 }
884 return deforient; 884 return deforient;
885} 885}
886 886
887/*! 887/*!
888 \internal 888 \internal
889*/ 889*/
890void QPEApplication::setDefaultRotation(int r) 890void QPEApplication::setDefaultRotation(int r)
891{ 891{
892 if ( qApp->type() == GuiServer ) { 892 if ( qApp->type() == GuiServer ) {
893 deforient = r; 893 deforient = r;
894 setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(r).latin1(), 1); 894 setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(r).latin1(), 1);
895 } else { 895 } else {
896 QCopEnvelope("QPE/System", "setDefaultRotation(int)") << r; 896 QCopEnvelope("QPE/System", "setDefaultRotation(int)") << r;
897 } 897 }
898} 898}
899 899
900/*! 900/*!
901 \internal 901 \internal
902*/ 902*/
903void QPEApplication::applyStyle() 903void QPEApplication::applyStyle()
904{ 904{
905 Config config( "qpe" ); 905 Config config( "qpe" );
906 906
907 config.setGroup( "Appearance" ); 907 config.setGroup( "Appearance" );
908 908
909 // Widget style 909 // Widget style
910 QString style = config.readEntry( "Style", "Light" ); 910 QString style = config.readEntry( "Style", "Light" );
911 internalSetStyle( style ); 911 internalSetStyle( style );
912 912
913 // Colors 913 // Colors
914 QColor bgcolor( config.readEntry( "Background", "#E5E1D5" ) ); 914 QColor bgcolor( config.readEntry( "Background", "#E5E1D5" ) );
915 QColor btncolor( config.readEntry( "Button", "#D6CDBB" ) ); 915 QColor btncolor( config.readEntry( "Button", "#D6CDBB" ) );
916 QPalette pal( btncolor, bgcolor ); 916 QPalette pal( btncolor, bgcolor );
917 QString color = config.readEntry( "Highlight", "#800000" ); 917 QString color = config.readEntry( "Highlight", "#800000" );
918 pal.setColor( QColorGroup::Highlight, QColor(color) ); 918 pal.setColor( QColorGroup::Highlight, QColor(color) );
919 color = config.readEntry( "HighlightedText", "#FFFFFF" ); 919 color = config.readEntry( "HighlightedText", "#FFFFFF" );
920 pal.setColor( QColorGroup::HighlightedText, QColor(color) ); 920 pal.setColor( QColorGroup::HighlightedText, QColor(color) );
921 color = config.readEntry( "Text", "#000000" ); 921 color = config.readEntry( "Text", "#000000" );
922 pal.setColor( QColorGroup::Text, QColor(color) ); 922 pal.setColor( QColorGroup::Text, QColor(color) );
923 color = config.readEntry( "ButtonText", "#000000" ); 923 color = config.readEntry( "ButtonText", "#000000" );
924 pal.setColor( QPalette::Active, QColorGroup::ButtonText, QColor(color) ); 924 pal.setColor( QPalette::Active, QColorGroup::ButtonText, QColor(color) );
925 color = config.readEntry( "Base", "#FFFFFF" ); 925 color = config.readEntry( "Base", "#FFFFFF" );
926 pal.setColor( QColorGroup::Base, QColor(color) ); 926 pal.setColor( QColorGroup::Base, QColor(color) );
927 927
928 pal.setColor( QPalette::Disabled, QColorGroup::Text, 928 pal.setColor( QPalette::Disabled, QColorGroup::Text,
929 pal.color(QPalette::Active, QColorGroup::Background).dark() ); 929 pal.color(QPalette::Active, QColorGroup::Background).dark() );
930 930
931 setPalette( pal, TRUE ); 931 setPalette( pal, TRUE );
932} 932}
933 933
934void QPEApplication::systemMessage( const QCString &msg, const QByteArray &data) 934void QPEApplication::systemMessage( const QCString &msg, const QByteArray &data)
935{ 935{
936#ifdef Q_WS_QWS 936#ifdef Q_WS_QWS
937 QDataStream stream( data, IO_ReadOnly ); 937 QDataStream stream( data, IO_ReadOnly );
938 if ( msg == "applyStyle()" ) { 938 if ( msg == "applyStyle()" ) {
939 applyStyle(); 939 applyStyle();
940 } else if ( msg == "setScreenSaverInterval(int)" ) { 940 } else if ( msg == "setScreenSaverInterval(int)" ) {
941 if ( type() == GuiServer ) { 941 if ( type() == GuiServer ) {
942 int time; 942 int time;
943 stream >> time; 943 stream >> time;
944 setScreenSaverInterval(time); 944 setScreenSaverInterval(time);
945 } 945 }
946 } else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { 946 } else if ( msg == "setScreenSaverIntervals(int,int,int)" ) {
947 if ( type() == GuiServer ) { 947 if ( type() == GuiServer ) {
948 int t1,t2,t3; 948 int t1,t2,t3;
949 stream >> t1 >> t2 >> t3; 949 stream >> t1 >> t2 >> t3;
950 setScreenSaverIntervals(t1,t2,t3); 950 setScreenSaverIntervals(t1,t2,t3);
951 } 951 }
952 } else if ( msg == "setBacklight(int)" ) { 952 } else if ( msg == "setBacklight(int)" ) {
953 if ( type() == GuiServer ) { 953 if ( type() == GuiServer ) {
954 int bright; 954 int bright;
955 stream >> bright; 955 stream >> bright;
956 setBacklight(bright); 956 setBacklight(bright);
957 } 957 }
958 } else if ( msg == "setDefaultRotation(int)" ) { 958 } else if ( msg == "setDefaultRotation(int)" ) {
959 if ( type() == GuiServer ) { 959 if ( type() == GuiServer ) {
960 int r; 960 int r;
961 stream >> r; 961 stream >> r;
962 setDefaultRotation(r); 962 setDefaultRotation(r);
963 } 963 }
964 } else if ( msg == "shutdown()" ) { 964 } else if ( msg == "shutdown()" ) {
965 if ( type() == GuiServer ) 965 if ( type() == GuiServer )
966 shutdown(); 966 shutdown();
967 } else if ( msg == "quit()" ) { 967 } else if ( msg == "quit()" ) {
968 if ( type() != GuiServer ) 968 if ( type() != GuiServer )
969 tryQuit(); 969 tryQuit();
970 } else if ( msg == "forceQuit()" ) { 970 } else if ( msg == "forceQuit()" ) {
971 if ( type() != GuiServer ) 971 if ( type() != GuiServer )
972 quit(); 972 quit();
973 } else if ( msg == "restart()" ) { 973 } else if ( msg == "restart()" ) {
974 if ( type() == GuiServer ) 974 if ( type() == GuiServer )
975 restart(); 975 restart();
976 } else if ( msg == "grabKeyboard(QString)" ) { 976 } else if ( msg == "grabKeyboard(QString)" ) {
977 QString who; 977 QString who;
978 stream >> who; 978 stream >> who;
979 if ( who.isEmpty() ) 979 if ( who.isEmpty() )
980 d->kbgrabber = 0; 980 d->kbgrabber = 0;
981 else if ( who != d->appName ) 981 else if ( who != d->appName )
982 d->kbgrabber = 1; 982 d->kbgrabber = 1;
983 else 983 else
984 d->kbgrabber = 2; 984 d->kbgrabber = 2;
985 } else if ( msg == "language(QString)" ) { 985 } else if ( msg == "language(QString)" ) {
986 if ( type() == GuiServer ) { 986 if ( type() == GuiServer ) {
987 QString l; 987 QString l;
988 stream >> l; 988 stream >> l;
989 QString cl = getenv("LANG"); 989 QString cl = getenv("LANG");
990 if ( cl != l ) { 990 if ( cl != l ) {
991 if ( l.isNull() ) 991 if ( l.isNull() )
992 unsetenv( "LANG" ); 992 unsetenv( "LANG" );
993 else 993 else
994 setenv( "LANG", l.latin1(), 1 ); 994 setenv( "LANG", l.latin1(), 1 );
995 restart(); 995 restart();