author | sandman <sandman> | 2002-09-29 13:32:19 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-09-29 13:32:19 (UTC) |
commit | 3e8ee39d31b43f01524670df6cb048efc2194b9a (patch) (unidiff) | |
tree | f0f20464e77c4d0e3d03cf5065dc77070279c4f9 | |
parent | b7fcdc189dacc8e054a32090af4677bc86955491 (diff) | |
download | opie-3e8ee39d31b43f01524670df6cb048efc2194b9a.zip opie-3e8ee39d31b43f01524670df6cb048efc2194b9a.tar.gz opie-3e8ee39d31b43f01524670df6cb048efc2194b9a.tar.bz2 |
Fast-load should work now again -- I think this was a Qtopia merge problem
-rw-r--r-- | library/global.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/library/global.cpp b/library/global.cpp index 7438891..2e4d03f 100644 --- a/library/global.cpp +++ b/library/global.cpp | |||
@@ -503,128 +503,131 @@ void Global::setBuiltinCommands( Command* list ) | |||
503 | if (!builtin) | 503 | if (!builtin) |
504 | return; | 504 | return; |
505 | while ( builtin[count].file ) | 505 | while ( builtin[count].file ) |
506 | count++; | 506 | count++; |
507 | 507 | ||
508 | running = new QGuardedPtr<QWidget> [ count ]; | 508 | running = new QGuardedPtr<QWidget> [ count ]; |
509 | } | 509 | } |
510 | 510 | ||
511 | /*! | 511 | /*! |
512 | \internal | 512 | \internal |
513 | */ | 513 | */ |
514 | void Global::setDocument( QWidget* receiver, const QString& document ) | 514 | void Global::setDocument( QWidget* receiver, const QString& document ) |
515 | { | 515 | { |
516 | Emitter emitter(receiver,document); | 516 | Emitter emitter(receiver,document); |
517 | } | 517 | } |
518 | 518 | ||
519 | /*! | 519 | /*! |
520 | \internal | 520 | \internal |
521 | */ | 521 | */ |
522 | bool Global::terminateBuiltin( const QString& n ) | 522 | bool Global::terminateBuiltin( const QString& n ) |
523 | { | 523 | { |
524 | if (!builtin) | 524 | if (!builtin) |
525 | return FALSE; | 525 | return FALSE; |
526 | for (int i = 0; builtin[i].file; i++) { | 526 | for (int i = 0; builtin[i].file; i++) { |
527 | if ( builtin[i].file == n ) { | 527 | if ( builtin[i].file == n ) { |
528 | delete running[i]; | 528 | delete running[i]; |
529 | return TRUE; | 529 | return TRUE; |
530 | } | 530 | } |
531 | } | 531 | } |
532 | return FALSE; | 532 | return FALSE; |
533 | } | 533 | } |
534 | 534 | ||
535 | /*! | 535 | /*! |
536 | \internal | 536 | \internal |
537 | */ | 537 | */ |
538 | void Global::terminate( const AppLnk* app ) | 538 | void Global::terminate( const AppLnk* app ) |
539 | { | 539 | { |
540 | //if ( terminateBuiltin(app->exec()) ) return; // maybe? haven't tried this | 540 | //if ( terminateBuiltin(app->exec()) ) return; // maybe? haven't tried this |
541 | 541 | ||
542 | #ifndef QT_NO_COP | 542 | #ifndef QT_NO_COP |
543 | QCString channel = "QPE/Application/" + app->exec().utf8(); | 543 | QCString channel = "QPE/Application/" + app->exec().utf8(); |
544 | if ( QCopChannel::isRegistered(channel) ) { | 544 | if ( QCopChannel::isRegistered(channel) ) { |
545 | QCopEnvelope e(channel, "quit()"); | 545 | QCopEnvelope e(channel, "quit()"); |
546 | } | 546 | } |
547 | #endif | 547 | #endif |
548 | } | 548 | } |
549 | 549 | ||
550 | /*! | 550 | /*! |
551 | Low-level function to run command \a c. | 551 | Low-level function to run command \a c. |
552 | 552 | ||
553 | \warning Do not use this function. Use execute instead. | 553 | \warning Do not use this function. Use execute instead. |
554 | 554 | ||
555 | \sa execute() | 555 | \sa execute() |
556 | */ | 556 | */ |
557 | void Global::invoke(const QString &c) | 557 | void Global::invoke(const QString &c) |
558 | { | 558 | { |
559 | // Convert the command line in to a list of arguments | 559 | // Convert the command line in to a list of arguments |
560 | QStringList list = QStringList::split(QRegExp(" *"),c); | 560 | QStringList list = QStringList::split(QRegExp(" *"),c); |
561 | 561 | ||
562 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 562 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
563 | QString ap=list[0]; | 563 | QString ap=list[0]; |
564 | // see if the application is already running | 564 | // see if the application is already running |
565 | // XXX should lock file /tmp/qcop-msg-ap | 565 | // XXX should lock file /tmp/qcop-msg-ap |
566 | if ( QCopChannel::isRegistered( ("QPE/Application/" + ap).latin1() ) ) { | 566 | if ( QCopChannel::isRegistered( ("QPE/Application/" + ap).latin1() ) ) { |
567 | // If the channel is already register, the app is already running, so show it. | ||
568 | { QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } | ||
569 | |||
567 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); | 570 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); |
568 | e << ap; | 571 | e << ap; |
569 | return; | 572 | return; |
570 | } | 573 | } |
571 | // XXX should unlock file /tmp/qcop-msg-ap | 574 | // XXX should unlock file /tmp/qcop-msg-ap |
572 | //see if it is being started | 575 | //see if it is being started |
573 | if ( StartingAppList::isStarting( ap ) ) { | 576 | if ( StartingAppList::isStarting( ap ) ) { |
574 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); | 577 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); |
575 | e << ap; | 578 | e << ap; |
576 | return; | 579 | return; |
577 | } | 580 | } |
578 | 581 | ||
579 | #endif | 582 | #endif |
580 | 583 | ||
581 | #ifdef QT_NO_QWS_MULTIPROCESS | 584 | #ifdef QT_NO_QWS_MULTIPROCESS |
582 | QMessageBox::warning( 0, "Error", "Could not find the application " + c, "Ok", 0, 0, 0, 1 ); | 585 | QMessageBox::warning( 0, "Error", "Could not find the application " + c, "Ok", 0, 0, 0, 1 ); |
583 | #else | 586 | #else |
584 | 587 | ||
585 | QStrList slist; | 588 | QStrList slist; |
586 | unsigned int j; | 589 | unsigned int j; |
587 | for ( j = 0; j < list.count(); j++ ) | 590 | for ( j = 0; j < list.count(); j++ ) |
588 | slist.append( list[j].utf8() ); | 591 | slist.append( list[j].utf8() ); |
589 | 592 | ||
590 | const char **args = new (const char *)[slist.count() + 1]; | 593 | const char **args = new (const char *)[slist.count() + 1]; |
591 | for ( j = 0; j < slist.count(); j++ ) | 594 | for ( j = 0; j < slist.count(); j++ ) |
592 | args[j] = slist.at(j); | 595 | args[j] = slist.at(j); |
593 | args[j] = NULL; | 596 | args[j] = NULL; |
594 | 597 | ||
595 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 598 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
596 | // an attempt to show a wait... | 599 | // an attempt to show a wait... |
597 | // more logic should be used, but this will be fine for the moment... | 600 | // more logic should be used, but this will be fine for the moment... |
598 | QCopEnvelope ( "QPE/System", "busy()" ); | 601 | QCopEnvelope ( "QPE/System", "busy()" ); |
599 | #endif | 602 | #endif |
600 | 603 | ||
601 | #ifdef HAVE_QUICKEXEC | 604 | #ifdef HAVE_QUICKEXEC |
602 | QString libexe = qpeDir()+"/binlib/lib"+args[0] + ".so"; | 605 | QString libexe = qpeDir()+"/binlib/lib"+args[0] + ".so"; |
603 | qDebug("libfile = %s", libexe.latin1() ); | 606 | qDebug("libfile = %s", libexe.latin1() ); |
604 | if ( QFile::exists( libexe ) ) { | 607 | if ( QFile::exists( libexe ) ) { |
605 | qDebug("calling quickexec %s", libexe.latin1() ); | 608 | qDebug("calling quickexec %s", libexe.latin1() ); |
606 | quickexecv( libexe.utf8().data(), (const char **)args ); | 609 | quickexecv( libexe.utf8().data(), (const char **)args ); |
607 | } else | 610 | } else |
608 | #endif | 611 | #endif |
609 | { | 612 | { |
610 | if ( !::vfork() ) { | 613 | if ( !::vfork() ) { |
611 | for ( int fd = 3; fd < 100; fd++ ) | 614 | for ( int fd = 3; fd < 100; fd++ ) |
612 | ::close( fd ); | 615 | ::close( fd ); |
613 | ::setpgid( ::getpid(), ::getppid() ); | 616 | ::setpgid( ::getpid(), ::getppid() ); |
614 | // Try bindir first, so that foo/bar works too | 617 | // Try bindir first, so that foo/bar works too |
615 | ::execv( qpeDir()+"/bin/"+args[0], (char * const *)args ); | 618 | ::execv( qpeDir()+"/bin/"+args[0], (char * const *)args ); |
616 | ::execvp( args[0], (char * const *)args ); | 619 | ::execvp( args[0], (char * const *)args ); |
617 | _exit( -1 ); | 620 | _exit( -1 ); |
618 | } | 621 | } |
619 | } | 622 | } |
620 | StartingAppList::add( list[0] ); | 623 | StartingAppList::add( list[0] ); |
621 | #endif //QT_NO_QWS_MULTIPROCESS | 624 | #endif //QT_NO_QWS_MULTIPROCESS |
622 | } | 625 | } |
623 | 626 | ||
624 | 627 | ||
625 | /*! | 628 | /*! |
626 | Executes the application identfied by \a c, passing \a | 629 | Executes the application identfied by \a c, passing \a |
627 | document if it isn't null. | 630 | document if it isn't null. |
628 | 631 | ||
629 | Note that a better approach might be to send a QCop message to the | 632 | Note that a better approach might be to send a QCop message to the |
630 | application's QPE/Application/\e{appname} channel. | 633 | application's QPE/Application/\e{appname} channel. |