-rw-r--r-- | core/apps/calibrate/main.cpp | 20 | ||||
-rw-r--r-- | core/apps/calibrate/opie-calibrate.control | 8 | ||||
-rw-r--r-- | core/launcher/desktop.cpp | 2 | ||||
-rw-r--r-- | core/launcher/launcher.pro | 4 | ||||
-rw-r--r-- | core/launcher/main.cpp | 15 | ||||
-rw-r--r-- | core/launcher/opie-taskbar.control | 4 | ||||
-rw-r--r-- | core/launcher/taskbar.cpp | 17 | ||||
-rw-r--r-- | core/launcher/taskbar.h | 2 |
8 files changed, 32 insertions, 40 deletions
diff --git a/core/apps/calibrate/main.cpp b/core/apps/calibrate/main.cpp index d1ad083..1c295eb 100644 --- a/core/apps/calibrate/main.cpp +++ b/core/apps/calibrate/main.cpp | |||
@@ -1,42 +1,46 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include "calibrate.h" | 21 | #include "calibrate.h" |
22 | 22 | ||
23 | #include <qfile.h> | 23 | #include <qfile.h> |
24 | #include <qpe/qpeapplication.h> | 24 | #include <qpe/qpeapplication.h> |
25 | 25 | ||
26 | #ifdef QWS | ||
27 | #include <qwindowsystem_qws.h> | ||
28 | #endif | ||
29 | |||
26 | int main( int argc, char ** argv ) | 30 | int main( int argc, char ** argv ) |
27 | { | 31 | { |
28 | QPEApplication a( argc, argv ); | 32 | QPEApplication a( argc, argv ); |
29 | int retval = 0; | 33 | int retval = 0; |
30 | 34 | ||
31 | #if defined(QT_QWS_CASSIOPEIA) || defined(QT_QWS_IPAQ) || defined(QT_QWS_SL5XXX) | 35 | #ifdef QWS |
32 | if ( !QFile::exists( "/etc/pointercal" ) ) { | 36 | if ( QWSServer::mouseHandler() ->inherits("QCalibratedMouseHandler") ) { |
37 | #endif | ||
33 | // Make sure calibration widget starts on top. | 38 | // Make sure calibration widget starts on top. |
34 | Calibrate *cal = new Calibrate; | 39 | Calibrate cal; |
35 | a.setMainWidget(cal); | 40 | a.setMainWidget(&cal); |
36 | a.showMainWidget(cal); | 41 | a.showMainWidget(&cal); |
37 | retval = a.exec(); | 42 | return a.exec(); |
38 | delete cal; | 43 | #ifdef QWS |
39 | } | 44 | } |
40 | #endif | 45 | #endif |
41 | return retval; | ||
42 | } | 46 | } |
diff --git a/core/apps/calibrate/opie-calibrate.control b/core/apps/calibrate/opie-calibrate.control new file mode 100644 index 0000000..6eafb94 --- a/dev/null +++ b/core/apps/calibrate/opie-calibrate.control | |||
@@ -0,0 +1,8 @@ | |||
1 | Files: bin/calibrate apps/Settings/Calibrate.desktop | ||
2 | Priority: required | ||
3 | Section: opie/system | ||
4 | Maintainer: Project Opie <opie@handhelds.org> | ||
5 | Architecture: arm | ||
6 | Version: $QPE_VERSION-$SUB_VERSION.3 | ||
7 | Depends: libqpe1, libqt2-emb | ||
8 | Description: Opie calibration tool | ||
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index 6def126..ef0bf4c 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp | |||
@@ -5,193 +5,192 @@ | |||
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include <syslog.h> | 21 | #include <syslog.h> |
22 | 22 | ||
23 | #include "desktop.h" | 23 | #include "desktop.h" |
24 | #include "info.h" | 24 | #include "info.h" |
25 | #include "launcher.h" | 25 | #include "launcher.h" |
26 | #include "qcopbridge.h" | 26 | #include "qcopbridge.h" |
27 | #include "shutdownimpl.h" | 27 | #include "shutdownimpl.h" |
28 | #include "startmenu.h" | 28 | #include "startmenu.h" |
29 | #include "taskbar.h" | 29 | #include "taskbar.h" |
30 | #include "transferserver.h" | 30 | #include "transferserver.h" |
31 | #include "irserver.h" | 31 | #include "irserver.h" |
32 | #include "packageslave.h" | 32 | #include "packageslave.h" |
33 | #include "screensaver.h" | 33 | #include "screensaver.h" |
34 | 34 | ||
35 | #include <qpe/applnk.h> | 35 | #include <qpe/applnk.h> |
36 | #include <qpe/mimetype.h> | 36 | #include <qpe/mimetype.h> |
37 | #include <qpe/password.h> | 37 | #include <qpe/password.h> |
38 | #include <qpe/config.h> | 38 | #include <qpe/config.h> |
39 | #include <qpe/power.h> | 39 | #include <qpe/power.h> |
40 | #include <qpe/timeconversion.h> | 40 | #include <qpe/timeconversion.h> |
41 | #include <qpe/qcopenvelope_qws.h> | 41 | #include <qpe/qcopenvelope_qws.h> |
42 | #include <qpe/network.h> | 42 | #include <qpe/network.h> |
43 | #include <qpe/global.h> | 43 | #include <qpe/global.h> |
44 | 44 | ||
45 | #if defined( QT_QWS_SL5XXX ) || defined( QT_QWS_IPAQ ) | 45 | #if defined( QT_QWS_SL5XXX ) || defined( QT_QWS_IPAQ ) |
46 | #include <qpe/custom.h> | 46 | #include <qpe/custom.h> |
47 | #endif | 47 | #endif |
48 | 48 | ||
49 | #include <opie/odevice.h> | 49 | #include <opie/odevice.h> |
50 | 50 | ||
51 | #include <qgfx_qws.h> | 51 | #include <qgfx_qws.h> |
52 | #include <qmainwindow.h> | 52 | #include <qmainwindow.h> |
53 | #include <qmessagebox.h> | 53 | #include <qmessagebox.h> |
54 | #include <qtimer.h> | 54 | #include <qtimer.h> |
55 | #include <qwindowsystem_qws.h> | 55 | #include <qwindowsystem_qws.h> |
56 | 56 | ||
57 | #include <qvaluelist.h> | 57 | #include <qvaluelist.h> |
58 | 58 | ||
59 | #include <stdlib.h> | 59 | #include <stdlib.h> |
60 | #include <unistd.h> | 60 | #include <unistd.h> |
61 | #include <fcntl.h> | 61 | #include <fcntl.h> |
62 | 62 | ||
63 | 63 | ||
64 | using namespace Opie; | 64 | using namespace Opie; |
65 | 65 | ||
66 | class QCopKeyRegister | 66 | class QCopKeyRegister |
67 | { | 67 | { |
68 | public: | 68 | public: |
69 | QCopKeyRegister() : keyCode( 0 ) | 69 | QCopKeyRegister() : keyCode( 0 ) |
70 | { } | 70 | { } |
71 | QCopKeyRegister( int k, const QCString &c, const QCString &m ) | 71 | QCopKeyRegister( int k, const QCString &c, const QCString &m ) |
72 | : keyCode( k ), channel( c ), message( m ) | 72 | : keyCode( k ), channel( c ), message( m ) |
73 | { } | 73 | { } |
74 | 74 | ||
75 | int getKeyCode() const | 75 | int getKeyCode() const |
76 | { | 76 | { |
77 | return keyCode; | 77 | return keyCode; |
78 | } | 78 | } |
79 | QCString getChannel() const | 79 | QCString getChannel() const |
80 | { | 80 | { |
81 | return channel; | 81 | return channel; |
82 | } | 82 | } |
83 | QCString getMessage() const | 83 | QCString getMessage() const |
84 | { | 84 | { |
85 | return message; | 85 | return message; |
86 | } | 86 | } |
87 | 87 | ||
88 | private: | 88 | private: |
89 | int keyCode; | 89 | int keyCode; |
90 | QCString channel, message; | 90 | QCString channel, message; |
91 | }; | 91 | }; |
92 | 92 | ||
93 | typedef QValueList<QCopKeyRegister> KeyRegisterList; | 93 | typedef QValueList<QCopKeyRegister> KeyRegisterList; |
94 | KeyRegisterList keyRegisterList; | 94 | KeyRegisterList keyRegisterList; |
95 | 95 | ||
96 | static Desktop* qpedesktop = 0; | 96 | static Desktop* qpedesktop = 0; |
97 | static int loggedin = 0; | 97 | static int loggedin = 0; |
98 | static void login( bool at_poweron ) | 98 | static void login( bool at_poweron ) |
99 | { | 99 | { |
100 | if ( !loggedin ) { | 100 | if ( !loggedin ) { |
101 | Global::terminateBuiltin( "calibrate" ); | ||
102 | Password::authenticate( at_poweron ); | 101 | Password::authenticate( at_poweron ); |
103 | loggedin = 1; | 102 | loggedin = 1; |
104 | QCopEnvelope e( "QPE/Desktop", "unlocked()" ); | 103 | QCopEnvelope e( "QPE/Desktop", "unlocked()" ); |
105 | } | 104 | } |
106 | } | 105 | } |
107 | 106 | ||
108 | bool Desktop::screenLocked() | 107 | bool Desktop::screenLocked() |
109 | { | 108 | { |
110 | return loggedin == 0; | 109 | return loggedin == 0; |
111 | } | 110 | } |
112 | 111 | ||
113 | /* | 112 | /* |
114 | Priority is number of alerts that are needed to pop up | 113 | Priority is number of alerts that are needed to pop up |
115 | alert. | 114 | alert. |
116 | */ | 115 | */ |
117 | class DesktopPowerAlerter : public QMessageBox | 116 | class DesktopPowerAlerter : public QMessageBox |
118 | { | 117 | { |
119 | public: | 118 | public: |
120 | DesktopPowerAlerter( QWidget *parent, const char *name = 0 ) | 119 | DesktopPowerAlerter( QWidget *parent, const char *name = 0 ) |
121 | : QMessageBox( tr( "Battery Status" ), "Low Battery", | 120 | : QMessageBox( tr( "Battery Status" ), "Low Battery", |
122 | QMessageBox::Critical, | 121 | QMessageBox::Critical, |
123 | QMessageBox::Ok | QMessageBox::Default, | 122 | QMessageBox::Ok | QMessageBox::Default, |
124 | QMessageBox::NoButton, QMessageBox::NoButton, | 123 | QMessageBox::NoButton, QMessageBox::NoButton, |
125 | parent, name, FALSE ) | 124 | parent, name, FALSE ) |
126 | { | 125 | { |
127 | currentPriority = INT_MAX; | 126 | currentPriority = INT_MAX; |
128 | alertCount = 0; | 127 | alertCount = 0; |
129 | } | 128 | } |
130 | 129 | ||
131 | void alert( const QString &text, int priority ); | 130 | void alert( const QString &text, int priority ); |
132 | void hideEvent( QHideEvent * ); | 131 | void hideEvent( QHideEvent * ); |
133 | private: | 132 | private: |
134 | int currentPriority; | 133 | int currentPriority; |
135 | int alertCount; | 134 | int alertCount; |
136 | }; | 135 | }; |
137 | 136 | ||
138 | void DesktopPowerAlerter::alert( const QString &text, int priority ) | 137 | void DesktopPowerAlerter::alert( const QString &text, int priority ) |
139 | { | 138 | { |
140 | alertCount++; | 139 | alertCount++; |
141 | if ( alertCount < priority ) | 140 | if ( alertCount < priority ) |
142 | return ; | 141 | return ; |
143 | if ( priority > currentPriority ) | 142 | if ( priority > currentPriority ) |
144 | return ; | 143 | return ; |
145 | currentPriority = priority; | 144 | currentPriority = priority; |
146 | setText( text ); | 145 | setText( text ); |
147 | show(); | 146 | show(); |
148 | } | 147 | } |
149 | 148 | ||
150 | 149 | ||
151 | void DesktopPowerAlerter::hideEvent( QHideEvent *e ) | 150 | void DesktopPowerAlerter::hideEvent( QHideEvent *e ) |
152 | { | 151 | { |
153 | QMessageBox::hideEvent( e ); | 152 | QMessageBox::hideEvent( e ); |
154 | alertCount = 0; | 153 | alertCount = 0; |
155 | currentPriority = INT_MAX; | 154 | currentPriority = INT_MAX; |
156 | } | 155 | } |
157 | 156 | ||
158 | 157 | ||
159 | void DesktopApplication::switchLCD ( bool on ) | 158 | void DesktopApplication::switchLCD ( bool on ) |
160 | { | 159 | { |
161 | if ( qApp ) { | 160 | if ( qApp ) { |
162 | DesktopApplication *dapp = (DesktopApplication *) qApp; | 161 | DesktopApplication *dapp = (DesktopApplication *) qApp; |
163 | 162 | ||
164 | if ( dapp-> m_screensaver ) { | 163 | if ( dapp-> m_screensaver ) { |
165 | if ( on ) { | 164 | if ( on ) { |
166 | dapp-> m_screensaver-> setDisplayState ( true ); | 165 | dapp-> m_screensaver-> setDisplayState ( true ); |
167 | dapp-> m_screensaver-> setBacklight ( -3 ); | 166 | dapp-> m_screensaver-> setBacklight ( -3 ); |
168 | } | 167 | } |
169 | else { | 168 | else { |
170 | dapp-> m_screensaver-> setDisplayState ( false ); | 169 | dapp-> m_screensaver-> setDisplayState ( false ); |
171 | } | 170 | } |
172 | } | 171 | } |
173 | } | 172 | } |
174 | } | 173 | } |
175 | 174 | ||
176 | 175 | ||
177 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) | 176 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) |
178 | : QPEApplication( argc, argv, appType ) | 177 | : QPEApplication( argc, argv, appType ) |
179 | { | 178 | { |
180 | m_ps = new PowerStatus; | 179 | m_ps = new PowerStatus; |
181 | m_ps_last = new PowerStatus; | 180 | m_ps_last = new PowerStatus; |
182 | pa = new DesktopPowerAlerter( 0 ); | 181 | pa = new DesktopPowerAlerter( 0 ); |
183 | 182 | ||
184 | m_apm_timer = new QTimer ( this ); | 183 | m_apm_timer = new QTimer ( this ); |
185 | connect ( m_apm_timer, SIGNAL( timeout ( )), this, SLOT( apmTimeout ( ))); | 184 | connect ( m_apm_timer, SIGNAL( timeout ( )), this, SLOT( apmTimeout ( ))); |
186 | reloadPowerWarnSettings ( ); | 185 | reloadPowerWarnSettings ( ); |
187 | 186 | ||
188 | m_last_button = 0; | 187 | m_last_button = 0; |
189 | m_button_timer = new QTimer ( ); | 188 | m_button_timer = new QTimer ( ); |
190 | connect ( m_button_timer, SIGNAL( timeout ( )), this, SLOT( sendHeldAction ( ))); | 189 | connect ( m_button_timer, SIGNAL( timeout ( )), this, SLOT( sendHeldAction ( ))); |
191 | 190 | ||
192 | channel = new QCopChannel( "QPE/System", this ); | 191 | channel = new QCopChannel( "QPE/System", this ); |
193 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 192 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
194 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); | 193 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); |
195 | 194 | ||
196 | channel = new QCopChannel( "QPE/Launcher", this ); | 195 | channel = new QCopChannel( "QPE/Launcher", this ); |
197 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 196 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
@@ -529,193 +528,192 @@ Desktop::Desktop() : | |||
529 | qApp-> setMainWidget ( launcher ); | 528 | qApp-> setMainWidget ( launcher ); |
530 | } | 529 | } |
531 | 530 | ||
532 | void Desktop::show() | 531 | void Desktop::show() |
533 | { | 532 | { |
534 | login( TRUE ); | 533 | login( TRUE ); |
535 | QWidget::show(); | 534 | QWidget::show(); |
536 | } | 535 | } |
537 | 536 | ||
538 | Desktop::~Desktop() | 537 | Desktop::~Desktop() |
539 | { | 538 | { |
540 | delete launcher; | 539 | delete launcher; |
541 | delete tb; | 540 | delete tb; |
542 | delete qcopBridge; | 541 | delete qcopBridge; |
543 | delete transferServer; | 542 | delete transferServer; |
544 | } | 543 | } |
545 | 544 | ||
546 | bool Desktop::recoverMemory() | 545 | bool Desktop::recoverMemory() |
547 | { | 546 | { |
548 | return tb->recoverMemory(); | 547 | return tb->recoverMemory(); |
549 | } | 548 | } |
550 | 549 | ||
551 | void Desktop::checkMemory() | 550 | void Desktop::checkMemory() |
552 | { | 551 | { |
553 | #if defined(QPE_HAVE_MEMALERTER) | 552 | #if defined(QPE_HAVE_MEMALERTER) |
554 | static bool ignoreNormal = FALSE; | 553 | static bool ignoreNormal = FALSE; |
555 | static bool existingMessage = FALSE; | 554 | static bool existingMessage = FALSE; |
556 | 555 | ||
557 | if ( existingMessage ) | 556 | if ( existingMessage ) |
558 | return ; // don't show a second message while still on first | 557 | return ; // don't show a second message while still on first |
559 | 558 | ||
560 | existingMessage = TRUE; | 559 | existingMessage = TRUE; |
561 | switch ( memstate ) { | 560 | switch ( memstate ) { |
562 | case Unknown: | 561 | case Unknown: |
563 | break; | 562 | break; |
564 | case Low: | 563 | case Low: |
565 | memstate = Unknown; | 564 | memstate = Unknown; |
566 | if ( recoverMemory() ) | 565 | if ( recoverMemory() ) |
567 | ignoreNormal = TRUE; | 566 | ignoreNormal = TRUE; |
568 | else | 567 | else |
569 | QMessageBox::warning( 0 , "Memory Status", | 568 | QMessageBox::warning( 0 , "Memory Status", |
570 | "The memory smacks of shortage. \n" | 569 | "The memory smacks of shortage. \n" |
571 | "Please save data. " ); | 570 | "Please save data. " ); |
572 | break; | 571 | break; |
573 | case Normal: | 572 | case Normal: |
574 | memstate = Unknown; | 573 | memstate = Unknown; |
575 | if ( ignoreNormal ) | 574 | if ( ignoreNormal ) |
576 | ignoreNormal = FALSE; | 575 | ignoreNormal = FALSE; |
577 | // else | 576 | // else |
578 | // QMessageBox::information ( 0 , "Memory Status", | 577 | // QMessageBox::information ( 0 , "Memory Status", |
579 | // "There is enough memory again." ); | 578 | // "There is enough memory again." ); |
580 | break; | 579 | break; |
581 | case VeryLow: | 580 | case VeryLow: |
582 | memstate = Unknown; | 581 | memstate = Unknown; |
583 | QMessageBox::critical( 0 , "Memory Status", | 582 | QMessageBox::critical( 0 , "Memory Status", |
584 | "The memory is very low. \n" | 583 | "The memory is very low. \n" |
585 | "Please end this application \n" | 584 | "Please end this application \n" |
586 | "immediately." ); | 585 | "immediately." ); |
587 | recoverMemory(); | 586 | recoverMemory(); |
588 | } | 587 | } |
589 | existingMessage = FALSE; | 588 | existingMessage = FALSE; |
590 | #endif | 589 | #endif |
591 | } | 590 | } |
592 | 591 | ||
593 | static bool isVisibleWindow( int wid ) | 592 | static bool isVisibleWindow( int wid ) |
594 | { | 593 | { |
595 | #ifdef QWS | 594 | #ifdef QWS |
596 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 595 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
597 | QWSWindow* w; | 596 | QWSWindow* w; |
598 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { | 597 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { |
599 | if ( w->winId() == wid ) | 598 | if ( w->winId() == wid ) |
600 | return !w->isFullyObscured(); | 599 | return !w->isFullyObscured(); |
601 | } | 600 | } |
602 | #endif | 601 | #endif |
603 | return FALSE; | 602 | return FALSE; |
604 | } | 603 | } |
605 | 604 | ||
606 | static bool hasVisibleWindow( const QString& clientname ) | 605 | static bool hasVisibleWindow( const QString& clientname ) |
607 | { | 606 | { |
608 | #ifdef QWS | 607 | #ifdef QWS |
609 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 608 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
610 | QWSWindow* w; | 609 | QWSWindow* w; |
611 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { | 610 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { |
612 | if ( w->client() ->identity() == clientname && !w->isFullyObscured() ) | 611 | if ( w->client() ->identity() == clientname && !w->isFullyObscured() ) |
613 | return TRUE; | 612 | return TRUE; |
614 | } | 613 | } |
615 | #endif | 614 | #endif |
616 | return FALSE; | 615 | return FALSE; |
617 | } | 616 | } |
618 | 617 | ||
619 | 618 | ||
620 | void Desktop::executeOrModify( const QString& appLnkFile ) | 619 | void Desktop::executeOrModify( const QString& appLnkFile ) |
621 | { | 620 | { |
622 | AppLnk lnk( MimeType::appsFolderName() + "/" + appLnkFile ); | 621 | AppLnk lnk( MimeType::appsFolderName() + "/" + appLnkFile ); |
623 | if ( lnk.isValid() ) { | 622 | if ( lnk.isValid() ) { |
624 | QCString app = lnk.exec().utf8(); | 623 | QCString app = lnk.exec().utf8(); |
625 | Global::terminateBuiltin( "calibrate" ); | ||
626 | if ( QCopChannel::isRegistered( "QPE/Application/" + app ) ) { | 624 | if ( QCopChannel::isRegistered( "QPE/Application/" + app ) ) { |
627 | // MRUList::addTask( &lnk ); | 625 | // MRUList::addTask( &lnk ); |
628 | if ( hasVisibleWindow( app ) ) | 626 | if ( hasVisibleWindow( app ) ) |
629 | QCopChannel::send( "QPE/Application/" + app, "nextView()" ); | 627 | QCopChannel::send( "QPE/Application/" + app, "nextView()" ); |
630 | else | 628 | else |
631 | QCopChannel::send( "QPE/Application/" + app, "raise()" ); | 629 | QCopChannel::send( "QPE/Application/" + app, "raise()" ); |
632 | } | 630 | } |
633 | else { | 631 | else { |
634 | lnk.execute(); | 632 | lnk.execute(); |
635 | } | 633 | } |
636 | } | 634 | } |
637 | } | 635 | } |
638 | 636 | ||
639 | // autoStarts apps on resume and start | 637 | // autoStarts apps on resume and start |
640 | void Desktop::execAutoStart() | 638 | void Desktop::execAutoStart() |
641 | { | 639 | { |
642 | QString appName; | 640 | QString appName; |
643 | int delay; | 641 | int delay; |
644 | QDateTime now = QDateTime::currentDateTime(); | 642 | QDateTime now = QDateTime::currentDateTime(); |
645 | Config cfg( "autostart" ); | 643 | Config cfg( "autostart" ); |
646 | cfg.setGroup( "AutoStart" ); | 644 | cfg.setGroup( "AutoStart" ); |
647 | appName = cfg.readEntry( "Apps", "" ); | 645 | appName = cfg.readEntry( "Apps", "" ); |
648 | delay = ( cfg.readEntry( "Delay", "0" ) ).toInt(); | 646 | delay = ( cfg.readEntry( "Delay", "0" ) ).toInt(); |
649 | // If the time between suspend and resume was longer then the | 647 | // If the time between suspend and resume was longer then the |
650 | // value saved as delay, start the app | 648 | // value saved as delay, start the app |
651 | if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) { | 649 | if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) { |
652 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 650 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
653 | e << QString( appName ); | 651 | e << QString( appName ); |
654 | } | 652 | } |
655 | } | 653 | } |
656 | 654 | ||
657 | #if defined(QPE_HAVE_TOGGLELIGHT) | 655 | #if defined(QPE_HAVE_TOGGLELIGHT) |
658 | #include <qpe/config.h> | 656 | #include <qpe/config.h> |
659 | 657 | ||
660 | #include <sys/ioctl.h> | 658 | #include <sys/ioctl.h> |
661 | #include <sys/types.h> | 659 | #include <sys/types.h> |
662 | #include <fcntl.h> | 660 | #include <fcntl.h> |
663 | #include <unistd.h> | 661 | #include <unistd.h> |
664 | #include <errno.h> | 662 | #include <errno.h> |
665 | #include <linux/ioctl.h> | 663 | #include <linux/ioctl.h> |
666 | #include <time.h> | 664 | #include <time.h> |
667 | #endif | 665 | #endif |
668 | 666 | ||
669 | 667 | ||
670 | void Desktop::togglePower() | 668 | void Desktop::togglePower() |
671 | { | 669 | { |
672 | static bool excllock = false; | 670 | static bool excllock = false; |
673 | 671 | ||
674 | if ( excllock ) | 672 | if ( excllock ) |
675 | return ; | 673 | return ; |
676 | 674 | ||
677 | excllock = true; | 675 | excllock = true; |
678 | 676 | ||
679 | bool wasloggedin = loggedin; | 677 | bool wasloggedin = loggedin; |
680 | loggedin = 0; | 678 | loggedin = 0; |
681 | suspendTime = QDateTime::currentDateTime(); | 679 | suspendTime = QDateTime::currentDateTime(); |
682 | 680 | ||
683 | #ifdef QWS | 681 | #ifdef QWS |
684 | 682 | ||
685 | if ( Password::needToAuthenticate ( true ) && qt_screen ) { | 683 | if ( Password::needToAuthenticate ( true ) && qt_screen ) { |
686 | // Should use a big black window instead. | 684 | // Should use a big black window instead. |
687 | // But this would not show up fast enough | 685 | // But this would not show up fast enough |
688 | QGfx *g = qt_screen-> screenGfx ( ); | 686 | QGfx *g = qt_screen-> screenGfx ( ); |
689 | g-> fillRect ( 0, 0, qt_screen-> width ( ), qt_screen-> height ( )); | 687 | g-> fillRect ( 0, 0, qt_screen-> width ( ), qt_screen-> height ( )); |
690 | delete g; | 688 | delete g; |
691 | } | 689 | } |
692 | #endif | 690 | #endif |
693 | 691 | ||
694 | ODevice::inst ( )-> suspend ( ); | 692 | ODevice::inst ( )-> suspend ( ); |
695 | 693 | ||
696 | DesktopApplication::switchLCD ( true ); // force LCD on without slow qcop call | 694 | DesktopApplication::switchLCD ( true ); // force LCD on without slow qcop call |
697 | QWSServer::screenSaverActivate ( false ); | 695 | QWSServer::screenSaverActivate ( false ); |
698 | 696 | ||
699 | { | 697 | { |
700 | QCopEnvelope( "QPE/Card", "mtabChanged()" ); // might have changed while asleep | 698 | QCopEnvelope( "QPE/Card", "mtabChanged()" ); // might have changed while asleep |
701 | } | 699 | } |
702 | 700 | ||
703 | if ( wasloggedin ) | 701 | if ( wasloggedin ) |
704 | login ( true ); | 702 | login ( true ); |
705 | 703 | ||
706 | execAutoStart(); | 704 | execAutoStart(); |
707 | //qcopBridge->closeOpenConnections(); | 705 | //qcopBridge->closeOpenConnections(); |
708 | 706 | ||
709 | excllock = false; | 707 | excllock = false; |
710 | } | 708 | } |
711 | 709 | ||
712 | void Desktop::toggleLight() | 710 | void Desktop::toggleLight() |
713 | { | 711 | { |
714 | QCopEnvelope e( "QPE/System", "setBacklight(int)" ); | 712 | QCopEnvelope e( "QPE/System", "setBacklight(int)" ); |
715 | e << -2; // toggle | 713 | e << -2; // toggle |
716 | } | 714 | } |
717 | 715 | ||
718 | void Desktop::toggleSymbolInput() | 716 | void Desktop::toggleSymbolInput() |
719 | { | 717 | { |
720 | tb->toggleSymbolInput(); | 718 | tb->toggleSymbolInput(); |
721 | } | 719 | } |
diff --git a/core/launcher/launcher.pro b/core/launcher/launcher.pro index d0a573b..007e48c 100644 --- a/core/launcher/launcher.pro +++ b/core/launcher/launcher.pro | |||
@@ -1,124 +1,120 @@ | |||
1 | TEMPLATE= app | 1 | TEMPLATE= app |
2 | CONFIG = qt warn_on release | 2 | CONFIG = qt warn_on release |
3 | DESTDIR = ../../bin | 3 | DESTDIR = ../../bin |
4 | HEADERS = background.h \ | 4 | HEADERS = background.h \ |
5 | desktop.h \ | 5 | desktop.h \ |
6 | screensaver.h \ | 6 | screensaver.h \ |
7 | mediummountgui.h \ | 7 | mediummountgui.h \ |
8 | info.h \ | 8 | info.h \ |
9 | appicons.h \ | 9 | appicons.h \ |
10 | taskbar.h \ | 10 | taskbar.h \ |
11 | sidething.h \ | 11 | sidething.h \ |
12 | runningappbar.h \ | 12 | runningappbar.h \ |
13 | stabmon.h \ | 13 | stabmon.h \ |
14 | inputmethods.h \ | 14 | inputmethods.h \ |
15 | systray.h \ | 15 | systray.h \ |
16 | wait.h \ | 16 | wait.h \ |
17 | shutdownimpl.h \ | 17 | shutdownimpl.h \ |
18 | launcher.h \ | 18 | launcher.h \ |
19 | launcherview.h \ | 19 | launcherview.h \ |
20 | ../../core/apps/calibrate/calibrate.h \ | ||
21 | startmenu.h \ | 20 | startmenu.h \ |
22 | transferserver.h \ | 21 | transferserver.h \ |
23 | qcopbridge.h \ | 22 | qcopbridge.h \ |
24 | packageslave.h \ | 23 | packageslave.h \ |
25 | irserver.h \ | 24 | irserver.h \ |
26 | ../../rsync/buf.h \ | 25 | ../../rsync/buf.h \ |
27 | ../../rsync/checksum.h \ | 26 | ../../rsync/checksum.h \ |
28 | ../../rsync/command.h \ | 27 | ../../rsync/command.h \ |
29 | ../../rsync/emit.h \ | 28 | ../../rsync/emit.h \ |
30 | ../../rsync/job.h \ | 29 | ../../rsync/job.h \ |
31 | ../../rsync/netint.h \ | 30 | ../../rsync/netint.h \ |
32 | ../../rsync/protocol.h \ | 31 | ../../rsync/protocol.h \ |
33 | ../../rsync/prototab.h \ | 32 | ../../rsync/prototab.h \ |
34 | ../../rsync/rsync.h \ | 33 | ../../rsync/rsync.h \ |
35 | ../../rsync/search.h \ | 34 | ../../rsync/search.h \ |
36 | ../../rsync/stream.h \ | 35 | ../../rsync/stream.h \ |
37 | ../../rsync/sumset.h \ | 36 | ../../rsync/sumset.h \ |
38 | ../../rsync/trace.h \ | 37 | ../../rsync/trace.h \ |
39 | ../../rsync/types.h \ | 38 | ../../rsync/types.h \ |
40 | ../../rsync/util.h \ | 39 | ../../rsync/util.h \ |
41 | ../../rsync/whole.h \ | 40 | ../../rsync/whole.h \ |
42 | ../../rsync/config_rsync.h \ | 41 | ../../rsync/config_rsync.h \ |
43 | ../../rsync/qrsync.h \ | 42 | ../../rsync/qrsync.h \ |
44 | quicklauncher.h | 43 | quicklauncher.h |
45 | SOURCES = background.cpp \ | 44 | SOURCES = background.cpp \ |
46 | desktop.cpp \ | 45 | desktop.cpp \ |
47 | screensaver.cpp \ | 46 | screensaver.cpp \ |
48 | mediummountgui.cpp \ | 47 | mediummountgui.cpp \ |
49 | info.cpp \ | 48 | info.cpp \ |
50 | appicons.cpp \ | 49 | appicons.cpp \ |
51 | taskbar.cpp \ | 50 | taskbar.cpp \ |
52 | sidething.cpp \ | 51 | sidething.cpp \ |
53 | runningappbar.cpp \ | 52 | runningappbar.cpp \ |
54 | stabmon.cpp \ | 53 | stabmon.cpp \ |
55 | inputmethods.cpp \ | 54 | inputmethods.cpp \ |
56 | systray.cpp \ | 55 | systray.cpp \ |
57 | wait.cpp \ | 56 | wait.cpp \ |
58 | shutdownimpl.cpp \ | 57 | shutdownimpl.cpp \ |
59 | launcher.cpp \ | 58 | launcher.cpp \ |
60 | launcherview.cpp \ | 59 | launcherview.cpp \ |
61 | ../../core/apps/calibrate/calibrate.cpp \ | ||
62 | transferserver.cpp \ | 60 | transferserver.cpp \ |
63 | packageslave.cpp \ | 61 | packageslave.cpp \ |
64 | irserver.cpp \ | 62 | irserver.cpp \ |
65 | qcopbridge.cpp \ | 63 | qcopbridge.cpp \ |
66 | startmenu.cpp \ | 64 | startmenu.cpp \ |
67 | main.cpp \ | 65 | main.cpp \ |
68 | ../../rsync/base64.c \ | 66 | ../../rsync/base64.c \ |
69 | ../../rsync/buf.c \ | 67 | ../../rsync/buf.c \ |
70 | ../../rsync/checksum.c \ | 68 | ../../rsync/checksum.c \ |
71 | ../../rsync/command.c \ | 69 | ../../rsync/command.c \ |
72 | ../../rsync/delta.c \ | 70 | ../../rsync/delta.c \ |
73 | ../../rsync/emit.c \ | 71 | ../../rsync/emit.c \ |
74 | ../../rsync/hex.c \ | 72 | ../../rsync/hex.c \ |
75 | ../../rsync/job.c \ | 73 | ../../rsync/job.c \ |
76 | ../../rsync/mdfour.c \ | 74 | ../../rsync/mdfour.c \ |
77 | ../../rsync/mksum.c \ | 75 | ../../rsync/mksum.c \ |
78 | ../../rsync/msg.c \ | 76 | ../../rsync/msg.c \ |
79 | ../../rsync/netint.c \ | 77 | ../../rsync/netint.c \ |
80 | ../../rsync/patch.c \ | 78 | ../../rsync/patch.c \ |
81 | ../../rsync/prototab.c \ | 79 | ../../rsync/prototab.c \ |
82 | ../../rsync/readsums.c \ | 80 | ../../rsync/readsums.c \ |
83 | ../../rsync/scoop.c \ | 81 | ../../rsync/scoop.c \ |
84 | ../../rsync/search.c \ | 82 | ../../rsync/search.c \ |
85 | ../../rsync/stats.c \ | 83 | ../../rsync/stats.c \ |
86 | ../../rsync/stream.c \ | 84 | ../../rsync/stream.c \ |
87 | ../../rsync/sumset.c \ | 85 | ../../rsync/sumset.c \ |
88 | ../../rsync/trace.c \ | 86 | ../../rsync/trace.c \ |
89 | ../../rsync/tube.c \ | 87 | ../../rsync/tube.c \ |
90 | ../../rsync/util.c \ | 88 | ../../rsync/util.c \ |
91 | ../../rsync/version.c \ | 89 | ../../rsync/version.c \ |
92 | ../../rsync/whole.c \ | 90 | ../../rsync/whole.c \ |
93 | ../../rsync/qrsync.cpp | 91 | ../../rsync/qrsync.cpp |
94 | INTERFACES= syncdialog.ui | 92 | INTERFACES= syncdialog.ui |
95 | INCLUDEPATH += ../../include | 93 | INCLUDEPATH += ../../include |
96 | DEPENDPATH+= ../../include . | 94 | DEPENDPATH+= ../../include . |
97 | INCLUDEPATH += ../../core/apps/calibrate | ||
98 | DEPENDPATH+= ../../core/apps/calibrate | ||
99 | INCLUDEPATH += ../../rsync | 95 | INCLUDEPATH += ../../rsync |
100 | DEPENDPATH+= ../../rsync | 96 | DEPENDPATH+= ../../rsync |
101 | TARGET = qpe | 97 | TARGET = qpe |
102 | LIBS += -lqpe -lcrypt -lopie | 98 | LIBS += -lqpe -lcrypt -lopie |
103 | 99 | ||
104 | TRANSLATIONS = ../../i18n/de/qpe.ts \ | 100 | TRANSLATIONS = ../../i18n/de/qpe.ts \ |
105 | ../../i18n/xx/qpe.ts \ | 101 | ../../i18n/xx/qpe.ts \ |
106 | ../../i18n/en/qpe.ts \ | 102 | ../../i18n/en/qpe.ts \ |
107 | ../../i18n/es/qpe.ts \ | 103 | ../../i18n/es/qpe.ts \ |
108 | ../../i18n/fr/qpe.ts \ | 104 | ../../i18n/fr/qpe.ts \ |
109 | ../../i18n/hu/qpe.ts \ | 105 | ../../i18n/hu/qpe.ts \ |
110 | ../../i18n/ja/qpe.ts \ | 106 | ../../i18n/ja/qpe.ts \ |
111 | ../../i18n/ko/qpe.ts \ | 107 | ../../i18n/ko/qpe.ts \ |
112 | ../../i18n/no/qpe.ts \ | 108 | ../../i18n/no/qpe.ts \ |
113 | ../../i18n/pl/qpe.ts \ | 109 | ../../i18n/pl/qpe.ts \ |
114 | ../../i18n/pt/qpe.ts \ | 110 | ../../i18n/pt/qpe.ts \ |
115 | ../../i18n/pt_BR/qpe.ts \ | 111 | ../../i18n/pt_BR/qpe.ts \ |
116 | ../../i18n/sl/qpe.ts \ | 112 | ../../i18n/sl/qpe.ts \ |
117 | ../../i18n/zh_CN/qpe.ts \ | 113 | ../../i18n/zh_CN/qpe.ts \ |
118 | ../../i18n/it/qpe.ts \ | 114 | ../../i18n/it/qpe.ts \ |
119 | ../../i18n/zh_TW/qpe.ts \ | 115 | ../../i18n/zh_TW/qpe.ts \ |
120 | ../../i18n/da/qpe.ts | 116 | ../../i18n/da/qpe.ts |
121 | 117 | ||
122 | 118 | ||
123 | 119 | ||
124 | include ( $(OPIEDIR)/include.pro ) | 120 | include ( $(OPIEDIR)/include.pro ) |
diff --git a/core/launcher/main.cpp b/core/launcher/main.cpp index 20a1ecd..e96eeae 100644 --- a/core/launcher/main.cpp +++ b/core/launcher/main.cpp | |||
@@ -1,191 +1,194 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include "desktop.h" | 21 | #include "desktop.h" |
22 | #include "taskbar.h" | 22 | #include "taskbar.h" |
23 | #include "stabmon.h" | 23 | #include "stabmon.h" |
24 | 24 | ||
25 | #include <qpe/qpeapplication.h> | 25 | #include <qpe/qpeapplication.h> |
26 | #include <qpe/network.h> | 26 | #include <qpe/network.h> |
27 | #include <qpe/config.h> | 27 | #include <qpe/config.h> |
28 | #if defined( QT_QWS_SL5XXX ) || defined( QT_QWS_IPAQ ) | 28 | #if defined( QT_QWS_SL5XXX ) || defined( QT_QWS_IPAQ ) |
29 | #include <qpe/custom.h> | 29 | #include <qpe/custom.h> |
30 | #endif | 30 | #endif |
31 | 31 | ||
32 | #include <opie/odevice.h> | 32 | #include <opie/odevice.h> |
33 | #include <opie/oprocess.h> | ||
33 | 34 | ||
34 | #include <qmessagebox.h> | 35 | #include <qmessagebox.h> |
35 | #include <qfile.h> | 36 | #include <qfile.h> |
36 | #include <qimage.h> | 37 | #include <qimage.h> |
37 | #include <qwindowsystem_qws.h> | 38 | #include <qwindowsystem_qws.h> |
38 | #include <qwsmouse_qws.h> | 39 | #include <qwsmouse_qws.h> |
39 | #include <qpe/qcopenvelope_qws.h> | 40 | #include <qpe/qcopenvelope_qws.h> |
40 | #include <qpe/alarmserver.h> | 41 | #include <qpe/alarmserver.h> |
41 | 42 | ||
42 | #include <stdlib.h> | 43 | #include <stdlib.h> |
43 | #include <stdio.h> | 44 | #include <stdio.h> |
44 | #include <signal.h> | 45 | #include <signal.h> |
45 | #include <unistd.h> | 46 | #include <unistd.h> |
46 | 47 | ||
47 | #include "../calibrate/calibrate.h" | ||
48 | |||
49 | using namespace Opie; | 48 | using namespace Opie; |
50 | 49 | ||
51 | void initEnvironment() | 50 | void initEnvironment() |
52 | { | 51 | { |
53 | int rot; | 52 | int rot; |
54 | Config config("locale"); | 53 | Config config("locale"); |
55 | 54 | ||
56 | config.setGroup( "Location" ); | 55 | config.setGroup( "Location" ); |
57 | QString tz = config.readEntry( "Timezone", getenv("TZ") ); | 56 | QString tz = config.readEntry( "Timezone", getenv("TZ") ); |
58 | 57 | ||
59 | // if not timezone set, pick New York | 58 | // if not timezone set, pick New York |
60 | if (tz.isNull()) | 59 | if (tz.isNull()) |
61 | tz = "America/New_York"; | 60 | tz = "America/New_York"; |
62 | 61 | ||
63 | setenv( "TZ", tz, 1 ); | 62 | setenv( "TZ", tz, 1 ); |
64 | config.writeEntry( "Timezone", tz); | 63 | config.writeEntry( "Timezone", tz); |
65 | 64 | ||
66 | config.setGroup( "Language" ); | 65 | config.setGroup( "Language" ); |
67 | QString lang = config.readEntry( "Language", getenv("LANG") ); | 66 | QString lang = config.readEntry( "Language", getenv("LANG") ); |
68 | if ( !lang.isNull() ) | 67 | if ( !lang.isNull() ) |
69 | setenv( "LANG", lang, 1 ); | 68 | setenv( "LANG", lang, 1 ); |
70 | 69 | ||
71 | #if !defined(QT_QWS_CASSIOPEIA) && !defined(QT_QWS_IPAQ) && !defined(QT_QWS_SL5XXX) | 70 | #if !defined(QT_QWS_CASSIOPEIA) && !defined(QT_QWS_IPAQ) && !defined(QT_QWS_SL5XXX) |
72 | setenv( "QWS_SIZE", "240x320", 0 ); | 71 | setenv( "QWS_SIZE", "240x320", 0 ); |
73 | #endif | 72 | #endif |
74 | 73 | ||
75 | QString env(getenv("QWS_DISPLAY")); | 74 | QString env(getenv("QWS_DISPLAY")); |
76 | if (env.contains("Transformed")) { | 75 | if (env.contains("Transformed")) { |
77 | // transformed driver default rotation is controlled by the hardware. | 76 | // transformed driver default rotation is controlled by the hardware. |
78 | Config config("qpe"); | 77 | Config config("qpe"); |
79 | config.setGroup( "Rotation" ); | 78 | config.setGroup( "Rotation" ); |
80 | if ( ( rot = config.readNumEntry( "Rot", -1 ) ) == -1 ) | 79 | if ( ( rot = config.readNumEntry( "Rot", -1 ) ) == -1 ) |
81 | rot = ODevice::inst ( )-> rotation ( ) * 90; | 80 | rot = ODevice::inst ( )-> rotation ( ) * 90; |
82 | 81 | ||
83 | setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(rot), 1); | 82 | setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(rot), 1); |
84 | QPEApplication::defaultRotation ( ); /* to ensure deforient matches reality */ | 83 | QPEApplication::defaultRotation ( ); /* to ensure deforient matches reality */ |
85 | } | 84 | } |
86 | } | 85 | } |
87 | 86 | ||
88 | 87 | ||
89 | int initApplication( int argc, char ** argv ) | 88 | int initApplication( int argc, char ** argv ) |
90 | { | 89 | { |
91 | initEnvironment(); | 90 | initEnvironment(); |
92 | 91 | ||
93 | //Don't flicker at startup: | 92 | //Don't flicker at startup: |
94 | QWSServer::setDesktopBackground( QImage() ); | 93 | QWSServer::setDesktopBackground( QImage() ); |
95 | 94 | ||
96 | DesktopApplication a( argc, argv, QApplication::GuiServer ); | 95 | DesktopApplication a( argc, argv, QApplication::GuiServer ); |
97 | 96 | ||
98 | ODevice::inst ( )-> setSoftSuspend ( true ); | 97 | ODevice::inst ( )-> setSoftSuspend ( true ); |
99 | 98 | ||
100 | { // init backlight | 99 | { // init backlight |
101 | QCopEnvelope e("QPE/System", "setBacklight(int)" ); | 100 | QCopEnvelope e("QPE/System", "setBacklight(int)" ); |
102 | e << -3; // Forced on | 101 | e << -3; // Forced on |
103 | } | 102 | } |
104 | 103 | ||
105 | AlarmServer::initialize(); | 104 | AlarmServer::initialize(); |
106 | 105 | ||
107 | Desktop *d = new Desktop(); | 106 | Desktop *d = new Desktop(); |
108 | 107 | ||
109 | QObject::connect( &a, SIGNAL(power()), d, SLOT(togglePower()) ); | 108 | QObject::connect( &a, SIGNAL(power()), d, SLOT(togglePower()) ); |
110 | QObject::connect( &a, SIGNAL(backlight()), d, SLOT(toggleLight()) ); | 109 | QObject::connect( &a, SIGNAL(backlight()), d, SLOT(toggleLight()) ); |
111 | QObject::connect( &a, SIGNAL(symbol()), d, SLOT(toggleSymbolInput()) ); | 110 | QObject::connect( &a, SIGNAL(symbol()), d, SLOT(toggleSymbolInput()) ); |
112 | QObject::connect( &a, SIGNAL(numLockStateToggle()), d, SLOT(toggleNumLockState()) ); | 111 | QObject::connect( &a, SIGNAL(numLockStateToggle()), d, SLOT(toggleNumLockState()) ); |
113 | QObject::connect( &a, SIGNAL(capsLockStateToggle()), d, SLOT(toggleCapsLockState()) ); | 112 | QObject::connect( &a, SIGNAL(capsLockStateToggle()), d, SLOT(toggleCapsLockState()) ); |
114 | QObject::connect( &a, SIGNAL(prepareForRestart()), d, SLOT(terminateServers()) ); | 113 | QObject::connect( &a, SIGNAL(prepareForRestart()), d, SLOT(terminateServers()) ); |
115 | 114 | ||
116 | (void)new SysFileMonitor(d); | 115 | (void)new SysFileMonitor(d); |
117 | Network::createServer(d); | 116 | Network::createServer(d); |
118 | 117 | ||
119 | if ( QWSServer::mouseHandler() ->inherits("QCalibratedMouseHandler") ) { | 118 | if ( QWSServer::mouseHandler() ->inherits("QCalibratedMouseHandler") ) { |
120 | if ( !QFile::exists( "/etc/pointercal" ) ) { | 119 | if ( !QFile::exists( "/etc/pointercal" ) ) { |
121 | // Make sure calibration widget starts on top. | 120 | OProcess cal; |
122 | Calibrate *cal = new Calibrate; | 121 | cal << "calibrate"; |
123 | cal->exec(); | 122 | |
124 | delete cal; | 123 | if ( ! cal.start(OProcess::Block, OProcess::NoCommunication) ) { |
124 | QMessageBox::warning( 0, "Unable to calibrate", | ||
125 | "Failed to start the calibration tool.\n" | ||
126 | ); | ||
127 | } | ||
125 | } | 128 | } |
126 | } | 129 | } |
127 | 130 | ||
128 | d->show(); | 131 | d->show(); |
129 | 132 | ||
130 | if ( QDate::currentDate ( ). year ( ) < 2000 ) { | 133 | if ( QDate::currentDate ( ). year ( ) < 2000 ) { |
131 | if ( QMessageBox::information ( 0, DesktopApplication::tr( "Information" ), DesktopApplication::tr( "<p>The system date doesn't seem to be valid.\n(%1)</p><p>Do you want to correct the clock ?</p>" ). arg( TimeString::dateString ( QDate::currentDate ( ))), QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) { | 134 | if ( QMessageBox::information ( 0, DesktopApplication::tr( "Information" ), DesktopApplication::tr( "<p>The system date doesn't seem to be valid.\n(%1)</p><p>Do you want to correct the clock ?</p>" ). arg( TimeString::dateString ( QDate::currentDate ( ))), QMessageBox::Yes, QMessageBox::No ) == QMessageBox::Yes ) { |
132 | QCopEnvelope e ( "QPE/Application/systemtime", "setDocument(QString)" ); | 135 | QCopEnvelope e ( "QPE/Application/systemtime", "setDocument(QString)" ); |
133 | e << QString ( ); | 136 | e << QString ( ); |
134 | } | 137 | } |
135 | } | 138 | } |
136 | 139 | ||
137 | int rv = a.exec(); | 140 | int rv = a.exec(); |
138 | 141 | ||
139 | delete d; | 142 | delete d; |
140 | 143 | ||
141 | ODevice::inst ( )-> setSoftSuspend ( false ); | 144 | ODevice::inst ( )-> setSoftSuspend ( false ); |
142 | 145 | ||
143 | return rv; | 146 | return rv; |
144 | } | 147 | } |
145 | 148 | ||
146 | static const char *pidfile_path = "/var/run/opie.pid"; | 149 | static const char *pidfile_path = "/var/run/opie.pid"; |
147 | 150 | ||
148 | void create_pidfile ( ) | 151 | void create_pidfile ( ) |
149 | { | 152 | { |
150 | FILE *f; | 153 | FILE *f; |
151 | 154 | ||
152 | if (( f = ::fopen ( pidfile_path, "w" ))) { | 155 | if (( f = ::fopen ( pidfile_path, "w" ))) { |
153 | ::fprintf ( f, "%d", getpid ( )); | 156 | ::fprintf ( f, "%d", getpid ( )); |
154 | ::fclose ( f ); | 157 | ::fclose ( f ); |
155 | } | 158 | } |
156 | } | 159 | } |
157 | 160 | ||
158 | void remove_pidfile ( ) | 161 | void remove_pidfile ( ) |
159 | { | 162 | { |
160 | ::unlink ( pidfile_path ); | 163 | ::unlink ( pidfile_path ); |
161 | } | 164 | } |
162 | 165 | ||
163 | void handle_sigterm ( int /* sig */ ) | 166 | void handle_sigterm ( int /* sig */ ) |
164 | { | 167 | { |
165 | if ( qApp ) | 168 | if ( qApp ) |
166 | qApp-> quit ( ); | 169 | qApp-> quit ( ); |
167 | } | 170 | } |
168 | 171 | ||
169 | int main( int argc, char ** argv ) | 172 | int main( int argc, char ** argv ) |
170 | { | 173 | { |
171 | ::signal ( SIGCHLD, SIG_IGN ); | 174 | ::signal ( SIGCHLD, SIG_IGN ); |
172 | 175 | ||
173 | ::signal ( SIGTERM, handle_sigterm ); | 176 | ::signal ( SIGTERM, handle_sigterm ); |
174 | ::signal ( SIGINT, handle_sigterm ); | 177 | ::signal ( SIGINT, handle_sigterm ); |
175 | 178 | ||
176 | ::setsid ( ); | 179 | ::setsid ( ); |
177 | ::setpgid ( 0, 0 ); | 180 | ::setpgid ( 0, 0 ); |
178 | 181 | ||
179 | ::atexit ( remove_pidfile ); | 182 | ::atexit ( remove_pidfile ); |
180 | create_pidfile ( ); | 183 | create_pidfile ( ); |
181 | 184 | ||
182 | int retVal = initApplication ( argc, argv ); | 185 | int retVal = initApplication ( argc, argv ); |
183 | 186 | ||
184 | // Kill them. Kill them all. | 187 | // Kill them. Kill them all. |
185 | ::kill ( 0, SIGTERM ); | 188 | ::kill ( 0, SIGTERM ); |
186 | ::sleep ( 1 ); | 189 | ::sleep ( 1 ); |
187 | ::kill ( 0, SIGKILL ); | 190 | ::kill ( 0, SIGKILL ); |
188 | 191 | ||
189 | return retVal; | 192 | return retVal; |
190 | } | 193 | } |
191 | 194 | ||
diff --git a/core/launcher/opie-taskbar.control b/core/launcher/opie-taskbar.control index c0430b7..db66a05 100644 --- a/core/launcher/opie-taskbar.control +++ b/core/launcher/opie-taskbar.control | |||
@@ -1,9 +1,9 @@ | |||
1 | Files: bin/qpe apps/Settings/Calibrate.desktop pics/launcher pics/devicebuttons/*.png plugins/applets/libsuspendapplet.so* plugins/applets/libhomeapplet.so* plugins/applets/liblogoutapplet.so* plugins/applets/librotateapplet.so* root/etc/init.d/opie | 1 | Files: bin/qpe pics/launcher pics/devicebuttons/*.png plugins/applets/libsuspendapplet.so* plugins/applets/libhomeapplet.so* plugins/applets/liblogoutapplet.so* plugins/applets/librotateapplet.so* root/etc/init.d/opie |
2 | Priority: required | 2 | Priority: required |
3 | Section: opie/system | 3 | Section: opie/system |
4 | Maintainer: Project Opie <opie@handhelds.org> | 4 | Maintainer: Project Opie <opie@handhelds.org> |
5 | Architecture: arm | 5 | Architecture: arm |
6 | Version: $QPE_VERSION-$SUB_VERSION.3 | 6 | Version: $QPE_VERSION-$SUB_VERSION.3 |
7 | Depends: opie-base | 7 | Depends: opie-base, opie-calibrate |
8 | Replaces: opie-rotation | 8 | Replaces: opie-rotation |
9 | Description: Launcher for Opie | 9 | Description: Launcher for Opie |
diff --git a/core/launcher/taskbar.cpp b/core/launcher/taskbar.cpp index 8af568d..8158128 100644 --- a/core/launcher/taskbar.cpp +++ b/core/launcher/taskbar.cpp | |||
@@ -1,189 +1,185 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | *********************************************************************/ | 19 | *********************************************************************/ |
20 | 20 | ||
21 | #include "startmenu.h" | 21 | #include "startmenu.h" |
22 | #include "inputmethods.h" | 22 | #include "inputmethods.h" |
23 | #include "runningappbar.h" | 23 | #include "runningappbar.h" |
24 | #include "systray.h" | 24 | #include "systray.h" |
25 | #include "calibrate.h" | ||
26 | #include "wait.h" | 25 | #include "wait.h" |
27 | #include "appicons.h" | 26 | #include "appicons.h" |
28 | 27 | ||
29 | #include "taskbar.h" | 28 | #include "taskbar.h" |
30 | #include "desktop.h" | 29 | #include "desktop.h" |
31 | 30 | ||
32 | #include <qpe/qpeapplication.h> | 31 | #include <qpe/qpeapplication.h> |
33 | #include <qpe/qcopenvelope_qws.h> | 32 | #include <qpe/qcopenvelope_qws.h> |
34 | #include <qpe/global.h> | 33 | #include <qpe/global.h> |
35 | 34 | ||
36 | #if defined( QT_QWS_SL5XXX ) || defined( QT_QWS_IPAQ ) | 35 | #if defined( QT_QWS_SL5XXX ) || defined( QT_QWS_IPAQ ) |
37 | #include <qpe/custom.h> | 36 | #include <qpe/custom.h> |
38 | #endif | 37 | #endif |
39 | 38 | ||
40 | #include <opie/odevice.h> | 39 | #include <opie/odevice.h> |
41 | 40 | ||
42 | #include <qlabel.h> | 41 | #include <qlabel.h> |
43 | #include <qlayout.h> | 42 | #include <qlayout.h> |
44 | #include <qtimer.h> | 43 | #include <qtimer.h> |
45 | #include <qwindowsystem_qws.h> | 44 | #include <qwindowsystem_qws.h> |
46 | #include <qwidgetstack.h> | 45 | #include <qwidgetstack.h> |
47 | 46 | ||
48 | #if defined( Q_WS_QWS ) | 47 | #if defined( Q_WS_QWS ) |
49 | #include <qwsdisplay_qws.h> | 48 | #include <qwsdisplay_qws.h> |
50 | #include <qgfx_qws.h> | 49 | #include <qgfx_qws.h> |
51 | #endif | 50 | #endif |
52 | 51 | ||
53 | 52 | ||
54 | using namespace Opie; | 53 | using namespace Opie; |
55 | 54 | ||
56 | #define FACTORY(T) \ | 55 | #define FACTORY(T) \ |
57 | static QWidget *new##T( bool maximized ) { \ | 56 | static QWidget *new##T( bool maximized ) { \ |
58 | QWidget *w = new T( 0, "test", QWidget::WDestructiveClose | QWidget::WGroupLeader ); \ | 57 | QWidget *w = new T( 0, "test", QWidget::WDestructiveClose | QWidget::WGroupLeader ); \ |
59 | if ( maximized ) { \ | 58 | if ( maximized ) { \ |
60 | if ( qApp->desktop()->width() <= 350 ) { \ | 59 | if ( qApp->desktop()->width() <= 350 ) { \ |
61 | w->showMaximized(); \ | 60 | w->showMaximized(); \ |
62 | } else { \ | 61 | } else { \ |
63 | w->resize( QSize( 300, 300 ) ); \ | 62 | w->resize( QSize( 300, 300 ) ); \ |
64 | } \ | 63 | } \ |
65 | } \ | 64 | } \ |
66 | w->show(); \ | 65 | w->show(); \ |
67 | return w; \ | 66 | return w; \ |
68 | } | 67 | } |
69 | 68 | ||
70 | 69 | ||
71 | #ifdef SINGLE_APP | 70 | #ifdef SINGLE_APP |
72 | #define APP(a,b,c,d) FACTORY(b) | 71 | #define APP(a,b,c,d) FACTORY(b) |
73 | #include "../launcher/apps.h" | 72 | #include "../launcher/apps.h" |
74 | #undef APP | 73 | #undef APP |
75 | #endif // SINGLE_APP | 74 | #endif // SINGLE_APP |
76 | 75 | ||
77 | static Global::Command builtins[] = { | 76 | static Global::Command builtins[] = { |
78 | 77 | ||
79 | #ifdef SINGLE_APP | 78 | #ifdef SINGLE_APP |
80 | #define APP(a,b,c,d) { a, new##b, c }, | 79 | #define APP(a,b,c,d) { a, new##b, c }, |
81 | #include "../launcher/apps.h" | 80 | #include "../launcher/apps.h" |
82 | #undef APP | 81 | #undef APP |
83 | #endif | 82 | #endif |
84 | 83 | ||
85 | #if defined(QT_QWS_IPAQ) || defined(QT_QWS_CASSIOPEIA) || defined(QT_QWS_SL5XXX) | ||
86 | { "calibrate", TaskBar::calibrate, 1, 0 }, | ||
87 | #endif | ||
88 | #if !defined(QT_QWS_CASSIOPEIA) | 84 | #if !defined(QT_QWS_CASSIOPEIA) |
89 | { "shutdown", Global::shutdown, 1, 0 }, | 85 | { "shutdown", Global::shutdown, 1, 0 }, |
90 | // { "run", run, 1, 0 }, | 86 | // { "run", run, 1, 0 }, |
91 | #endif | 87 | #endif |
92 | 88 | ||
93 | { 0, TaskBar::calibrate, 0, 0 }, | 89 | { 0, 0, 0, 0 }, |
94 | }; | 90 | }; |
95 | 91 | ||
96 | static bool initNumLock() | 92 | static bool initNumLock() |
97 | { | 93 | { |
98 | #ifdef QPE_INITIAL_NUMLOCK_STATE | 94 | #ifdef QPE_INITIAL_NUMLOCK_STATE |
99 | QPE_INITIAL_NUMLOCK_STATE | 95 | QPE_INITIAL_NUMLOCK_STATE |
100 | #endif | 96 | #endif |
101 | return FALSE; | 97 | return FALSE; |
102 | } | 98 | } |
103 | 99 | ||
104 | class LockKeyState : public QWidget | 100 | class LockKeyState : public QWidget |
105 | { | 101 | { |
106 | public: | 102 | public: |
107 | LockKeyState( QWidget *parent ) : | 103 | LockKeyState( QWidget *parent ) : |
108 | QWidget(parent), | 104 | QWidget(parent), |
109 | nl(initNumLock()), cl(FALSE) | 105 | nl(initNumLock()), cl(FALSE) |
110 | { | 106 | { |
111 | nl_pm = Resource::loadPixmap("numlock"); | 107 | nl_pm = Resource::loadPixmap("numlock"); |
112 | cl_pm = Resource::loadPixmap("capslock"); | 108 | cl_pm = Resource::loadPixmap("capslock"); |
113 | } | 109 | } |
114 | QSize sizeHint() const | 110 | QSize sizeHint() const |
115 | { | 111 | { |
116 | return QSize(nl_pm.width()+2,nl_pm.width()+nl_pm.height()+1); | 112 | return QSize(nl_pm.width()+2,nl_pm.width()+nl_pm.height()+1); |
117 | } | 113 | } |
118 | void toggleNumLockState() | 114 | void toggleNumLockState() |
119 | { | 115 | { |
120 | nl = !nl; repaint(); | 116 | nl = !nl; repaint(); |
121 | } | 117 | } |
122 | void toggleCapsLockState() | 118 | void toggleCapsLockState() |
123 | { | 119 | { |
124 | cl = !cl; repaint(); | 120 | cl = !cl; repaint(); |
125 | } | 121 | } |
126 | void paintEvent( QPaintEvent * ) | 122 | void paintEvent( QPaintEvent * ) |
127 | { | 123 | { |
128 | int y = (height()-sizeHint().height())/2; | 124 | int y = (height()-sizeHint().height())/2; |
129 | QPainter p(this); | 125 | QPainter p(this); |
130 | if ( nl ) | 126 | if ( nl ) |
131 | p.drawPixmap(1,y,nl_pm); | 127 | p.drawPixmap(1,y,nl_pm); |
132 | if ( cl ) | 128 | if ( cl ) |
133 | p.drawPixmap(1,y+nl_pm.height()+1,cl_pm); | 129 | p.drawPixmap(1,y+nl_pm.height()+1,cl_pm); |
134 | } | 130 | } |
135 | private: | 131 | private: |
136 | QPixmap nl_pm, cl_pm; | 132 | QPixmap nl_pm, cl_pm; |
137 | bool nl, cl; | 133 | bool nl, cl; |
138 | }; | 134 | }; |
139 | 135 | ||
140 | TaskBar::~TaskBar() | 136 | TaskBar::~TaskBar() |
141 | { | 137 | { |
142 | } | 138 | } |
143 | 139 | ||
144 | 140 | ||
145 | TaskBar::TaskBar() : QHBox(0, 0, WStyle_Customize | WStyle_Tool | WStyle_StaysOnTop | WGroupLeader) | 141 | TaskBar::TaskBar() : QHBox(0, 0, WStyle_Customize | WStyle_Tool | WStyle_StaysOnTop | WGroupLeader) |
146 | { | 142 | { |
147 | Global::setBuiltinCommands(builtins); | 143 | Global::setBuiltinCommands(builtins); |
148 | 144 | ||
149 | sm = new StartMenu( this ); | 145 | sm = new StartMenu( this ); |
150 | 146 | ||
151 | inputMethods = new InputMethods( this ); | 147 | inputMethods = new InputMethods( this ); |
152 | connect( inputMethods, SIGNAL(inputToggled(bool)), | 148 | connect( inputMethods, SIGNAL(inputToggled(bool)), |
153 | this, SLOT(calcMaxWindowRect()) ); | 149 | this, SLOT(calcMaxWindowRect()) ); |
154 | //new QuickLauncher( this ); | 150 | //new QuickLauncher( this ); |
155 | 151 | ||
156 | stack = new QWidgetStack( this ); | 152 | stack = new QWidgetStack( this ); |
157 | stack->setSizePolicy( QSizePolicy( QSizePolicy::Expanding, QSizePolicy::Minimum ) ); | 153 | stack->setSizePolicy( QSizePolicy( QSizePolicy::Expanding, QSizePolicy::Minimum ) ); |
158 | label = new QLabel(stack); | 154 | label = new QLabel(stack); |
159 | 155 | ||
160 | //mru = new MRUList( stack ); | 156 | //mru = new MRUList( stack ); |
161 | //stack->raiseWidget( mru ); | 157 | //stack->raiseWidget( mru ); |
162 | 158 | ||
163 | runningAppBar = new RunningAppBar(stack); | 159 | runningAppBar = new RunningAppBar(stack); |
164 | stack->raiseWidget(runningAppBar); | 160 | stack->raiseWidget(runningAppBar); |
165 | 161 | ||
166 | waitIcon = new Wait( this ); | 162 | waitIcon = new Wait( this ); |
167 | (void) new AppIcons( this ); | 163 | (void) new AppIcons( this ); |
168 | 164 | ||
169 | sysTray = new SysTray( this ); | 165 | sysTray = new SysTray( this ); |
170 | 166 | ||
171 | // ## make customizable in some way? | 167 | // ## make customizable in some way? |
172 | lockState = new LockKeyState( this ); | 168 | lockState = new LockKeyState( this ); |
173 | 169 | ||
174 | #if defined(Q_WS_QWS) | 170 | #if defined(Q_WS_QWS) |
175 | #if !defined(QT_NO_COP) | 171 | #if !defined(QT_NO_COP) |
176 | QCopChannel *channel = new QCopChannel( "QPE/TaskBar", this ); | 172 | QCopChannel *channel = new QCopChannel( "QPE/TaskBar", this ); |
177 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 173 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
178 | this, SLOT(receive(const QCString&, const QByteArray&)) ); | 174 | this, SLOT(receive(const QCString&, const QByteArray&)) ); |
179 | #endif | 175 | #endif |
180 | #endif | 176 | #endif |
181 | waitTimer = new QTimer( this ); | 177 | waitTimer = new QTimer( this ); |
182 | connect( waitTimer, SIGNAL( timeout() ), this, SLOT( stopWait() ) ); | 178 | connect( waitTimer, SIGNAL( timeout() ), this, SLOT( stopWait() ) ); |
183 | clearer = new QTimer( this ); | 179 | clearer = new QTimer( this ); |
184 | QObject::connect(clearer, SIGNAL(timeout()), SLOT(clearStatusBar())); | 180 | QObject::connect(clearer, SIGNAL(timeout()), SLOT(clearStatusBar())); |
185 | QObject::connect(clearer, SIGNAL(timeout()), sysTray, SLOT(show())); | 181 | QObject::connect(clearer, SIGNAL(timeout()), sysTray, SLOT(show())); |
186 | } | 182 | } |
187 | 183 | ||
188 | void TaskBar::setStatusMessage( const QString &text ) | 184 | void TaskBar::setStatusMessage( const QString &text ) |
189 | { | 185 | { |
@@ -213,132 +209,121 @@ void TaskBar::startWait() | |||
213 | } | 209 | } |
214 | 210 | ||
215 | void TaskBar::stopWait(const QString& /*app*/) | 211 | void TaskBar::stopWait(const QString& /*app*/) |
216 | { | 212 | { |
217 | waitTimer->stop(); | 213 | waitTimer->stop(); |
218 | //mru->addTask(sm->execToLink(app)); | 214 | //mru->addTask(sm->execToLink(app)); |
219 | waitIcon->setWaiting( false ); | 215 | waitIcon->setWaiting( false ); |
220 | } | 216 | } |
221 | 217 | ||
222 | void TaskBar::stopWait() | 218 | void TaskBar::stopWait() |
223 | { | 219 | { |
224 | waitTimer->stop(); | 220 | waitTimer->stop(); |
225 | 221 | ||
226 | waitIcon->setWaiting( false ); | 222 | waitIcon->setWaiting( false ); |
227 | } | 223 | } |
228 | 224 | ||
229 | void TaskBar::resizeEvent( QResizeEvent *e ) | 225 | void TaskBar::resizeEvent( QResizeEvent *e ) |
230 | { | 226 | { |
231 | QHBox::resizeEvent( e ); | 227 | QHBox::resizeEvent( e ); |
232 | calcMaxWindowRect(); | 228 | calcMaxWindowRect(); |
233 | } | 229 | } |
234 | 230 | ||
235 | void TaskBar::styleChange( QStyle &s ) | 231 | void TaskBar::styleChange( QStyle &s ) |
236 | { | 232 | { |
237 | QHBox::styleChange( s ); | 233 | QHBox::styleChange( s ); |
238 | calcMaxWindowRect(); | 234 | calcMaxWindowRect(); |
239 | } | 235 | } |
240 | 236 | ||
241 | void TaskBar::calcMaxWindowRect() | 237 | void TaskBar::calcMaxWindowRect() |
242 | { | 238 | { |
243 | #ifdef Q_WS_QWS | 239 | #ifdef Q_WS_QWS |
244 | QRect wr; | 240 | QRect wr; |
245 | int displayWidth = qApp->desktop()->width(); | 241 | int displayWidth = qApp->desktop()->width(); |
246 | QRect ir = inputMethods->inputRect(); | 242 | QRect ir = inputMethods->inputRect(); |
247 | if ( ir.isValid() ) { | 243 | if ( ir.isValid() ) { |
248 | wr.setCoords( 0, 0, displayWidth-1, ir.top()-1 ); | 244 | wr.setCoords( 0, 0, displayWidth-1, ir.top()-1 ); |
249 | } else { | 245 | } else { |
250 | wr.setCoords( 0, 0, displayWidth-1, y()-1 ); | 246 | wr.setCoords( 0, 0, displayWidth-1, y()-1 ); |
251 | } | 247 | } |
252 | 248 | ||
253 | #if QT_VERSION < 300 | 249 | #if QT_VERSION < 300 |
254 | QWSServer::setMaxWindowRect( qt_screen->mapToDevice(wr, | 250 | QWSServer::setMaxWindowRect( qt_screen->mapToDevice(wr, |
255 | QSize(qt_screen->width(),qt_screen->height())) | 251 | QSize(qt_screen->width(),qt_screen->height())) |
256 | ); | 252 | ); |
257 | #else | 253 | #else |
258 | QWSServer::setMaxWindowRect( wr ); | 254 | QWSServer::setMaxWindowRect( wr ); |
259 | #endif | 255 | #endif |
260 | #endif | 256 | #endif |
261 | } | 257 | } |
262 | 258 | ||
263 | void TaskBar::receive( const QCString &msg, const QByteArray &data ) | 259 | void TaskBar::receive( const QCString &msg, const QByteArray &data ) |
264 | { | 260 | { |
265 | QDataStream stream( data, IO_ReadOnly ); | 261 | QDataStream stream( data, IO_ReadOnly ); |
266 | if ( msg == "message(QString)" ) { | 262 | if ( msg == "message(QString)" ) { |
267 | QString text; | 263 | QString text; |
268 | stream >> text; | 264 | stream >> text; |
269 | setStatusMessage( text ); | 265 | setStatusMessage( text ); |
270 | } else if ( msg == "hideInputMethod()" ) { | 266 | } else if ( msg == "hideInputMethod()" ) { |
271 | inputMethods->hideInputMethod(); | 267 | inputMethods->hideInputMethod(); |
272 | } else if ( msg == "showInputMethod()" ) { | 268 | } else if ( msg == "showInputMethod()" ) { |
273 | inputMethods->showInputMethod(); | 269 | inputMethods->showInputMethod(); |
274 | } else if ( msg == "reloadInputMethods()" ) { | 270 | } else if ( msg == "reloadInputMethods()" ) { |
275 | inputMethods->loadInputMethods(); | 271 | inputMethods->loadInputMethods(); |
276 | } else if ( msg == "reloadApps()" ) { | 272 | } else if ( msg == "reloadApps()" ) { |
277 | sm->reloadApps(); | 273 | sm->reloadApps(); |
278 | } else if ( msg == "reloadApplets()" ) { | 274 | } else if ( msg == "reloadApplets()" ) { |
279 | sysTray->clearApplets(); | 275 | sysTray->clearApplets(); |
280 | sysTray->addApplets(); | 276 | sysTray->addApplets(); |
281 | sm->reloadApplets(); | 277 | sm->reloadApplets(); |
282 | } else if ( msg == "soundAlarm()" ) { | 278 | } else if ( msg == "soundAlarm()" ) { |
283 | DesktopApplication::soundAlarm ( ); | 279 | DesktopApplication::soundAlarm ( ); |
284 | } | 280 | } |
285 | else if ( msg == "setLed(int,bool)" ) { | 281 | else if ( msg == "setLed(int,bool)" ) { |
286 | int led, status; | 282 | int led, status; |
287 | stream >> led >> status; | 283 | stream >> led >> status; |
288 | 284 | ||
289 | QValueList <OLed> ll = ODevice::inst ( )-> ledList ( ); | 285 | QValueList <OLed> ll = ODevice::inst ( )-> ledList ( ); |
290 | if ( ll. count ( )){ | 286 | if ( ll. count ( )){ |
291 | OLed l = ll. contains ( Led_Mail ) ? Led_Mail : ll [0]; | 287 | OLed l = ll. contains ( Led_Mail ) ? Led_Mail : ll [0]; |
292 | bool canblink = ODevice::inst ( )-> ledStateList ( l ). contains ( Led_BlinkSlow ); | 288 | bool canblink = ODevice::inst ( )-> ledStateList ( l ). contains ( Led_BlinkSlow ); |
293 | 289 | ||
294 | ODevice::inst ( )-> setLedState ( l, status ? ( canblink ? Led_BlinkSlow : Led_On ) : Led_Off ); | 290 | ODevice::inst ( )-> setLedState ( l, status ? ( canblink ? Led_BlinkSlow : Led_On ) : Led_Off ); |
295 | } | 291 | } |
296 | } | 292 | } |
297 | else if ( msg == "toggleMenu()" ) { | 293 | else if ( msg == "toggleMenu()" ) { |
298 | if ( sm-> launchMenu-> isVisible ( )) | 294 | if ( sm-> launchMenu-> isVisible ( )) |
299 | sm-> launch ( ); | 295 | sm-> launch ( ); |
300 | else { | 296 | else { |
301 | QCopEnvelope e ( "QPE/System", "toggleApplicationMenu()" ); | 297 | QCopEnvelope e ( "QPE/System", "toggleApplicationMenu()" ); |
302 | } | 298 | } |
303 | } | 299 | } |
304 | else if ( msg == "toggleStartMenu()" ) { | 300 | else if ( msg == "toggleStartMenu()" ) { |
305 | sm-> launch ( ); | 301 | sm-> launch ( ); |
306 | } | 302 | } |
307 | } | 303 | } |
308 | 304 | ||
309 | QWidget *TaskBar::calibrate(bool) | ||
310 | { | ||
311 | #ifdef Q_WS_QWS | ||
312 | Calibrate *c = new Calibrate; | ||
313 | c->show(); | ||
314 | return c; | ||
315 | #else | ||
316 | return 0; | ||
317 | #endif | ||
318 | } | ||
319 | |||
320 | void TaskBar::toggleNumLockState() | 305 | void TaskBar::toggleNumLockState() |
321 | { | 306 | { |
322 | if ( lockState ) lockState->toggleNumLockState(); | 307 | if ( lockState ) lockState->toggleNumLockState(); |
323 | } | 308 | } |
324 | 309 | ||
325 | void TaskBar::toggleCapsLockState() | 310 | void TaskBar::toggleCapsLockState() |
326 | { | 311 | { |
327 | if ( lockState ) lockState->toggleCapsLockState(); | 312 | if ( lockState ) lockState->toggleCapsLockState(); |
328 | } | 313 | } |
329 | 314 | ||
330 | void TaskBar::toggleSymbolInput() | 315 | void TaskBar::toggleSymbolInput() |
331 | { | 316 | { |
332 | if ( inputMethods->currentShown() == "Unicode" ) { | 317 | if ( inputMethods->currentShown() == "Unicode" ) { |
333 | inputMethods->hideInputMethod(); | 318 | inputMethods->hideInputMethod(); |
334 | } else { | 319 | } else { |
335 | inputMethods->showInputMethod("Unicode"); | 320 | inputMethods->showInputMethod("Unicode"); |
336 | } | 321 | } |
337 | } | 322 | } |
338 | 323 | ||
339 | bool TaskBar::recoverMemory() | 324 | bool TaskBar::recoverMemory() |
340 | { | 325 | { |
341 | //eturn mru->quitOldApps(); | 326 | //eturn mru->quitOldApps(); |
342 | return true; | 327 | return true; |
343 | } | 328 | } |
344 | 329 | ||
diff --git a/core/launcher/taskbar.h b/core/launcher/taskbar.h index a0bf395..575a8c9 100644 --- a/core/launcher/taskbar.h +++ b/core/launcher/taskbar.h | |||
@@ -1,85 +1,83 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #ifndef __TASKBAR_H__ | 21 | #ifndef __TASKBAR_H__ |
22 | #define __TASKBAR_H__ | 22 | #define __TASKBAR_H__ |
23 | 23 | ||
24 | #include <qhbox.h> | 24 | #include <qhbox.h> |
25 | 25 | ||
26 | class QLabel; | 26 | class QLabel; |
27 | class QTimer; | 27 | class QTimer; |
28 | class InputMethods; | 28 | class InputMethods; |
29 | class Wait; | 29 | class Wait; |
30 | class SysTray; | 30 | class SysTray; |
31 | //class MRUList; | 31 | //class MRUList; |
32 | class RunningAppBar; | 32 | class RunningAppBar; |
33 | class QWidgetStack; | 33 | class QWidgetStack; |
34 | class QTimer; | 34 | class QTimer; |
35 | class QLabel; | 35 | class QLabel; |
36 | class StartMenu; | 36 | class StartMenu; |
37 | class LockKeyState; | 37 | class LockKeyState; |
38 | 38 | ||
39 | class TaskBar : public QHBox { | 39 | class TaskBar : public QHBox { |
40 | Q_OBJECT | 40 | Q_OBJECT |
41 | public: | 41 | public: |
42 | TaskBar(); | 42 | TaskBar(); |
43 | ~TaskBar(); | 43 | ~TaskBar(); |
44 | 44 | ||
45 | static QWidget *calibrate( bool ); | ||
46 | |||
47 | bool recoverMemory(); | 45 | bool recoverMemory(); |
48 | 46 | ||
49 | StartMenu *startMenu() const { return sm; } | 47 | StartMenu *startMenu() const { return sm; } |
50 | public slots: | 48 | public slots: |
51 | void startWait(); | 49 | void startWait(); |
52 | void stopWait(const QString&); | 50 | void stopWait(const QString&); |
53 | void stopWait(); | 51 | void stopWait(); |
54 | void clearStatusBar(); | 52 | void clearStatusBar(); |
55 | void toggleNumLockState(); | 53 | void toggleNumLockState(); |
56 | void toggleCapsLockState(); | 54 | void toggleCapsLockState(); |
57 | void toggleSymbolInput(); | 55 | void toggleSymbolInput(); |
58 | 56 | ||
59 | protected: | 57 | protected: |
60 | void resizeEvent( QResizeEvent * ); | 58 | void resizeEvent( QResizeEvent * ); |
61 | void styleChange( QStyle & ); | 59 | void styleChange( QStyle & ); |
62 | void setStatusMessage( const QString &text ); | 60 | void setStatusMessage( const QString &text ); |
63 | 61 | ||
64 | public slots: | 62 | public slots: |
65 | void calcMaxWindowRect(); | 63 | void calcMaxWindowRect(); |
66 | private slots: | 64 | private slots: |
67 | void receive( const QCString &msg, const QByteArray &data ); | 65 | void receive( const QCString &msg, const QByteArray &data ); |
68 | 66 | ||
69 | private: | 67 | private: |
70 | 68 | ||
71 | QTimer *waitTimer; | 69 | QTimer *waitTimer; |
72 | Wait *waitIcon; | 70 | Wait *waitIcon; |
73 | InputMethods *inputMethods; | 71 | InputMethods *inputMethods; |
74 | SysTray *sysTray; | 72 | SysTray *sysTray; |
75 | // MRUList *mru; | 73 | // MRUList *mru; |
76 | RunningAppBar* runningAppBar; | 74 | RunningAppBar* runningAppBar; |
77 | QWidgetStack *stack; | 75 | QWidgetStack *stack; |
78 | QTimer *clearer; | 76 | QTimer *clearer; |
79 | QLabel *label; | 77 | QLabel *label; |
80 | LockKeyState* lockState; | 78 | LockKeyState* lockState; |
81 | StartMenu *sm; | 79 | StartMenu *sm; |
82 | }; | 80 | }; |
83 | 81 | ||
84 | 82 | ||
85 | #endif // __TASKBAR_H__ | 83 | #endif // __TASKBAR_H__ |