-rw-r--r-- | core/launcher/desktop.cpp | 2 | ||||
-rw-r--r-- | core/launcher/main.cpp | 132 |
2 files changed, 7 insertions, 127 deletions
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index bf19280..dee5535 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp @@ -612,24 +612,26 @@ void Desktop::togglePower() excllock = true; bool wasloggedin = loggedin; loggedin=0; suspendTime = QDateTime::currentDateTime(); // qpe_setBacklight ( 0 ); // force LCD off (sandman: why ????) if ( wasloggedin ) blankScreen(); + qDebug ( "OPIE suspending\n" ); + ODevice::inst ( )-> suspend ( ); QWSServer::screenSaverActivate ( false ); qpe_setBacklight ( -3 ); // force LCD on { QCopEnvelope("QPE/Card", "mtabChanged()" ); // might have changed while asleep } if ( wasloggedin ) login(TRUE); diff --git a/core/launcher/main.cpp b/core/launcher/main.cpp index 5cf624b..ca0bbe4 100644 --- a/core/launcher/main.cpp +++ b/core/launcher/main.cpp @@ -32,138 +32,28 @@ #include <opie/odevice.h> #include <qfile.h> #include <qwindowsystem_qws.h> #include <qpe/qcopenvelope_qws.h> #include <qpe/alarmserver.h> #include <stdlib.h> #include <stdio.h> #include <signal.h> #include <unistd.h> -#if defined(QT_QWS_CASSIOPEIA) || defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) +#if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) #include "../calibrate/calibrate.h" #endif -#ifdef QT_QWS_CASSIOPEIA -static void ignoreMessage( QtMsgType, const char * ) -{ -} -#include <sys/mount.h> -#include <sys/types.h> -#include <sys/stat.h> -#include <sys/time.h> -#include <fcntl.h> -#include <qdatetime.h> - -void initCassiopeia() -{ - // MIPSEL-specific init - make sure /proc exists for shm -/* - if ( mount("/dev/ram0", "/", "ext2", MS_REMOUNT | MS_MGC_VAL, 0 ) ) { - perror("Remounting - / read/write"); - } -*/ - if ( mount("none", "/tmp", "ramfs", 0, 0 ) ) { - perror("mounting ramfs /tmp"); - } else { - fprintf( stderr, "mounted /tmp\n" ); - } - if ( mount("none", "/home", "ramfs", 0, 0 ) ) { - perror("mounting ramfs /home"); - } else { - fprintf( stderr, "mounted /home\n" ); - } - if ( mount("none","/proc","proc",0,0) ) { - perror("Mounting - /proc"); - } else { - fprintf( stderr, "mounted /proc\n" ); - } - if ( mount("none","/mnt","shm",0,0) ) { - perror("Mounting - shm"); - } - setenv( "QTDIR", "/", 1 ); - setenv( "OPIEDIR", "/", 1 ); - setenv( "HOME", "/home", 1 ); - mkdir( "/home/Documents", 0755 ); - - // set a reasonable starting date - QDateTime dt( QDate( 2001, 3, 15 ) ); - QDateTime now = QDateTime::currentDateTime(); - int change = now.secsTo( dt ); - - time_t t = ::time(0); - t += change; - stime(&t); - - qInstallMsgHandler(ignoreMessage); -} -#endif - -#ifdef QPE_OWNAPM -#include <sys/ioctl.h> -#include <sys/types.h> -#include <fcntl.h> -#include <unistd.h> -#include <errno.h> -#include <linux/ioctl.h> -#include <qpe/global.h> - -static void disableAPM() -{ - - int fd, cur_val, ret; - char *device = "/dev/apm_bios"; - - fd = open (device, O_WRONLY); - - if (fd == -1) { - perror(device); - return; - } - - cur_val = ioctl(fd, APM_IOCGEVTSRC, 0); - if (cur_val == -1) { - perror("ioctl"); - exit(errno); - } - - ret = ioctl(fd, APM_IOCSEVTSRC, cur_val & ~APM_EVT_POWER_BUTTON); - if (ret == -1) { - perror("ioctl"); - return; - } - close(fd); -} - -static void initAPM() -{ - // So that we have to do it ourself, but better. - disableAPM(); -} -#endif - -#ifdef QT_DEMO_SINGLE_FLOPPY -#include <sys/mount.h> - -void initFloppy() -{ - mount("none","/proc","proc",0,0); - setenv( "QTDIR", "/", 0 ); - setenv( "HOME", "/root", 0 ); - setenv( "QWS_SIZE", "240x320", 0 ); -} -#endif - void initEnvironment() { Config config("locale"); config.setGroup( "Location" ); QString tz = config.readEntry( "Timezone", getenv("TZ") ); // if not timezone set, pick New York if (tz.isNull()) tz = "America/New_York"; setenv( "TZ", tz, 1 ); @@ -264,35 +154,25 @@ public: QWSServer::sendKeyEvent ( -1, Key_F35, 0, false, false ); } private: OModel m_model; int m_power_timer; }; int initApplication( int argc, char ** argv ) { -#ifdef QT_QWS_CASSIOPEIA - initCassiopeia(); -#endif - -#ifdef QPE_OWNAPM - initAPM(); -#endif - -#ifdef QT_DEMO_SINGLE_FLOPPY - initFloppy(); -#endif + ODevice::inst ( )-> setPowerButtonHandler ( ODevice::OPIE ); initEnvironment(); #if !defined(QT_QWS_CASSIOPEIA) && !defined(QT_QWS_IPAQ) && !defined(QT_QWS_EBX) setenv( "QWS_SIZE", "240x320", 0 ); #endif //Don't flicker at startup: QWSServer::setDesktopBackground( QImage() ); DesktopApplication a( argc, argv, QApplication::GuiServer ); (void) new ModelKeyFilter ( ); @@ -323,24 +203,26 @@ int initApplication( int argc, char ** argv ) Calibrate *cal = new Calibrate; cal->exec(); delete cal; } #endif d->show(); int rv = a.exec(); delete d; + ODevice::inst ( )-> setPowerButtonHandler ( ODevice::KERNEL ); + return rv; } static const char *pidfile_path = "/var/run/opie.pid"; void create_pidfile ( ) { FILE *f; if (( f = ::fopen ( pidfile_path, "w" ))) { ::fprintf ( f, "%d", getpid ( )); ::fclose ( f ); @@ -351,37 +233,33 @@ void remove_pidfile ( ) { ::unlink ( pidfile_path ); } void handle_sigterm ( int /* sig */ ) { if ( qApp ) qApp-> quit ( ); } int main( int argc, char ** argv ) { -#ifndef SINGLE_APP ::signal( SIGCHLD, SIG_IGN ); ::signal ( SIGTERM, handle_sigterm ); ::signal ( SIGINT, handle_sigterm ); ::setsid ( ); ::setpgid ( 0, 0 ); ::atexit ( remove_pidfile ); create_pidfile ( ); -#endif int retVal = initApplication ( argc, argv ); -#ifndef SINGLE_APP // Kill them. Kill them all. ::kill ( 0, SIGTERM ); - ::sleep( 1 ); + ::sleep ( 1 ); ::kill ( 0, SIGKILL ); -#endif return retVal; } |