summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/applauncher.cpp69
1 files changed, 39 insertions, 30 deletions
diff --git a/core/launcher/applauncher.cpp b/core/launcher/applauncher.cpp
index 50c1b71..d6f93da 100644
--- a/core/launcher/applauncher.cpp
+++ b/core/launcher/applauncher.cpp
@@ -22,17 +22,17 @@
22#define QTOPIA_INTERNAL_PRELOADACCESS 22#define QTOPIA_INTERNAL_PRELOADACCESS
23#endif 23#endif
24#ifndef QTOPIA_INTERNAL_FILEOPERATIONS 24#ifndef QTOPIA_INTERNAL_FILEOPERATIONS
25#define QTOPIA_INTERNAL_FILEOPERATIONS 25#define QTOPIA_INTERNAL_FILEOPERATIONS
26#endif 26#endif
27#ifndef QTOPIA_PROGRAM_MONITOR 27#ifndef QTOPIA_PROGRAM_MONITOR
28#define QTOPIA_PROGRAM_MONITOR 28#define QTOPIA_PROGRAM_MONITOR
29#endif 29#endif
30#include <qtopia/qpeglobal.h> 30#include <qtopia/global.h>
31 31
32#ifndef Q_OS_WIN32 32#ifndef Q_OS_WIN32
33#include <sys/stat.h> 33#include <sys/stat.h>
34#include <sys/wait.h> 34#include <sys/wait.h>
35#include <sys/file.h> 35#include <sys/file.h>
36#include <unistd.h> 36#include <unistd.h>
37#include <sys/time.h> 37#include <sys/time.h>
38#include <sys/resource.h> 38#include <sys/resource.h>
@@ -56,31 +56,32 @@
56#include <qtopia/qcopenvelope_qws.h> 56#include <qtopia/qcopenvelope_qws.h>
57#include <qtopia/applnk.h> 57#include <qtopia/applnk.h>
58#include <qtopia/qpeapplication.h> 58#include <qtopia/qpeapplication.h>
59#include <qtopia/config.h> 59#include <qtopia/config.h>
60#include <qtopia/global.h> 60#include <qtopia/global.h>
61 61
62#include "applauncher.h" 62#include "applauncher.h"
63#include "documentlist.h" 63#include "documentlist.h"
64#include "launcherglobal.h"
64 65
65const int AppLauncher::RAISE_TIMEOUT_MS = 5000; 66const int AppLauncher::RAISE_TIMEOUT_MS = 5000;
66 67
67//--------------------------------------------------------------------------- 68//---------------------------------------------------------------------------
68 69
69static AppLauncher* appLauncherPtr; 70static AppLauncher* appLauncherPtr;
70 71
71const int appStopEventID = 1290; 72const int appStopEventID = 1290;
72 73
73class AppStoppedEvent : public QCustomEvent 74class AppStoppedEvent : public QCustomEvent
74{ 75{
75public: 76public:
76 AppStoppedEvent(int pid, int status) 77 AppStoppedEvent(int pid, int status)
77 : QCustomEvent( appStopEventID ), mPid(pid), mStatus(status) { } 78 : QCustomEvent( appStopEventID ), mPid(pid), mStatus(status) { }
78 79
79 int pid() { return mPid; } 80 int pid() { return mPid; }
80 int status() { return mStatus; } 81 int status() { return mStatus; }
81 82
82private: 83private:
83 int mPid, mStatus; 84 int mPid, mStatus;
84}; 85};
85 86
86AppLauncher::AppLauncher(QObject *parent, const char *name) 87AppLauncher::AppLauncher(QObject *parent, const char *name)
@@ -91,28 +92,28 @@ AppLauncher::AppLauncher(QObject *parent, const char *name)
91 connect(qwsServer, SIGNAL(removedChannel(const QString&)), this, SLOT(removedQcopChannel(const QString&))); 92 connect(qwsServer, SIGNAL(removedChannel(const QString&)), this, SLOT(removedQcopChannel(const QString&)));
92 QCopChannel* channel = new QCopChannel( "QPE/System", this ); 93 QCopChannel* channel = new QCopChannel( "QPE/System", this );
93 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), 94 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)),
94 this, SLOT(received(const QCString&, const QByteArray&)) ); 95 this, SLOT(received(const QCString&, const QByteArray&)) );
95 96
96 channel = new QCopChannel( "QPE/Server", this ); 97 channel = new QCopChannel( "QPE/Server", this );
97 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), 98 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)),
98 this, SLOT(received(const QCString&, const QByteArray&)) ); 99 this, SLOT(received(const QCString&, const QByteArray&)) );
99 100
100#ifndef Q_OS_WIN32 101#ifndef Q_OS_WIN32
101 signal(SIGCHLD, signalHandler); 102 signal(SIGCHLD, signalHandler);
102#else 103#else
103 runningAppsProc.setAutoDelete( TRUE ); 104 runningAppsProc.setAutoDelete( TRUE );
104#endif 105#endif
105 QString tmp = qApp->argv()[0]; 106 QString tmp = qApp->argv()[0];
106 int pos = tmp.findRev('/'); 107 int pos = tmp.findRev('/');
107 if ( pos > -1 ) 108 if ( pos > -1 )
108 tmp = tmp.mid(++pos); 109 tmp = tmp.mid(++pos);
109 runningApps[::getpid()] = tmp; 110 runningApps[::getpid()] = tmp;
110 111
111 appLauncherPtr = this; 112 appLauncherPtr = this;
112 113
113 QTimer::singleShot( 1000, this, SLOT(createQuickLauncher()) ); 114 QTimer::singleShot( 1000, this, SLOT(createQuickLauncher()) );
114} 115}
115 116
116AppLauncher::~AppLauncher() 117AppLauncher::~AppLauncher()
117{ 118{
118 appLauncherPtr = 0; 119 appLauncherPtr = 0;
@@ -123,17 +124,17 @@ AppLauncher::~AppLauncher()
123 int status; 124 int status;
124 ::kill( qlPid, SIGTERM ); 125 ::kill( qlPid, SIGTERM );
125 waitpid( qlPid, &status, 0 ); 126 waitpid( qlPid, &status, 0 );
126 } 127 }
127} 128}
128 129
129/* We use the QCopChannel of the app as an indicator of when it has been launched 130/* We use the QCopChannel of the app as an indicator of when it has been launched
130 so that we can disable the busy indicators */ 131 so that we can disable the busy indicators */
131void AppLauncher::newQcopChannel(const QString& channelName) 132void AppLauncher::newQcopChannel(const QString& channelName)
132{ 133{
133// qDebug("channel %s added", channelName.data() ); 134// qDebug("channel %s added", channelName.data() );
134 QString prefix("QPE/Application/"); 135 QString prefix("QPE/Application/");
135 if (channelName.startsWith(prefix)) { 136 if (channelName.startsWith(prefix)) {
136 { 137 {
137 QCopEnvelope e("QPE/System", "newChannel(QString)"); 138 QCopEnvelope e("QPE/System", "newChannel(QString)");
138 e << channelName; 139 e << channelName;
139 } 140 }
@@ -146,17 +147,17 @@ void AppLauncher::newQcopChannel(const QString& channelName)
146 } else if (channelName.startsWith("QPE/QuickLauncher-")) { 147 } else if (channelName.startsWith("QPE/QuickLauncher-")) {
147 qDebug("Registered %s", channelName.latin1()); 148 qDebug("Registered %s", channelName.latin1());
148 int pid = channelName.mid(18).toInt(); 149 int pid = channelName.mid(18).toInt();
149 if (pid == qlPid) 150 if (pid == qlPid)
150 qlReady = TRUE; 151 qlReady = TRUE;
151 } 152 }
152} 153}
153 154
154void AppLauncher::removedQcopChannel(const QString& channelName) 155void AppLauncher::removedQcopChannel(const QString& channelName)
155{ 156{
156 if (channelName.startsWith("QPE/Application/")) { 157 if (channelName.startsWith("QPE/Application/")) {
157 QCopEnvelope e("QPE/System", "removedChannel(QString)"); 158 QCopEnvelope e("QPE/System", "removedChannel(QString)");
158 e << channelName; 159 e << channelName;
159 } 160 }
160} 161}
161 162
162void AppLauncher::received(const QCString& msg, const QByteArray& data) 163void AppLauncher::received(const QCString& msg, const QByteArray& data)
@@ -254,17 +255,17 @@ void AppLauncher::signalHandler(int)
254 255
255bool AppLauncher::event(QEvent *e) 256bool AppLauncher::event(QEvent *e)
256{ 257{
257 if ( e->type() == appStopEventID ) { 258 if ( e->type() == appStopEventID ) {
258 AppStoppedEvent *ae = (AppStoppedEvent *) e; 259 AppStoppedEvent *ae = (AppStoppedEvent *) e;
259 sigStopped(ae->pid(), ae->status() ); 260 sigStopped(ae->pid(), ae->status() );
260 return TRUE; 261 return TRUE;
261 } 262 }
262 263
263 return QObject::event(e); 264 return QObject::event(e);
264} 265}
265 266
266void AppLauncher::timerEvent( QTimerEvent *e ) 267void AppLauncher::timerEvent( QTimerEvent *e )
267{ 268{
268 int id = e->timerId(); 269 int id = e->timerId();
269 QMap<QString,int>::Iterator it; 270 QMap<QString,int>::Iterator it;
270 for ( it = waitingHeartbeat.begin(); it != waitingHeartbeat.end(); ++it ) { 271 for ( it = waitingHeartbeat.begin(); it != waitingHeartbeat.end(); ++it ) {
@@ -277,41 +278,41 @@ void AppLauncher::timerEvent( QTimerEvent *e )
277 waitingHeartbeat.remove( it ); 278 waitingHeartbeat.remove( it );
278 279
279 // qDebug("Checking in on %s", appKillerName.latin1()); 280 // qDebug("Checking in on %s", appKillerName.latin1());
280 281
281 // We store this incase the application responds while we're 282 // We store this incase the application responds while we're
282 // waiting for user input so we know not to delete ourselves. 283 // waiting for user input so we know not to delete ourselves.
283 appKillerBox = new QMessageBox(tr("Application Problem"), 284 appKillerBox = new QMessageBox(tr("Application Problem"),
284 tr("<p>%1 is not responding.</p>").arg(appKillerName) + 285 tr("<p>%1 is not responding.</p>").arg(appKillerName) +
285 tr("<p>Would you like to force the application to exit?</p>"), 286 tr("<p>Would you like to force the application to exit?</p>"),
286 QMessageBox::Warning, QMessageBox::Yes, 287 QMessageBox::Warning, QMessageBox::Yes,
287 QMessageBox::No | QMessageBox::Default, 288 QMessageBox::No | QMessageBox::Default,
288 QMessageBox::NoButton); 289 QMessageBox::NoButton);
289 if (appKillerBox->exec() == QMessageBox::Yes) { 290 if (appKillerBox->exec() == QMessageBox::Yes) {
290 // qDebug("Killing the app!!! Bwuhahahaha!"); 291 // qDebug("Killing the app!!! Bwuhahahaha!");
291 int pid = pidForName(appKillerName); 292 int pid = pidForName(appKillerName);
292 if ( pid > 0 ) 293 if ( pid > 0 )
293 kill( pid ); 294 kill( pid );
294 } 295 }
295 appKillerName = QString::null; 296 appKillerName = QString::null;
296 delete appKillerBox; 297 delete appKillerBox;
297 appKillerBox = 0; 298 appKillerBox = 0;
298 return; 299 return;
299 } 300 }
300 } 301 }
301 302
302 QObject::timerEvent( e ); 303 QObject::timerEvent( e );
303} 304}
304 305
305#ifndef Q_OS_WIN32 306#ifndef Q_OS_WIN32
306void AppLauncher::sigStopped(int sigPid, int sigStatus) 307void AppLauncher::sigStopped(int sigPid, int sigStatus)
307{ 308{
308 int exitStatus = 0; 309 int exitStatus = 0;
309 310
310 bool crashed = WIFSIGNALED(sigStatus); 311 bool crashed = WIFSIGNALED(sigStatus);
311 if ( !crashed ) { 312 if ( !crashed ) {
312 if ( WIFEXITED(sigStatus) ) 313 if ( WIFEXITED(sigStatus) )
313 exitStatus = WEXITSTATUS(sigStatus); 314 exitStatus = WEXITSTATUS(sigStatus);
314 } else { 315 } else {
315 exitStatus = WTERMSIG(sigStatus); 316 exitStatus = WTERMSIG(sigStatus);
316 } 317 }
317 318
@@ -359,22 +360,22 @@ void AppLauncher::sigStopped(int sigPid, int sigStatus)
359 cfg.setGroup("Preload"); 360 cfg.setGroup("Preload");
360 QStringList apps = cfg.readListEntry("Apps",','); 361 QStringList apps = cfg.readListEntry("Apps",',');
361 QString exe = app->exec(); 362 QString exe = app->exec();
362 apps.remove(exe); 363 apps.remove(exe);
363 cfg.writeEntry("Apps",apps,','); 364 cfg.writeEntry("Apps",apps,',');
364 preloadDisabled = TRUE; 365 preloadDisabled = TRUE;
365 } 366 }
366 367
367 // clean up 368 // clean up
368 if ( exitStatus ) { 369 if ( exitStatus ) {
369 QCopEnvelope e("QPE/System", "notBusy(QString)"); 370 QCopEnvelope e("QPE/System", "notBusy(QString)");
370 e << app->exec(); 371 e << app->exec();
371 } 372 }
372/* 373/*
373 // debug info 374 // debug info
374 for (it = runningApps.begin(); it != runningApps.end(); ++it) { 375 for (it = runningApps.begin(); it != runningApps.end(); ++it) {
375 qDebug("running according to internal list: %s, with pid %d", (*it).data(), it.key() ); 376 qDebug("running according to internal list: %s, with pid %d", (*it).data(), it.key() );
376 } 377 }
377*/ 378*/
378 379
379#ifdef QTOPIA_PROGRAM_MONITOR 380#ifdef QTOPIA_PROGRAM_MONITOR
380 if ( crashed ) { 381 if ( crashed ) {
@@ -391,34 +392,35 @@ void AppLauncher::sigStopped(int sigPid, int sigStatus)
391 case SIGQUIT: sig = "SIGQUIT"; break; 392 case SIGQUIT: sig = "SIGQUIT"; break;
392 case SIGSEGV: sig = "SIGSEGV"; break; 393 case SIGSEGV: sig = "SIGSEGV"; break;
393 case SIGTERM: sig = "SIGTERM"; break; 394 case SIGTERM: sig = "SIGTERM"; break;
394 case SIGTRAP: sig = "SIGTRAP"; break; 395 case SIGTRAP: sig = "SIGTRAP"; break;
395 default: sig = QString("Unkown %1").arg(exitStatus); 396 default: sig = QString("Unkown %1").arg(exitStatus);
396 } 397 }
397 if ( preloadDisabled ) 398 if ( preloadDisabled )
398 sig += tr("<qt><p>Fast loading has been disabled for this application. Tap and hold the application icon to reenable it.</qt>"); 399 sig += tr("<qt><p>Fast loading has been disabled for this application. Tap and hold the application icon to reenable it.</qt>");
399 400
400 QString str = tr("<qt><b>%1</b> was terminated due to signal code %2</qt>").arg( app->name() ).arg( sig ); 401 QString str = tr("<qt><b>%1</b> was terminated due to signal code %2</qt>").arg( app->name() ).arg( sig );
401 QMessageBox::information(0, tr("Application terminated"), str ); 402 QMessageBox::information(0, tr("Application terminated"), str );
402 } else { 403 } else {
403 if ( exitStatus == 255 ) { //could not find app (because global returns -1) 404 if ( exitStatus == 255 ) { //could not find app (because global returns -1)
404 QMessageBox::information(0, tr("Application not found"), tr("<qt>Could not locate application <b>%1</b></qt>").arg( app->exec() ) ); 405 QMessageBox::information(0, tr("Application not found"), tr("<qt>Could not locate application <b>%1</b></qt>").arg( app->exec() ) );
405 } else { 406 } else {
406 QFileInfo fi(Global::tempDir() + "qcop-msg-" + appName); 407 QFileInfo fi(Opie::Global::tempDir() + "qcop-msg-" + appName);
407 if ( fi.exists() && fi.size() ) { 408 if ( fi.exists() && fi.size() ) {
408 emit terminated(sigPid, appName); 409 emit terminated(sigPid, appName);
409 execute( appName, QString::null ); 410 qWarning("Re executing obmitted for %s", appName.latin1() );
411 // execute( appName, QString::null );
410 return; 412 return;
411 } 413 }
412 } 414 }
413 } 415 }
414 416
415#endif 417#endif
416 418
417 emit terminated(sigPid, appName); 419 emit terminated(sigPid, appName);
418} 420}
419#else 421#else
420void AppLauncher::sigStopped(int sigPid, int sigStatus) 422void AppLauncher::sigStopped(int sigPid, int sigStatus)
421{ 423{
422 qDebug("Unhandled signal : AppLauncher::sigStopped(int sigPid, int sigStatus)"); 424 qDebug("Unhandled signal : AppLauncher::sigStopped(int sigPid, int sigStatus)");
423} 425}
424#endif // Q_OS_WIN32 426#endif // Q_OS_WIN32
@@ -439,19 +441,19 @@ bool AppLauncher::isRunning(const QString &app)
439 } 441 }
440 } 442 }
441 443
442 return FALSE; 444 return FALSE;
443} 445}
444 446
445bool AppLauncher::executeBuiltin(const QString &c, const QString &document) 447bool AppLauncher::executeBuiltin(const QString &c, const QString &document)
446{ 448{
447 Global::Command* builtin = Global::builtinCommands(); 449 Global::Command* builtin = Opie::Global::builtinCommands();
448 QGuardedPtr<QWidget> *running = Global::builtinRunning(); 450 QGuardedPtr<QWidget> *running = Opie::Global::builtinRunning();
449 451
450 // Attempt to execute the app using a builtin class for the app 452 // Attempt to execute the app using a builtin class for the app
451 if (builtin) { 453 if (builtin) {
452 for (int i = 0; builtin[i].file; i++) { 454 for (int i = 0; builtin[i].file; i++) {
453 if ( builtin[i].file == c ) { 455 if ( builtin[i].file == c ) {
454 if ( running[i] ) { 456 if ( running[i] ) {
455 if ( !document.isNull() && builtin[i].documentary ) 457 if ( !document.isNull() && builtin[i].documentary )
456 Global::setDocument(running[i], document); 458 Global::setDocument(running[i], document);
457 running[i]->raise(); 459 running[i]->raise();
@@ -478,33 +480,34 @@ bool AppLauncher::executeBuiltin(const QString &c, const QString &document)
478 return TRUE; 480 return TRUE;
479 } 481 }
480 482
481 return FALSE; 483 return FALSE;
482} 484}
483 485
484bool AppLauncher::execute(const QString &c, const QString &docParam, bool noRaise) 486bool AppLauncher::execute(const QString &c, const QString &docParam, bool noRaise)
485{ 487{
488 qWarning("AppLauncher::execute");
486 // Convert the command line in to a list of arguments 489 // Convert the command line in to a list of arguments
487 QStringList list = QStringList::split(QRegExp(" *"),c); 490 QStringList list = QStringList::split(QRegExp(" *"),c);
488 if ( !docParam.isEmpty() ) 491 if ( !docParam.isEmpty() )
489 list.append( docParam ); 492 list.append( docParam );
490 493
491 QString appName = list[0]; 494 QString appName = list[0];
492 if ( isRunning(appName) ) { 495 if ( isRunning(appName) ) {
493 QCString channel = "QPE/Application/"; 496 QCString channel = "QPE/Application/";
494 channel += appName.latin1(); 497 channel += appName.latin1();
495 498
496 // Need to lock it to avoid race conditions with QPEApplication::processQCopFile 499 // Need to lock it to avoid race conditions with QPEApplication::processQCopFile
497 QFile f(Global::tempDir() + "qcop-msg-" + appName); 500 QFile f(Opie::Global::tempDir() + "qcop-msg-" + appName);
498 if ( !noRaise && f.open(IO_WriteOnly | IO_Append) ) { 501 if ( !noRaise && f.open(IO_WriteOnly | IO_Append) ) {
499#ifndef Q_OS_WIN32 502#ifndef Q_OS_WIN32
500 flock(f.handle(), LOCK_EX); 503 flock(f.handle(), LOCK_EX);
501#endif 504#endif
502 505
503 QDataStream ds(&f); 506 QDataStream ds(&f);
504 QByteArray b; 507 QByteArray b;
505 QDataStream bstream(b, IO_WriteOnly); 508 QDataStream bstream(b, IO_WriteOnly);
506 if ( !f.size() ) { 509 if ( !f.size() ) {
507 ds << channel << QCString("raise()") << b; 510 ds << channel << QCString("raise()") << b;
508 if ( !waitingHeartbeat.contains( appName ) && appKillerName != appName ) { 511 if ( !waitingHeartbeat.contains( appName ) && appKillerName != appName ) {
509 int id = startTimer(RAISE_TIMEOUT_MS); 512 int id = startTimer(RAISE_TIMEOUT_MS);
510 waitingHeartbeat.insert( appName, id ); 513 waitingHeartbeat.insert( appName, id );
@@ -518,22 +521,22 @@ bool AppLauncher::execute(const QString &c, const QString &docParam, bool noRais
518 f.flush(); 521 f.flush();
519#ifndef Q_OS_WIN32 522#ifndef Q_OS_WIN32
520 flock(f.handle(), LOCK_UN); 523 flock(f.handle(), LOCK_UN);
521#endif 524#endif
522 f.close(); 525 f.close();
523 } 526 }
524 if ( QCopChannel::isRegistered(channel) ) // avoid unnecessary warnings 527 if ( QCopChannel::isRegistered(channel) ) // avoid unnecessary warnings
525 QCopChannel::send(channel,"QPEProcessQCop()"); 528 QCopChannel::send(channel,"QPEProcessQCop()");
526 529
527 return TRUE; 530 return TRUE;
528 } 531 }
529 532
530#ifdef QT_NO_QWS_MULTIPROCESS 533#ifdef QT_NO_QWS_MULTIPROCESS
531 QMessageBox::warning( 0, tr("Error"), tr("Could not find the application %1").arg(c), 534 QMessageBox::warning( 0, tr("Error"), tr("<qt>Could not find the application %1</qt>").arg(c),
532 tr("OK"), 0, 0, 0, 1 ); 535 tr("OK"), 0, 0, 0, 1 );
533#else 536#else
534 537
535 QStrList slist; 538 QStrList slist;
536 unsigned j; 539 unsigned j;
537 for ( j = 0; j < list.count(); j++ ) 540 for ( j = 0; j < list.count(); j++ )
538 slist.append( list[j].utf8() ); 541 slist.append( list[j].utf8() );
539 542
@@ -580,17 +583,17 @@ bool AppLauncher::execute(const QString &c, const QString &docParam, bool noRais
580 proc->addArgument(args[i]); 583 proc->addArgument(args[i]);
581 connect(proc, SIGNAL(processExited()), this, SLOT(processExited())); 584 connect(proc, SIGNAL(processExited()), this, SLOT(processExited()));
582 if (!proc->start()){ 585 if (!proc->start()){
583 qDebug("Unable to start application %s", args[0]); 586 qDebug("Unable to start application %s", args[0]);
584 }else{ 587 }else{
585 PROCESS_INFORMATION *procInfo = (PROCESS_INFORMATION *)proc->processIdentifier(); 588 PROCESS_INFORMATION *procInfo = (PROCESS_INFORMATION *)proc->processIdentifier();
586 if (procInfo){ 589 if (procInfo){
587 DWORD pid = procInfo->dwProcessId; 590 DWORD pid = procInfo->dwProcessId;
588 runningApps[pid] = QString(args[0]); 591 runningApps[pid] = QString(args[0]);
589 runningAppsProc.append(proc); 592 runningAppsProc.append(proc);
590 emit launched(pid, QString(args[0])); 593 emit launched(pid, QString(args[0]));
591 QCopEnvelope e("QPE/System", "busy()"); 594 QCopEnvelope e("QPE/System", "busy()");
592 }else{ 595 }else{
593 qDebug("Unable to read process inforation #1 for %s", args[0]); 596 qDebug("Unable to read process inforation #1 for %s", args[0]);
594 } 597 }
595 } 598 }
596 }else{ 599 }else{
@@ -630,29 +633,35 @@ int AppLauncher::pidForName( const QString &appName )
630 } 633 }
631 } 634 }
632 635
633 return pid; 636 return pid;
634} 637}
635 638
636void AppLauncher::createQuickLauncher() 639void AppLauncher::createQuickLauncher()
637{ 640{
641 static bool disabled = FALSE;
642 if (disabled)
643 return;
644
638 qlReady = FALSE; 645 qlReady = FALSE;
639 qlPid = ::vfork(); 646 qlPid = ::vfork();
640 if ( !qlPid ) { 647 if ( !qlPid ) {
641 char **args = new char *[2]; 648 char **args = new char *[2];
642 args[0] = "quicklauncher"; 649 args[0] = "quicklauncher";
643 args[1] = 0; 650 args[1] = 0;
644 for ( int fd = 3; fd < 100; fd++ ) 651 for ( int fd = 3; fd < 100; fd++ )
645 ::close( fd ); 652 ::close( fd );
646 ::setpgid( ::getpid(), ::getppid() ); 653 ::setpgid( ::getpid(), ::getppid() );
647 // Try bindir first, so that foo/bar works too 654 // Try bindir first, so that foo/bar works too
648 setenv( "LD_BIND_NOW", "1", 1 ); 655 setenv( "LD_BIND_NOW", "1", 1 );
649 ::execv( QPEApplication::qpeDir()+"bin/quicklauncher", args ); 656 ::execv( QPEApplication::qpeDir()+"bin/quicklauncher", args );
650 ::execvp( "quicklauncher", args ); 657 ::execvp( "quicklauncher", args );
658 delete []args;
659 disabled = TRUE;
651 _exit( -1 ); 660 _exit( -1 );
652 } else if ( qlPid == -1 ) { 661 } else if ( qlPid == -1 ) {
653 qlPid = 0; 662 qlPid = 0;
654 } else { 663 } else {
655 if ( getuid() == 0 ) 664 if ( getuid() == 0 )
656 setpriority( PRIO_PROCESS, qlPid, 19 ); 665 setpriority( PRIO_PROCESS, qlPid, 19 );
657 } 666 }
658} 667}
@@ -666,17 +675,17 @@ void AppLauncher::processExited()
666 QProcess *proc = (QProcess *) sender(); 675 QProcess *proc = (QProcess *) sender();
667 if (!proc){ 676 if (!proc){
668 qDebug("Interanl error NULL proc"); 677 qDebug("Interanl error NULL proc");
669 return; 678 return;
670 } 679 }
671 680
672 QString appName = proc->arguments()[0]; 681 QString appName = proc->arguments()[0];
673 qDebug("Removing application %s", appName.latin1()); 682 qDebug("Removing application %s", appName.latin1());
674 runningAppsProc.remove(proc); 683 runningAppsProc.remove(proc);
675 684
676 QMap<QString,int>::Iterator hbit = waitingHeartbeat.find(appName); 685 QMap<QString,int>::Iterator hbit = waitingHeartbeat.find(appName);
677 if ( hbit != waitingHeartbeat.end() ) { 686 if ( hbit != waitingHeartbeat.end() ) {
678 killTimer( *hbit ); 687 killTimer( *hbit );
679 waitingHeartbeat.remove( hbit ); 688 waitingHeartbeat.remove( hbit );
680 } 689 }
681 if ( appName == appKillerName ) { 690 if ( appName == appKillerName ) {
682 appKillerName = QString::null; 691 appKillerName = QString::null;
@@ -694,12 +703,12 @@ void AppLauncher::processExited()
694 } 703 }
695 704
696 if (found){ 705 if (found){
697 emit terminated(it.key(), it.data()); 706 emit terminated(it.key(), it.data());
698 runningApps.remove(it.key()); 707 runningApps.remove(it.key());
699 }else{ 708 }else{
700 qDebug("Internal error application %s not listed as running", appName.latin1()); 709 qDebug("Internal error application %s not listed as running", appName.latin1());
701 } 710 }
702 711
703#endif 712#endif
704} 713}
705 714