author | zecke <zecke> | 2002-10-17 16:45:38 (UTC) |
---|---|---|
committer | zecke <zecke> | 2002-10-17 16:45:38 (UTC) |
commit | 0655456f68849bfad9019a7760dec961792d7519 (patch) (unidiff) | |
tree | 4651cad54a144385442a26e78f4a83b57501830f | |
parent | 8511273d7122d50ffea27f78ba13ab72af60326d (diff) | |
download | opie-0655456f68849bfad9019a7760dec961792d7519.zip opie-0655456f68849bfad9019a7760dec961792d7519.tar.gz opie-0655456f68849bfad9019a7760dec961792d7519.tar.bz2 |
Move around some #ifdefs to be able to be built with Qt2/X11
-rw-r--r-- | core/launcher/desktop.cpp | 10 | ||||
-rw-r--r-- | core/launcher/launcher.cpp | 2 | ||||
-rw-r--r-- | core/launcher/main.cpp | 7 | ||||
-rw-r--r-- | core/launcher/qcopbridge.cpp | 2 | ||||
-rw-r--r-- | core/launcher/runningappbar.cpp | 2 | ||||
-rw-r--r-- | core/launcher/transferserver.cpp | 2 |
6 files changed, 12 insertions, 13 deletions
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index d74b745..1fd3f6a 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp | |||
@@ -1,1051 +1,1053 @@ | |||
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 "info.h" | 22 | #include "info.h" |
23 | #include "launcher.h" | 23 | #include "launcher.h" |
24 | //#include "mrulist.h" | 24 | //#include "mrulist.h" |
25 | #include "qcopbridge.h" | 25 | #include "qcopbridge.h" |
26 | #include "shutdownimpl.h" | 26 | #include "shutdownimpl.h" |
27 | #include "startmenu.h" | 27 | #include "startmenu.h" |
28 | #include "taskbar.h" | 28 | #include "taskbar.h" |
29 | #include "transferserver.h" | 29 | #include "transferserver.h" |
30 | #include "irserver.h" | 30 | #include "irserver.h" |
31 | #include "packageslave.h" | 31 | #include "packageslave.h" |
32 | 32 | ||
33 | #include <qpe/applnk.h> | 33 | #include <qpe/applnk.h> |
34 | #include <qpe/mimetype.h> | 34 | #include <qpe/mimetype.h> |
35 | #include <qpe/password.h> | 35 | #include <qpe/password.h> |
36 | #include <qpe/config.h> | 36 | #include <qpe/config.h> |
37 | #include <qpe/power.h> | 37 | #include <qpe/power.h> |
38 | #include <qpe/timeconversion.h> | 38 | #include <qpe/timeconversion.h> |
39 | #include <qpe/qcopenvelope_qws.h> | 39 | #include <qpe/qcopenvelope_qws.h> |
40 | #include <qpe/network.h> | 40 | #include <qpe/network.h> |
41 | #include <qpe/global.h> | 41 | #include <qpe/global.h> |
42 | 42 | ||
43 | #if defined( QT_QWS_CUSTOM ) || defined( QT_QWS_IPAQ ) | 43 | #if defined( QT_QWS_CUSTOM ) || defined( QT_QWS_IPAQ ) |
44 | #include <qpe/custom.h> | 44 | #include <qpe/custom.h> |
45 | #endif | 45 | #endif |
46 | 46 | ||
47 | #include <opie/odevice.h> | 47 | #include <opie/odevice.h> |
48 | 48 | ||
49 | #include <qgfx_qws.h> | 49 | #include <qgfx_qws.h> |
50 | #include <qmainwindow.h> | 50 | #include <qmainwindow.h> |
51 | #include <qmessagebox.h> | 51 | #include <qmessagebox.h> |
52 | #include <qtimer.h> | 52 | #include <qtimer.h> |
53 | #include <qwindowsystem_qws.h> | 53 | #include <qwindowsystem_qws.h> |
54 | 54 | ||
55 | #include <qvaluelist.h> | 55 | #include <qvaluelist.h> |
56 | 56 | ||
57 | #include <stdlib.h> | 57 | #include <stdlib.h> |
58 | #include <unistd.h> | 58 | #include <unistd.h> |
59 | #include <fcntl.h> | 59 | #include <fcntl.h> |
60 | 60 | ||
61 | using namespace Opie; | 61 | using namespace Opie; |
62 | 62 | ||
63 | class QCopKeyRegister | 63 | class QCopKeyRegister |
64 | { | 64 | { |
65 | public: | 65 | public: |
66 | QCopKeyRegister() : keyCode( 0 ) | 66 | QCopKeyRegister() : keyCode( 0 ) |
67 | { } | 67 | { } |
68 | QCopKeyRegister( int k, const QString &c, const QString &m ) | 68 | QCopKeyRegister( int k, const QString &c, const QString &m ) |
69 | : keyCode( k ), channel( c ), message( m ) | 69 | : keyCode( k ), channel( c ), message( m ) |
70 | { } | 70 | { } |
71 | 71 | ||
72 | int getKeyCode() const | 72 | int getKeyCode() const |
73 | { | 73 | { |
74 | return keyCode; | 74 | return keyCode; |
75 | } | 75 | } |
76 | QString getChannel() const | 76 | QString getChannel() const |
77 | { | 77 | { |
78 | return channel; | 78 | return channel; |
79 | } | 79 | } |
80 | QString getMessage() const | 80 | QString getMessage() const |
81 | { | 81 | { |
82 | return message; | 82 | return message; |
83 | } | 83 | } |
84 | 84 | ||
85 | private: | 85 | private: |
86 | int keyCode; | 86 | int keyCode; |
87 | QString channel, message; | 87 | QString channel, message; |
88 | }; | 88 | }; |
89 | 89 | ||
90 | typedef QValueList<QCopKeyRegister> KeyRegisterList; | 90 | typedef QValueList<QCopKeyRegister> KeyRegisterList; |
91 | KeyRegisterList keyRegisterList; | 91 | KeyRegisterList keyRegisterList; |
92 | 92 | ||
93 | static Desktop* qpedesktop = 0; | 93 | static Desktop* qpedesktop = 0; |
94 | static int loggedin = 0; | 94 | static int loggedin = 0; |
95 | static void login( bool at_poweron ) | 95 | static void login( bool at_poweron ) |
96 | { | 96 | { |
97 | if ( !loggedin ) { | 97 | if ( !loggedin ) { |
98 | Global::terminateBuiltin( "calibrate" ); | 98 | Global::terminateBuiltin( "calibrate" ); |
99 | Password::authenticate( at_poweron ); | 99 | Password::authenticate( at_poweron ); |
100 | loggedin = 1; | 100 | loggedin = 1; |
101 | QCopEnvelope e( "QPE/Desktop", "unlocked()" ); | 101 | QCopEnvelope e( "QPE/Desktop", "unlocked()" ); |
102 | } | 102 | } |
103 | } | 103 | } |
104 | 104 | ||
105 | bool Desktop::screenLocked() | 105 | bool Desktop::screenLocked() |
106 | { | 106 | { |
107 | return loggedin == 0; | 107 | return loggedin == 0; |
108 | } | 108 | } |
109 | 109 | ||
110 | /* | 110 | /* |
111 | Priority is number of alerts that are needed to pop up | 111 | Priority is number of alerts that are needed to pop up |
112 | alert. | 112 | alert. |
113 | */ | 113 | */ |
114 | class DesktopPowerAlerter : public QMessageBox | 114 | class DesktopPowerAlerter : public QMessageBox |
115 | { | 115 | { |
116 | public: | 116 | public: |
117 | DesktopPowerAlerter( QWidget *parent, const char *name = 0 ) | 117 | DesktopPowerAlerter( QWidget *parent, const char *name = 0 ) |
118 | : QMessageBox( tr( "Battery Status" ), "Low Battery", | 118 | : QMessageBox( tr( "Battery Status" ), "Low Battery", |
119 | QMessageBox::Critical, | 119 | QMessageBox::Critical, |
120 | QMessageBox::Ok | QMessageBox::Default, | 120 | QMessageBox::Ok | QMessageBox::Default, |
121 | QMessageBox::NoButton, QMessageBox::NoButton, | 121 | QMessageBox::NoButton, QMessageBox::NoButton, |
122 | parent, name, FALSE ) | 122 | parent, name, FALSE ) |
123 | { | 123 | { |
124 | currentPriority = INT_MAX; | 124 | currentPriority = INT_MAX; |
125 | alertCount = 0; | 125 | alertCount = 0; |
126 | } | 126 | } |
127 | 127 | ||
128 | void alert( const QString &text, int priority ); | 128 | void alert( const QString &text, int priority ); |
129 | void hideEvent( QHideEvent * ); | 129 | void hideEvent( QHideEvent * ); |
130 | private: | 130 | private: |
131 | int currentPriority; | 131 | int currentPriority; |
132 | int alertCount; | 132 | int alertCount; |
133 | }; | 133 | }; |
134 | 134 | ||
135 | void DesktopPowerAlerter::alert( const QString &text, int priority ) | 135 | void DesktopPowerAlerter::alert( const QString &text, int priority ) |
136 | { | 136 | { |
137 | alertCount++; | 137 | alertCount++; |
138 | if ( alertCount < priority ) | 138 | if ( alertCount < priority ) |
139 | return ; | 139 | return ; |
140 | if ( priority > currentPriority ) | 140 | if ( priority > currentPriority ) |
141 | return ; | 141 | return ; |
142 | currentPriority = priority; | 142 | currentPriority = priority; |
143 | setText( text ); | 143 | setText( text ); |
144 | show(); | 144 | show(); |
145 | } | 145 | } |
146 | 146 | ||
147 | 147 | ||
148 | void DesktopPowerAlerter::hideEvent( QHideEvent *e ) | 148 | void DesktopPowerAlerter::hideEvent( QHideEvent *e ) |
149 | { | 149 | { |
150 | QMessageBox::hideEvent( e ); | 150 | QMessageBox::hideEvent( e ); |
151 | alertCount = 0; | 151 | alertCount = 0; |
152 | currentPriority = INT_MAX; | 152 | currentPriority = INT_MAX; |
153 | } | 153 | } |
154 | 154 | ||
155 | |||
156 | class QPEScreenSaver : public QWSScreenSaver | 155 | class QPEScreenSaver : public QWSScreenSaver |
157 | { | 156 | { |
158 | private: | 157 | private: |
159 | int LcdOn; | 158 | int LcdOn; |
160 | 159 | ||
161 | public: | 160 | public: |
162 | QPEScreenSaver() | 161 | QPEScreenSaver() |
163 | { | 162 | { |
164 | m_disable_suspend = 100; | 163 | m_disable_suspend = 100; |
165 | m_enable_dim = false; | 164 | m_enable_dim = false; |
166 | m_enable_lightoff = false; | 165 | m_enable_lightoff = false; |
167 | m_enable_onlylcdoff = false; | 166 | m_enable_onlylcdoff = false; |
168 | 167 | ||
169 | m_lcd_status = true; | 168 | m_lcd_status = true; |
170 | 169 | ||
171 | m_backlight_bright = -1; | 170 | m_backlight_bright = -1; |
172 | m_backlight_forcedoff = false; | 171 | m_backlight_forcedoff = false; |
173 | 172 | ||
174 | // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off) | 173 | // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off) |
175 | ODevice::inst ( ) -> setDisplayStatus ( true ); | 174 | ODevice::inst ( ) -> setDisplayStatus ( true ); |
176 | } | 175 | } |
177 | void restore() | 176 | void restore() |
178 | { | 177 | { |
179 | if ( !m_lcd_status ) { // We must have turned it off | 178 | if ( !m_lcd_status ) { // We must have turned it off |
180 | ODevice::inst ( ) -> setDisplayStatus ( true ); | 179 | ODevice::inst ( ) -> setDisplayStatus ( true ); |
181 | m_lcd_status = true; | 180 | m_lcd_status = true; |
182 | } | 181 | } |
183 | 182 | ||
184 | setBacklight ( -1 ); | 183 | setBacklight ( -1 ); |
185 | } | 184 | } |
186 | bool save( int level ) | 185 | bool save( int level ) |
187 | { | 186 | { |
188 | switch ( level ) { | 187 | switch ( level ) { |
189 | case 0: | 188 | case 0: |
190 | if ( m_disable_suspend > 0 && m_enable_dim ) { | 189 | if ( m_disable_suspend > 0 && m_enable_dim ) { |
191 | if ( backlight() > 1 ) | 190 | if ( backlight() > 1 ) |
192 | setBacklight( 1 ); // lowest non-off | 191 | setBacklight( 1 ); // lowest non-off |
193 | } | 192 | } |
194 | return true; | 193 | return true; |
195 | break; | 194 | break; |
196 | case 1: | 195 | case 1: |
197 | if ( m_disable_suspend > 1 && m_enable_lightoff ) { | 196 | if ( m_disable_suspend > 1 && m_enable_lightoff ) { |
198 | setBacklight( 0 ); // off | 197 | setBacklight( 0 ); // off |
199 | } | 198 | } |
200 | return true; | 199 | return true; |
201 | break; | 200 | break; |
202 | case 2: | 201 | case 2: |
203 | if ( m_enable_onlylcdoff ) { | 202 | if ( m_enable_onlylcdoff ) { |
204 | ODevice::inst ( ) -> setDisplayStatus ( false ); | 203 | ODevice::inst ( ) -> setDisplayStatus ( false ); |
205 | m_lcd_status = false; | 204 | m_lcd_status = false; |
206 | return true; | 205 | return true; |
207 | } | 206 | } |
208 | else // We're going to suspend the whole machine | 207 | else // We're going to suspend the whole machine |
209 | { | 208 | { |
210 | if ( ( m_disable_suspend > 2 ) && | 209 | if ( ( m_disable_suspend > 2 ) && |
211 | ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && | 210 | ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && |
212 | ( !Network::networkOnline ( ) ) ) { | 211 | ( !Network::networkOnline ( ) ) ) { |
213 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); | 212 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); |
214 | return true; | 213 | return true; |
215 | } | 214 | } |
216 | } | 215 | } |
217 | break; | 216 | break; |
218 | } | 217 | } |
219 | return false; | 218 | return false; |
220 | } | 219 | } |
221 | 220 | ||
222 | private: | 221 | private: |
223 | static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def ) | 222 | static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def ) |
224 | { | 223 | { |
225 | if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) | 224 | if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) |
226 | return 0; | 225 | return 0; |
227 | 226 | ||
228 | if ( interval < 0 ) { | 227 | if ( interval < 0 ) { |
229 | // Restore screen blanking and power saving state | 228 | // Restore screen blanking and power saving state |
230 | interval = config.readNumEntry( value, def ); | 229 | interval = config.readNumEntry( value, def ); |
231 | } | 230 | } |
232 | return interval; | 231 | return interval; |
233 | } | 232 | } |
234 | 233 | ||
235 | public: | 234 | public: |
236 | void setIntervals( int i1, int i2, int i3 ) | 235 | void setIntervals( int i1, int i2, int i3 ) |
237 | { | 236 | { |
238 | Config config( "qpe" ); | 237 | Config config( "qpe" ); |
239 | config.setGroup( "Screensaver" ); | 238 | config.setGroup( "Screensaver" ); |
240 | 239 | ||
241 | int v[ 4 ]; | 240 | int v[ 4 ]; |
242 | i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 ); | 241 | i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 ); |
243 | i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 ); | 242 | i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 ); |
244 | i3 = ssi( i3, config, "", "Interval", 60 ); | 243 | i3 = ssi( i3, config, "", "Interval", 60 ); |
245 | 244 | ||
246 | //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); | 245 | //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); |
247 | 246 | ||
248 | v [ 0 ] = QMAX( 1000 * i1, 100 ); | 247 | v [ 0 ] = QMAX( 1000 * i1, 100 ); |
249 | v [ 1 ] = QMAX( 1000 * i2, 100 ); | 248 | v [ 1 ] = QMAX( 1000 * i2, 100 ); |
250 | v [ 2 ] = QMAX( 1000 * i3, 100 ); | 249 | v [ 2 ] = QMAX( 1000 * i3, 100 ); |
251 | v [ 3 ] = 0; | 250 | v [ 3 ] = 0; |
252 | m_enable_dim = ( ( i1 != 0 ) ? config. readNumEntry ( "Dim", 1 ) : false ); | 251 | m_enable_dim = ( ( i1 != 0 ) ? config. readNumEntry ( "Dim", 1 ) : false ); |
253 | m_enable_lightoff = ( ( i2 != 0 ) ? config. readNumEntry ( "LightOff", 1 ) : false ); | 252 | m_enable_lightoff = ( ( i2 != 0 ) ? config. readNumEntry ( "LightOff", 1 ) : false ); |
254 | m_enable_onlylcdoff = config. readNumEntry ( "LcdOffOnly", 0 ); | 253 | m_enable_onlylcdoff = config. readNumEntry ( "LcdOffOnly", 0 ); |
255 | 254 | ||
256 | if ( !i1 && !i2 && !i3 ) | 255 | if ( !i1 && !i2 && !i3 ) |
257 | QWSServer::setScreenSaverInterval( 0 ); | 256 | QWSServer::setScreenSaverInterval( 0 ); |
258 | else | 257 | else |
259 | QWSServer::setScreenSaverIntervals( v ); | 258 | QWSServer::setScreenSaverIntervals( v ); |
260 | } | 259 | } |
261 | 260 | ||
262 | void setInterval ( int interval ) | 261 | void setInterval ( int interval ) |
263 | { | 262 | { |
264 | setIntervals ( -1, -1, interval ); | 263 | setIntervals ( -1, -1, interval ); |
265 | } | 264 | } |
266 | 265 | ||
267 | void setMode ( int mode ) | 266 | void setMode ( int mode ) |
268 | { | 267 | { |
269 | if ( mode > m_disable_suspend ) | 268 | if ( mode > m_disable_suspend ) |
270 | setInterval( -1 ); | 269 | setInterval( -1 ); |
271 | m_disable_suspend = mode; | 270 | m_disable_suspend = mode; |
272 | } | 271 | } |
273 | 272 | ||
274 | int backlight ( ) | 273 | int backlight ( ) |
275 | { | 274 | { |
276 | if ( m_backlight_bright == -1 ) { | 275 | if ( m_backlight_bright == -1 ) { |
277 | // Read from config | 276 | // Read from config |
278 | Config config ( "qpe" ); | 277 | Config config ( "qpe" ); |
279 | config. setGroup ( "Screensaver" ); | 278 | config. setGroup ( "Screensaver" ); |
280 | m_backlight_bright = config. readNumEntry ( "Brightness", 255 ); | 279 | m_backlight_bright = config. readNumEntry ( "Brightness", 255 ); |
281 | } | 280 | } |
282 | return m_backlight_bright; | 281 | return m_backlight_bright; |
283 | } | 282 | } |
284 | 283 | ||
285 | void setBacklight ( int bright ) | 284 | void setBacklight ( int bright ) |
286 | { | 285 | { |
287 | if ( bright == -3 ) { | 286 | if ( bright == -3 ) { |
288 | // Forced on | 287 | // Forced on |
289 | m_backlight_forcedoff = false; | 288 | m_backlight_forcedoff = false; |
290 | bright = -1; | 289 | bright = -1; |
291 | } | 290 | } |
292 | if ( m_backlight_forcedoff && bright != -2 ) | 291 | if ( m_backlight_forcedoff && bright != -2 ) |
293 | return ; | 292 | return ; |
294 | if ( bright == -2 ) { | 293 | if ( bright == -2 ) { |
295 | // Toggle between off and on | 294 | // Toggle between off and on |
296 | bright = m_backlight_bright ? 0 : -1; | 295 | bright = m_backlight_bright ? 0 : -1; |
297 | m_backlight_forcedoff = !bright; | 296 | m_backlight_forcedoff = !bright; |
298 | } | 297 | } |
299 | 298 | ||
300 | m_backlight_bright = bright; | 299 | m_backlight_bright = bright; |
301 | 300 | ||
302 | bright = backlight ( ); | 301 | bright = backlight ( ); |
303 | ODevice::inst ( ) -> setDisplayBrightness ( bright ); | 302 | ODevice::inst ( ) -> setDisplayBrightness ( bright ); |
304 | 303 | ||
305 | m_backlight_bright = bright; | 304 | m_backlight_bright = bright; |
306 | } | 305 | } |
307 | 306 | ||
308 | void setDisplayState ( bool on ) | 307 | void setDisplayState ( bool on ) |
309 | { | 308 | { |
310 | if ( m_lcd_status != on ) { | 309 | if ( m_lcd_status != on ) { |
311 | ODevice::inst ( ) -> setDisplayStatus ( on ); | 310 | ODevice::inst ( ) -> setDisplayStatus ( on ); |
312 | m_lcd_status = on; | 311 | m_lcd_status = on; |
313 | } | 312 | } |
314 | } | 313 | } |
315 | 314 | ||
316 | private: | 315 | private: |
317 | int m_disable_suspend; | 316 | int m_disable_suspend; |
318 | bool m_enable_dim; | 317 | bool m_enable_dim; |
319 | bool m_enable_lightoff; | 318 | bool m_enable_lightoff; |
320 | bool m_enable_onlylcdoff; | 319 | bool m_enable_onlylcdoff; |
321 | 320 | ||
322 | bool m_lcd_status; | 321 | bool m_lcd_status; |
323 | 322 | ||
324 | int m_backlight_bright; | 323 | int m_backlight_bright; |
325 | bool m_backlight_forcedoff; | 324 | bool m_backlight_forcedoff; |
326 | }; | 325 | }; |
327 | 326 | ||
328 | |||
329 | void DesktopApplication::switchLCD ( bool on ) | 327 | void DesktopApplication::switchLCD ( bool on ) |
330 | { | 328 | { |
331 | if ( qApp ) { | 329 | if ( qApp ) { |
332 | DesktopApplication *dapp = (DesktopApplication *) qApp; | 330 | DesktopApplication *dapp = (DesktopApplication *) qApp; |
333 | 331 | ||
334 | if ( dapp-> m_screensaver ) { | 332 | if ( dapp-> m_screensaver ) { |
335 | if ( on ) { | 333 | if ( on ) { |
336 | dapp-> m_screensaver-> setDisplayState ( true ); | 334 | dapp-> m_screensaver-> setDisplayState ( true ); |
337 | dapp-> m_screensaver-> setBacklight ( -3 ); | 335 | dapp-> m_screensaver-> setBacklight ( -3 ); |
338 | } | 336 | } |
339 | else { | 337 | else { |
340 | dapp-> m_screensaver-> setDisplayState ( false ); | 338 | dapp-> m_screensaver-> setDisplayState ( false ); |
341 | } | 339 | } |
342 | } | 340 | } |
343 | } | 341 | } |
344 | } | 342 | } |
345 | 343 | ||
346 | 344 | ||
347 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) | 345 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) |
348 | : QPEApplication( argc, argv, appType ) | 346 | : QPEApplication( argc, argv, appType ) |
349 | { | 347 | { |
350 | 348 | ||
351 | QTimer * t = new QTimer( this ); | 349 | QTimer * t = new QTimer( this ); |
352 | connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); | 350 | connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); |
353 | t->start( 10000 ); | 351 | t->start( 10000 ); |
354 | ps = new PowerStatus; | 352 | ps = new PowerStatus; |
355 | pa = new DesktopPowerAlerter( 0 ); | 353 | pa = new DesktopPowerAlerter( 0 ); |
356 | 354 | ||
357 | channel = new QCopChannel( "QPE/Desktop", this ); | 355 | channel = new QCopChannel( "QPE/Desktop", this ); |
358 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 356 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
359 | this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); | 357 | this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); |
360 | 358 | ||
361 | channel = new QCopChannel( "QPE/System", this ); | 359 | channel = new QCopChannel( "QPE/System", this ); |
362 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 360 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
363 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); | 361 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); |
364 | 362 | ||
365 | m_screensaver = new QPEScreenSaver; | 363 | m_screensaver = new QPEScreenSaver; |
366 | 364 | ||
367 | m_screensaver-> setInterval ( -1 ); | 365 | m_screensaver-> setInterval ( -1 ); |
368 | QWSServer::setScreenSaver( m_screensaver ); | 366 | QWSServer::setScreenSaver( m_screensaver ); |
369 | } | 367 | } |
370 | 368 | ||
371 | 369 | ||
372 | DesktopApplication::~DesktopApplication() | 370 | DesktopApplication::~DesktopApplication() |
373 | { | 371 | { |
374 | delete ps; | 372 | delete ps; |
375 | delete pa; | 373 | delete pa; |
376 | } | 374 | } |
377 | 375 | ||
378 | void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) | 376 | void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) |
379 | { | 377 | { |
380 | #ifdef Q_WS_QWS | 378 | #ifdef Q_WS_QWS |
381 | QDataStream stream( data, IO_ReadOnly ); | 379 | QDataStream stream( data, IO_ReadOnly ); |
382 | if ( msg == "keyRegister(int key, QString channel, QString message)" ) { | 380 | if ( msg == "keyRegister(int key, QString channel, QString message)" ) { |
383 | int k; | 381 | int k; |
384 | QString c, m; | 382 | QString c, m; |
385 | stream >> k; | 383 | stream >> k; |
386 | stream >> c; | 384 | stream >> c; |
387 | stream >> m; | 385 | stream >> m; |
388 | 386 | ||
389 | qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); | 387 | qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); |
390 | keyRegisterList.append( QCopKeyRegister( k, c, m ) ); | 388 | keyRegisterList.append( QCopKeyRegister( k, c, m ) ); |
391 | } | 389 | } |
392 | #endif | 390 | #endif |
393 | } | 391 | } |
394 | 392 | ||
395 | 393 | ||
396 | void DesktopApplication::systemMessage( const QCString & msg, const QByteArray & data ) | 394 | void DesktopApplication::systemMessage( const QCString & msg, const QByteArray & data ) |
397 | { | 395 | { |
398 | #ifdef Q_WS_QWS | 396 | #ifdef Q_WS_QWS |
399 | QDataStream stream ( data, IO_ReadOnly ); | 397 | QDataStream stream ( data, IO_ReadOnly ); |
400 | 398 | ||
401 | if ( msg == "setScreenSaverInterval(int)" ) { | 399 | if ( msg == "setScreenSaverInterval(int)" ) { |
402 | int time; | 400 | int time; |
403 | stream >> time; | 401 | stream >> time; |
404 | m_screensaver-> setInterval( time ); | 402 | m_screensaver-> setInterval( time ); |
405 | } | 403 | } |
406 | else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { | 404 | else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { |
407 | int t1, t2, t3; | 405 | int t1, t2, t3; |
408 | stream >> t1 >> t2 >> t3; | 406 | stream >> t1 >> t2 >> t3; |
409 | m_screensaver-> setIntervals( t1, t2, t3 ); | 407 | m_screensaver-> setIntervals( t1, t2, t3 ); |
410 | } | 408 | } |
411 | else if ( msg == "setBacklight(int)" ) { | 409 | else if ( msg == "setBacklight(int)" ) { |
412 | int bright; | 410 | int bright; |
413 | stream >> bright; | 411 | stream >> bright; |
414 | m_screensaver-> setBacklight( bright ); | 412 | m_screensaver-> setBacklight( bright ); |
415 | } | 413 | } |
416 | else if ( msg == "setScreenSaverMode(int)" ) { | 414 | else if ( msg == "setScreenSaverMode(int)" ) { |
417 | int mode; | 415 | int mode; |
418 | stream >> mode; | 416 | stream >> mode; |
419 | m_screensaver-> setMode ( mode ); | 417 | m_screensaver-> setMode ( mode ); |
420 | } | 418 | } |
421 | else if ( msg == "setDisplayState(int)" ) { | 419 | else if ( msg == "setDisplayState(int)" ) { |
422 | int state; | 420 | int state; |
423 | stream >> state; | 421 | stream >> state; |
424 | m_screensaver-> setDisplayState ( state != 0 ); | 422 | m_screensaver-> setDisplayState ( state != 0 ); |
425 | } | 423 | } |
426 | else if ( msg == "suspend()" ) { | 424 | else if ( msg == "suspend()" ) { |
427 | emit power(); | 425 | emit power(); |
428 | } | 426 | } |
429 | #endif | 427 | #endif |
430 | } | 428 | } |
431 | 429 | ||
432 | enum MemState { Unknown, VeryLow, Low, Normal } memstate = Unknown; | 430 | enum MemState { Unknown, VeryLow, Low, Normal } memstate = Unknown; |
433 | 431 | ||
434 | #ifdef Q_WS_QWS | 432 | #ifdef Q_WS_QWS |
435 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) | 433 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) |
436 | { | 434 | { |
437 | qpedesktop->checkMemory(); | 435 | qpedesktop->checkMemory(); |
438 | 436 | ||
439 | if ( e->type == QWSEvent::Key ) { | 437 | if ( e->type == QWSEvent::Key ) { |
440 | QWSKeyEvent * ke = ( QWSKeyEvent * ) e; | 438 | QWSKeyEvent * ke = ( QWSKeyEvent * ) e; |
441 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) | 439 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) |
442 | return TRUE; | 440 | return TRUE; |
443 | bool press = ke->simpleData.is_press; | 441 | bool press = ke->simpleData.is_press; |
444 | bool autoRepeat = ke->simpleData.is_auto_repeat; | 442 | bool autoRepeat = ke->simpleData.is_auto_repeat; |
445 | 443 | ||
446 | /* | 444 | /* |
447 | app that registers key/message to be sent back to the app, when it doesn't have focus, | 445 | app that registers key/message to be sent back to the app, when it doesn't have focus, |
448 | when user presses key, unless keyboard has been requested from app. | 446 | when user presses key, unless keyboard has been requested from app. |
449 | will not send multiple repeats if user holds key | 447 | will not send multiple repeats if user holds key |
450 | i.e. one shot | 448 | i.e. one shot |
451 | */ | 449 | */ |
452 | if ( !keyRegisterList.isEmpty() && ke->simpleData.keycode !=0 && press) { | 450 | if ( !keyRegisterList.isEmpty() && ke->simpleData.keycode !=0 && press) { |
453 | // qDebug("<<<<<<<<<<<<<keycode %d", ke->simpleData.keycode); | 451 | // qDebug("<<<<<<<<<<<<<keycode %d", ke->simpleData.keycode); |
454 | KeyRegisterList::Iterator it; | 452 | KeyRegisterList::Iterator it; |
455 | for ( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { | 453 | for ( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { |
456 | if ( ( *it ).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() ) { | 454 | if ( ( *it ).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() ) { |
457 | if ( press ) | 455 | if ( press ) |
458 | qDebug( "press" ); | 456 | qDebug( "press" ); |
459 | else | 457 | else |
460 | qDebug( "release" ); | 458 | qDebug( "release" ); |
461 | QCopEnvelope( ( *it ).getChannel().utf8(), ( *it ).getMessage().utf8() ); | 459 | QCopEnvelope( ( *it ).getChannel().utf8(), ( *it ).getMessage().utf8() ); |
462 | } | 460 | } |
463 | } | 461 | } |
464 | } | 462 | } |
465 | 463 | ||
466 | if ( !keyboardGrabbed() ) { | 464 | if ( !keyboardGrabbed() ) { |
467 | if ( ke->simpleData.keycode == Key_F9 ) { | 465 | if ( ke->simpleData.keycode == Key_F9 ) { |
468 | if ( press ) | 466 | if ( press ) |
469 | emit datebook(); | 467 | emit datebook(); |
470 | return TRUE; | 468 | return TRUE; |
471 | } | 469 | } |
472 | if ( ke->simpleData.keycode == Key_F10 ) { | 470 | if ( ke->simpleData.keycode == Key_F10 ) { |
473 | if ( !press && cardSendTimer ) { | 471 | if ( !press && cardSendTimer ) { |
474 | emit contacts(); | 472 | emit contacts(); |
475 | delete cardSendTimer; | 473 | delete cardSendTimer; |
476 | } | 474 | } |
477 | else if ( press ) { | 475 | else if ( press ) { |
478 | cardSendTimer = new QTimer(); | 476 | cardSendTimer = new QTimer(); |
479 | cardSendTimer->start( 2000, TRUE ); | 477 | cardSendTimer->start( 2000, TRUE ); |
480 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); | 478 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); |
481 | } | 479 | } |
482 | return TRUE; | 480 | return TRUE; |
483 | } | 481 | } |
484 | /* menu key now opens application menu/toolbar | 482 | /* menu key now opens application menu/toolbar |
485 | if ( ke->simpleData.keycode == Key_F11 ) { | 483 | if ( ke->simpleData.keycode == Key_F11 ) { |
486 | if ( press ) emit menu(); | 484 | if ( press ) emit menu(); |
487 | return TRUE; | 485 | return TRUE; |
488 | } | 486 | } |
489 | */ | 487 | */ |
490 | if ( ke->simpleData.keycode == Key_F12 ) { | 488 | if ( ke->simpleData.keycode == Key_F12 ) { |
491 | while ( activePopupWidget() ) | 489 | while ( activePopupWidget() ) |
492 | activePopupWidget() ->close(); | 490 | activePopupWidget() ->close(); |
493 | if ( press ) | 491 | if ( press ) |
494 | emit launch(); | 492 | emit launch(); |
495 | return TRUE; | 493 | return TRUE; |
496 | } | 494 | } |
497 | if ( ke->simpleData.keycode == Key_F13 ) { | 495 | if ( ke->simpleData.keycode == Key_F13 ) { |
498 | if ( press ) | 496 | if ( press ) |
499 | emit email(); | 497 | emit email(); |
500 | return TRUE; | 498 | return TRUE; |
501 | } | 499 | } |
502 | } | 500 | } |
503 | 501 | ||
504 | if ( ke->simpleData.keycode == Key_F34 ) { | 502 | if ( ke->simpleData.keycode == Key_F34 ) { |
505 | if ( press ) | 503 | if ( press ) |
506 | emit power(); | 504 | emit power(); |
507 | return TRUE; | 505 | return TRUE; |
508 | } | 506 | } |
509 | // This was used for the iPAQ PowerButton | 507 | // This was used for the iPAQ PowerButton |
510 | // See main.cpp for new KeyboardFilter | 508 | // See main.cpp for new KeyboardFilter |
511 | // | 509 | // |
512 | // if ( ke->simpleData.keycode == Key_SysReq ) { | 510 | // if ( ke->simpleData.keycode == Key_SysReq ) { |
513 | // if ( press ) emit power(); | 511 | // if ( press ) emit power(); |
514 | // return TRUE; | 512 | // return TRUE; |
515 | // } | 513 | // } |
516 | if ( ke->simpleData.keycode == Key_F35 ) { | 514 | if ( ke->simpleData.keycode == Key_F35 ) { |
517 | if ( press ) | 515 | if ( press ) |
518 | emit backlight(); | 516 | emit backlight(); |
519 | return TRUE; | 517 | return TRUE; |
520 | } | 518 | } |
521 | if ( ke->simpleData.keycode == Key_F32 ) { | 519 | if ( ke->simpleData.keycode == Key_F32 ) { |
522 | if ( press ) | 520 | if ( press ) |
523 | QCopEnvelope e( "QPE/Desktop", "startSync()" ); | 521 | QCopEnvelope e( "QPE/Desktop", "startSync()" ); |
524 | return TRUE; | 522 | return TRUE; |
525 | } | 523 | } |
526 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { | 524 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { |
527 | if ( press ) | 525 | if ( press ) |
528 | emit symbol(); | 526 | emit symbol(); |
529 | return TRUE; | 527 | return TRUE; |
530 | } | 528 | } |
531 | if ( ke->simpleData.keycode == Key_NumLock ) { | 529 | if ( ke->simpleData.keycode == Key_NumLock ) { |
532 | if ( press ) | 530 | if ( press ) |
533 | emit numLockStateToggle(); | 531 | emit numLockStateToggle(); |
534 | } | 532 | } |
535 | if ( ke->simpleData.keycode == Key_CapsLock ) { | 533 | if ( ke->simpleData.keycode == Key_CapsLock ) { |
536 | if ( press ) | 534 | if ( press ) |
537 | emit capsLockStateToggle(); | 535 | emit capsLockStateToggle(); |
538 | } | 536 | } |
539 | if ( ( press && !autoRepeat ) || ( !press && autoRepeat ) ) | 537 | if ( ( press && !autoRepeat ) || ( !press && autoRepeat ) ) |
540 | qpedesktop->keyClick(); | 538 | qpedesktop->keyClick(); |
541 | } | 539 | } |
542 | else { | 540 | else { |
543 | if ( e->type == QWSEvent::Mouse ) { | 541 | if ( e->type == QWSEvent::Mouse ) { |
544 | QWSMouseEvent * me = ( QWSMouseEvent * ) e; | 542 | QWSMouseEvent * me = ( QWSMouseEvent * ) e; |
545 | static bool up = TRUE; | 543 | static bool up = TRUE; |
546 | if ( me->simpleData.state & LeftButton ) { | 544 | if ( me->simpleData.state & LeftButton ) { |
547 | if ( up ) { | 545 | if ( up ) { |
548 | up = FALSE; | 546 | up = FALSE; |
549 | qpedesktop->screenClick(); | 547 | qpedesktop->screenClick(); |
550 | } | 548 | } |
551 | } | 549 | } |
552 | else { | 550 | else { |
553 | up = TRUE; | 551 | up = TRUE; |
554 | } | 552 | } |
555 | } | 553 | } |
556 | } | 554 | } |
557 | 555 | ||
558 | return QPEApplication::qwsEventFilter( e ); | 556 | return QPEApplication::qwsEventFilter( e ); |
559 | } | 557 | } |
560 | #endif | 558 | #endif |
561 | 559 | ||
562 | void DesktopApplication::psTimeout() | 560 | void DesktopApplication::psTimeout() |
563 | { | 561 | { |
564 | qpedesktop->checkMemory(); // in case no events are being generated | 562 | qpedesktop->checkMemory(); // in case no events are being generated |
565 | 563 | ||
566 | *ps = PowerStatusManager::readStatus(); | 564 | *ps = PowerStatusManager::readStatus(); |
567 | 565 | ||
568 | if ( ( ps->batteryStatus() == PowerStatus::VeryLow ) ) { | 566 | if ( ( ps->batteryStatus() == PowerStatus::VeryLow ) ) { |
569 | pa->alert( tr( "Battery is running very low." ), 6 ); | 567 | pa->alert( tr( "Battery is running very low." ), 6 ); |
570 | } | 568 | } |
571 | 569 | ||
572 | if ( ps->batteryStatus() == PowerStatus::Critical ) { | 570 | if ( ps->batteryStatus() == PowerStatus::Critical ) { |
573 | pa->alert( tr( "Battery level is critical!\n" | 571 | pa->alert( tr( "Battery level is critical!\n" |
574 | "Keep power off until power restored!" ), 1 ); | 572 | "Keep power off until power restored!" ), 1 ); |
575 | } | 573 | } |
576 | 574 | ||
577 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { | 575 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { |
578 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); | 576 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); |
579 | } | 577 | } |
580 | } | 578 | } |
581 | 579 | ||
582 | 580 | ||
583 | void DesktopApplication::sendCard() | 581 | void DesktopApplication::sendCard() |
584 | { | 582 | { |
585 | delete cardSendTimer; | 583 | delete cardSendTimer; |
586 | cardSendTimer = 0; | 584 | cardSendTimer = 0; |
587 | QString card = getenv( "HOME" ); | 585 | QString card = getenv( "HOME" ); |
588 | card += "/Applications/addressbook/businesscard.vcf"; | 586 | card += "/Applications/addressbook/businesscard.vcf"; |
589 | 587 | ||
590 | if ( QFile::exists( card ) ) { | 588 | if ( QFile::exists( card ) ) { |
591 | QCopEnvelope e( "QPE/Obex", "send(QString,QString,QString)" ); | 589 | QCopEnvelope e( "QPE/Obex", "send(QString,QString,QString)" ); |
592 | QString mimetype = "text/x-vCard"; | 590 | QString mimetype = "text/x-vCard"; |
593 | e << tr( "business card" ) << card << mimetype; | 591 | e << tr( "business card" ) << card << mimetype; |
594 | } | 592 | } |
595 | } | 593 | } |
596 | 594 | ||
597 | #if defined(QPE_HAVE_MEMALERTER) | 595 | #if defined(QPE_HAVE_MEMALERTER) |
598 | QPE_MEMALERTER_IMPL | 596 | QPE_MEMALERTER_IMPL |
599 | #endif | 597 | #endif |
600 | 598 | ||
601 | //=========================================================================== | 599 | //=========================================================================== |
602 | 600 | ||
603 | Desktop::Desktop() : | 601 | Desktop::Desktop() : |
604 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), | 602 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), |
605 | qcopBridge( 0 ), | 603 | qcopBridge( 0 ), |
606 | transferServer( 0 ), | 604 | transferServer( 0 ), |
607 | packageSlave( 0 ) | 605 | packageSlave( 0 ) |
608 | { | 606 | { |
609 | qpedesktop = this; | 607 | qpedesktop = this; |
610 | 608 | ||
611 | // bg = new Info( this ); | 609 | // bg = new Info( this ); |
612 | tb = new TaskBar; | 610 | tb = new TaskBar; |
613 | 611 | ||
614 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); | 612 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); |
615 | 613 | ||
616 | connect( launcher, SIGNAL( busy() ), tb, SLOT( startWait() ) ); | 614 | connect( launcher, SIGNAL( busy() ), tb, SLOT( startWait() ) ); |
617 | connect( launcher, SIGNAL( notBusy( const QString& ) ), tb, SLOT( stopWait( const QString& ) ) ); | 615 | connect( launcher, SIGNAL( notBusy( const QString& ) ), tb, SLOT( stopWait( const QString& ) ) ); |
618 | 616 | ||
619 | int displayw = qApp->desktop() ->width(); | 617 | int displayw = qApp->desktop() ->width(); |
620 | int displayh = qApp->desktop() ->height(); | 618 | int displayh = qApp->desktop() ->height(); |
621 | 619 | ||
622 | 620 | ||
623 | QSize sz = tb->sizeHint(); | 621 | QSize sz = tb->sizeHint(); |
624 | 622 | ||
625 | setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); | 623 | setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); |
626 | tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); | 624 | tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); |
627 | 625 | ||
628 | tb->show(); | 626 | tb->show(); |
629 | launcher->showMaximized(); | 627 | launcher->showMaximized(); |
630 | launcher->show(); | 628 | launcher->show(); |
631 | launcher->raise(); | 629 | launcher->raise(); |
632 | #if defined(QPE_HAVE_MEMALERTER) | 630 | #if defined(QPE_HAVE_MEMALERTER) |
633 | 631 | ||
634 | initMemalerter(); | 632 | initMemalerter(); |
635 | #endif | 633 | #endif |
636 | // start services | 634 | // start services |
637 | startTransferServer(); | 635 | startTransferServer(); |
638 | ( void ) new IrServer( this ); | 636 | ( void ) new IrServer( this ); |
639 | rereadVolumes(); | 637 | rereadVolumes(); |
640 | 638 | ||
641 | packageSlave = new PackageSlave( this ); | 639 | packageSlave = new PackageSlave( this ); |
642 | connect( qApp, SIGNAL( volumeChanged( bool ) ), this, SLOT( rereadVolumes() ) ); | 640 | connect( qApp, SIGNAL( volumeChanged( bool ) ), this, SLOT( rereadVolumes() ) ); |
643 | 641 | ||
644 | qApp->installEventFilter( this ); | 642 | qApp->installEventFilter( this ); |
645 | 643 | ||
646 | qApp-> setMainWidget ( launcher ); | 644 | qApp-> setMainWidget ( launcher ); |
647 | } | 645 | } |
648 | 646 | ||
649 | void Desktop::show() | 647 | void Desktop::show() |
650 | { | 648 | { |
651 | login( TRUE ); | 649 | login( TRUE ); |
652 | QWidget::show(); | 650 | QWidget::show(); |
653 | } | 651 | } |
654 | 652 | ||
655 | Desktop::~Desktop() | 653 | Desktop::~Desktop() |
656 | { | 654 | { |
657 | delete launcher; | 655 | delete launcher; |
658 | delete tb; | 656 | delete tb; |
659 | delete qcopBridge; | 657 | delete qcopBridge; |
660 | delete transferServer; | 658 | delete transferServer; |
661 | } | 659 | } |
662 | 660 | ||
663 | bool Desktop::recoverMemory() | 661 | bool Desktop::recoverMemory() |
664 | { | 662 | { |
665 | return tb->recoverMemory(); | 663 | return tb->recoverMemory(); |
666 | } | 664 | } |
667 | 665 | ||
668 | void Desktop::checkMemory() | 666 | void Desktop::checkMemory() |
669 | { | 667 | { |
670 | #if defined(QPE_HAVE_MEMALERTER) | 668 | #if defined(QPE_HAVE_MEMALERTER) |
671 | static bool ignoreNormal = FALSE; | 669 | static bool ignoreNormal = FALSE; |
672 | static bool existingMessage = FALSE; | 670 | static bool existingMessage = FALSE; |
673 | 671 | ||
674 | if ( existingMessage ) | 672 | if ( existingMessage ) |
675 | return ; // don't show a second message while still on first | 673 | return ; // don't show a second message while still on first |
676 | 674 | ||
677 | existingMessage = TRUE; | 675 | existingMessage = TRUE; |
678 | switch ( memstate ) { | 676 | switch ( memstate ) { |
679 | case Unknown: | 677 | case Unknown: |
680 | break; | 678 | break; |
681 | case Low: | 679 | case Low: |
682 | memstate = Unknown; | 680 | memstate = Unknown; |
683 | if ( recoverMemory() ) | 681 | if ( recoverMemory() ) |
684 | ignoreNormal = TRUE; | 682 | ignoreNormal = TRUE; |
685 | else | 683 | else |
686 | QMessageBox::warning( 0 , "Memory Status", | 684 | QMessageBox::warning( 0 , "Memory Status", |
687 | "The memory smacks of shortage. \n" | 685 | "The memory smacks of shortage. \n" |
688 | "Please save data. " ); | 686 | "Please save data. " ); |
689 | break; | 687 | break; |
690 | case Normal: | 688 | case Normal: |
691 | memstate = Unknown; | 689 | memstate = Unknown; |
692 | if ( ignoreNormal ) | 690 | if ( ignoreNormal ) |
693 | ignoreNormal = FALSE; | 691 | ignoreNormal = FALSE; |
694 | // else | 692 | // else |
695 | // QMessageBox::information ( 0 , "Memory Status", | 693 | // QMessageBox::information ( 0 , "Memory Status", |
696 | // "There is enough memory again." ); | 694 | // "There is enough memory again." ); |
697 | break; | 695 | break; |
698 | case VeryLow: | 696 | case VeryLow: |
699 | memstate = Unknown; | 697 | memstate = Unknown; |
700 | QMessageBox::critical( 0 , "Memory Status", | 698 | QMessageBox::critical( 0 , "Memory Status", |
701 | "The memory is very low. \n" | 699 | "The memory is very low. \n" |
702 | "Please end this application \n" | 700 | "Please end this application \n" |
703 | "immediately." ); | 701 | "immediately." ); |
704 | recoverMemory(); | 702 | recoverMemory(); |
705 | } | 703 | } |
706 | existingMessage = FALSE; | 704 | existingMessage = FALSE; |
707 | #endif | 705 | #endif |
708 | } | 706 | } |
709 | 707 | ||
710 | static bool isVisibleWindow( int wid ) | 708 | static bool isVisibleWindow( int wid ) |
711 | { | 709 | { |
710 | #ifdef QWS | ||
712 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 711 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
713 | QWSWindow* w; | 712 | QWSWindow* w; |
714 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { | 713 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { |
715 | if ( w->winId() == wid ) | 714 | if ( w->winId() == wid ) |
716 | return !w->isFullyObscured(); | 715 | return !w->isFullyObscured(); |
717 | } | 716 | } |
717 | #endif | ||
718 | return FALSE; | 718 | return FALSE; |
719 | } | 719 | } |
720 | 720 | ||
721 | static bool hasVisibleWindow( const QString& clientname ) | 721 | static bool hasVisibleWindow( const QString& clientname ) |
722 | { | 722 | { |
723 | #ifdef QWS | ||
723 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 724 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
724 | QWSWindow* w; | 725 | QWSWindow* w; |
725 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { | 726 | for ( QListIterator<QWSWindow> it( list ); ( w = it.current() ); ++it ) { |
726 | if ( w->client() ->identity() == clientname && !w->isFullyObscured() ) | 727 | if ( w->client() ->identity() == clientname && !w->isFullyObscured() ) |
727 | return TRUE; | 728 | return TRUE; |
728 | } | 729 | } |
730 | #endif | ||
729 | return FALSE; | 731 | return FALSE; |
730 | } | 732 | } |
731 | 733 | ||
732 | void Desktop::raiseLauncher() | 734 | void Desktop::raiseLauncher() |
733 | { | 735 | { |
734 | Config cfg( "qpe" ); //F12 'Home' | 736 | Config cfg( "qpe" ); //F12 'Home' |
735 | cfg.setGroup( "AppsKey" ); | 737 | cfg.setGroup( "AppsKey" ); |
736 | QString tempItem; | 738 | QString tempItem; |
737 | tempItem = cfg.readEntry( "Middle", "Home" ); | 739 | tempItem = cfg.readEntry( "Middle", "Home" ); |
738 | if ( tempItem == "Home" || tempItem.isEmpty() ) { | 740 | if ( tempItem == "Home" || tempItem.isEmpty() ) { |
739 | home ( ); | 741 | home ( ); |
740 | } | 742 | } |
741 | else { | 743 | else { |
742 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 744 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
743 | e << tempItem; | 745 | e << tempItem; |
744 | } | 746 | } |
745 | } | 747 | } |
746 | 748 | ||
747 | void Desktop::home ( ) | 749 | void Desktop::home ( ) |
748 | { | 750 | { |
749 | if ( isVisibleWindow( launcher->winId() ) ) | 751 | if ( isVisibleWindow( launcher->winId() ) ) |
750 | launcher->nextView(); | 752 | launcher->nextView(); |
751 | else | 753 | else |
752 | launcher->raise(); | 754 | launcher->raise(); |
753 | } | 755 | } |
754 | 756 | ||
755 | void Desktop::executeOrModify( const QString& appLnkFile ) | 757 | void Desktop::executeOrModify( const QString& appLnkFile ) |
756 | { | 758 | { |
757 | AppLnk lnk( MimeType::appsFolderName() + "/" + appLnkFile ); | 759 | AppLnk lnk( MimeType::appsFolderName() + "/" + appLnkFile ); |
758 | if ( lnk.isValid() ) { | 760 | if ( lnk.isValid() ) { |
759 | QCString app = lnk.exec().utf8(); | 761 | QCString app = lnk.exec().utf8(); |
760 | Global::terminateBuiltin( "calibrate" ); | 762 | Global::terminateBuiltin( "calibrate" ); |
761 | if ( QCopChannel::isRegistered( "QPE/Application/" + app ) ) { | 763 | if ( QCopChannel::isRegistered( "QPE/Application/" + app ) ) { |
762 | // MRUList::addTask( &lnk ); | 764 | // MRUList::addTask( &lnk ); |
763 | if ( hasVisibleWindow( app ) ) | 765 | if ( hasVisibleWindow( app ) ) |
764 | QCopChannel::send( "QPE/Application/" + app, "nextView()" ); | 766 | QCopChannel::send( "QPE/Application/" + app, "nextView()" ); |
765 | else | 767 | else |
766 | QCopChannel::send( "QPE/Application/" + app, "raise()" ); | 768 | QCopChannel::send( "QPE/Application/" + app, "raise()" ); |
767 | } | 769 | } |
768 | else { | 770 | else { |
769 | lnk.execute(); | 771 | lnk.execute(); |
770 | } | 772 | } |
771 | } | 773 | } |
772 | } | 774 | } |
773 | 775 | ||
774 | void Desktop::raiseDatebook() | 776 | void Desktop::raiseDatebook() |
775 | { | 777 | { |
776 | Config cfg( "qpe" ); //F9 'Activity' | 778 | Config cfg( "qpe" ); //F9 'Activity' |
777 | cfg.setGroup( "AppsKey" ); | 779 | cfg.setGroup( "AppsKey" ); |
778 | QString tempItem; | 780 | QString tempItem; |
779 | tempItem = cfg.readEntry( "LeftEnd" , "Calendar" ); | 781 | tempItem = cfg.readEntry( "LeftEnd" , "Calendar" ); |
780 | if ( tempItem == "Calendar" || tempItem.isEmpty() ) { | 782 | if ( tempItem == "Calendar" || tempItem.isEmpty() ) { |
781 | tempItem = "datebook"; | 783 | tempItem = "datebook"; |
782 | } | 784 | } |
783 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 785 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
784 | e << tempItem; | 786 | e << tempItem; |
785 | } | 787 | } |
786 | 788 | ||
787 | void Desktop::raiseContacts() | 789 | void Desktop::raiseContacts() |
788 | { | 790 | { |
789 | Config cfg( "qpe" ); //F10, 'Contacts' | 791 | Config cfg( "qpe" ); //F10, 'Contacts' |
790 | cfg.setGroup( "AppsKey" ); | 792 | cfg.setGroup( "AppsKey" ); |
791 | QString tempItem; | 793 | QString tempItem; |
792 | tempItem = cfg.readEntry( "Left2nd", "Address Book" ); | 794 | tempItem = cfg.readEntry( "Left2nd", "Address Book" ); |
793 | if ( tempItem == "Address Book" || tempItem.isEmpty() ) { | 795 | if ( tempItem == "Address Book" || tempItem.isEmpty() ) { |
794 | tempItem = "addressbook"; | 796 | tempItem = "addressbook"; |
795 | } | 797 | } |
796 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 798 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
797 | e << tempItem; | 799 | e << tempItem; |
798 | } | 800 | } |
799 | 801 | ||
800 | void Desktop::raiseMenu() | 802 | void Desktop::raiseMenu() |
801 | { | 803 | { |
802 | Config cfg( "qpe" ); //F11, 'Menu | 804 | Config cfg( "qpe" ); //F11, 'Menu |
803 | cfg.setGroup( "AppsKey" ); | 805 | cfg.setGroup( "AppsKey" ); |
804 | QString tempItem; | 806 | QString tempItem; |
805 | tempItem = cfg.readEntry( "Right2nd" , "Popup Menu" ); | 807 | tempItem = cfg.readEntry( "Right2nd" , "Popup Menu" ); |
806 | if ( tempItem == "Popup Menu" || tempItem.isEmpty() ) { | 808 | if ( tempItem == "Popup Menu" || tempItem.isEmpty() ) { |
807 | Global::terminateBuiltin( "calibrate" ); | 809 | Global::terminateBuiltin( "calibrate" ); |
808 | tb->startMenu() ->launch(); | 810 | tb->startMenu() ->launch(); |
809 | } | 811 | } |
810 | else { | 812 | else { |
811 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 813 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
812 | e << tempItem; | 814 | e << tempItem; |
813 | } | 815 | } |
814 | } | 816 | } |
815 | 817 | ||
816 | void Desktop::raiseEmail() | 818 | void Desktop::raiseEmail() |
817 | { | 819 | { |
818 | Config cfg( "qpe" ); //F13, 'Mail' // only in zaurus, on ipaq mail key is F11 | 820 | Config cfg( "qpe" ); //F13, 'Mail' // only in zaurus, on ipaq mail key is F11 |
819 | cfg.setGroup( "AppsKey" ); | 821 | cfg.setGroup( "AppsKey" ); |
820 | QString tempItem; | 822 | QString tempItem; |
821 | tempItem = cfg.readEntry( "RightEnd", "Mail" ); | 823 | tempItem = cfg.readEntry( "RightEnd", "Mail" ); |
822 | if ( tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty() ) { | 824 | if ( tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty() ) { |
823 | tempItem = "mail"; | 825 | tempItem = "mail"; |
824 | } | 826 | } |
825 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 827 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
826 | e << tempItem; | 828 | e << tempItem; |
827 | } | 829 | } |
828 | 830 | ||
829 | // autoStarts apps on resume and start | 831 | // autoStarts apps on resume and start |
830 | void Desktop::execAutoStart() | 832 | void Desktop::execAutoStart() |
831 | { | 833 | { |
832 | QString appName; | 834 | QString appName; |
833 | int delay; | 835 | int delay; |
834 | QDateTime now = QDateTime::currentDateTime(); | 836 | QDateTime now = QDateTime::currentDateTime(); |
835 | Config cfg( "autostart" ); | 837 | Config cfg( "autostart" ); |
836 | cfg.setGroup( "AutoStart" ); | 838 | cfg.setGroup( "AutoStart" ); |
837 | appName = cfg.readEntry( "Apps", "" ); | 839 | appName = cfg.readEntry( "Apps", "" ); |
838 | delay = ( cfg.readEntry( "Delay", "0" ) ).toInt(); | 840 | delay = ( cfg.readEntry( "Delay", "0" ) ).toInt(); |
839 | // If the time between suspend and resume was longer then the | 841 | // If the time between suspend and resume was longer then the |
840 | // value saved as delay, start the app | 842 | // value saved as delay, start the app |
841 | if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) { | 843 | if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) { |
842 | QCopEnvelope e( "QPE/System", "execute(QString)" ); | 844 | QCopEnvelope e( "QPE/System", "execute(QString)" ); |
843 | e << QString( appName ); | 845 | e << QString( appName ); |
844 | } | 846 | } |
845 | } | 847 | } |
846 | 848 | ||
847 | #if defined(QPE_HAVE_TOGGLELIGHT) | 849 | #if defined(QPE_HAVE_TOGGLELIGHT) |
848 | #include <qpe/config.h> | 850 | #include <qpe/config.h> |
849 | 851 | ||
850 | #include <sys/ioctl.h> | 852 | #include <sys/ioctl.h> |
851 | #include <sys/types.h> | 853 | #include <sys/types.h> |
852 | #include <fcntl.h> | 854 | #include <fcntl.h> |
853 | #include <unistd.h> | 855 | #include <unistd.h> |
854 | #include <errno.h> | 856 | #include <errno.h> |
855 | #include <linux/ioctl.h> | 857 | #include <linux/ioctl.h> |
856 | #include <time.h> | 858 | #include <time.h> |
857 | #endif | 859 | #endif |
858 | 860 | ||
859 | 861 | ||
860 | void Desktop::togglePower() | 862 | void Desktop::togglePower() |
861 | { | 863 | { |
862 | static bool excllock = false; | 864 | static bool excllock = false; |
863 | 865 | ||
864 | qDebug ( "togglePower (locked == %d)", excllock ? 1 : 0 ); | 866 | qDebug ( "togglePower (locked == %d)", excllock ? 1 : 0 ); |
865 | 867 | ||
866 | if ( excllock ) | 868 | if ( excllock ) |
867 | return; | 869 | return; |
868 | 870 | ||
869 | excllock = true; | 871 | excllock = true; |
870 | 872 | ||
871 | bool wasloggedin = loggedin; | 873 | bool wasloggedin = loggedin; |
872 | loggedin = 0; | 874 | loggedin = 0; |
873 | suspendTime = QDateTime::currentDateTime(); | 875 | suspendTime = QDateTime::currentDateTime(); |
874 | 876 | ||
875 | #ifdef QWS | 877 | #ifdef QWS |
876 | if ( Password::needToAuthenticate ( true ) && qt_screen ) { | 878 | if ( Password::needToAuthenticate ( true ) && qt_screen ) { |
877 | // Should use a big black window instead. | 879 | // Should use a big black window instead. |
878 | // But this would not show up fast enough | 880 | // But this would not show up fast enough |
879 | QGfx *g = qt_screen-> screenGfx ( ); | 881 | QGfx *g = qt_screen-> screenGfx ( ); |
880 | g-> fillRect ( 0, 0, qt_screen-> width ( ), qt_screen-> height ( )); | 882 | g-> fillRect ( 0, 0, qt_screen-> width ( ), qt_screen-> height ( )); |
881 | delete g; | 883 | delete g; |
882 | } | 884 | } |
883 | #endif | 885 | #endif |
884 | 886 | ||
885 | ODevice::inst ( )-> suspend ( ); | 887 | ODevice::inst ( )-> suspend ( ); |
886 | 888 | ||
887 | DesktopApplication::switchLCD ( true ); // force LCD on without slow qcop call | 889 | DesktopApplication::switchLCD ( true ); // force LCD on without slow qcop call |
888 | QWSServer::screenSaverActivate ( false ); | 890 | QWSServer::screenSaverActivate ( false ); |
889 | 891 | ||
890 | { | 892 | { |
891 | QCopEnvelope( "QPE/Card", "mtabChanged()" ); // might have changed while asleep | 893 | QCopEnvelope( "QPE/Card", "mtabChanged()" ); // might have changed while asleep |
892 | } | 894 | } |
893 | 895 | ||
894 | if ( wasloggedin ) | 896 | if ( wasloggedin ) |
895 | login ( true ); | 897 | login ( true ); |
896 | 898 | ||
897 | execAutoStart(); | 899 | execAutoStart(); |
898 | //qcopBridge->closeOpenConnections(); | 900 | //qcopBridge->closeOpenConnections(); |
899 | 901 | ||
900 | excllock = false; | 902 | excllock = false; |
901 | } | 903 | } |
902 | 904 | ||
903 | void Desktop::toggleLight() | 905 | void Desktop::toggleLight() |
904 | { | 906 | { |
905 | QCopEnvelope e( "QPE/System", "setBacklight(int)" ); | 907 | QCopEnvelope e( "QPE/System", "setBacklight(int)" ); |
906 | e << -2; // toggle | 908 | e << -2; // toggle |
907 | } | 909 | } |
908 | 910 | ||
909 | void Desktop::toggleSymbolInput() | 911 | void Desktop::toggleSymbolInput() |
910 | { | 912 | { |
911 | tb->toggleSymbolInput(); | 913 | tb->toggleSymbolInput(); |
912 | } | 914 | } |
913 | 915 | ||
914 | void Desktop::toggleNumLockState() | 916 | void Desktop::toggleNumLockState() |
915 | { | 917 | { |
916 | tb->toggleNumLockState(); | 918 | tb->toggleNumLockState(); |
917 | } | 919 | } |
918 | 920 | ||
919 | void Desktop::toggleCapsLockState() | 921 | void Desktop::toggleCapsLockState() |
920 | { | 922 | { |
921 | tb->toggleCapsLockState(); | 923 | tb->toggleCapsLockState(); |
922 | } | 924 | } |
923 | 925 | ||
924 | void Desktop::styleChange( QStyle &s ) | 926 | void Desktop::styleChange( QStyle &s ) |
925 | { | 927 | { |
926 | QWidget::styleChange( s ); | 928 | QWidget::styleChange( s ); |
927 | int displayw = qApp->desktop() ->width(); | 929 | int displayw = qApp->desktop() ->width(); |
928 | int displayh = qApp->desktop() ->height(); | 930 | int displayh = qApp->desktop() ->height(); |
929 | 931 | ||
930 | QSize sz = tb->sizeHint(); | 932 | QSize sz = tb->sizeHint(); |
931 | 933 | ||
932 | tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); | 934 | tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); |
933 | } | 935 | } |
934 | 936 | ||
935 | void DesktopApplication::shutdown() | 937 | void DesktopApplication::shutdown() |
936 | { | 938 | { |
937 | if ( type() != GuiServer ) | 939 | if ( type() != GuiServer ) |
938 | return ; | 940 | return ; |
939 | ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); | 941 | ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); |
940 | connect( sd, SIGNAL( shutdown( ShutdownImpl::Type ) ), | 942 | connect( sd, SIGNAL( shutdown( ShutdownImpl::Type ) ), |
941 | this, SLOT( shutdown( ShutdownImpl::Type ) ) ); | 943 | this, SLOT( shutdown( ShutdownImpl::Type ) ) ); |
942 | sd->showMaximized(); | 944 | sd->showMaximized(); |
943 | } | 945 | } |
944 | 946 | ||
945 | void DesktopApplication::shutdown( ShutdownImpl::Type t ) | 947 | void DesktopApplication::shutdown( ShutdownImpl::Type t ) |
946 | { | 948 | { |
947 | switch ( t ) { | 949 | switch ( t ) { |
948 | case ShutdownImpl::ShutdownSystem: | 950 | case ShutdownImpl::ShutdownSystem: |
949 | execlp( "shutdown", "shutdown", "-h", "now", ( void* ) 0 ); | 951 | execlp( "shutdown", "shutdown", "-h", "now", ( void* ) 0 ); |
950 | break; | 952 | break; |
951 | case ShutdownImpl::RebootSystem: | 953 | case ShutdownImpl::RebootSystem: |
952 | execlp( "shutdown", "shutdown", "-r", "now", ( void* ) 0 ); | 954 | execlp( "shutdown", "shutdown", "-r", "now", ( void* ) 0 ); |
953 | break; | 955 | break; |
954 | case ShutdownImpl::RestartDesktop: | 956 | case ShutdownImpl::RestartDesktop: |
955 | restart(); | 957 | restart(); |
956 | break; | 958 | break; |
957 | case ShutdownImpl::TerminateDesktop: | 959 | case ShutdownImpl::TerminateDesktop: |
958 | prepareForTermination( FALSE ); | 960 | prepareForTermination( FALSE ); |
959 | 961 | ||
960 | // This is a workaround for a Qt bug | 962 | // This is a workaround for a Qt bug |
961 | // clipboard applet has to stop its poll timer, or Qt/E | 963 | // clipboard applet has to stop its poll timer, or Qt/E |
962 | // will hang on quit() right before it emits aboutToQuit() | 964 | // will hang on quit() right before it emits aboutToQuit() |
963 | emit aboutToQuit ( ); | 965 | emit aboutToQuit ( ); |
964 | 966 | ||
965 | quit(); | 967 | quit(); |
966 | break; | 968 | break; |
967 | } | 969 | } |
968 | } | 970 | } |
969 | 971 | ||
970 | void DesktopApplication::restart() | 972 | void DesktopApplication::restart() |
971 | { | 973 | { |
972 | prepareForTermination( TRUE ); | 974 | prepareForTermination( TRUE ); |
973 | 975 | ||
974 | #ifdef Q_WS_QWS | 976 | #ifdef Q_WS_QWS |
975 | 977 | ||
976 | for ( int fd = 3; fd < 100; fd++ ) | 978 | for ( int fd = 3; fd < 100; fd++ ) |
977 | close( fd ); | 979 | close( fd ); |
978 | #if defined(QT_DEMO_SINGLE_FLOPPY) | 980 | #if defined(QT_DEMO_SINGLE_FLOPPY) |
979 | 981 | ||
980 | execl( "/sbin/init", "qpe", 0 ); | 982 | execl( "/sbin/init", "qpe", 0 ); |
981 | #elif defined(QT_QWS_CASSIOPEIA) | 983 | #elif defined(QT_QWS_CASSIOPEIA) |
982 | 984 | ||
983 | execl( "/bin/sh", "sh", 0 ); | 985 | execl( "/bin/sh", "sh", 0 ); |
984 | #else | 986 | #else |
985 | 987 | ||
986 | execl( ( qpeDir() + "/bin/qpe" ).latin1(), "qpe", 0 ); | 988 | execl( ( qpeDir() + "/bin/qpe" ).latin1(), "qpe", 0 ); |
987 | #endif | 989 | #endif |
988 | 990 | ||
989 | exit( 1 ); | 991 | exit( 1 ); |
990 | #endif | 992 | #endif |
991 | } | 993 | } |
992 | 994 | ||
993 | void Desktop::startTransferServer() | 995 | void Desktop::startTransferServer() |
994 | { | 996 | { |
995 | // start qcop bridge server | 997 | // start qcop bridge server |
996 | qcopBridge = new QCopBridge( 4243 ); | 998 | qcopBridge = new QCopBridge( 4243 ); |
997 | if ( !qcopBridge->ok() ) { | 999 | if ( !qcopBridge->ok() ) { |
998 | delete qcopBridge; | 1000 | delete qcopBridge; |
999 | qcopBridge = 0; | 1001 | qcopBridge = 0; |
1000 | } | 1002 | } |
1001 | // start transfer server | 1003 | // start transfer server |
1002 | transferServer = new TransferServer( 4242 ); | 1004 | transferServer = new TransferServer( 4242 ); |
1003 | if ( !transferServer->ok() ) { | 1005 | if ( !transferServer->ok() ) { |
1004 | delete transferServer; | 1006 | delete transferServer; |
1005 | transferServer = 0; | 1007 | transferServer = 0; |
1006 | } | 1008 | } |
1007 | if ( !transferServer || !qcopBridge ) | 1009 | if ( !transferServer || !qcopBridge ) |
1008 | startTimer( 2000 ); | 1010 | startTimer( 2000 ); |
1009 | } | 1011 | } |
1010 | 1012 | ||
1011 | void Desktop::timerEvent( QTimerEvent *e ) | 1013 | void Desktop::timerEvent( QTimerEvent *e ) |
1012 | { | 1014 | { |
1013 | killTimer( e->timerId() ); | 1015 | killTimer( e->timerId() ); |
1014 | startTransferServer(); | 1016 | startTransferServer(); |
1015 | } | 1017 | } |
1016 | 1018 | ||
1017 | void Desktop::terminateServers() | 1019 | void Desktop::terminateServers() |
1018 | { | 1020 | { |
1019 | delete transferServer; | 1021 | delete transferServer; |
1020 | delete qcopBridge; | 1022 | delete qcopBridge; |
1021 | transferServer = 0; | 1023 | transferServer = 0; |
1022 | qcopBridge = 0; | 1024 | qcopBridge = 0; |
1023 | } | 1025 | } |
1024 | 1026 | ||
1025 | void Desktop::rereadVolumes() | 1027 | void Desktop::rereadVolumes() |
1026 | { | 1028 | { |
1027 | Config cfg( "qpe" ); | 1029 | Config cfg( "qpe" ); |
1028 | cfg.setGroup( "Volume" ); | 1030 | cfg.setGroup( "Volume" ); |
1029 | touchclick = cfg.readBoolEntry( "TouchSound" ); | 1031 | touchclick = cfg.readBoolEntry( "TouchSound" ); |
1030 | keyclick = cfg.readBoolEntry( "KeySound" ); | 1032 | keyclick = cfg.readBoolEntry( "KeySound" ); |
1031 | alarmsound = cfg.readBoolEntry( "AlarmSound" ); | 1033 | alarmsound = cfg.readBoolEntry( "AlarmSound" ); |
1032 | } | 1034 | } |
1033 | 1035 | ||
1034 | void Desktop::keyClick() | 1036 | void Desktop::keyClick() |
1035 | { | 1037 | { |
1036 | if ( keyclick ) | 1038 | if ( keyclick ) |
1037 | ODevice::inst ( ) -> keySound ( ); | 1039 | ODevice::inst ( ) -> keySound ( ); |
1038 | } | 1040 | } |
1039 | 1041 | ||
1040 | void Desktop::screenClick() | 1042 | void Desktop::screenClick() |
1041 | { | 1043 | { |
1042 | if ( touchclick ) | 1044 | if ( touchclick ) |
1043 | ODevice::inst ( ) -> touchSound ( ); | 1045 | ODevice::inst ( ) -> touchSound ( ); |
1044 | } | 1046 | } |
1045 | 1047 | ||
1046 | void Desktop::soundAlarm() | 1048 | void Desktop::soundAlarm() |
1047 | { | 1049 | { |
1048 | if ( qpedesktop-> alarmsound ) | 1050 | if ( qpedesktop-> alarmsound ) |
1049 | ODevice::inst ( ) -> alarmSound ( ); | 1051 | ODevice::inst ( ) -> alarmSound ( ); |
1050 | } | 1052 | } |
1051 | 1053 | ||
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp index 66cc3e6..a5955a4 100644 --- a/core/launcher/launcher.cpp +++ b/core/launcher/launcher.cpp | |||
@@ -1,1051 +1,1049 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | // WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT | 21 | // WARNING: Do *NOT* define this yourself. The SL5xxx from SHARP does NOT |
22 | // have this class. | 22 | // have this class. |
23 | #define QTOPIA_INTERNAL_FSLP | 23 | #define QTOPIA_INTERNAL_FSLP |
24 | 24 | ||
25 | #ifdef QWS | ||
26 | #include <qpe/qcopenvelope_qws.h> | 25 | #include <qpe/qcopenvelope_qws.h> |
27 | #endif | ||
28 | #include <qpe/resource.h> | 26 | #include <qpe/resource.h> |
29 | #include <qpe/applnk.h> | 27 | #include <qpe/applnk.h> |
30 | #include <qpe/config.h> | 28 | #include <qpe/config.h> |
31 | #include <qpe/global.h> | 29 | #include <qpe/global.h> |
32 | #include <qpe/qpeapplication.h> | 30 | #include <qpe/qpeapplication.h> |
33 | #include <qpe/mimetype.h> | 31 | #include <qpe/mimetype.h> |
34 | #include <qpe/storage.h> | 32 | #include <qpe/storage.h> |
35 | #include <qpe/palmtoprecord.h> | 33 | #include <qpe/palmtoprecord.h> |
36 | 34 | ||
37 | #include <qpe/version.h> | 35 | #include <qpe/version.h> |
38 | 36 | ||
39 | #include <qdir.h> | 37 | #include <qdir.h> |
40 | #ifdef QWS | 38 | #ifdef QWS |
41 | #include <qwindowsystem_qws.h> | 39 | #include <qwindowsystem_qws.h> |
42 | #endif | 40 | #endif |
43 | #include <qtimer.h> | 41 | #include <qtimer.h> |
44 | #include <qcombobox.h> | 42 | #include <qcombobox.h> |
45 | #include <qvbox.h> | 43 | #include <qvbox.h> |
46 | #include <qlayout.h> | 44 | #include <qlayout.h> |
47 | #include <qstyle.h> | 45 | #include <qstyle.h> |
48 | #include <qpushbutton.h> | 46 | #include <qpushbutton.h> |
49 | #include <qtabbar.h> | 47 | #include <qtabbar.h> |
50 | #include <qwidgetstack.h> | 48 | #include <qwidgetstack.h> |
51 | #include <qlayout.h> | 49 | #include <qlayout.h> |
52 | #include <qregexp.h> | 50 | #include <qregexp.h> |
53 | #include <qmessagebox.h> | 51 | #include <qmessagebox.h> |
54 | #include <qframe.h> | 52 | #include <qframe.h> |
55 | #include <qpainter.h> | 53 | #include <qpainter.h> |
56 | #include <qlabel.h> | 54 | #include <qlabel.h> |
57 | #include <qtextstream.h> | 55 | #include <qtextstream.h> |
58 | #include <qpopupmenu.h> | 56 | #include <qpopupmenu.h> |
59 | 57 | ||
60 | #include "launcherview.h" | 58 | #include "launcherview.h" |
61 | #include "launcher.h" | 59 | #include "launcher.h" |
62 | #include "syncdialog.h" | 60 | #include "syncdialog.h" |
63 | #include "desktop.h" | 61 | #include "desktop.h" |
64 | #include <qpe/lnkproperties.h> | 62 | #include <qpe/lnkproperties.h> |
65 | //#include "mrulist.h" | 63 | //#include "mrulist.h" |
66 | #include "qrsync.h" | 64 | #include "qrsync.h" |
67 | #include <stdlib.h> | 65 | #include <stdlib.h> |
68 | #include <unistd.h> | 66 | #include <unistd.h> |
69 | 67 | ||
70 | #if defined(_OS_LINUX_) || defined(Q_OS_LINUX) | 68 | #if defined(_OS_LINUX_) || defined(Q_OS_LINUX) |
71 | #include <stdio.h> | 69 | #include <stdio.h> |
72 | #include <sys/vfs.h> | 70 | #include <sys/vfs.h> |
73 | #include <mntent.h> | 71 | #include <mntent.h> |
74 | #endif | 72 | #endif |
75 | 73 | ||
76 | #include <qpe/storage.h> | 74 | #include <qpe/storage.h> |
77 | #include "mediummountgui.h" | 75 | #include "mediummountgui.h" |
78 | 76 | ||
79 | namespace { | 77 | namespace { |
80 | QStringList configToMime( Config *cfg ){ | 78 | QStringList configToMime( Config *cfg ){ |
81 | QStringList mimes; | 79 | QStringList mimes; |
82 | bool tmpMime = true; | 80 | bool tmpMime = true; |
83 | cfg->setGroup("mimetypes" ); | 81 | cfg->setGroup("mimetypes" ); |
84 | tmpMime = cfg->readBoolEntry("all" ,true); | 82 | tmpMime = cfg->readBoolEntry("all" ,true); |
85 | if( tmpMime ){ | 83 | if( tmpMime ){ |
86 | mimes << QString::null; | 84 | mimes << QString::null; |
87 | return mimes; | 85 | return mimes; |
88 | }else{ | 86 | }else{ |
89 | tmpMime = cfg->readBoolEntry("audio", true ); | 87 | tmpMime = cfg->readBoolEntry("audio", true ); |
90 | if(tmpMime ) | 88 | if(tmpMime ) |
91 | mimes.append("audio/*" ); | 89 | mimes.append("audio/*" ); |
92 | 90 | ||
93 | tmpMime = cfg->readBoolEntry("image", true ); | 91 | tmpMime = cfg->readBoolEntry("image", true ); |
94 | if(tmpMime ) | 92 | if(tmpMime ) |
95 | mimes.append("image/*" ); | 93 | mimes.append("image/*" ); |
96 | 94 | ||
97 | tmpMime = cfg->readBoolEntry("text", true ); | 95 | tmpMime = cfg->readBoolEntry("text", true ); |
98 | if(tmpMime ) | 96 | if(tmpMime ) |
99 | mimes.append("text/*"); | 97 | mimes.append("text/*"); |
100 | 98 | ||
101 | tmpMime = cfg->readBoolEntry("video", true ); | 99 | tmpMime = cfg->readBoolEntry("video", true ); |
102 | if(tmpMime ) | 100 | if(tmpMime ) |
103 | mimes.append("video/*" ); | 101 | mimes.append("video/*" ); |
104 | } | 102 | } |
105 | return mimes; | 103 | return mimes; |
106 | } | 104 | } |
107 | 105 | ||
108 | } | 106 | } |
109 | 107 | ||
110 | 108 | ||
111 | 109 | ||
112 | //#define SHOW_ALL | 110 | //#define SHOW_ALL |
113 | 111 | ||
114 | class CategoryTab : public QTab | 112 | class CategoryTab : public QTab |
115 | { | 113 | { |
116 | public: | 114 | public: |
117 | CategoryTab( const QIconSet &icon, const QString &text=QString::null ) | 115 | CategoryTab( const QIconSet &icon, const QString &text=QString::null ) |
118 | : QTab( icon, text ) | 116 | : QTab( icon, text ) |
119 | { | 117 | { |
120 | } | 118 | } |
121 | 119 | ||
122 | QColor bgColor; | 120 | QColor bgColor; |
123 | QColor fgColor; | 121 | QColor fgColor; |
124 | }; | 122 | }; |
125 | 123 | ||
126 | //=========================================================================== | 124 | //=========================================================================== |
127 | 125 | ||
128 | CategoryTabWidget::CategoryTabWidget( QWidget* parent ) : | 126 | CategoryTabWidget::CategoryTabWidget( QWidget* parent ) : |
129 | QVBox( parent ) | 127 | QVBox( parent ) |
130 | { | 128 | { |
131 | categoryBar = 0; | 129 | categoryBar = 0; |
132 | stack = 0; | 130 | stack = 0; |
133 | } | 131 | } |
134 | 132 | ||
135 | void CategoryTabWidget::prevTab() | 133 | void CategoryTabWidget::prevTab() |
136 | { | 134 | { |
137 | if ( categoryBar ) { | 135 | if ( categoryBar ) { |
138 | int n = categoryBar->count(); | 136 | int n = categoryBar->count(); |
139 | int tab = categoryBar->currentTab(); | 137 | int tab = categoryBar->currentTab(); |
140 | if ( tab >= 0 ) | 138 | if ( tab >= 0 ) |
141 | categoryBar->setCurrentTab( (tab - 1 + n)%n ); | 139 | categoryBar->setCurrentTab( (tab - 1 + n)%n ); |
142 | } | 140 | } |
143 | } | 141 | } |
144 | 142 | ||
145 | void CategoryTabWidget::nextTab() | 143 | void CategoryTabWidget::nextTab() |
146 | { | 144 | { |
147 | if ( categoryBar ) { | 145 | if ( categoryBar ) { |
148 | int n = categoryBar->count(); | 146 | int n = categoryBar->count(); |
149 | int tab = categoryBar->currentTab(); | 147 | int tab = categoryBar->currentTab(); |
150 | categoryBar->setCurrentTab( (tab + 1)%n ); | 148 | categoryBar->setCurrentTab( (tab + 1)%n ); |
151 | } | 149 | } |
152 | } | 150 | } |
153 | 151 | ||
154 | void CategoryTabWidget::addItem( const QString& linkfile ) | 152 | void CategoryTabWidget::addItem( const QString& linkfile ) |
155 | { | 153 | { |
156 | int i=0; | 154 | int i=0; |
157 | AppLnk *app = new AppLnk(linkfile); | 155 | AppLnk *app = new AppLnk(linkfile); |
158 | if ( !app->isValid() ) { | 156 | if ( !app->isValid() ) { |
159 | delete app; | 157 | delete app; |
160 | app=0; | 158 | app=0; |
161 | } | 159 | } |
162 | if ( !app || !app->file().isEmpty() ) { | 160 | if ( !app || !app->file().isEmpty() ) { |
163 | // A document | 161 | // A document |
164 | delete app; | 162 | delete app; |
165 | app = new DocLnk(linkfile); | 163 | app = new DocLnk(linkfile); |
166 | if ( app->fileKnown() ) { | 164 | if ( app->fileKnown() ) { |
167 | ((LauncherView*)(stack->widget(ids.count()-1)))->addItem(app); | 165 | ((LauncherView*)(stack->widget(ids.count()-1)))->addItem(app); |
168 | } else { | 166 | } else { |
169 | ((LauncherView*)(stack->widget(ids.count()-1)))->sort(); | 167 | ((LauncherView*)(stack->widget(ids.count()-1)))->sort(); |
170 | delete app; | 168 | delete app; |
171 | } | 169 | } |
172 | return; | 170 | return; |
173 | } | 171 | } |
174 | // An application | 172 | // An application |
175 | for ( QStringList::Iterator it=ids.begin(); it!=ids.end(); ++it) { | 173 | for ( QStringList::Iterator it=ids.begin(); it!=ids.end(); ++it) { |
176 | if ( !(*it).isEmpty() ) { | 174 | if ( !(*it).isEmpty() ) { |
177 | QRegExp tf(*it,FALSE,TRUE); | 175 | QRegExp tf(*it,FALSE,TRUE); |
178 | if ( tf.match(app->type()) >= 0 ) { | 176 | if ( tf.match(app->type()) >= 0 ) { |
179 | ((LauncherView*)stack->widget(i))->addItem(app); | 177 | ((LauncherView*)stack->widget(i))->addItem(app); |
180 | return; | 178 | return; |
181 | } | 179 | } |
182 | i++; | 180 | i++; |
183 | } | 181 | } |
184 | } | 182 | } |
185 | 183 | ||
186 | QCopEnvelope e("QPE/TaskBar","reloadApps()"); | 184 | QCopEnvelope e("QPE/TaskBar","reloadApps()"); |
187 | } | 185 | } |
188 | 186 | ||
189 | void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder, | 187 | void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder, |
190 | AppLnkSet* docFolder, const QList<FileSystem> &fs) | 188 | AppLnkSet* docFolder, const QList<FileSystem> &fs) |
191 | { | 189 | { |
192 | delete categoryBar; | 190 | delete categoryBar; |
193 | categoryBar = new CategoryTabBar( this ); | 191 | categoryBar = new CategoryTabBar( this ); |
194 | QPalette pal = categoryBar->palette(); | 192 | QPalette pal = categoryBar->palette(); |
195 | pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) ); | 193 | pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) ); |
196 | pal.setColor( QColorGroup::Background, pal.active().background().light(110) ); | 194 | pal.setColor( QColorGroup::Background, pal.active().background().light(110) ); |
197 | categoryBar->setPalette( pal ); | 195 | categoryBar->setPalette( pal ); |
198 | 196 | ||
199 | delete stack; | 197 | delete stack; |
200 | stack = new QWidgetStack(this); | 198 | stack = new QWidgetStack(this); |
201 | tabs=0; | 199 | tabs=0; |
202 | 200 | ||
203 | ids.clear(); | 201 | ids.clear(); |
204 | 202 | ||
205 | Config cfg("Launcher"); | 203 | Config cfg("Launcher"); |
206 | 204 | ||
207 | QStringList types = rootFolder->types(); | 205 | QStringList types = rootFolder->types(); |
208 | for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) { | 206 | for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) { |
209 | if ( !(*it).isEmpty() ) { | 207 | if ( !(*it).isEmpty() ) { |
210 | (void)newView(*it,rootFolder->typePixmap(*it),rootFolder->typeName(*it)); | 208 | (void)newView(*it,rootFolder->typePixmap(*it),rootFolder->typeName(*it)); |
211 | setTabAppearance( *it, cfg ); | 209 | setTabAppearance( *it, cfg ); |
212 | } | 210 | } |
213 | } | 211 | } |
214 | QListIterator<AppLnk> it( rootFolder->children() ); | 212 | QListIterator<AppLnk> it( rootFolder->children() ); |
215 | AppLnk* l; | 213 | AppLnk* l; |
216 | while ( (l=it.current()) ) { | 214 | while ( (l=it.current()) ) { |
217 | if ( l->type() == "Separator" ) { // No tr | 215 | if ( l->type() == "Separator" ) { // No tr |
218 | rootFolder->remove(l); | 216 | rootFolder->remove(l); |
219 | delete l; | 217 | delete l; |
220 | } else { | 218 | } else { |
221 | int i=0; | 219 | int i=0; |
222 | for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) { | 220 | for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) { |
223 | if ( *it == l->type() ) | 221 | if ( *it == l->type() ) |
224 | ((LauncherView*)stack->widget(i))->addItem(l,FALSE); | 222 | ((LauncherView*)stack->widget(i))->addItem(l,FALSE); |
225 | i++; | 223 | i++; |
226 | } | 224 | } |
227 | } | 225 | } |
228 | ++it; | 226 | ++it; |
229 | } | 227 | } |
230 | rootFolder->detachChildren(); | 228 | rootFolder->detachChildren(); |
231 | for (int i=0; i<tabs; i++) | 229 | for (int i=0; i<tabs; i++) |
232 | ((LauncherView*)stack->widget(i))->sort(); | 230 | ((LauncherView*)stack->widget(i))->sort(); |
233 | 231 | ||
234 | // all documents | 232 | // all documents |
235 | QImage img( Resource::loadImage( "DocsIcon" ) ); | 233 | QImage img( Resource::loadImage( "DocsIcon" ) ); |
236 | QPixmap pm; | 234 | QPixmap pm; |
237 | pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); | 235 | pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); |
238 | docview = newView( "Documents", // No tr | 236 | docview = newView( "Documents", // No tr |
239 | pm, tr("Documents")); | 237 | pm, tr("Documents")); |
240 | docview->populate( docFolder, QString::null ); | 238 | docview->populate( docFolder, QString::null ); |
241 | docFolder->detachChildren(); | 239 | docFolder->detachChildren(); |
242 | docview->setFileSystems(fs); | 240 | docview->setFileSystems(fs); |
243 | docview->setToolsEnabled(TRUE); | 241 | docview->setToolsEnabled(TRUE); |
244 | setTabAppearance( "Documents", cfg ); // No tr | 242 | setTabAppearance( "Documents", cfg ); // No tr |
245 | 243 | ||
246 | connect( categoryBar, SIGNAL(selected(int)), stack, SLOT(raiseWidget(int)) ); | 244 | connect( categoryBar, SIGNAL(selected(int)), stack, SLOT(raiseWidget(int)) ); |
247 | 245 | ||
248 | ((LauncherView*)stack->widget(0))->setFocus(); | 246 | ((LauncherView*)stack->widget(0))->setFocus(); |
249 | 247 | ||
250 | cfg. setGroup ( "GUI" ); | 248 | cfg. setGroup ( "GUI" ); |
251 | setBusyIndicatorType ( cfg. readEntry ( "BusyType", QString::null )); | 249 | setBusyIndicatorType ( cfg. readEntry ( "BusyType", QString::null )); |
252 | 250 | ||
253 | categoryBar->show(); | 251 | categoryBar->show(); |
254 | stack->show(); | 252 | stack->show(); |
255 | } | 253 | } |
256 | 254 | ||
257 | void CategoryTabWidget::setTabAppearance( const QString &id, Config &cfg ) | 255 | void CategoryTabWidget::setTabAppearance( const QString &id, Config &cfg ) |
258 | { | 256 | { |
259 | QString grp( "Tab %1" ); // No tr | 257 | QString grp( "Tab %1" ); // No tr |
260 | cfg.setGroup( grp.arg(id) ); | 258 | cfg.setGroup( grp.arg(id) ); |
261 | LauncherView *v = view( id ); | 259 | LauncherView *v = view( id ); |
262 | int idx = ids.findIndex( id ); | 260 | int idx = ids.findIndex( id ); |
263 | CategoryTab *tab = (CategoryTab *)categoryBar->tab( idx ); | 261 | CategoryTab *tab = (CategoryTab *)categoryBar->tab( idx ); |
264 | 262 | ||
265 | // View | 263 | // View |
266 | QString view = cfg.readEntry( "View", "Icon" ); | 264 | QString view = cfg.readEntry( "View", "Icon" ); |
267 | if ( view == "List" ) // No tr | 265 | if ( view == "List" ) // No tr |
268 | v->setViewMode( LauncherView::List ); | 266 | v->setViewMode( LauncherView::List ); |
269 | QString bgType = cfg.readEntry( "BackgroundType", "Image" ); | 267 | QString bgType = cfg.readEntry( "BackgroundType", "Image" ); |
270 | if ( bgType == "Image" ) { // No tr | 268 | if ( bgType == "Image" ) { // No tr |
271 | QString pm = cfg.readEntry( "BackgroundImage", "launcher/opie-background" ); | 269 | QString pm = cfg.readEntry( "BackgroundImage", "launcher/opie-background" ); |
272 | v->setBackgroundType( LauncherView::Image, pm ); | 270 | v->setBackgroundType( LauncherView::Image, pm ); |
273 | } else if ( bgType == "SolidColor" ) { | 271 | } else if ( bgType == "SolidColor" ) { |
274 | QString c = cfg.readEntry( "BackgroundColor" ); | 272 | QString c = cfg.readEntry( "BackgroundColor" ); |
275 | v->setBackgroundType( LauncherView::SolidColor, c ); | 273 | v->setBackgroundType( LauncherView::SolidColor, c ); |
276 | } | 274 | } |
277 | QString textCol = cfg.readEntry( "TextColor" ); | 275 | QString textCol = cfg.readEntry( "TextColor" ); |
278 | if ( textCol.isEmpty() ) | 276 | if ( textCol.isEmpty() ) |
279 | v->setTextColor( QColor() ); | 277 | v->setTextColor( QColor() ); |
280 | else | 278 | else |
281 | v->setTextColor( QColor(textCol) ); | 279 | v->setTextColor( QColor(textCol) ); |
282 | QStringList font = cfg.readListEntry( "Font", ',' ); | 280 | QStringList font = cfg.readListEntry( "Font", ',' ); |
283 | if ( font.count() == 4 ) | 281 | if ( font.count() == 4 ) |
284 | v->setViewFont( QFont(font[0], font[1].toInt(), font[2].toInt(), font[3].toInt()!=0) ); | 282 | v->setViewFont( QFont(font[0], font[1].toInt(), font[2].toInt(), font[3].toInt()!=0) ); |
285 | 283 | ||
286 | // Tabs | 284 | // Tabs |
287 | QString tabCol = cfg.readEntry( "TabColor" ); | 285 | QString tabCol = cfg.readEntry( "TabColor" ); |
288 | if ( tabCol.isEmpty() ) | 286 | if ( tabCol.isEmpty() ) |
289 | tab->bgColor = QColor(); | 287 | tab->bgColor = QColor(); |
290 | else | 288 | else |
291 | tab->bgColor = QColor(tabCol); | 289 | tab->bgColor = QColor(tabCol); |
292 | QString tabTextCol = cfg.readEntry( "TabTextColor" ); | 290 | QString tabTextCol = cfg.readEntry( "TabTextColor" ); |
293 | if ( tabTextCol.isEmpty() ) | 291 | if ( tabTextCol.isEmpty() ) |
294 | tab->fgColor = QColor(); | 292 | tab->fgColor = QColor(); |
295 | else | 293 | else |
296 | tab->fgColor = QColor(tabTextCol); | 294 | tab->fgColor = QColor(tabTextCol); |
297 | } | 295 | } |
298 | 296 | ||
299 | void CategoryTabWidget::updateDocs(AppLnkSet* docFolder, const QList<FileSystem> &fs) | 297 | void CategoryTabWidget::updateDocs(AppLnkSet* docFolder, const QList<FileSystem> &fs) |
300 | { | 298 | { |
301 | docview->populate( docFolder, QString::null ); | 299 | docview->populate( docFolder, QString::null ); |
302 | docFolder->detachChildren(); | 300 | docFolder->detachChildren(); |
303 | docview->setFileSystems(fs); | 301 | docview->setFileSystems(fs); |
304 | docview->updateTools(); | 302 | docview->updateTools(); |
305 | } | 303 | } |
306 | 304 | ||
307 | void CategoryTabWidget::tabProperties() | 305 | void CategoryTabWidget::tabProperties() |
308 | { | 306 | { |
309 | LauncherView *view = (LauncherView*)stack->widget( categoryBar->currentTab() ); | 307 | LauncherView *view = (LauncherView*)stack->widget( categoryBar->currentTab() ); |
310 | QPopupMenu *m = new QPopupMenu( this ); | 308 | QPopupMenu *m = new QPopupMenu( this ); |
311 | m->insertItem( tr("Icon View"), LauncherView::Icon ); | 309 | m->insertItem( tr("Icon View"), LauncherView::Icon ); |
312 | m->insertItem( tr("List View"), LauncherView::List ); | 310 | m->insertItem( tr("List View"), LauncherView::List ); |
313 | m->setItemChecked( (int)view->viewMode(), TRUE ); | 311 | m->setItemChecked( (int)view->viewMode(), TRUE ); |
314 | int rv = m->exec( QCursor::pos() ); | 312 | int rv = m->exec( QCursor::pos() ); |
315 | if ( rv >= 0 && rv != view->viewMode() ) { | 313 | if ( rv >= 0 && rv != view->viewMode() ) { |
316 | view->setViewMode( (LauncherView::ViewMode)rv ); | 314 | view->setViewMode( (LauncherView::ViewMode)rv ); |
317 | } | 315 | } |
318 | 316 | ||
319 | delete m; | 317 | delete m; |
320 | } | 318 | } |
321 | 319 | ||
322 | QString CategoryTabWidget::getAllDocLinkInfo() const | 320 | QString CategoryTabWidget::getAllDocLinkInfo() const |
323 | { | 321 | { |
324 | return docview->getAllDocLinkInfo(); | 322 | return docview->getAllDocLinkInfo(); |
325 | } | 323 | } |
326 | 324 | ||
327 | LauncherView* CategoryTabWidget::newView( const QString& id, const QPixmap& pm, const QString& label ) | 325 | LauncherView* CategoryTabWidget::newView( const QString& id, const QPixmap& pm, const QString& label ) |
328 | { | 326 | { |
329 | LauncherView* view = new LauncherView( stack ); | 327 | LauncherView* view = new LauncherView( stack ); |
330 | connect( view, SIGNAL(clicked(const AppLnk*)), | 328 | connect( view, SIGNAL(clicked(const AppLnk*)), |
331 | this, SIGNAL(clicked(const AppLnk*))); | 329 | this, SIGNAL(clicked(const AppLnk*))); |
332 | connect( view, SIGNAL(rightPressed(AppLnk*)), | 330 | connect( view, SIGNAL(rightPressed(AppLnk*)), |
333 | this, SIGNAL(rightPressed(AppLnk*))); | 331 | this, SIGNAL(rightPressed(AppLnk*))); |
334 | ids.append(id); | 332 | ids.append(id); |
335 | categoryBar->addTab( new CategoryTab( pm, label ) ); | 333 | categoryBar->addTab( new CategoryTab( pm, label ) ); |
336 | stack->addWidget( view, tabs++ ); | 334 | stack->addWidget( view, tabs++ ); |
337 | return view; | 335 | return view; |
338 | } | 336 | } |
339 | 337 | ||
340 | void CategoryTabWidget::updateLink(const QString& linkfile) | 338 | void CategoryTabWidget::updateLink(const QString& linkfile) |
341 | { | 339 | { |
342 | int i=0; | 340 | int i=0; |
343 | LauncherView* view; | 341 | LauncherView* view; |
344 | while ((view = (LauncherView*)stack->widget(i++))) { | 342 | while ((view = (LauncherView*)stack->widget(i++))) { |
345 | if ( view->removeLink(linkfile) ) | 343 | if ( view->removeLink(linkfile) ) |
346 | break; | 344 | break; |
347 | } | 345 | } |
348 | addItem(linkfile); | 346 | addItem(linkfile); |
349 | docview->updateTools(); | 347 | docview->updateTools(); |
350 | } | 348 | } |
351 | 349 | ||
352 | void CategoryTabWidget::paletteChange( const QPalette &p ) | 350 | void CategoryTabWidget::paletteChange( const QPalette &p ) |
353 | { | 351 | { |
354 | QVBox::paletteChange( p ); | 352 | QVBox::paletteChange( p ); |
355 | QPalette pal = palette(); | 353 | QPalette pal = palette(); |
356 | pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) ); | 354 | pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) ); |
357 | pal.setColor( QColorGroup::Background, pal.active().background().light(110) ); | 355 | pal.setColor( QColorGroup::Background, pal.active().background().light(110) ); |
358 | categoryBar->setPalette( pal ); | 356 | categoryBar->setPalette( pal ); |
359 | categoryBar->update(); | 357 | categoryBar->update(); |
360 | } | 358 | } |
361 | 359 | ||
362 | void CategoryTabWidget::setBusy(bool on) | 360 | void CategoryTabWidget::setBusy(bool on) |
363 | { | 361 | { |
364 | if ( on ) | 362 | if ( on ) |
365 | ((LauncherView*)stack->visibleWidget())->setBusy(TRUE); | 363 | ((LauncherView*)stack->visibleWidget())->setBusy(TRUE); |
366 | else | 364 | else |
367 | for (int i=0; i<tabs; i++) | 365 | for (int i=0; i<tabs; i++) |
368 | ((LauncherView*)stack->widget(i))->setBusy(FALSE); | 366 | ((LauncherView*)stack->widget(i))->setBusy(FALSE); |
369 | } | 367 | } |
370 | 368 | ||
371 | LauncherView *CategoryTabWidget::view( const QString &id ) | 369 | LauncherView *CategoryTabWidget::view( const QString &id ) |
372 | { | 370 | { |
373 | int idx = ids.findIndex( id ); | 371 | int idx = ids.findIndex( id ); |
374 | return (LauncherView *)stack->widget(idx); | 372 | return (LauncherView *)stack->widget(idx); |
375 | } | 373 | } |
376 | 374 | ||
377 | void CategoryTabWidget::setBusyIndicatorType ( const QString &type ) | 375 | void CategoryTabWidget::setBusyIndicatorType ( const QString &type ) |
378 | { | 376 | { |
379 | for ( QStringList::Iterator it = ids. begin ( ); it != ids. end ( ); ++it ) | 377 | for ( QStringList::Iterator it = ids. begin ( ); it != ids. end ( ); ++it ) |
380 | view ( *it )-> setBusyIndicatorType ( type ); | 378 | view ( *it )-> setBusyIndicatorType ( type ); |
381 | } | 379 | } |
382 | 380 | ||
383 | //=========================================================================== | 381 | //=========================================================================== |
384 | 382 | ||
385 | CategoryTabBar::CategoryTabBar( QWidget *parent, const char *name ) | 383 | CategoryTabBar::CategoryTabBar( QWidget *parent, const char *name ) |
386 | : QTabBar( parent, name ) | 384 | : QTabBar( parent, name ) |
387 | { | 385 | { |
388 | setFocusPolicy( NoFocus ); | 386 | setFocusPolicy( NoFocus ); |
389 | connect( this, SIGNAL( selected(int) ), this, SLOT( layoutTabs() ) ); | 387 | connect( this, SIGNAL( selected(int) ), this, SLOT( layoutTabs() ) ); |
390 | } | 388 | } |
391 | 389 | ||
392 | CategoryTabBar::~CategoryTabBar() | 390 | CategoryTabBar::~CategoryTabBar() |
393 | { | 391 | { |
394 | } | 392 | } |
395 | 393 | ||
396 | void CategoryTabBar::layoutTabs() | 394 | void CategoryTabBar::layoutTabs() |
397 | { | 395 | { |
398 | if ( !count() ) | 396 | if ( !count() ) |
399 | return; | 397 | return; |
400 | 398 | ||
401 | // int percentFalloffTable[] = { 100, 70, 40, 12, 6, 3, 1, 0 }; | 399 | // int percentFalloffTable[] = { 100, 70, 40, 12, 6, 3, 1, 0 }; |
402 | int available = width()-1; | 400 | int available = width()-1; |
403 | QFontMetrics fm = fontMetrics(); | 401 | QFontMetrics fm = fontMetrics(); |
404 | int hiddenTabWidth = -7; | 402 | int hiddenTabWidth = -7; |
405 | int middleTab = currentTab(); | 403 | int middleTab = currentTab(); |
406 | int hframe, vframe, overlap; | 404 | int hframe, vframe, overlap; |
407 | style().tabbarMetrics( this, hframe, vframe, overlap ); | 405 | style().tabbarMetrics( this, hframe, vframe, overlap ); |
408 | int x = 0; | 406 | int x = 0; |
409 | QRect r; | 407 | QRect r; |
410 | QTab *t; | 408 | QTab *t; |
411 | int required = 0; | 409 | int required = 0; |
412 | int eventabwidth = (width()-1)/count(); | 410 | int eventabwidth = (width()-1)/count(); |
413 | enum Mode { HideBackText, Pack, Even } mode=Even; | 411 | enum Mode { HideBackText, Pack, Even } mode=Even; |
414 | for ( int i = 0; i < count(); i++ ) { | 412 | for ( int i = 0; i < count(); i++ ) { |
415 | t = tab(i); | 413 | t = tab(i); |
416 | int iw = fm.width( t->text() ) + hframe - overlap; | 414 | int iw = fm.width( t->text() ) + hframe - overlap; |
417 | if ( i != middleTab ) { | 415 | if ( i != middleTab ) { |
418 | available -= hiddenTabWidth + hframe - overlap; | 416 | available -= hiddenTabWidth + hframe - overlap; |
419 | if ( t->iconSet() != 0 ) | 417 | if ( t->iconSet() != 0 ) |
420 | available -= t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 418 | available -= t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
421 | } | 419 | } |
422 | if ( t->iconSet() != 0 ) | 420 | if ( t->iconSet() != 0 ) |
423 | iw += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 421 | iw += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
424 | required += iw; | 422 | required += iw; |
425 | // As space gets tight, packed looks better than even. "10" must be at least 0. | 423 | // As space gets tight, packed looks better than even. "10" must be at least 0. |
426 | if ( iw >= eventabwidth-10 ) | 424 | if ( iw >= eventabwidth-10 ) |
427 | mode = Pack; | 425 | mode = Pack; |
428 | } | 426 | } |
429 | if ( mode == Pack && required > width()-1 ) | 427 | if ( mode == Pack && required > width()-1 ) |
430 | mode = HideBackText; | 428 | mode = HideBackText; |
431 | for ( int i = 0; i < count(); i++ ) { | 429 | for ( int i = 0; i < count(); i++ ) { |
432 | t = tab(i); | 430 | t = tab(i); |
433 | if ( mode != HideBackText ) { | 431 | if ( mode != HideBackText ) { |
434 | int w = fm.width( t->text() ); | 432 | int w = fm.width( t->text() ); |
435 | int ih = 0; | 433 | int ih = 0; |
436 | if ( t->iconSet() != 0 ) { | 434 | if ( t->iconSet() != 0 ) { |
437 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 435 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
438 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 436 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
439 | } | 437 | } |
440 | int h = QMAX( fm.height(), ih ); | 438 | int h = QMAX( fm.height(), ih ); |
441 | h = QMAX( h, QApplication::globalStrut().height() ); | 439 | h = QMAX( h, QApplication::globalStrut().height() ); |
442 | 440 | ||
443 | h += vframe; | 441 | h += vframe; |
444 | w += hframe; | 442 | w += hframe; |
445 | 443 | ||
446 | QRect tr(x, 0, | 444 | QRect tr(x, 0, |
447 | mode == Even ? eventabwidth : w * (width()-1)/required, h); | 445 | mode == Even ? eventabwidth : w * (width()-1)/required, h); |
448 | t->setRect(tr); | 446 | t->setRect(tr); |
449 | x += tr.width() - overlap; | 447 | x += tr.width() - overlap; |
450 | r = r.unite(tr); | 448 | r = r.unite(tr); |
451 | } else if ( i != middleTab ) { | 449 | } else if ( i != middleTab ) { |
452 | int w = hiddenTabWidth; | 450 | int w = hiddenTabWidth; |
453 | int ih = 0; | 451 | int ih = 0; |
454 | if ( t->iconSet() != 0 ) { | 452 | if ( t->iconSet() != 0 ) { |
455 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 453 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
456 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 454 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
457 | } | 455 | } |
458 | int h = QMAX( fm.height(), ih ); | 456 | int h = QMAX( fm.height(), ih ); |
459 | h = QMAX( h, QApplication::globalStrut().height() ); | 457 | h = QMAX( h, QApplication::globalStrut().height() ); |
460 | 458 | ||
461 | h += vframe; | 459 | h += vframe; |
462 | w += hframe; | 460 | w += hframe; |
463 | 461 | ||
464 | t->setRect( QRect(x, 0, w, h) ); | 462 | t->setRect( QRect(x, 0, w, h) ); |
465 | x += t->rect().width() - overlap; | 463 | x += t->rect().width() - overlap; |
466 | r = r.unite( t->rect() ); | 464 | r = r.unite( t->rect() ); |
467 | } else { | 465 | } else { |
468 | int ih = 0; | 466 | int ih = 0; |
469 | if ( t->iconSet() != 0 ) { | 467 | if ( t->iconSet() != 0 ) { |
470 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 468 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
471 | } | 469 | } |
472 | int h = QMAX( fm.height(), ih ); | 470 | int h = QMAX( fm.height(), ih ); |
473 | h = QMAX( h, QApplication::globalStrut().height() ); | 471 | h = QMAX( h, QApplication::globalStrut().height() ); |
474 | 472 | ||
475 | h += vframe; | 473 | h += vframe; |
476 | 474 | ||
477 | t->setRect( QRect(x, 0, available, h) ); | 475 | t->setRect( QRect(x, 0, available, h) ); |
478 | x += t->rect().width() - overlap; | 476 | x += t->rect().width() - overlap; |
479 | r = r.unite( t->rect() ); | 477 | r = r.unite( t->rect() ); |
480 | } | 478 | } |
481 | } | 479 | } |
482 | 480 | ||
483 | QRect rr = tab(count()-1)->rect(); | 481 | QRect rr = tab(count()-1)->rect(); |
484 | rr.setRight(width()-1); | 482 | rr.setRight(width()-1); |
485 | tab(count()-1)->setRect( rr ); | 483 | tab(count()-1)->setRect( rr ); |
486 | 484 | ||
487 | for ( t = tabList()->first(); t; t = tabList()->next() ) { | 485 | for ( t = tabList()->first(); t; t = tabList()->next() ) { |
488 | QRect tr = t->rect(); | 486 | QRect tr = t->rect(); |
489 | tr.setHeight( r.height() ); | 487 | tr.setHeight( r.height() ); |
490 | t->setRect( tr ); | 488 | t->setRect( tr ); |
491 | } | 489 | } |
492 | 490 | ||
493 | update(); | 491 | update(); |
494 | } | 492 | } |
495 | 493 | ||
496 | 494 | ||
497 | void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const | 495 | void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const |
498 | { | 496 | { |
499 | CategoryTabBar *that = (CategoryTabBar *) this; | 497 | CategoryTabBar *that = (CategoryTabBar *) this; |
500 | CategoryTab *ct = (CategoryTab *)t; | 498 | CategoryTab *ct = (CategoryTab *)t; |
501 | QPalette pal = palette(); | 499 | QPalette pal = palette(); |
502 | bool setPal = FALSE; | 500 | bool setPal = FALSE; |
503 | if ( ct->bgColor.isValid() ) { | 501 | if ( ct->bgColor.isValid() ) { |
504 | pal.setColor( QPalette::Active, QColorGroup::Background, ct->bgColor ); | 502 | pal.setColor( QPalette::Active, QColorGroup::Background, ct->bgColor ); |
505 | pal.setColor( QPalette::Active, QColorGroup::Button, ct->bgColor ); | 503 | pal.setColor( QPalette::Active, QColorGroup::Button, ct->bgColor ); |
506 | pal.setColor( QPalette::Inactive, QColorGroup::Background, ct->bgColor ); | 504 | pal.setColor( QPalette::Inactive, QColorGroup::Background, ct->bgColor ); |
507 | pal.setColor( QPalette::Inactive, QColorGroup::Button, ct->bgColor ); | 505 | pal.setColor( QPalette::Inactive, QColorGroup::Button, ct->bgColor ); |
508 | that->setUpdatesEnabled( FALSE ); | 506 | that->setUpdatesEnabled( FALSE ); |
509 | that->setPalette( pal ); | 507 | that->setPalette( pal ); |
510 | setPal = TRUE; | 508 | setPal = TRUE; |
511 | } | 509 | } |
512 | #if QT_VERSION >= 300 | 510 | #if QT_VERSION >= 300 |
513 | QStyle::SFlags flags = QStyle::Style_Default; | 511 | QStyle::SFlags flags = QStyle::Style_Default; |
514 | if ( selected ) | 512 | if ( selected ) |
515 | flags |= QStyle::Style_Selected; | 513 | flags |= QStyle::Style_Selected; |
516 | style().drawControl( QStyle::CE_TabBarTab, p, this, t->rect(), | 514 | style().drawControl( QStyle::CE_TabBarTab, p, this, t->rect(), |
517 | colorGroup(), flags, QStyleOption(t) ); | 515 | colorGroup(), flags, QStyleOption(t) ); |
518 | #else | 516 | #else |
519 | style().drawTab( p, this, t, selected ); | 517 | style().drawTab( p, this, t, selected ); |
520 | #endif | 518 | #endif |
521 | 519 | ||
522 | QRect r( t->rect() ); | 520 | QRect r( t->rect() ); |
523 | QFont f( font() ); | 521 | QFont f( font() ); |
524 | if ( selected ) | 522 | if ( selected ) |
525 | f.setBold( TRUE ); | 523 | f.setBold( TRUE ); |
526 | p->setFont( f ); | 524 | p->setFont( f ); |
527 | 525 | ||
528 | if ( ct->fgColor.isValid() ) { | 526 | if ( ct->fgColor.isValid() ) { |
529 | pal.setColor( QPalette::Active, QColorGroup::Foreground, ct->fgColor ); | 527 | pal.setColor( QPalette::Active, QColorGroup::Foreground, ct->fgColor ); |
530 | pal.setColor( QPalette::Inactive, QColorGroup::Foreground, ct->fgColor ); | 528 | pal.setColor( QPalette::Inactive, QColorGroup::Foreground, ct->fgColor ); |
531 | that->setUpdatesEnabled( FALSE ); | 529 | that->setUpdatesEnabled( FALSE ); |
532 | that->setPalette( pal ); | 530 | that->setPalette( pal ); |
533 | setPal = TRUE; | 531 | setPal = TRUE; |
534 | } | 532 | } |
535 | int iw = 0; | 533 | int iw = 0; |
536 | int ih = 0; | 534 | int ih = 0; |
537 | if ( t->iconSet() != 0 ) { | 535 | if ( t->iconSet() != 0 ) { |
538 | iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; | 536 | iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; |
539 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 537 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
540 | } | 538 | } |
541 | int w = iw + p->fontMetrics().width( t->text() ) + 4; | 539 | int w = iw + p->fontMetrics().width( t->text() ) + 4; |
542 | int h = QMAX(p->fontMetrics().height() + 4, ih ); | 540 | int h = QMAX(p->fontMetrics().height() + 4, ih ); |
543 | paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, | 541 | paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, |
544 | r.top() + (r.height()-h)/2, w, h ), t, | 542 | r.top() + (r.height()-h)/2, w, h ), t, |
545 | #if QT_VERSION >= 300 | 543 | #if QT_VERSION >= 300 |
546 | t->identifier() == keyboardFocusTab() | 544 | t->identifier() == keyboardFocusTab() |
547 | #else | 545 | #else |
548 | t->identitifer() == keyboardFocusTab() | 546 | t->identitifer() == keyboardFocusTab() |
549 | #endif | 547 | #endif |
550 | ); | 548 | ); |
551 | if ( setPal ) { | 549 | if ( setPal ) { |
552 | that->unsetPalette(); | 550 | that->unsetPalette(); |
553 | that->setUpdatesEnabled( TRUE ); | 551 | that->setUpdatesEnabled( TRUE ); |
554 | } | 552 | } |
555 | } | 553 | } |
556 | 554 | ||
557 | 555 | ||
558 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, | 556 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, |
559 | QTab* t, bool has_focus ) const | 557 | QTab* t, bool has_focus ) const |
560 | { | 558 | { |
561 | QRect r = t->rect(); | 559 | QRect r = t->rect(); |
562 | // if ( t->id != currentTab() ) | 560 | // if ( t->id != currentTab() ) |
563 | //r.moveBy( 1, 1 ); | 561 | //r.moveBy( 1, 1 ); |
564 | // | 562 | // |
565 | if ( t->iconSet() ) { | 563 | if ( t->iconSet() ) { |
566 | // the tab has an iconset, draw it in the right mode | 564 | // the tab has an iconset, draw it in the right mode |
567 | QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; | 565 | QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; |
568 | if ( mode == QIconSet::Normal && has_focus ) | 566 | if ( mode == QIconSet::Normal && has_focus ) |
569 | mode = QIconSet::Active; | 567 | mode = QIconSet::Active; |
570 | QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); | 568 | QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); |
571 | int pixw = pixmap.width(); | 569 | int pixw = pixmap.width(); |
572 | int pixh = pixmap.height(); | 570 | int pixh = pixmap.height(); |
573 | p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); | 571 | p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); |
574 | r.setLeft( r.left() + pixw + 5 ); | 572 | r.setLeft( r.left() + pixw + 5 ); |
575 | } | 573 | } |
576 | 574 | ||
577 | QRect tr = r; | 575 | QRect tr = r; |
578 | 576 | ||
579 | if ( r.width() < 20 ) | 577 | if ( r.width() < 20 ) |
580 | return; | 578 | return; |
581 | 579 | ||
582 | if ( t->isEnabled() && isEnabled() ) { | 580 | if ( t->isEnabled() && isEnabled() ) { |
583 | #if defined(_WS_WIN32_) | 581 | #if defined(_WS_WIN32_) |
584 | if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) | 582 | if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) |
585 | p->setPen( colorGroup().buttonText() ); | 583 | p->setPen( colorGroup().buttonText() ); |
586 | else | 584 | else |
587 | p->setPen( colorGroup().foreground() ); | 585 | p->setPen( colorGroup().foreground() ); |
588 | #else | 586 | #else |
589 | p->setPen( colorGroup().foreground() ); | 587 | p->setPen( colorGroup().foreground() ); |
590 | #endif | 588 | #endif |
591 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); | 589 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); |
592 | } else { | 590 | } else { |
593 | p->setPen( palette().disabled().foreground() ); | 591 | p->setPen( palette().disabled().foreground() ); |
594 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); | 592 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); |
595 | } | 593 | } |
596 | } | 594 | } |
597 | 595 | ||
598 | //--------------------------------------------------------------------------- | 596 | //--------------------------------------------------------------------------- |
599 | 597 | ||
600 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) | 598 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) |
601 | : QMainWindow( parent, name, fl ) | 599 | : QMainWindow( parent, name, fl ) |
602 | { | 600 | { |
603 | setCaption( tr("Launcher") ); | 601 | setCaption( tr("Launcher") ); |
604 | 602 | ||
605 | syncDialog = 0; | 603 | syncDialog = 0; |
606 | 604 | ||
607 | // we have a pretty good idea how big we'll be | 605 | // we have a pretty good idea how big we'll be |
608 | setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); | 606 | setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); |
609 | 607 | ||
610 | tabs = 0; | 608 | tabs = 0; |
611 | rootFolder = 0; | 609 | rootFolder = 0; |
612 | docsFolder = 0; | 610 | docsFolder = 0; |
613 | 611 | ||
614 | int stamp = uidgen.generate(); // this is our timestamp to see which devices we know | 612 | int stamp = uidgen.generate(); // this is our timestamp to see which devices we know |
615 | //uidgen.store( stamp ); | 613 | //uidgen.store( stamp ); |
616 | m_timeStamp = QString::number( stamp ); | 614 | m_timeStamp = QString::number( stamp ); |
617 | 615 | ||
618 | tabs = new CategoryTabWidget( this ); | 616 | tabs = new CategoryTabWidget( this ); |
619 | tabs->setMaximumWidth( qApp->desktop()->width() ); | 617 | tabs->setMaximumWidth( qApp->desktop()->width() ); |
620 | setCentralWidget( tabs ); | 618 | setCentralWidget( tabs ); |
621 | 619 | ||
622 | connect( tabs, SIGNAL(selected(const QString&)), | 620 | connect( tabs, SIGNAL(selected(const QString&)), |
623 | this, SLOT(viewSelected(const QString&)) ); | 621 | this, SLOT(viewSelected(const QString&)) ); |
624 | connect( tabs, SIGNAL(clicked(const AppLnk*)), | 622 | connect( tabs, SIGNAL(clicked(const AppLnk*)), |
625 | this, SLOT(select(const AppLnk*))); | 623 | this, SLOT(select(const AppLnk*))); |
626 | connect( tabs, SIGNAL(rightPressed(AppLnk*)), | 624 | connect( tabs, SIGNAL(rightPressed(AppLnk*)), |
627 | this, SLOT(properties(AppLnk*))); | 625 | this, SLOT(properties(AppLnk*))); |
628 | 626 | ||
629 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 627 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
630 | QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); | 628 | QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); |
631 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 629 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
632 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); | 630 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); |
633 | QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); | 631 | QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); |
634 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 632 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
635 | this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); | 633 | this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); |
636 | #endif | 634 | #endif |
637 | 635 | ||
638 | storage = new StorageInfo( this ); | 636 | storage = new StorageInfo( this ); |
639 | connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); | 637 | connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); |
640 | 638 | ||
641 | updateTabs(); | 639 | updateTabs(); |
642 | 640 | ||
643 | preloadApps(); | 641 | preloadApps(); |
644 | 642 | ||
645 | in_lnk_props = FALSE; | 643 | in_lnk_props = FALSE; |
646 | got_lnk_change = FALSE; | 644 | got_lnk_change = FALSE; |
647 | } | 645 | } |
648 | 646 | ||
649 | Launcher::~Launcher() | 647 | Launcher::~Launcher() |
650 | { | 648 | { |
651 | delete rootFolder; | 649 | delete rootFolder; |
652 | delete docsFolder; | 650 | delete docsFolder; |
653 | } | 651 | } |
654 | 652 | ||
655 | static bool isVisibleWindow(int wid) | 653 | static bool isVisibleWindow(int wid) |
656 | { | 654 | { |
657 | #ifdef QWS | 655 | #ifdef QWS |
658 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 656 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
659 | QWSWindow* w; | 657 | QWSWindow* w; |
660 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { | 658 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { |
661 | if ( w->winId() == wid ) | 659 | if ( w->winId() == wid ) |
662 | return !w->isFullyObscured(); | 660 | return !w->isFullyObscured(); |
663 | } | 661 | } |
664 | #endif | 662 | #endif |
665 | return FALSE; | 663 | return FALSE; |
666 | } | 664 | } |
667 | 665 | ||
668 | void Launcher::showMaximized() | 666 | void Launcher::showMaximized() |
669 | { | 667 | { |
670 | if ( isVisibleWindow( winId() ) ) | 668 | if ( isVisibleWindow( winId() ) ) |
671 | doMaximize(); | 669 | doMaximize(); |
672 | else | 670 | else |
673 | QTimer::singleShot( 20, this, SLOT(doMaximize()) ); | 671 | QTimer::singleShot( 20, this, SLOT(doMaximize()) ); |
674 | } | 672 | } |
675 | 673 | ||
676 | void Launcher::doMaximize() | 674 | void Launcher::doMaximize() |
677 | { | 675 | { |
678 | QMainWindow::showMaximized(); | 676 | QMainWindow::showMaximized(); |
679 | } | 677 | } |
680 | 678 | ||
681 | void Launcher::updateMimeTypes() | 679 | void Launcher::updateMimeTypes() |
682 | { | 680 | { |
683 | MimeType::clear(); | 681 | MimeType::clear(); |
684 | updateMimeTypes(rootFolder); | 682 | updateMimeTypes(rootFolder); |
685 | } | 683 | } |
686 | 684 | ||
687 | void Launcher::updateMimeTypes(AppLnkSet* folder) | 685 | void Launcher::updateMimeTypes(AppLnkSet* folder) |
688 | { | 686 | { |
689 | for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { | 687 | for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { |
690 | AppLnk *app = it.current(); | 688 | AppLnk *app = it.current(); |
691 | if ( app->type() == "Folder" ) // No tr | 689 | if ( app->type() == "Folder" ) // No tr |
692 | updateMimeTypes((AppLnkSet *)app); | 690 | updateMimeTypes((AppLnkSet *)app); |
693 | else { | 691 | else { |
694 | MimeType::registerApp(*app); | 692 | MimeType::registerApp(*app); |
695 | } | 693 | } |
696 | } | 694 | } |
697 | } | 695 | } |
698 | 696 | ||
699 | /** This is a HACK.... | 697 | /** This is a HACK.... |
700 | * Reason: scanning huge mediums, microdirvers for examples | 698 | * Reason: scanning huge mediums, microdirvers for examples |
701 | * consomes time. To avoid that we invented the MediumMountCheck | 699 | * consomes time. To avoid that we invented the MediumMountCheck |
702 | * | 700 | * |
703 | * a) the user globally disabled medium checking. We can ignore | 701 | * a) the user globally disabled medium checking. We can ignore |
704 | * all removable medium | 702 | * all removable medium |
705 | * b) the user enabled medium checking globally and we need to use this mimefilter | 703 | * b) the user enabled medium checking globally and we need to use this mimefilter |
706 | * c) the user enabled medium checking on a per medium bases | 704 | * c) the user enabled medium checking on a per medium bases |
707 | * c1) we already checked and its not ask again turns | 705 | * c1) we already checked and its not ask again turns |
708 | * c2) we need to ask and then apply the mimefilter | 706 | * c2) we need to ask and then apply the mimefilter |
709 | */ | 707 | */ |
710 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: | 708 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: |
711 | { | 709 | { |
712 | delete docsFolder; | 710 | delete docsFolder; |
713 | docsFolder = new DocLnkSet; | 711 | docsFolder = new DocLnkSet; |
714 | 712 | ||
715 | DocLnkSet *tmp = 0; | 713 | DocLnkSet *tmp = 0; |
716 | QString home = QString(getenv("HOME")) + "/Documents"; | 714 | QString home = QString(getenv("HOME")) + "/Documents"; |
717 | tmp = new DocLnkSet( home , QString::null); | 715 | tmp = new DocLnkSet( home , QString::null); |
718 | docsFolder->appendFrom( *tmp ); | 716 | docsFolder->appendFrom( *tmp ); |
719 | delete tmp; | 717 | delete tmp; |
720 | 718 | ||
721 | // RAM documents | 719 | // RAM documents |
722 | StorageInfo storage; | 720 | StorageInfo storage; |
723 | const QList<FileSystem> &fileSystems = storage.fileSystems(); | 721 | const QList<FileSystem> &fileSystems = storage.fileSystems(); |
724 | QListIterator<FileSystem> it ( fileSystems ); | 722 | QListIterator<FileSystem> it ( fileSystems ); |
725 | 723 | ||
726 | for ( ; it.current(); ++it ) { | 724 | for ( ; it.current(); ++it ) { |
727 | if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { | 725 | if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { |
728 | tmp = new DocLnkSet( (*it)->path(), QString::null ); | 726 | tmp = new DocLnkSet( (*it)->path(), QString::null ); |
729 | docsFolder->appendFrom( *tmp ); | 727 | docsFolder->appendFrom( *tmp ); |
730 | delete tmp; | 728 | delete tmp; |
731 | } | 729 | } |
732 | } | 730 | } |
733 | 731 | ||
734 | Config mediumCfg( "medium"); | 732 | Config mediumCfg( "medium"); |
735 | mediumCfg.setGroup("main"); | 733 | mediumCfg.setGroup("main"); |
736 | // a) -zecke we don't want to check | 734 | // a) -zecke we don't want to check |
737 | if(!mediumCfg.readBoolEntry("use", true ) ) | 735 | if(!mediumCfg.readBoolEntry("use", true ) ) |
738 | return; | 736 | return; |
739 | 737 | ||
740 | // find out wich filesystems are new in this round | 738 | // find out wich filesystems are new in this round |
741 | // We will do this by having a timestamp inside each mountpoint | 739 | // We will do this by having a timestamp inside each mountpoint |
742 | // if the current timestamp doesn't match this is a new file system and | 740 | // if the current timestamp doesn't match this is a new file system and |
743 | // come up with our MediumMountGui :) let the hacking begin | 741 | // come up with our MediumMountGui :) let the hacking begin |
744 | int stamp = uidgen.generate(); | 742 | int stamp = uidgen.generate(); |
745 | 743 | ||
746 | QString newStamp = QString::number( stamp ); // generates newtime Stamp | 744 | QString newStamp = QString::number( stamp ); // generates newtime Stamp |
747 | 745 | ||
748 | // b) | 746 | // b) |
749 | if( mediumCfg.readBoolEntry("global", true ) ){ | 747 | if( mediumCfg.readBoolEntry("global", true ) ){ |
750 | QString mime = configToMime(&mediumCfg).join(";"); | 748 | QString mime = configToMime(&mediumCfg).join(";"); |
751 | for( it.toFirst(); it.current(); ++it ){ | 749 | for( it.toFirst(); it.current(); ++it ){ |
752 | if( (*it)->isRemovable() ){ | 750 | if( (*it)->isRemovable() ){ |
753 | tmp = new DocLnkSet( (*it)->path(), mime ); | 751 | tmp = new DocLnkSet( (*it)->path(), mime ); |
754 | docsFolder->appendFrom( *tmp ); | 752 | docsFolder->appendFrom( *tmp ); |
755 | delete tmp; | 753 | delete tmp; |
756 | } | 754 | } |
757 | } // done | 755 | } // done |
758 | return; // save the else | 756 | return; // save the else |
759 | } | 757 | } |
760 | // c) zecke | 758 | // c) zecke |
761 | for ( it.toFirst(); it.current(); ++it ) { | 759 | for ( it.toFirst(); it.current(); ++it ) { |
762 | if ( (*it)->isRemovable() ) { // let's find out if we should search on it | 760 | if ( (*it)->isRemovable() ) { // let's find out if we should search on it |
763 | Config cfg( (*it)->path() + "/.opiestorage.cf", Config::File); | 761 | Config cfg( (*it)->path() + "/.opiestorage.cf", Config::File); |
764 | cfg.setGroup("main"); | 762 | cfg.setGroup("main"); |
765 | QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); | 763 | QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); |
766 | /** This medium is uptodate | 764 | /** This medium is uptodate |
767 | */ | 765 | */ |
768 | if( stamp == m_timeStamp ){ // ok we know this card | 766 | if( stamp == m_timeStamp ){ // ok we know this card |
769 | cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp | 767 | cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp |
770 | // we need to scan the list now. Hopefully the cache will be there | 768 | // we need to scan the list now. Hopefully the cache will be there |
771 | // read the mimetypes from the config and search for documents | 769 | // read the mimetypes from the config and search for documents |
772 | QStringList mimetypes = configToMime( &cfg); | 770 | QStringList mimetypes = configToMime( &cfg); |
773 | tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); | 771 | tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); |
774 | docsFolder->appendFrom( *tmp ); | 772 | docsFolder->appendFrom( *tmp ); |
775 | delete tmp; | 773 | delete tmp; |
776 | 774 | ||
777 | }else{ // come up with the gui cause this a new card | 775 | }else{ // come up with the gui cause this a new card |
778 | MediumMountGui medium(&cfg, (*it)->path() ); | 776 | MediumMountGui medium(&cfg, (*it)->path() ); |
779 | if( medium.check() ){ // we did not ask before or ask again is off | 777 | if( medium.check() ){ // we did not ask before or ask again is off |
780 | /** c2) */ | 778 | /** c2) */ |
781 | if( medium.exec() ){ // he clicked yes so search it | 779 | if( medium.exec() ){ // he clicked yes so search it |
782 | // speicher | 780 | // speicher |
783 | //cfg.read(); // cause of a race we need to reread - fixed | 781 | //cfg.read(); // cause of a race we need to reread - fixed |
784 | cfg.setGroup("main"); | 782 | cfg.setGroup("main"); |
785 | cfg.writeEntry("timestamp", newStamp ); | 783 | cfg.writeEntry("timestamp", newStamp ); |
786 | cfg.write(); | 784 | cfg.write(); |
787 | tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); | 785 | tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); |
788 | docsFolder->appendFrom( *tmp ); | 786 | docsFolder->appendFrom( *tmp ); |
789 | delete tmp; | 787 | delete tmp; |
790 | }// no else | 788 | }// no else |
791 | /** c1) */ | 789 | /** c1) */ |
792 | }else{ // we checked | 790 | }else{ // we checked |
793 | // do something different see what we need to do | 791 | // do something different see what we need to do |
794 | // let's see if we should check the device | 792 | // let's see if we should check the device |
795 | cfg.setGroup("main" ); | 793 | cfg.setGroup("main" ); |
796 | bool check = cfg.readBoolEntry("autocheck", true ); | 794 | bool check = cfg.readBoolEntry("autocheck", true ); |
797 | if( check ){ // find the documents | 795 | if( check ){ // find the documents |
798 | tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); | 796 | tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); |
799 | docsFolder->appendFrom( *tmp ); | 797 | docsFolder->appendFrom( *tmp ); |
800 | delete tmp; | 798 | delete tmp; |
801 | } | 799 | } |
802 | } | 800 | } |
803 | } | 801 | } |
804 | } | 802 | } |
805 | } | 803 | } |
806 | m_timeStamp = newStamp; | 804 | m_timeStamp = newStamp; |
807 | } | 805 | } |
808 | 806 | ||
809 | void Launcher::updateTabs() | 807 | void Launcher::updateTabs() |
810 | { | 808 | { |
811 | MimeType::updateApplications(); // ### reads all applnks twice | 809 | MimeType::updateApplications(); // ### reads all applnks twice |
812 | 810 | ||
813 | delete rootFolder; | 811 | delete rootFolder; |
814 | rootFolder = new AppLnkSet( MimeType::appsFolderName() ); | 812 | rootFolder = new AppLnkSet( MimeType::appsFolderName() ); |
815 | 813 | ||
816 | loadDocs(); | 814 | loadDocs(); |
817 | 815 | ||
818 | tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); | 816 | tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); |
819 | } | 817 | } |
820 | 818 | ||
821 | void Launcher::updateDocs() | 819 | void Launcher::updateDocs() |
822 | { | 820 | { |
823 | loadDocs(); | 821 | loadDocs(); |
824 | tabs->updateDocs(docsFolder,storage->fileSystems()); | 822 | tabs->updateDocs(docsFolder,storage->fileSystems()); |
825 | } | 823 | } |
826 | 824 | ||
827 | void Launcher::viewSelected(const QString& s) | 825 | void Launcher::viewSelected(const QString& s) |
828 | { | 826 | { |
829 | setCaption( s + tr(" - Launcher") ); | 827 | setCaption( s + tr(" - Launcher") ); |
830 | } | 828 | } |
831 | 829 | ||
832 | void Launcher::nextView() | 830 | void Launcher::nextView() |
833 | { | 831 | { |
834 | tabs->nextTab(); | 832 | tabs->nextTab(); |
835 | } | 833 | } |
836 | 834 | ||
837 | 835 | ||
838 | void Launcher::select( const AppLnk *appLnk ) | 836 | void Launcher::select( const AppLnk *appLnk ) |
839 | { | 837 | { |
840 | if ( appLnk->type() == "Folder" ) { // No tr | 838 | if ( appLnk->type() == "Folder" ) { // No tr |
841 | // Not supported: flat is simpler for the user | 839 | // Not supported: flat is simpler for the user |
842 | } else { | 840 | } else { |
843 | if ( appLnk->exec().isNull() ) { | 841 | if ( appLnk->exec().isNull() ) { |
844 | QMessageBox::information(this,tr("No application"), | 842 | QMessageBox::information(this,tr("No application"), |
845 | tr("<p>No application is defined for this document." | 843 | tr("<p>No application is defined for this document." |
846 | "<p>Type is %1.").arg(appLnk->type())); | 844 | "<p>Type is %1.").arg(appLnk->type())); |
847 | return; | 845 | return; |
848 | } | 846 | } |
849 | tabs->setBusy(TRUE); | 847 | tabs->setBusy(TRUE); |
850 | emit executing( appLnk ); | 848 | emit executing( appLnk ); |
851 | appLnk->execute(); | 849 | appLnk->execute(); |
852 | } | 850 | } |
853 | } | 851 | } |
854 | 852 | ||
855 | void Launcher::externalSelected(const AppLnk *appLnk) | 853 | void Launcher::externalSelected(const AppLnk *appLnk) |
856 | { | 854 | { |
857 | tabs->setBusy(TRUE); | 855 | tabs->setBusy(TRUE); |
858 | emit executing( appLnk ); | 856 | emit executing( appLnk ); |
859 | } | 857 | } |
860 | 858 | ||
861 | void Launcher::properties( AppLnk *appLnk ) | 859 | void Launcher::properties( AppLnk *appLnk ) |
862 | { | 860 | { |
863 | if ( appLnk->type() == "Folder" ) { // No tr | 861 | if ( appLnk->type() == "Folder" ) { // No tr |
864 | // Not supported: flat is simpler for the user | 862 | // Not supported: flat is simpler for the user |
865 | } else { | 863 | } else { |
866 | in_lnk_props = TRUE; | 864 | in_lnk_props = TRUE; |
867 | got_lnk_change = FALSE; | 865 | got_lnk_change = FALSE; |
868 | LnkProperties prop(appLnk); | 866 | LnkProperties prop(appLnk); |
869 | connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); | 867 | connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); |
870 | prop.showMaximized(); | 868 | prop.showMaximized(); |
871 | prop.exec(); | 869 | prop.exec(); |
872 | in_lnk_props = FALSE; | 870 | in_lnk_props = FALSE; |
873 | if ( got_lnk_change ) { | 871 | if ( got_lnk_change ) { |
874 | updateLink(lnk_change); | 872 | updateLink(lnk_change); |
875 | } | 873 | } |
876 | } | 874 | } |
877 | } | 875 | } |
878 | 876 | ||
879 | void Launcher::updateLink(const QString& link) | 877 | void Launcher::updateLink(const QString& link) |
880 | { | 878 | { |
881 | if (link.isNull()) | 879 | if (link.isNull()) |
882 | updateTabs(); | 880 | updateTabs(); |
883 | else if (link.isEmpty()) | 881 | else if (link.isEmpty()) |
884 | updateDocs(); | 882 | updateDocs(); |
885 | else | 883 | else |
886 | tabs->updateLink(link); | 884 | tabs->updateLink(link); |
887 | } | 885 | } |
888 | 886 | ||
889 | void Launcher::systemMessage( const QCString &msg, const QByteArray &data) | 887 | void Launcher::systemMessage( const QCString &msg, const QByteArray &data) |
890 | { | 888 | { |
891 | QDataStream stream( data, IO_ReadOnly ); | 889 | QDataStream stream( data, IO_ReadOnly ); |
892 | if ( msg == "linkChanged(QString)" ) { | 890 | if ( msg == "linkChanged(QString)" ) { |
893 | QString link; | 891 | QString link; |
894 | stream >> link; | 892 | stream >> link; |
895 | if ( in_lnk_props ) { | 893 | if ( in_lnk_props ) { |
896 | got_lnk_change = TRUE; | 894 | got_lnk_change = TRUE; |
897 | lnk_change = link; | 895 | lnk_change = link; |
898 | } else { | 896 | } else { |
899 | updateLink(link); | 897 | updateLink(link); |
900 | } | 898 | } |
901 | } else if ( msg == "busy()" ) { | 899 | } else if ( msg == "busy()" ) { |
902 | emit busy(); | 900 | emit busy(); |
903 | } else if ( msg == "notBusy(QString)" ) { | 901 | } else if ( msg == "notBusy(QString)" ) { |
904 | QString app; | 902 | QString app; |
905 | stream >> app; | 903 | stream >> app; |
906 | tabs->setBusy(FALSE); | 904 | tabs->setBusy(FALSE); |
907 | emit notBusy(app); | 905 | emit notBusy(app); |
908 | } else if ( msg == "mkdir(QString)" ) { | 906 | } else if ( msg == "mkdir(QString)" ) { |
909 | QString dir; | 907 | QString dir; |
910 | stream >> dir; | 908 | stream >> dir; |
911 | if ( !dir.isEmpty() ) | 909 | if ( !dir.isEmpty() ) |
912 | mkdir( dir ); | 910 | mkdir( dir ); |
913 | } else if ( msg == "rdiffGenSig(QString,QString)" ) { | 911 | } else if ( msg == "rdiffGenSig(QString,QString)" ) { |
914 | QString baseFile, sigFile; | 912 | QString baseFile, sigFile; |
915 | stream >> baseFile >> sigFile; | 913 | stream >> baseFile >> sigFile; |
916 | QRsync::generateSignature( baseFile, sigFile ); | 914 | QRsync::generateSignature( baseFile, sigFile ); |
917 | } else if ( msg == "rdiffGenDiff(QString,QString,QString)" ) { | 915 | } else if ( msg == "rdiffGenDiff(QString,QString,QString)" ) { |
918 | QString baseFile, sigFile, deltaFile; | 916 | QString baseFile, sigFile, deltaFile; |
919 | stream >> baseFile >> sigFile >> deltaFile; | 917 | stream >> baseFile >> sigFile >> deltaFile; |
920 | QRsync::generateDiff( baseFile, sigFile, deltaFile ); | 918 | QRsync::generateDiff( baseFile, sigFile, deltaFile ); |
921 | } else if ( msg == "rdiffApplyPatch(QString,QString)" ) { | 919 | } else if ( msg == "rdiffApplyPatch(QString,QString)" ) { |
922 | QString baseFile, deltaFile; | 920 | QString baseFile, deltaFile; |
923 | stream >> baseFile >> deltaFile; | 921 | stream >> baseFile >> deltaFile; |
924 | if ( !QFile::exists( baseFile ) ) { | 922 | if ( !QFile::exists( baseFile ) ) { |
925 | QFile f( baseFile ); | 923 | QFile f( baseFile ); |
926 | f.open( IO_WriteOnly ); | 924 | f.open( IO_WriteOnly ); |
927 | f.close(); | 925 | f.close(); |
928 | } | 926 | } |
929 | QRsync::applyDiff( baseFile, deltaFile ); | 927 | QRsync::applyDiff( baseFile, deltaFile ); |
930 | #ifndef QT_NO_COP | 928 | #ifndef QT_NO_COP |
931 | QCopEnvelope e( "QPE/Desktop", "patchApplied(QString)" ); | 929 | QCopEnvelope e( "QPE/Desktop", "patchApplied(QString)" ); |
932 | e << baseFile; | 930 | e << baseFile; |
933 | #endif | 931 | #endif |
934 | } else if ( msg == "rdiffCleanup()" ) { | 932 | } else if ( msg == "rdiffCleanup()" ) { |
935 | mkdir( "/tmp/rdiff" ); | 933 | mkdir( "/tmp/rdiff" ); |
936 | QDir dir; | 934 | QDir dir; |
937 | dir.setPath( "/tmp/rdiff" ); | 935 | dir.setPath( "/tmp/rdiff" ); |
938 | QStringList entries = dir.entryList(); | 936 | QStringList entries = dir.entryList(); |
939 | for ( QStringList::Iterator it = entries.begin(); it != entries.end(); ++it ) | 937 | for ( QStringList::Iterator it = entries.begin(); it != entries.end(); ++it ) |
940 | dir.remove( *it ); | 938 | dir.remove( *it ); |
941 | } else if ( msg == "sendHandshakeInfo()" ) { | 939 | } else if ( msg == "sendHandshakeInfo()" ) { |
942 | QString home = getenv( "HOME" ); | 940 | QString home = getenv( "HOME" ); |
943 | #ifndef QT_NO_COP | 941 | #ifndef QT_NO_COP |
944 | QCopEnvelope e( "QPE/Desktop", "handshakeInfo(QString,bool)" ); | 942 | QCopEnvelope e( "QPE/Desktop", "handshakeInfo(QString,bool)" ); |
945 | e << home; | 943 | e << home; |
946 | int locked = (int) Desktop::screenLocked(); | 944 | int locked = (int) Desktop::screenLocked(); |
947 | e << locked; | 945 | e << locked; |
948 | #endif | 946 | #endif |
949 | } else if ( msg == "autoStart(QString)" ) { | 947 | } else if ( msg == "autoStart(QString)" ) { |
950 | QString appName; | 948 | QString appName; |
951 | stream >> appName; | 949 | stream >> appName; |
952 | Config cfg( "autostart" ); | 950 | Config cfg( "autostart" ); |
953 | cfg.setGroup( "AutoStart" ); | 951 | cfg.setGroup( "AutoStart" ); |
954 | if ( appName.compare("clear") == 0){ | 952 | if ( appName.compare("clear") == 0){ |
955 | cfg.writeEntry("Apps", ""); | 953 | cfg.writeEntry("Apps", ""); |
956 | } | 954 | } |
957 | } else if ( msg == "autoStart(QString,QString)" ) { | 955 | } else if ( msg == "autoStart(QString,QString)" ) { |
958 | QString modifier, appName; | 956 | QString modifier, appName; |
959 | stream >> modifier >> appName; | 957 | stream >> modifier >> appName; |
960 | Config cfg( "autostart" ); | 958 | Config cfg( "autostart" ); |
961 | cfg.setGroup( "AutoStart" ); | 959 | cfg.setGroup( "AutoStart" ); |
962 | if ( modifier.compare("add") == 0 ){ | 960 | if ( modifier.compare("add") == 0 ){ |
963 | // only add if appname is entered | 961 | // only add if appname is entered |
964 | if (!appName.isEmpty()) { | 962 | if (!appName.isEmpty()) { |
965 | cfg.writeEntry("Apps", appName); | 963 | cfg.writeEntry("Apps", appName); |
966 | } | 964 | } |
967 | } else if (modifier.compare("remove") == 0 ) { | 965 | } else if (modifier.compare("remove") == 0 ) { |
968 | // need to change for multiple entries | 966 | // need to change for multiple entries |
969 | // actually remove is right now simular to clear, but in future there | 967 | // actually remove is right now simular to clear, but in future there |
970 | // should be multiple apps in autostart possible. | 968 | // should be multiple apps in autostart possible. |
971 | QString checkName; | 969 | QString checkName; |
972 | checkName = cfg.readEntry("Apps", ""); | 970 | checkName = cfg.readEntry("Apps", ""); |
973 | if (checkName == appName) { | 971 | if (checkName == appName) { |
974 | cfg.writeEntry("Apps", ""); | 972 | cfg.writeEntry("Apps", ""); |
975 | } | 973 | } |
976 | } | 974 | } |
977 | // case the autostart feature should be delayed | 975 | // case the autostart feature should be delayed |
978 | } else if ( msg == "autoStart(QString,QString,QString)") { | 976 | } else if ( msg == "autoStart(QString,QString,QString)") { |
979 | QString modifier, appName, delay; | 977 | QString modifier, appName, delay; |
980 | stream >> modifier >> appName >> delay; | 978 | stream >> modifier >> appName >> delay; |
981 | Config cfg( "autostart" ); | 979 | Config cfg( "autostart" ); |
982 | cfg.setGroup( "AutoStart" ); | 980 | cfg.setGroup( "AutoStart" ); |
983 | if ( modifier.compare("add") == 0 ){ | 981 | if ( modifier.compare("add") == 0 ){ |
984 | // only add it appname is entered | 982 | // only add it appname is entered |
985 | if (!appName.isEmpty()) { | 983 | if (!appName.isEmpty()) { |
986 | cfg.writeEntry("Apps", appName); | 984 | cfg.writeEntry("Apps", appName); |
987 | cfg.writeEntry("Delay", delay); | 985 | cfg.writeEntry("Delay", delay); |
988 | } | 986 | } |
989 | } else { | 987 | } else { |
990 | } | 988 | } |
991 | } | 989 | } |
992 | /* | 990 | /* |
993 | * QtopiaDesktop relies on the major number | 991 | * QtopiaDesktop relies on the major number |
994 | * to start with 1. We're at 0.9 | 992 | * to start with 1. We're at 0.9 |
995 | * so wee need to fake at least 1.4 to be able | 993 | * so wee need to fake at least 1.4 to be able |
996 | * to sync with QtopiaDesktop1.6 | 994 | * to sync with QtopiaDesktop1.6 |
997 | */ | 995 | */ |
998 | else if ( msg == "sendVersionInfo()" ) { | 996 | else if ( msg == "sendVersionInfo()" ) { |
999 | QCopEnvelope e( "QPE/Desktop", "versionInfo(QString)" ); | 997 | QCopEnvelope e( "QPE/Desktop", "versionInfo(QString)" ); |
1000 | QString v2 = QString::fromLatin1("1.4"); | 998 | QString v2 = QString::fromLatin1("1.4"); |
1001 | e << v2; | 999 | e << v2; |
1002 | //qDebug("version %s\n", line.latin1()); | 1000 | //qDebug("version %s\n", line.latin1()); |
1003 | } else if ( msg == "sendCardInfo()" ) { | 1001 | } else if ( msg == "sendCardInfo()" ) { |
1004 | #ifndef QT_NO_COP | 1002 | #ifndef QT_NO_COP |
1005 | QCopEnvelope e( "QPE/Desktop", "cardInfo(QString)" ); | 1003 | QCopEnvelope e( "QPE/Desktop", "cardInfo(QString)" ); |
1006 | #endif | 1004 | #endif |
1007 | const QList<FileSystem> &fs = storage->fileSystems(); | 1005 | const QList<FileSystem> &fs = storage->fileSystems(); |
1008 | QListIterator<FileSystem> it ( fs ); | 1006 | QListIterator<FileSystem> it ( fs ); |
1009 | QString s; | 1007 | QString s; |
1010 | QString homeDir = getenv("HOME"); | 1008 | QString homeDir = getenv("HOME"); |
1011 | QString hardDiskHome, hardDiskHomePath; | 1009 | QString hardDiskHome, hardDiskHomePath; |
1012 | for ( ; it.current(); ++it ) { | 1010 | for ( ; it.current(); ++it ) { |
1013 | int k4 = (*it)->blockSize()/256; | 1011 | int k4 = (*it)->blockSize()/256; |
1014 | if ( (*it)->isRemovable() || (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs") { | 1012 | if ( (*it)->isRemovable() || (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs") { |
1015 | s += (*it)->name() + "=" + (*it)->path() + "/Documents " | 1013 | s += (*it)->name() + "=" + (*it)->path() + "/Documents " |
1016 | + QString::number( (*it)->availBlocks() * k4/4 ) | 1014 | + QString::number( (*it)->availBlocks() * k4/4 ) |
1017 | + "K " + (*it)->options() + ";"; | 1015 | + "K " + (*it)->options() + ";"; |
1018 | } else if ( (*it)->disk() == "/dev/mtdblock1" || | 1016 | } else if ( (*it)->disk() == "/dev/mtdblock1" || |
1019 | (*it)->disk() == "/dev/mtdblock/1" ) { | 1017 | (*it)->disk() == "/dev/mtdblock/1" ) { |
1020 | s += (*it)->name() + "=" + homeDir + "/Documents " | 1018 | s += (*it)->name() + "=" + homeDir + "/Documents " |
1021 | + QString::number( (*it)->availBlocks() * k4/4 ) | 1019 | + QString::number( (*it)->availBlocks() * k4/4 ) |
1022 | + "K " + (*it)->options() + ";"; | 1020 | + "K " + (*it)->options() + ";"; |
1023 | } else if ( (*it)->name().contains( "Hard Disk") && | 1021 | } else if ( (*it)->name().contains( "Hard Disk") && |
1024 | homeDir.contains( (*it)->path() ) && | 1022 | homeDir.contains( (*it)->path() ) && |
1025 | (*it)->path().length() > hardDiskHomePath.length() ) { | 1023 | (*it)->path().length() > hardDiskHomePath.length() ) { |
1026 | hardDiskHomePath = (*it)->path(); | 1024 | hardDiskHomePath = (*it)->path(); |
1027 | hardDiskHome = | 1025 | hardDiskHome = |
1028 | (*it)->name() + "=" + homeDir + "/Documents " | 1026 | (*it)->name() + "=" + homeDir + "/Documents " |
1029 | + QString::number( (*it)->availBlocks() * k4/4 ) | 1027 | + QString::number( (*it)->availBlocks() * k4/4 ) |
1030 | + "K " + (*it)->options() + ";"; | 1028 | + "K " + (*it)->options() + ";"; |
1031 | } | 1029 | } |
1032 | } | 1030 | } |
1033 | if ( !hardDiskHome.isEmpty() ) | 1031 | if ( !hardDiskHome.isEmpty() ) |
1034 | s += hardDiskHome; | 1032 | s += hardDiskHome; |
1035 | 1033 | ||
1036 | #ifndef QT_NO_COP | 1034 | #ifndef QT_NO_COP |
1037 | e << s; | 1035 | e << s; |
1038 | #endif | 1036 | #endif |
1039 | } else if ( msg == "sendSyncDate(QString)" ) { | 1037 | } else if ( msg == "sendSyncDate(QString)" ) { |
1040 | QString app; | 1038 | QString app; |
1041 | stream >> app; | 1039 | stream >> app; |
1042 | Config cfg( "qpe" ); | 1040 | Config cfg( "qpe" ); |
1043 | cfg.setGroup("SyncDate"); | 1041 | cfg.setGroup("SyncDate"); |
1044 | #ifndef QT_NO_COP | 1042 | #ifndef QT_NO_COP |
1045 | QCopEnvelope e( "QPE/Desktop", "syncDate(QString,QString)" ); | 1043 | QCopEnvelope e( "QPE/Desktop", "syncDate(QString,QString)" ); |
1046 | e << app << cfg.readEntry( app ); | 1044 | e << app << cfg.readEntry( app ); |
1047 | #endif | 1045 | #endif |
1048 | //qDebug("QPE/System sendSyncDate for %s: response %s", app.latin1(), | 1046 | //qDebug("QPE/System sendSyncDate for %s: response %s", app.latin1(), |
1049 | //cfg.readEntry( app ).latin1() ); | 1047 | //cfg.readEntry( app ).latin1() ); |
1050 | } else if ( msg == "setSyncDate(QString,QString)" ) { | 1048 | } else if ( msg == "setSyncDate(QString,QString)" ) { |
1051 | QString app, date; | 1049 | QString app, date; |
diff --git a/core/launcher/main.cpp b/core/launcher/main.cpp index 073e19a..762a596 100644 --- a/core/launcher/main.cpp +++ b/core/launcher/main.cpp | |||
@@ -1,172 +1,173 @@ | |||
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_CUSTOM ) || defined( QT_QWS_IPAQ ) | 28 | #if defined( QT_QWS_CUSTOM ) || 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 | 33 | ||
34 | #include <qfile.h> | 34 | #include <qfile.h> |
35 | #include <qimage.h> | ||
35 | #include <qwindowsystem_qws.h> | 36 | #include <qwindowsystem_qws.h> |
36 | #include <qpe/qcopenvelope_qws.h> | 37 | #include <qpe/qcopenvelope_qws.h> |
37 | #include <qpe/alarmserver.h> | 38 | #include <qpe/alarmserver.h> |
38 | 39 | ||
39 | #include <stdlib.h> | 40 | #include <stdlib.h> |
40 | #include <stdio.h> | 41 | #include <stdio.h> |
41 | #include <signal.h> | 42 | #include <signal.h> |
42 | #include <unistd.h> | 43 | #include <unistd.h> |
43 | 44 | ||
44 | #if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) | 45 | #if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) |
45 | #include "../calibrate/calibrate.h" | 46 | #include "../calibrate/calibrate.h" |
46 | #endif | 47 | #endif |
47 | 48 | ||
48 | using namespace Opie; | 49 | using namespace Opie; |
49 | 50 | ||
50 | void initEnvironment() | 51 | void initEnvironment() |
51 | { | 52 | { |
52 | Config config("locale"); | 53 | Config config("locale"); |
53 | config.setGroup( "Location" ); | 54 | config.setGroup( "Location" ); |
54 | QString tz = config.readEntry( "Timezone", getenv("TZ") ); | 55 | QString tz = config.readEntry( "Timezone", getenv("TZ") ); |
55 | 56 | ||
56 | // if not timezone set, pick New York | 57 | // if not timezone set, pick New York |
57 | if (tz.isNull()) | 58 | if (tz.isNull()) |
58 | tz = "America/New_York"; | 59 | tz = "America/New_York"; |
59 | 60 | ||
60 | setenv( "TZ", tz, 1 ); | 61 | setenv( "TZ", tz, 1 ); |
61 | config.writeEntry( "Timezone", tz); | 62 | config.writeEntry( "Timezone", tz); |
62 | 63 | ||
63 | config.setGroup( "Language" ); | 64 | config.setGroup( "Language" ); |
64 | QString lang = config.readEntry( "Language", getenv("LANG") ); | 65 | QString lang = config.readEntry( "Language", getenv("LANG") ); |
65 | if ( !lang.isNull() ) | 66 | if ( !lang.isNull() ) |
66 | setenv( "LANG", lang, 1 ); | 67 | setenv( "LANG", lang, 1 ); |
67 | } | 68 | } |
68 | 69 | ||
69 | 70 | ||
70 | int initApplication( int argc, char ** argv ) | 71 | int initApplication( int argc, char ** argv ) |
71 | { | 72 | { |
72 | initEnvironment(); | 73 | initEnvironment(); |
73 | 74 | ||
74 | #if !defined(QT_QWS_CASSIOPEIA) && !defined(QT_QWS_IPAQ) && !defined(QT_QWS_EBX) | 75 | #if !defined(QT_QWS_CASSIOPEIA) && !defined(QT_QWS_IPAQ) && !defined(QT_QWS_EBX) |
75 | setenv( "QWS_SIZE", "240x320", 0 ); | 76 | setenv( "QWS_SIZE", "240x320", 0 ); |
76 | #endif | 77 | #endif |
77 | 78 | ||
78 | //Don't flicker at startup: | 79 | //Don't flicker at startup: |
79 | QWSServer::setDesktopBackground( QImage() ); | 80 | QWSServer::setDesktopBackground( QImage() ); |
80 | DesktopApplication a( argc, argv, QApplication::GuiServer ); | 81 | DesktopApplication a( argc, argv, QApplication::GuiServer ); |
81 | 82 | ||
82 | ODevice::inst ( )-> setSoftSuspend ( true ); | 83 | ODevice::inst ( )-> setSoftSuspend ( true ); |
83 | 84 | ||
84 | { // init backlight | 85 | { // init backlight |
85 | QCopEnvelope e("QPE/System", "setBacklight(int)" ); | 86 | QCopEnvelope e("QPE/System", "setBacklight(int)" ); |
86 | e << -3; // Forced on | 87 | e << -3; // Forced on |
87 | } | 88 | } |
88 | 89 | ||
89 | AlarmServer::initialize(); | 90 | AlarmServer::initialize(); |
90 | 91 | ||
91 | Desktop *d = new Desktop(); | 92 | Desktop *d = new Desktop(); |
92 | 93 | ||
93 | QObject::connect( &a, SIGNAL(datebook()), d, SLOT(raiseDatebook()) ); | 94 | QObject::connect( &a, SIGNAL(datebook()), d, SLOT(raiseDatebook()) ); |
94 | QObject::connect( &a, SIGNAL(contacts()), d, SLOT(raiseContacts()) ); | 95 | QObject::connect( &a, SIGNAL(contacts()), d, SLOT(raiseContacts()) ); |
95 | QObject::connect( &a, SIGNAL(launch()), d, SLOT(raiseLauncher()) ); | 96 | QObject::connect( &a, SIGNAL(launch()), d, SLOT(raiseLauncher()) ); |
96 | QObject::connect( &a, SIGNAL(email()), d, SLOT(raiseEmail()) ); | 97 | QObject::connect( &a, SIGNAL(email()), d, SLOT(raiseEmail()) ); |
97 | QObject::connect( &a, SIGNAL(power()), d, SLOT(togglePower()) ); | 98 | QObject::connect( &a, SIGNAL(power()), d, SLOT(togglePower()) ); |
98 | QObject::connect( &a, SIGNAL(backlight()), d, SLOT(toggleLight()) ); | 99 | QObject::connect( &a, SIGNAL(backlight()), d, SLOT(toggleLight()) ); |
99 | QObject::connect( &a, SIGNAL(symbol()), d, SLOT(toggleSymbolInput()) ); | 100 | QObject::connect( &a, SIGNAL(symbol()), d, SLOT(toggleSymbolInput()) ); |
100 | QObject::connect( &a, SIGNAL(numLockStateToggle()), d, SLOT(toggleNumLockState()) ); | 101 | QObject::connect( &a, SIGNAL(numLockStateToggle()), d, SLOT(toggleNumLockState()) ); |
101 | QObject::connect( &a, SIGNAL(capsLockStateToggle()), d, SLOT(toggleCapsLockState()) ); | 102 | QObject::connect( &a, SIGNAL(capsLockStateToggle()), d, SLOT(toggleCapsLockState()) ); |
102 | QObject::connect( &a, SIGNAL(prepareForRestart()), d, SLOT(terminateServers()) ); | 103 | QObject::connect( &a, SIGNAL(prepareForRestart()), d, SLOT(terminateServers()) ); |
103 | 104 | ||
104 | (void)new SysFileMonitor(d); | 105 | (void)new SysFileMonitor(d); |
105 | Network::createServer(d); | 106 | Network::createServer(d); |
106 | 107 | ||
107 | #if defined(QT_QWS_CASSIOPEIA) || defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) | 108 | #if defined(QT_QWS_CASSIOPEIA) || defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) |
108 | if ( !QFile::exists( "/etc/pointercal" ) ) { | 109 | if ( !QFile::exists( "/etc/pointercal" ) ) { |
109 | // Make sure calibration widget starts on top. | 110 | // Make sure calibration widget starts on top. |
110 | Calibrate *cal = new Calibrate; | 111 | Calibrate *cal = new Calibrate; |
111 | cal->exec(); | 112 | cal->exec(); |
112 | delete cal; | 113 | delete cal; |
113 | } | 114 | } |
114 | #endif | 115 | #endif |
115 | 116 | ||
116 | d->show(); | 117 | d->show(); |
117 | 118 | ||
118 | int rv = a.exec(); | 119 | int rv = a.exec(); |
119 | 120 | ||
120 | delete d; | 121 | delete d; |
121 | 122 | ||
122 | ODevice::inst ( )-> setSoftSuspend ( false ); | 123 | ODevice::inst ( )-> setSoftSuspend ( false ); |
123 | 124 | ||
124 | return rv; | 125 | return rv; |
125 | } | 126 | } |
126 | 127 | ||
127 | static const char *pidfile_path = "/var/run/opie.pid"; | 128 | static const char *pidfile_path = "/var/run/opie.pid"; |
128 | 129 | ||
129 | void create_pidfile ( ) | 130 | void create_pidfile ( ) |
130 | { | 131 | { |
131 | FILE *f; | 132 | FILE *f; |
132 | 133 | ||
133 | if (( f = ::fopen ( pidfile_path, "w" ))) { | 134 | if (( f = ::fopen ( pidfile_path, "w" ))) { |
134 | ::fprintf ( f, "%d", getpid ( )); | 135 | ::fprintf ( f, "%d", getpid ( )); |
135 | ::fclose ( f ); | 136 | ::fclose ( f ); |
136 | } | 137 | } |
137 | } | 138 | } |
138 | 139 | ||
139 | void remove_pidfile ( ) | 140 | void remove_pidfile ( ) |
140 | { | 141 | { |
141 | ::unlink ( pidfile_path ); | 142 | ::unlink ( pidfile_path ); |
142 | } | 143 | } |
143 | 144 | ||
144 | void handle_sigterm ( int /* sig */ ) | 145 | void handle_sigterm ( int /* sig */ ) |
145 | { | 146 | { |
146 | if ( qApp ) | 147 | if ( qApp ) |
147 | qApp-> quit ( ); | 148 | qApp-> quit ( ); |
148 | } | 149 | } |
149 | 150 | ||
150 | int main( int argc, char ** argv ) | 151 | int main( int argc, char ** argv ) |
151 | { | 152 | { |
152 | ::signal ( SIGCHLD, SIG_IGN ); | 153 | ::signal ( SIGCHLD, SIG_IGN ); |
153 | 154 | ||
154 | ::signal ( SIGTERM, handle_sigterm ); | 155 | ::signal ( SIGTERM, handle_sigterm ); |
155 | ::signal ( SIGINT, handle_sigterm ); | 156 | ::signal ( SIGINT, handle_sigterm ); |
156 | 157 | ||
157 | ::setsid ( ); | 158 | ::setsid ( ); |
158 | ::setpgid ( 0, 0 ); | 159 | ::setpgid ( 0, 0 ); |
159 | 160 | ||
160 | ::atexit ( remove_pidfile ); | 161 | ::atexit ( remove_pidfile ); |
161 | create_pidfile ( ); | 162 | create_pidfile ( ); |
162 | 163 | ||
163 | int retVal = initApplication ( argc, argv ); | 164 | int retVal = initApplication ( argc, argv ); |
164 | 165 | ||
165 | // Kill them. Kill them all. | 166 | // Kill them. Kill them all. |
166 | ::kill ( 0, SIGTERM ); | 167 | ::kill ( 0, SIGTERM ); |
167 | ::sleep ( 1 ); | 168 | ::sleep ( 1 ); |
168 | ::kill ( 0, SIGKILL ); | 169 | ::kill ( 0, SIGKILL ); |
169 | 170 | ||
170 | return retVal; | 171 | return retVal; |
171 | } | 172 | } |
172 | 173 | ||
diff --git a/core/launcher/qcopbridge.cpp b/core/launcher/qcopbridge.cpp index 85993ee..6177a7c 100644 --- a/core/launcher/qcopbridge.cpp +++ b/core/launcher/qcopbridge.cpp | |||
@@ -1,424 +1,422 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 "qcopbridge.h" | 21 | #include "qcopbridge.h" |
22 | #include "transferserver.h" | 22 | #include "transferserver.h" |
23 | 23 | ||
24 | #ifdef QWS | ||
25 | #include <qpe/qcopenvelope_qws.h> | 24 | #include <qpe/qcopenvelope_qws.h> |
26 | #endif | ||
27 | #include <qpe/qpeapplication.h> | 25 | #include <qpe/qpeapplication.h> |
28 | #include <qpe/version.h> | 26 | #include <qpe/version.h> |
29 | 27 | ||
30 | #include <qdir.h> | 28 | #include <qdir.h> |
31 | #include <qfile.h> | 29 | #include <qfile.h> |
32 | #include <qtextstream.h> | 30 | #include <qtextstream.h> |
33 | #include <qdatastream.h> | 31 | #include <qdatastream.h> |
34 | #include <qstringlist.h> | 32 | #include <qstringlist.h> |
35 | #include <qfileinfo.h> | 33 | #include <qfileinfo.h> |
36 | #include <qregexp.h> | 34 | #include <qregexp.h> |
37 | #ifdef QWS | 35 | #ifdef QWS |
38 | #include <qcopchannel_qws.h> | 36 | #include <qcopchannel_qws.h> |
39 | #endif | 37 | #endif |
40 | 38 | ||
41 | #define _XOPEN_SOURCE | 39 | #define _XOPEN_SOURCE |
42 | #include <pwd.h> | 40 | #include <pwd.h> |
43 | #include <sys/types.h> | 41 | #include <sys/types.h> |
44 | #include <unistd.h> | 42 | #include <unistd.h> |
45 | 43 | ||
46 | #if defined(_OS_LINUX_) | 44 | #if defined(_OS_LINUX_) |
47 | #include <shadow.h> | 45 | #include <shadow.h> |
48 | #endif | 46 | #endif |
49 | 47 | ||
50 | //#define INSECURE | 48 | //#define INSECURE |
51 | 49 | ||
52 | const int block_size = 51200; | 50 | const int block_size = 51200; |
53 | 51 | ||
54 | QCopBridge::QCopBridge( Q_UINT16 port, QObject *parent , | 52 | QCopBridge::QCopBridge( Q_UINT16 port, QObject *parent , |
55 | const char* name ) | 53 | const char* name ) |
56 | : QServerSocket( port, 1, parent, name ), | 54 | : QServerSocket( port, 1, parent, name ), |
57 | desktopChannel( 0 ), | 55 | desktopChannel( 0 ), |
58 | cardChannel( 0 ) | 56 | cardChannel( 0 ) |
59 | { | 57 | { |
60 | if ( !ok() ) | 58 | if ( !ok() ) |
61 | qWarning( "Failed to bind to port %d", port ); | 59 | qWarning( "Failed to bind to port %d", port ); |
62 | else { | 60 | else { |
63 | #ifndef QT_NO_COP | 61 | #ifndef QT_NO_COP |
64 | desktopChannel = new QCopChannel( "QPE/Desktop", this ); | 62 | desktopChannel = new QCopChannel( "QPE/Desktop", this ); |
65 | connect( desktopChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 63 | connect( desktopChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
66 | this, SLOT(desktopMessage( const QCString &, const QByteArray &)) ); | 64 | this, SLOT(desktopMessage( const QCString &, const QByteArray &)) ); |
67 | cardChannel = new QCopChannel( "QPE/Card", this ); | 65 | cardChannel = new QCopChannel( "QPE/Card", this ); |
68 | connect( cardChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 66 | connect( cardChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
69 | this, SLOT(desktopMessage( const QCString &, const QByteArray &)) ); | 67 | this, SLOT(desktopMessage( const QCString &, const QByteArray &)) ); |
70 | #endif | 68 | #endif |
71 | } | 69 | } |
72 | sendSync = FALSE; | 70 | sendSync = FALSE; |
73 | } | 71 | } |
74 | 72 | ||
75 | QCopBridge::~QCopBridge() | 73 | QCopBridge::~QCopBridge() |
76 | { | 74 | { |
77 | #ifndef QT_NO_COP | 75 | #ifndef QT_NO_COP |
78 | delete desktopChannel; | 76 | delete desktopChannel; |
79 | #endif | 77 | #endif |
80 | } | 78 | } |
81 | 79 | ||
82 | void QCopBridge::newConnection( int socket ) | 80 | void QCopBridge::newConnection( int socket ) |
83 | { | 81 | { |
84 | QCopBridgePI *pi = new QCopBridgePI( socket, this ); | 82 | QCopBridgePI *pi = new QCopBridgePI( socket, this ); |
85 | openConnections.append( pi ); | 83 | openConnections.append( pi ); |
86 | connect ( pi, SIGNAL( connectionClosed( QCopBridgePI *) ), this, SLOT( connectionClosed( QCopBridgePI *) ) ); | 84 | connect ( pi, SIGNAL( connectionClosed( QCopBridgePI *) ), this, SLOT( connectionClosed( QCopBridgePI *) ) ); |
87 | #ifndef QT_NO_COP | 85 | #ifndef QT_NO_COP |
88 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::DisableSuspend; | 86 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::DisableSuspend; |
89 | #endif | 87 | #endif |
90 | 88 | ||
91 | if ( sendSync ) { | 89 | if ( sendSync ) { |
92 | pi ->startSync(); | 90 | pi ->startSync(); |
93 | sendSync = FALSE; | 91 | sendSync = FALSE; |
94 | } | 92 | } |
95 | } | 93 | } |
96 | 94 | ||
97 | void QCopBridge::connectionClosed( QCopBridgePI *pi ) | 95 | void QCopBridge::connectionClosed( QCopBridgePI *pi ) |
98 | { | 96 | { |
99 | openConnections.remove( pi ); | 97 | openConnections.remove( pi ); |
100 | if ( openConnections.count() == 0 ) { | 98 | if ( openConnections.count() == 0 ) { |
101 | #ifndef QT_NO_COP | 99 | #ifndef QT_NO_COP |
102 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; | 100 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; |
103 | #endif | 101 | #endif |
104 | } | 102 | } |
105 | } | 103 | } |
106 | 104 | ||
107 | void QCopBridge::closeOpenConnections() | 105 | void QCopBridge::closeOpenConnections() |
108 | { | 106 | { |
109 | QCopBridgePI *pi; | 107 | QCopBridgePI *pi; |
110 | for ( pi = openConnections.first(); pi != 0; pi = openConnections.next() ) | 108 | for ( pi = openConnections.first(); pi != 0; pi = openConnections.next() ) |
111 | pi->close(); | 109 | pi->close(); |
112 | } | 110 | } |
113 | 111 | ||
114 | 112 | ||
115 | void QCopBridge::desktopMessage( const QCString &command, const QByteArray &args ) | 113 | void QCopBridge::desktopMessage( const QCString &command, const QByteArray &args ) |
116 | { | 114 | { |
117 | command.stripWhiteSpace(); | 115 | command.stripWhiteSpace(); |
118 | 116 | ||
119 | int paren = command.find( "(" ); | 117 | int paren = command.find( "(" ); |
120 | if ( paren <= 0 ) { | 118 | if ( paren <= 0 ) { |
121 | qDebug("DesktopMessage: bad qcop syntax"); | 119 | qDebug("DesktopMessage: bad qcop syntax"); |
122 | return; | 120 | return; |
123 | } | 121 | } |
124 | 122 | ||
125 | QString params = command.mid( paren + 1 ); | 123 | QString params = command.mid( paren + 1 ); |
126 | if ( params[params.length()-1] != ')' ) { | 124 | if ( params[params.length()-1] != ')' ) { |
127 | qDebug("DesktopMessage: bad qcop syntax"); | 125 | qDebug("DesktopMessage: bad qcop syntax"); |
128 | return; | 126 | return; |
129 | } | 127 | } |
130 | 128 | ||
131 | params.truncate( params.length()-1 ); | 129 | params.truncate( params.length()-1 ); |
132 | 130 | ||
133 | QStringList paramList = QStringList::split( ",", params ); | 131 | QStringList paramList = QStringList::split( ",", params ); |
134 | QString data; | 132 | QString data; |
135 | if ( paramList.count() ) { | 133 | if ( paramList.count() ) { |
136 | QDataStream stream( args, IO_ReadOnly ); | 134 | QDataStream stream( args, IO_ReadOnly ); |
137 | for ( QStringList::Iterator it = paramList.begin(); it != paramList.end(); ++it ) { | 135 | for ( QStringList::Iterator it = paramList.begin(); it != paramList.end(); ++it ) { |
138 | QString str; | 136 | QString str; |
139 | if ( *it == "QString" ) { | 137 | if ( *it == "QString" ) { |
140 | stream >> str; | 138 | stream >> str; |
141 | } else if ( *it == "QCString" ) { | 139 | } else if ( *it == "QCString" ) { |
142 | QCString cstr; | 140 | QCString cstr; |
143 | stream >> cstr; | 141 | stream >> cstr; |
144 | str = QString::fromLocal8Bit( cstr ); | 142 | str = QString::fromLocal8Bit( cstr ); |
145 | } else if ( *it == "int" ) { | 143 | } else if ( *it == "int" ) { |
146 | int i; | 144 | int i; |
147 | stream >> i; | 145 | stream >> i; |
148 | str = QString::number( i ); | 146 | str = QString::number( i ); |
149 | } else if ( *it == "bool" ) { | 147 | } else if ( *it == "bool" ) { |
150 | int i; | 148 | int i; |
151 | stream >> i; | 149 | stream >> i; |
152 | str = QString::number( i ); | 150 | str = QString::number( i ); |
153 | } else { | 151 | } else { |
154 | qDebug(" cannot route the argument type %s throught the qcop bridge", (*it).latin1() ); | 152 | qDebug(" cannot route the argument type %s throught the qcop bridge", (*it).latin1() ); |
155 | return; | 153 | return; |
156 | } | 154 | } |
157 | QString estr; | 155 | QString estr; |
158 | for (int i=0; i<(int)str.length(); i++) { | 156 | for (int i=0; i<(int)str.length(); i++) { |
159 | QChar ch = str[i]; | 157 | QChar ch = str[i]; |
160 | if ( ch.row() ) | 158 | if ( ch.row() ) |
161 | goto quick; | 159 | goto quick; |
162 | switch (ch.cell()) { | 160 | switch (ch.cell()) { |
163 | case '&': | 161 | case '&': |
164 | estr.append( "&" ); | 162 | estr.append( "&" ); |
165 | break; | 163 | break; |
166 | case ' ': | 164 | case ' ': |
167 | estr.append( "&0x20;" ); | 165 | estr.append( "&0x20;" ); |
168 | break; | 166 | break; |
169 | case '\n': | 167 | case '\n': |
170 | estr.append( "&0x0d;" ); | 168 | estr.append( "&0x0d;" ); |
171 | break; | 169 | break; |
172 | case '\r': | 170 | case '\r': |
173 | estr.append( "&0x0a;" ); | 171 | estr.append( "&0x0a;" ); |
174 | break; | 172 | break; |
175 | default: quick: | 173 | default: quick: |
176 | estr.append(ch); | 174 | estr.append(ch); |
177 | } | 175 | } |
178 | } | 176 | } |
179 | data += " " + estr; | 177 | data += " " + estr; |
180 | } | 178 | } |
181 | } | 179 | } |
182 | QString sendCommand = QString(command.data()) + data; | 180 | QString sendCommand = QString(command.data()) + data; |
183 | // send the command to all open connections | 181 | // send the command to all open connections |
184 | if ( command == "startSync()" ) { | 182 | if ( command == "startSync()" ) { |
185 | // we need to buffer it a bit | 183 | // we need to buffer it a bit |
186 | sendSync = TRUE; | 184 | sendSync = TRUE; |
187 | startTimer( 20000 ); | 185 | startTimer( 20000 ); |
188 | } | 186 | } |
189 | 187 | ||
190 | QCopBridgePI *pi; | 188 | QCopBridgePI *pi; |
191 | for ( pi = openConnections.first(); pi != 0; pi = openConnections.next() ) { | 189 | for ( pi = openConnections.first(); pi != 0; pi = openConnections.next() ) { |
192 | pi->sendDesktopMessage( sendCommand ); | 190 | pi->sendDesktopMessage( sendCommand ); |
193 | } | 191 | } |
194 | } | 192 | } |
195 | 193 | ||
196 | void QCopBridge::timerEvent( QTimerEvent * ) | 194 | void QCopBridge::timerEvent( QTimerEvent * ) |
197 | { | 195 | { |
198 | sendSync = FALSE; | 196 | sendSync = FALSE; |
199 | killTimers(); | 197 | killTimers(); |
200 | } | 198 | } |
201 | 199 | ||
202 | 200 | ||
203 | QCopBridgePI::QCopBridgePI( int socket, QObject *parent , const char* name ) | 201 | QCopBridgePI::QCopBridgePI( int socket, QObject *parent , const char* name ) |
204 | : QSocket( parent, name ) | 202 | : QSocket( parent, name ) |
205 | { | 203 | { |
206 | setSocket( socket ); | 204 | setSocket( socket ); |
207 | 205 | ||
208 | peerport = peerPort(); | 206 | peerport = peerPort(); |
209 | peeraddress = peerAddress(); | 207 | peeraddress = peerAddress(); |
210 | 208 | ||
211 | #ifndef INSECURE | 209 | #ifndef INSECURE |
212 | if ( !SyncAuthentication::isAuthorized(peeraddress) ) { | 210 | if ( !SyncAuthentication::isAuthorized(peeraddress) ) { |
213 | state = Forbidden; | 211 | state = Forbidden; |
214 | startTimer( 0 ); | 212 | startTimer( 0 ); |
215 | } else | 213 | } else |
216 | #endif | 214 | #endif |
217 | { | 215 | { |
218 | state = Connected; | 216 | state = Connected; |
219 | sendSync = FALSE; | 217 | sendSync = FALSE; |
220 | connect( this, SIGNAL( readyRead() ), SLOT( read() ) ); | 218 | connect( this, SIGNAL( readyRead() ), SLOT( read() ) ); |
221 | connect( this, SIGNAL( connectionClosed() ), SLOT( connectionClosed() ) ); | 219 | connect( this, SIGNAL( connectionClosed() ), SLOT( connectionClosed() ) ); |
222 | 220 | ||
223 | QString intro="220 Qtopia "; | 221 | QString intro="220 Qtopia "; |
224 | intro += QPE_VERSION; intro += ";"; | 222 | intro += QPE_VERSION; intro += ";"; |
225 | intro += "challenge="; intro += SyncAuthentication::serverId(); intro += ";"; | 223 | intro += "challenge="; intro += SyncAuthentication::serverId(); intro += ";"; |
226 | intro += "loginname="; intro += SyncAuthentication::loginName(); intro += ";"; | 224 | intro += "loginname="; intro += SyncAuthentication::loginName(); intro += ";"; |
227 | intro += "displayname="; intro += SyncAuthentication::ownerName(); intro += ";"; | 225 | intro += "displayname="; intro += SyncAuthentication::ownerName(); intro += ";"; |
228 | send( intro ); | 226 | send( intro ); |
229 | state = Wait_USER; | 227 | state = Wait_USER; |
230 | 228 | ||
231 | // idle timer to close connections when not used anymore | 229 | // idle timer to close connections when not used anymore |
232 | startTimer( 60000 ); | 230 | startTimer( 60000 ); |
233 | connected = TRUE; | 231 | connected = TRUE; |
234 | } | 232 | } |
235 | } | 233 | } |
236 | 234 | ||
237 | 235 | ||
238 | QCopBridgePI::~QCopBridgePI() | 236 | QCopBridgePI::~QCopBridgePI() |
239 | { | 237 | { |
240 | 238 | ||
241 | } | 239 | } |
242 | 240 | ||
243 | void QCopBridgePI::connectionClosed() | 241 | void QCopBridgePI::connectionClosed() |
244 | { | 242 | { |
245 | emit connectionClosed( this ); | 243 | emit connectionClosed( this ); |
246 | // qDebug( "Debug: Connection closed" ); | 244 | // qDebug( "Debug: Connection closed" ); |
247 | delete this; | 245 | delete this; |
248 | } | 246 | } |
249 | 247 | ||
250 | void QCopBridgePI::sendDesktopMessage( const QString &msg ) | 248 | void QCopBridgePI::sendDesktopMessage( const QString &msg ) |
251 | { | 249 | { |
252 | QString str = "CALL QPE/Desktop " + msg; | 250 | QString str = "CALL QPE/Desktop " + msg; |
253 | send ( str ); | 251 | send ( str ); |
254 | } | 252 | } |
255 | 253 | ||
256 | 254 | ||
257 | void QCopBridgePI::send( const QString& msg ) | 255 | void QCopBridgePI::send( const QString& msg ) |
258 | { | 256 | { |
259 | QTextStream os( this ); | 257 | QTextStream os( this ); |
260 | os << msg << endl; | 258 | os << msg << endl; |
261 | //qDebug( "sending qcop message: %s", msg.latin1() ); | 259 | //qDebug( "sending qcop message: %s", msg.latin1() ); |
262 | } | 260 | } |
263 | 261 | ||
264 | void QCopBridgePI::read() | 262 | void QCopBridgePI::read() |
265 | { | 263 | { |
266 | while ( canReadLine() ) | 264 | while ( canReadLine() ) |
267 | process( readLine().stripWhiteSpace() ); | 265 | process( readLine().stripWhiteSpace() ); |
268 | } | 266 | } |
269 | 267 | ||
270 | void QCopBridgePI::process( const QString& message ) | 268 | void QCopBridgePI::process( const QString& message ) |
271 | { | 269 | { |
272 | //qDebug( "Command: %s", message.latin1() ); | 270 | //qDebug( "Command: %s", message.latin1() ); |
273 | 271 | ||
274 | // split message using "," as separator | 272 | // split message using "," as separator |
275 | QStringList msg = QStringList::split( " ", message ); | 273 | QStringList msg = QStringList::split( " ", message ); |
276 | if ( msg.isEmpty() ) return; | 274 | if ( msg.isEmpty() ) return; |
277 | 275 | ||
278 | // command token | 276 | // command token |
279 | QString cmd = msg[0].upper(); | 277 | QString cmd = msg[0].upper(); |
280 | 278 | ||
281 | // argument token | 279 | // argument token |
282 | QString arg; | 280 | QString arg; |
283 | if ( msg.count() >= 2 ) | 281 | if ( msg.count() >= 2 ) |
284 | arg = msg[1]; | 282 | arg = msg[1]; |
285 | 283 | ||
286 | // we always respond to QUIT, regardless of state | 284 | // we always respond to QUIT, regardless of state |
287 | if ( cmd == "QUIT" ) { | 285 | if ( cmd == "QUIT" ) { |
288 | send( "211 Have a nice day!" ); | 286 | send( "211 Have a nice day!" ); |
289 | delete this; | 287 | delete this; |
290 | return; | 288 | return; |
291 | } | 289 | } |
292 | 290 | ||
293 | // connected to client | 291 | // connected to client |
294 | if ( Connected == state ) | 292 | if ( Connected == state ) |
295 | return; | 293 | return; |
296 | 294 | ||
297 | // waiting for user name | 295 | // waiting for user name |
298 | if ( Wait_USER == state ) { | 296 | if ( Wait_USER == state ) { |
299 | 297 | ||
300 | if ( cmd != "USER" || msg.count() < 2 || !SyncAuthentication::checkUser( arg ) ) { | 298 | if ( cmd != "USER" || msg.count() < 2 || !SyncAuthentication::checkUser( arg ) ) { |
301 | send( "530 Please login with USER and PASS" ); | 299 | send( "530 Please login with USER and PASS" ); |
302 | return; | 300 | return; |
303 | } | 301 | } |
304 | send( "331 User name ok, need password" ); | 302 | send( "331 User name ok, need password" ); |
305 | state = Wait_PASS; | 303 | state = Wait_PASS; |
306 | return; | 304 | return; |
307 | } | 305 | } |
308 | 306 | ||
309 | // waiting for password | 307 | // waiting for password |
310 | if ( Wait_PASS == state ) { | 308 | if ( Wait_PASS == state ) { |
311 | 309 | ||
312 | if ( cmd != "PASS" || !SyncAuthentication::checkPassword( arg ) ) { | 310 | if ( cmd != "PASS" || !SyncAuthentication::checkPassword( arg ) ) { |
313 | send( "530 Please login with USER and PASS" ); | 311 | send( "530 Please login with USER and PASS" ); |
314 | return; | 312 | return; |
315 | } | 313 | } |
316 | send( "230 User logged in, proceed" ); | 314 | send( "230 User logged in, proceed" ); |
317 | state = Ready; | 315 | state = Ready; |
318 | if ( sendSync ) { | 316 | if ( sendSync ) { |
319 | sendDesktopMessage( "startSync()" ); | 317 | sendDesktopMessage( "startSync()" ); |
320 | sendSync = FALSE; | 318 | sendSync = FALSE; |
321 | } | 319 | } |
322 | return; | 320 | return; |
323 | } | 321 | } |
324 | 322 | ||
325 | // noop (NOOP) | 323 | // noop (NOOP) |
326 | else if ( cmd == "NOOP" ) { | 324 | else if ( cmd == "NOOP" ) { |
327 | connected = TRUE; | 325 | connected = TRUE; |
328 | send( "200 Command okay" ); | 326 | send( "200 Command okay" ); |
329 | } | 327 | } |
330 | 328 | ||
331 | // call (CALL) | 329 | // call (CALL) |
332 | else if ( cmd == "CALL" ) { | 330 | else if ( cmd == "CALL" ) { |
333 | 331 | ||
334 | // example: call QPE/System execute(QString) addressbook | 332 | // example: call QPE/System execute(QString) addressbook |
335 | 333 | ||
336 | if ( msg.count() < 3 ) { | 334 | if ( msg.count() < 3 ) { |
337 | send( "500 Syntax error, command unrecognized" ); | 335 | send( "500 Syntax error, command unrecognized" ); |
338 | } | 336 | } |
339 | else { | 337 | else { |
340 | 338 | ||
341 | QString channel = msg[1]; | 339 | QString channel = msg[1]; |
342 | QString command = msg[2]; | 340 | QString command = msg[2]; |
343 | 341 | ||
344 | command.stripWhiteSpace(); | 342 | command.stripWhiteSpace(); |
345 | 343 | ||
346 | int paren = command.find( "(" ); | 344 | int paren = command.find( "(" ); |
347 | if ( paren <= 0 ) { | 345 | if ( paren <= 0 ) { |
348 | send( "500 Syntax error, command unrecognized" ); | 346 | send( "500 Syntax error, command unrecognized" ); |
349 | return; | 347 | return; |
350 | } | 348 | } |
351 | 349 | ||
352 | QString params = command.mid( paren + 1 ); | 350 | QString params = command.mid( paren + 1 ); |
353 | if ( params[params.length()-1] != ')' ) { | 351 | if ( params[params.length()-1] != ')' ) { |
354 | send( "500 Syntax error, command unrecognized" ); | 352 | send( "500 Syntax error, command unrecognized" ); |
355 | return; | 353 | return; |
356 | } | 354 | } |
357 | 355 | ||
358 | params.truncate( params.length()-1 ); | 356 | params.truncate( params.length()-1 ); |
359 | QByteArray buffer; | 357 | QByteArray buffer; |
360 | QDataStream ds( buffer, IO_WriteOnly ); | 358 | QDataStream ds( buffer, IO_WriteOnly ); |
361 | 359 | ||
362 | int msgId = 3; | 360 | int msgId = 3; |
363 | 361 | ||
364 | QStringList paramList = QStringList::split( ",", params ); | 362 | QStringList paramList = QStringList::split( ",", params ); |
365 | if ( paramList.count() > msg.count() - 3 ) { | 363 | if ( paramList.count() > msg.count() - 3 ) { |
366 | send( "500 Syntax error, command unrecognized" ); | 364 | send( "500 Syntax error, command unrecognized" ); |
367 | return; | 365 | return; |
368 | } | 366 | } |
369 | 367 | ||
370 | for ( QStringList::Iterator it = paramList.begin(); it != paramList.end(); ++it ) { | 368 | for ( QStringList::Iterator it = paramList.begin(); it != paramList.end(); ++it ) { |
371 | 369 | ||
372 | QString arg = msg[msgId]; | 370 | QString arg = msg[msgId]; |
373 | arg.replace( QRegExp("&0x20;"), " " ); | 371 | arg.replace( QRegExp("&0x20;"), " " ); |
374 | arg.replace( QRegExp("&"), "&" ); | 372 | arg.replace( QRegExp("&"), "&" ); |
375 | arg.replace( QRegExp("&0x0d;"), "\n" ); | 373 | arg.replace( QRegExp("&0x0d;"), "\n" ); |
376 | arg.replace( QRegExp("&0x0a;"), "\r" ); | 374 | arg.replace( QRegExp("&0x0a;"), "\r" ); |
377 | if ( *it == "QString" ) | 375 | if ( *it == "QString" ) |
378 | ds << arg; | 376 | ds << arg; |
379 | else if ( *it == "QCString" ) | 377 | else if ( *it == "QCString" ) |
380 | ds << arg.local8Bit(); | 378 | ds << arg.local8Bit(); |
381 | else if ( *it == "int" ) | 379 | else if ( *it == "int" ) |
382 | ds << arg.toInt(); | 380 | ds << arg.toInt(); |
383 | else if ( *it == "bool" ) | 381 | else if ( *it == "bool" ) |
384 | ds << arg.toInt(); | 382 | ds << arg.toInt(); |
385 | else { | 383 | else { |
386 | send( "500 Syntax error, command unrecognized" ); | 384 | send( "500 Syntax error, command unrecognized" ); |
387 | return; | 385 | return; |
388 | } | 386 | } |
389 | msgId++; | 387 | msgId++; |
390 | } | 388 | } |
391 | 389 | ||
392 | #ifndef QT_NO_COP | 390 | #ifndef QT_NO_COP |
393 | if ( !QCopChannel::isRegistered( channel.latin1() ) ) { | 391 | if ( !QCopChannel::isRegistered( channel.latin1() ) ) { |
394 | // send message back about it | 392 | // send message back about it |
395 | QString answer = "599 ChannelNotRegistered " + channel; | 393 | QString answer = "599 ChannelNotRegistered " + channel; |
396 | send( answer ); | 394 | send( answer ); |
397 | return; | 395 | return; |
398 | } | 396 | } |
399 | #endif | 397 | #endif |
400 | 398 | ||
401 | #ifndef QT_NO_COP | 399 | #ifndef QT_NO_COP |
402 | if ( paramList.count() ) | 400 | if ( paramList.count() ) |
403 | QCopChannel::send( channel.latin1(), command.latin1(), buffer ); | 401 | QCopChannel::send( channel.latin1(), command.latin1(), buffer ); |
404 | else | 402 | else |
405 | QCopChannel::send( channel.latin1(), command.latin1() ); | 403 | QCopChannel::send( channel.latin1(), command.latin1() ); |
406 | 404 | ||
407 | send( "200 Command okay" ); | 405 | send( "200 Command okay" ); |
408 | #endif | 406 | #endif |
409 | } | 407 | } |
410 | } | 408 | } |
411 | // not implemented | 409 | // not implemented |
412 | else | 410 | else |
413 | send( "502 Command not implemented" ); | 411 | send( "502 Command not implemented" ); |
414 | } | 412 | } |
415 | 413 | ||
416 | 414 | ||
417 | 415 | ||
418 | void QCopBridgePI::timerEvent( QTimerEvent * ) | 416 | void QCopBridgePI::timerEvent( QTimerEvent * ) |
419 | { | 417 | { |
420 | if ( connected ) | 418 | if ( connected ) |
421 | connected = FALSE; | 419 | connected = FALSE; |
422 | else | 420 | else |
423 | connectionClosed(); | 421 | connectionClosed(); |
424 | } | 422 | } |
diff --git a/core/launcher/runningappbar.cpp b/core/launcher/runningappbar.cpp index b830d1b..c8f45d5 100644 --- a/core/launcher/runningappbar.cpp +++ b/core/launcher/runningappbar.cpp | |||
@@ -1,289 +1,291 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | 21 | ||
22 | #define QTOPIA_INTERNAL_PRELOADACCESS | 22 | #define QTOPIA_INTERNAL_PRELOADACCESS |
23 | 23 | ||
24 | // For "kill" | 24 | // For "kill" |
25 | #include <sys/types.h> | 25 | #include <sys/types.h> |
26 | #include <signal.h> | 26 | #include <signal.h> |
27 | 27 | ||
28 | #include <qtimer.h> | 28 | #include <qtimer.h> |
29 | #include <qpopupmenu.h> | 29 | #include <qpopupmenu.h> |
30 | #include <qmessagebox.h> | 30 | #include <qmessagebox.h> |
31 | #include <qpainter.h> | 31 | #include <qpainter.h> |
32 | #include "qprocess.h" | 32 | #include "qprocess.h" |
33 | #include <qpe/qpeapplication.h> | 33 | #include <qpe/qpeapplication.h> |
34 | #include <qpe/applnk.h> | 34 | #include <qpe/applnk.h> |
35 | #include <qpe/qcopenvelope_qws.h> | 35 | #include <qpe/qcopenvelope_qws.h> |
36 | #include <qpe/global.h> | 36 | #include <qpe/global.h> |
37 | #include <qwindowsystem_qws.h> | 37 | #include <qwindowsystem_qws.h> |
38 | #include "runningappbar.h" | 38 | #include "runningappbar.h" |
39 | 39 | ||
40 | RunningAppBar::RunningAppBar(QWidget* parent) | 40 | RunningAppBar::RunningAppBar(QWidget* parent) |
41 | : QFrame(parent), m_AppLnkSet(0L), m_SelectedAppIndex(-1) | 41 | : QFrame(parent), m_AppLnkSet(0L), m_SelectedAppIndex(-1) |
42 | { | 42 | { |
43 | setBackgroundMode( PaletteBackground ); | 43 | setBackgroundMode( PaletteBackground ); |
44 | 44 | ||
45 | m_AppLnkSet = new AppLnkSet( QPEApplication::qpeDir() + "apps" ); | 45 | m_AppLnkSet = new AppLnkSet( QPEApplication::qpeDir() + "apps" ); |
46 | 46 | ||
47 | #ifdef QWS | ||
47 | connect(qwsServer, SIGNAL(newChannel(const QString&)), this, SLOT(newQcopChannel(const QString&))); | 48 | connect(qwsServer, SIGNAL(newChannel(const QString&)), this, SLOT(newQcopChannel(const QString&))); |
48 | connect(qwsServer, SIGNAL(removedChannel(const QString&)), this, SLOT(removedQcopChannel(const QString&))); | 49 | connect(qwsServer, SIGNAL(removedChannel(const QString&)), this, SLOT(removedQcopChannel(const QString&))); |
50 | #endif | ||
49 | QCopChannel* channel = new QCopChannel( "QPE/System", this ); | 51 | QCopChannel* channel = new QCopChannel( "QPE/System", this ); |
50 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 52 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
51 | this, SLOT(received(const QCString&, const QByteArray&)) ); | 53 | this, SLOT(received(const QCString&, const QByteArray&)) ); |
52 | 54 | ||
53 | spacing = AppLnk::smallIconSize()+3; | 55 | spacing = AppLnk::smallIconSize()+3; |
54 | } | 56 | } |
55 | 57 | ||
56 | RunningAppBar::~RunningAppBar() { | 58 | RunningAppBar::~RunningAppBar() { |
57 | } | 59 | } |
58 | 60 | ||
59 | void RunningAppBar::newQcopChannel(const QString& channelName) { | 61 | void RunningAppBar::newQcopChannel(const QString& channelName) { |
60 | QString prefix("QPE/Application/"); | 62 | QString prefix("QPE/Application/"); |
61 | if (channelName.startsWith(prefix)) { | 63 | if (channelName.startsWith(prefix)) { |
62 | QString appName = channelName.mid(prefix.length()); | 64 | QString appName = channelName.mid(prefix.length()); |
63 | // qDebug("App %s just connected!", appName.latin1()); | 65 | // qDebug("App %s just connected!", appName.latin1()); |
64 | const AppLnk* newGuy = m_AppLnkSet->findExec(appName); | 66 | const AppLnk* newGuy = m_AppLnkSet->findExec(appName); |
65 | if (newGuy && !newGuy->isPreloaded()) { | 67 | if (newGuy && !newGuy->isPreloaded()) { |
66 | addTask(*newGuy); | 68 | addTask(*newGuy); |
67 | } | 69 | } |
68 | } | 70 | } |
69 | } | 71 | } |
70 | 72 | ||
71 | void RunningAppBar::removedQcopChannel(const QString& channelName) { | 73 | void RunningAppBar::removedQcopChannel(const QString& channelName) { |
72 | QString prefix("QPE/Application/"); | 74 | QString prefix("QPE/Application/"); |
73 | if (channelName.startsWith(prefix)) { | 75 | if (channelName.startsWith(prefix)) { |
74 | QString appName = channelName.mid(prefix.length()); | 76 | QString appName = channelName.mid(prefix.length()); |
75 | qDebug("App %s just disconnected!", appName.latin1()); | 77 | qDebug("App %s just disconnected!", appName.latin1()); |
76 | const AppLnk* newGuy = m_AppLnkSet->findExec(appName); | 78 | const AppLnk* newGuy = m_AppLnkSet->findExec(appName); |
77 | if (newGuy) { | 79 | if (newGuy) { |
78 | removeTask(*newGuy); | 80 | removeTask(*newGuy); |
79 | } | 81 | } |
80 | } | 82 | } |
81 | } | 83 | } |
82 | 84 | ||
83 | void RunningAppBar::received(const QCString& msg, const QByteArray& data) { | 85 | void RunningAppBar::received(const QCString& msg, const QByteArray& data) { |
84 | // Since fast apps appear and disappear without disconnecting from their | 86 | // Since fast apps appear and disappear without disconnecting from their |
85 | // channel we need to watch for the showing/hiding events and update according. | 87 | // channel we need to watch for the showing/hiding events and update according. |
86 | QDataStream stream( data, IO_ReadOnly ); | 88 | QDataStream stream( data, IO_ReadOnly ); |
87 | if ( msg == "fastAppShowing(QString)") { | 89 | if ( msg == "fastAppShowing(QString)") { |
88 | QString appName; | 90 | QString appName; |
89 | stream >> appName; | 91 | stream >> appName; |
90 | addTask(*m_AppLnkSet->findExec(appName)); | 92 | addTask(*m_AppLnkSet->findExec(appName)); |
91 | } else if ( msg == "fastAppHiding(QString)") { | 93 | } else if ( msg == "fastAppHiding(QString)") { |
92 | QString appName; | 94 | QString appName; |
93 | stream >> appName; | 95 | stream >> appName; |
94 | removeTask(*m_AppLnkSet->findExec(appName)); | 96 | removeTask(*m_AppLnkSet->findExec(appName)); |
95 | } | 97 | } |
96 | } | 98 | } |
97 | 99 | ||
98 | void RunningAppBar::addTask(const AppLnk& appLnk) { | 100 | void RunningAppBar::addTask(const AppLnk& appLnk) { |
99 | // qDebug("Added %s to app list.", appLnk.name().latin1()); | 101 | // qDebug("Added %s to app list.", appLnk.name().latin1()); |
100 | AppLnk* newApp = new AppLnk(appLnk); | 102 | AppLnk* newApp = new AppLnk(appLnk); |
101 | newApp->setExec(appLnk.exec()); | 103 | newApp->setExec(appLnk.exec()); |
102 | m_AppList.prepend(newApp); | 104 | m_AppList.prepend(newApp); |
103 | update(); | 105 | update(); |
104 | } | 106 | } |
105 | 107 | ||
106 | void RunningAppBar::removeTask(const AppLnk& appLnk) { | 108 | void RunningAppBar::removeTask(const AppLnk& appLnk) { |
107 | unsigned int i = 0; | 109 | unsigned int i = 0; |
108 | for (; i < m_AppList.count() ; i++) { | 110 | for (; i < m_AppList.count() ; i++) { |
109 | AppLnk* target = m_AppList.at(i); | 111 | AppLnk* target = m_AppList.at(i); |
110 | if (target->exec() == appLnk.exec()) { | 112 | if (target->exec() == appLnk.exec()) { |
111 | qDebug("Removing %s from app list.", appLnk.name().latin1()); | 113 | qDebug("Removing %s from app list.", appLnk.name().latin1()); |
112 | m_AppList.remove(); | 114 | m_AppList.remove(); |
113 | delete target; | 115 | delete target; |
114 | } | 116 | } |
115 | } | 117 | } |
116 | update(); | 118 | update(); |
117 | } | 119 | } |
118 | 120 | ||
119 | void RunningAppBar::mousePressEvent(QMouseEvent *e) | 121 | void RunningAppBar::mousePressEvent(QMouseEvent *e) |
120 | { | 122 | { |
121 | // Find out if the user is clicking on an app icon... | 123 | // Find out if the user is clicking on an app icon... |
122 | // If so, snag the index so when we repaint we show it | 124 | // If so, snag the index so when we repaint we show it |
123 | // as highlighed. | 125 | // as highlighed. |
124 | m_SelectedAppIndex = 0; | 126 | m_SelectedAppIndex = 0; |
125 | int x=0; | 127 | int x=0; |
126 | QListIterator<AppLnk> it( m_AppList ); | 128 | QListIterator<AppLnk> it( m_AppList ); |
127 | for ( ; it.current(); ++it,++m_SelectedAppIndex,x+=spacing ) { | 129 | for ( ; it.current(); ++it,++m_SelectedAppIndex,x+=spacing ) { |
128 | if ( x + spacing <= width() ) { | 130 | if ( x + spacing <= width() ) { |
129 | if ( e->x() >= x && e->x() < x+spacing ) { | 131 | if ( e->x() >= x && e->x() < x+spacing ) { |
130 | if ( m_SelectedAppIndex < (int)m_AppList.count() ) { | 132 | if ( m_SelectedAppIndex < (int)m_AppList.count() ) { |
131 | repaint(FALSE); | 133 | repaint(FALSE); |
132 | return; | 134 | return; |
133 | } | 135 | } |
134 | } | 136 | } |
135 | } else { | 137 | } else { |
136 | break; | 138 | break; |
137 | } | 139 | } |
138 | } | 140 | } |
139 | m_SelectedAppIndex = -1; | 141 | m_SelectedAppIndex = -1; |
140 | repaint( FALSE ); | 142 | repaint( FALSE ); |
141 | } | 143 | } |
142 | 144 | ||
143 | void RunningAppBar::mouseReleaseEvent(QMouseEvent *e) | 145 | void RunningAppBar::mouseReleaseEvent(QMouseEvent *e) |
144 | { | 146 | { |
145 | if (e->button() == QMouseEvent::RightButton) { | 147 | if (e->button() == QMouseEvent::RightButton) { |
146 | return; | 148 | return; |
147 | } | 149 | } |
148 | if ( m_SelectedAppIndex >= 0 ) { | 150 | if ( m_SelectedAppIndex >= 0 ) { |
149 | QString channel = QString("QPE/Application/") + m_AppList.at(m_SelectedAppIndex)->exec(); | 151 | QString channel = QString("QPE/Application/") + m_AppList.at(m_SelectedAppIndex)->exec(); |
150 | if (QCopChannel::isRegistered(channel.latin1())) { | 152 | if (QCopChannel::isRegistered(channel.latin1())) { |
151 | // qDebug("%s is running!", m_AppList.at(m_SelectedAppIndex)->exec().latin1()); | 153 | // qDebug("%s is running!", m_AppList.at(m_SelectedAppIndex)->exec().latin1()); |
152 | QCopEnvelope e(channel.latin1(), "raise()"); | 154 | QCopEnvelope e(channel.latin1(), "raise()"); |
153 | // This class will delete itself after hearing from the app or the timer expiring | 155 | // This class will delete itself after hearing from the app or the timer expiring |
154 | (void)new AppMonitor(*m_AppList.at(m_SelectedAppIndex), *this); | 156 | (void)new AppMonitor(*m_AppList.at(m_SelectedAppIndex), *this); |
155 | } | 157 | } |
156 | else { | 158 | else { |
157 | removeTask(*m_AppList.at(m_SelectedAppIndex)); | 159 | removeTask(*m_AppList.at(m_SelectedAppIndex)); |
158 | } | 160 | } |
159 | 161 | ||
160 | m_SelectedAppIndex = -1; | 162 | m_SelectedAppIndex = -1; |
161 | update(); | 163 | update(); |
162 | } | 164 | } |
163 | } | 165 | } |
164 | 166 | ||
165 | void RunningAppBar::paintEvent( QPaintEvent * ) | 167 | void RunningAppBar::paintEvent( QPaintEvent * ) |
166 | { | 168 | { |
167 | QPainter p( this ); | 169 | QPainter p( this ); |
168 | AppLnk *curApp; | 170 | AppLnk *curApp; |
169 | int x = 0; | 171 | int x = 0; |
170 | int y = (height() - AppLnk::smallIconSize()) / 2; | 172 | int y = (height() - AppLnk::smallIconSize()) / 2; |
171 | int i = 0; | 173 | int i = 0; |
172 | 174 | ||
173 | //p.fillRect( 0, 0, width(), height(), colorGroup().background() ); | 175 | //p.fillRect( 0, 0, width(), height(), colorGroup().background() ); |
174 | 176 | ||
175 | QListIterator<AppLnk> it(m_AppList); | 177 | QListIterator<AppLnk> it(m_AppList); |
176 | 178 | ||
177 | for (; it.current(); i++, ++it ) { | 179 | for (; it.current(); i++, ++it ) { |
178 | if ( x + spacing <= width() ) { | 180 | if ( x + spacing <= width() ) { |
179 | curApp = it.current(); | 181 | curApp = it.current(); |
180 | if ( (int)i == m_SelectedAppIndex ) | 182 | if ( (int)i == m_SelectedAppIndex ) |
181 | p.fillRect( x, y, spacing, curApp->pixmap().height()+1, colorGroup().highlight() ); | 183 | p.fillRect( x, y, spacing, curApp->pixmap().height()+1, colorGroup().highlight() ); |
182 | else | 184 | else |
183 | // p.eraseRect( x, y, spacing, curApp->pixmap().height()+1 ); | 185 | // p.eraseRect( x, y, spacing, curApp->pixmap().height()+1 ); |
184 | p.drawPixmap( x, y, curApp->pixmap() ); | 186 | p.drawPixmap( x, y, curApp->pixmap() ); |
185 | x += spacing; | 187 | x += spacing; |
186 | } | 188 | } |
187 | } | 189 | } |
188 | } | 190 | } |
189 | 191 | ||
190 | QSize RunningAppBar::sizeHint() const | 192 | QSize RunningAppBar::sizeHint() const |
191 | { | 193 | { |
192 | return QSize( frameWidth(), AppLnk::smallIconSize()+frameWidth()*2+3 ); | 194 | return QSize( frameWidth(), AppLnk::smallIconSize()+frameWidth()*2+3 ); |
193 | } | 195 | } |
194 | 196 | ||
195 | const int AppMonitor::RAISE_TIMEOUT_MS = 500; | 197 | const int AppMonitor::RAISE_TIMEOUT_MS = 500; |
196 | 198 | ||
197 | AppMonitor::AppMonitor(const AppLnk& app, RunningAppBar& owner) | 199 | AppMonitor::AppMonitor(const AppLnk& app, RunningAppBar& owner) |
198 | : QObject(0L), m_Owner(owner), m_App(app), m_PsProc(0L), m_AppKillerBox(0L) { | 200 | : QObject(0L), m_Owner(owner), m_App(app), m_PsProc(0L), m_AppKillerBox(0L) { |
199 | QCopChannel* channel = new QCopChannel( "QPE/System", this ); | 201 | QCopChannel* channel = new QCopChannel( "QPE/System", this ); |
200 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 202 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
201 | this, SLOT(received(const QCString&, const QByteArray&)) ); | 203 | this, SLOT(received(const QCString&, const QByteArray&)) ); |
202 | connect(&m_Timer, SIGNAL(timeout()), this, SLOT(timerExpired())); | 204 | connect(&m_Timer, SIGNAL(timeout()), this, SLOT(timerExpired())); |
203 | m_Timer.start(RAISE_TIMEOUT_MS, TRUE); | 205 | m_Timer.start(RAISE_TIMEOUT_MS, TRUE); |
204 | } | 206 | } |
205 | 207 | ||
206 | AppMonitor::~AppMonitor() { | 208 | AppMonitor::~AppMonitor() { |
207 | if (m_AppKillerBox) { | 209 | if (m_AppKillerBox) { |
208 | delete m_AppKillerBox; | 210 | delete m_AppKillerBox; |
209 | m_AppKillerBox = 0L; | 211 | m_AppKillerBox = 0L; |
210 | } | 212 | } |
211 | } | 213 | } |
212 | 214 | ||
213 | void AppMonitor::received(const QCString& msg, const QByteArray& data) { | 215 | void AppMonitor::received(const QCString& msg, const QByteArray& data) { |
214 | QDataStream stream( data, IO_ReadOnly ); | 216 | QDataStream stream( data, IO_ReadOnly ); |
215 | 217 | ||
216 | if (msg == "appRaised(QString)") { | 218 | if (msg == "appRaised(QString)") { |
217 | QString appName; | 219 | QString appName; |
218 | stream >> appName; | 220 | stream >> appName; |
219 | if (appName == m_App.exec()) { | 221 | if (appName == m_App.exec()) { |
220 | // qDebug("Got a heartbeat from %s", appName.latin1()); | 222 | // qDebug("Got a heartbeat from %s", appName.latin1()); |
221 | m_Timer.stop(); | 223 | m_Timer.stop(); |
222 | // Check to make sure we're not waiting on user input... | 224 | // Check to make sure we're not waiting on user input... |
223 | if (m_AppKillerBox) { | 225 | if (m_AppKillerBox) { |
224 | // If we are, we kill the dialog box, and the code waiting on the result | 226 | // If we are, we kill the dialog box, and the code waiting on the result |
225 | // will clean us up (basically the user said "no"). | 227 | // will clean us up (basically the user said "no"). |
226 | delete m_AppKillerBox; | 228 | delete m_AppKillerBox; |
227 | m_AppKillerBox = 0L; | 229 | m_AppKillerBox = 0L; |
228 | } | 230 | } |
229 | else { | 231 | else { |
230 | // Ok, we're not waiting on user input, so clean us up now. | 232 | // Ok, we're not waiting on user input, so clean us up now. |
231 | // WE DELETE OURSELVES HERE! Don't do anything else!! | 233 | // WE DELETE OURSELVES HERE! Don't do anything else!! |
232 | delete this; | 234 | delete this; |
233 | } | 235 | } |
234 | } | 236 | } |
235 | } | 237 | } |
236 | } | 238 | } |
237 | 239 | ||
238 | void AppMonitor::timerExpired() { | 240 | void AppMonitor::timerExpired() { |
239 | // qDebug("Checking in on %s", m_App.name().latin1()); | 241 | // qDebug("Checking in on %s", m_App.name().latin1()); |
240 | // We store this incase the application responds while we're | 242 | // We store this incase the application responds while we're |
241 | // waiting for user input so we know not to delete ourselves. This | 243 | // waiting for user input so we know not to delete ourselves. This |
242 | // will be cleaned up in the destructor. | 244 | // will be cleaned up in the destructor. |
243 | m_AppKillerBox = new QMessageBox(tr("Application Problem"), | 245 | m_AppKillerBox = new QMessageBox(tr("Application Problem"), |
244 | tr("<p>%1 is not responding.</p>").arg(m_App.name()) + | 246 | tr("<p>%1 is not responding.</p>").arg(m_App.name()) + |
245 | tr("<p>Would you like to force the application to exit?</p>"), | 247 | tr("<p>Would you like to force the application to exit?</p>"), |
246 | QMessageBox::Warning, QMessageBox::Yes, | 248 | QMessageBox::Warning, QMessageBox::Yes, |
247 | QMessageBox::No | QMessageBox::Default, | 249 | QMessageBox::No | QMessageBox::Default, |
248 | QMessageBox::NoButton); | 250 | QMessageBox::NoButton); |
249 | if (m_AppKillerBox->exec() == QMessageBox::Yes) { | 251 | if (m_AppKillerBox->exec() == QMessageBox::Yes) { |
250 | // qDebug("Killing the app!!! Bwuhahahaha!"); | 252 | // qDebug("Killing the app!!! Bwuhahahaha!"); |
251 | m_PsProc = new QProcess(QString("ps")); | 253 | m_PsProc = new QProcess(QString("ps")); |
252 | m_PsProc->addArgument("h"); | 254 | m_PsProc->addArgument("h"); |
253 | m_PsProc->addArgument("-C"); | 255 | m_PsProc->addArgument("-C"); |
254 | m_PsProc->addArgument(m_App.exec()); | 256 | m_PsProc->addArgument(m_App.exec()); |
255 | m_PsProc->addArgument("-o"); | 257 | m_PsProc->addArgument("-o"); |
256 | m_PsProc->addArgument("pid"); | 258 | m_PsProc->addArgument("pid"); |
257 | connect(m_PsProc, SIGNAL(processExited()), this, SLOT(psProcFinished())); | 259 | connect(m_PsProc, SIGNAL(processExited()), this, SLOT(psProcFinished())); |
258 | m_PsProc->start(); | 260 | m_PsProc->start(); |
259 | } | 261 | } |
260 | else { | 262 | else { |
261 | // qDebug("Wuss.."); | 263 | // qDebug("Wuss.."); |
262 | // WE DELETE OURSELVES HERE! Don't do anything else!! | 264 | // WE DELETE OURSELVES HERE! Don't do anything else!! |
263 | delete this; | 265 | delete this; |
264 | } | 266 | } |
265 | } | 267 | } |
266 | 268 | ||
267 | void AppMonitor::psProcFinished() { | 269 | void AppMonitor::psProcFinished() { |
268 | QString pid = m_PsProc->readLineStdout(); | 270 | QString pid = m_PsProc->readLineStdout(); |
269 | delete m_PsProc; | 271 | delete m_PsProc; |
270 | m_PsProc = 0L; | 272 | m_PsProc = 0L; |
271 | 273 | ||
272 | // qDebug("Killing app %s", pid.latin1()); | 274 | // qDebug("Killing app %s", pid.latin1()); |
273 | if (pid.isEmpty()) { | 275 | if (pid.isEmpty()) { |
274 | // Hmm.. did the application bail before we got there? | 276 | // Hmm.. did the application bail before we got there? |
275 | qDebug("AppMonitor: Tried to kill application %s but ps couldn't find it.", m_App.exec().latin1()); | 277 | qDebug("AppMonitor: Tried to kill application %s but ps couldn't find it.", m_App.exec().latin1()); |
276 | } | 278 | } |
277 | else { | 279 | else { |
278 | int success = kill(pid.toUInt(), SIGKILL); | 280 | int success = kill(pid.toUInt(), SIGKILL); |
279 | if (success == 0) { | 281 | if (success == 0) { |
280 | m_Owner.removeTask(m_App); | 282 | m_Owner.removeTask(m_App); |
281 | } | 283 | } |
282 | else { | 284 | else { |
283 | qWarning("Could not kill task %s", m_App.exec().latin1()); | 285 | qWarning("Could not kill task %s", m_App.exec().latin1()); |
284 | } | 286 | } |
285 | } | 287 | } |
286 | 288 | ||
287 | // WE DELETE OURSELVES HERE! Don't do anything else!! | 289 | // WE DELETE OURSELVES HERE! Don't do anything else!! |
288 | delete this; | 290 | delete this; |
289 | } | 291 | } |
diff --git a/core/launcher/transferserver.cpp b/core/launcher/transferserver.cpp index d2f5501..dea140d 100644 --- a/core/launcher/transferserver.cpp +++ b/core/launcher/transferserver.cpp | |||
@@ -1,1085 +1,1083 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the 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 | #define _XOPEN_SOURCE | 20 | #define _XOPEN_SOURCE |
21 | #include <pwd.h> | 21 | #include <pwd.h> |
22 | #include <sys/types.h> | 22 | #include <sys/types.h> |
23 | #include <unistd.h> | 23 | #include <unistd.h> |
24 | #include <stdlib.h> | 24 | #include <stdlib.h> |
25 | #include <time.h> | 25 | #include <time.h> |
26 | #include <shadow.h> | 26 | #include <shadow.h> |
27 | 27 | ||
28 | /* we need the _OS_LINUX stuff first ! */ | 28 | /* we need the _OS_LINUX stuff first ! */ |
29 | #include <qglobal.h> | 29 | #include <qglobal.h> |
30 | 30 | ||
31 | #ifndef _OS_LINUX_ | 31 | #ifndef _OS_LINUX_ |
32 | 32 | ||
33 | extern "C" { | 33 | extern "C" { |
34 | #include <uuid/uuid.h> | 34 | #include <uuid/uuid.h> |
35 | #define UUID_H_INCLUDED | 35 | #define UUID_H_INCLUDED |
36 | } | 36 | } |
37 | 37 | ||
38 | #endif // not defined linux | 38 | #endif // not defined linux |
39 | 39 | ||
40 | #if defined(_OS_LINUX_) | 40 | #if defined(_OS_LINUX_) |
41 | #include <shadow.h> | 41 | #include <shadow.h> |
42 | #endif | 42 | #endif |
43 | 43 | ||
44 | #include <qdir.h> | 44 | #include <qdir.h> |
45 | #include <qfile.h> | 45 | #include <qfile.h> |
46 | #include <qtextstream.h> | 46 | #include <qtextstream.h> |
47 | #include <qdatastream.h> | 47 | #include <qdatastream.h> |
48 | #include <qmessagebox.h> | 48 | #include <qmessagebox.h> |
49 | #include <qstringlist.h> | 49 | #include <qstringlist.h> |
50 | #include <qfileinfo.h> | 50 | #include <qfileinfo.h> |
51 | #include <qregexp.h> | 51 | #include <qregexp.h> |
52 | //#include <qpe/qcopchannel_qws.h> | 52 | //#include <qpe/qcopchannel_qws.h> |
53 | #include <qpe/process.h> | 53 | #include <qpe/process.h> |
54 | #include <qpe/global.h> | 54 | #include <qpe/global.h> |
55 | #include <qpe/config.h> | 55 | #include <qpe/config.h> |
56 | #include <qpe/contact.h> | 56 | #include <qpe/contact.h> |
57 | #include <qpe/quuid.h> | 57 | #include <qpe/quuid.h> |
58 | #include <qpe/version.h> | 58 | #include <qpe/version.h> |
59 | #ifdef QWS | ||
60 | #include <qpe/qcopenvelope_qws.h> | 59 | #include <qpe/qcopenvelope_qws.h> |
61 | #endif | ||
62 | 60 | ||
63 | #include "transferserver.h" | 61 | #include "transferserver.h" |
64 | #include "qprocess.h" | 62 | #include "qprocess.h" |
65 | 63 | ||
66 | const int block_size = 51200; | 64 | const int block_size = 51200; |
67 | 65 | ||
68 | TransferServer::TransferServer( Q_UINT16 port, QObject *parent , | 66 | TransferServer::TransferServer( Q_UINT16 port, QObject *parent , |
69 | const char* name ) | 67 | const char* name ) |
70 | : QServerSocket( port, 1, parent, name ) | 68 | : QServerSocket( port, 1, parent, name ) |
71 | { | 69 | { |
72 | if ( !ok() ) | 70 | if ( !ok() ) |
73 | qWarning( "Failed to bind to port %d", port ); | 71 | qWarning( "Failed to bind to port %d", port ); |
74 | } | 72 | } |
75 | 73 | ||
76 | TransferServer::~TransferServer() | 74 | TransferServer::~TransferServer() |
77 | { | 75 | { |
78 | 76 | ||
79 | } | 77 | } |
80 | 78 | ||
81 | void TransferServer::newConnection( int socket ) | 79 | void TransferServer::newConnection( int socket ) |
82 | { | 80 | { |
83 | (void) new ServerPI( socket, this ); | 81 | (void) new ServerPI( socket, this ); |
84 | } | 82 | } |
85 | 83 | ||
86 | /* | 84 | /* |
87 | * small class in anonymous namespace | 85 | * small class in anonymous namespace |
88 | * to generate a QUUid for us | 86 | * to generate a QUUid for us |
89 | */ | 87 | */ |
90 | namespace { | 88 | namespace { |
91 | struct UidGen { | 89 | struct UidGen { |
92 | QString uuid(); | 90 | QString uuid(); |
93 | }; | 91 | }; |
94 | #if !defined(_OS_LINUX_) | 92 | #if !defined(_OS_LINUX_) |
95 | QString UidGen::uuid() { | 93 | QString UidGen::uuid() { |
96 | uuid_t uuid; | 94 | uuid_t uuid; |
97 | uuid_generate( uuid ); | 95 | uuid_generate( uuid ); |
98 | return QUUid( uuid ).toString(); | 96 | return QUUid( uuid ).toString(); |
99 | } | 97 | } |
100 | #else | 98 | #else |
101 | /* | 99 | /* |
102 | * linux got a /proc/sys/kernel/random/uuid file | 100 | * linux got a /proc/sys/kernel/random/uuid file |
103 | * it'll generate the uuids for us | 101 | * it'll generate the uuids for us |
104 | */ | 102 | */ |
105 | QString UidGen::uuid() { | 103 | QString UidGen::uuid() { |
106 | QFile file( "/proc/sys/kernel/random/uuid" ); | 104 | QFile file( "/proc/sys/kernel/random/uuid" ); |
107 | if (!file.open(IO_ReadOnly ) ) | 105 | if (!file.open(IO_ReadOnly ) ) |
108 | return QString::null; | 106 | return QString::null; |
109 | 107 | ||
110 | QTextStream stream(&file); | 108 | QTextStream stream(&file); |
111 | 109 | ||
112 | return "{" + stream.read().stripWhiteSpace() + "}"; | 110 | return "{" + stream.read().stripWhiteSpace() + "}"; |
113 | } | 111 | } |
114 | #endif | 112 | #endif |
115 | } | 113 | } |
116 | 114 | ||
117 | QString SyncAuthentication::serverId() | 115 | QString SyncAuthentication::serverId() |
118 | { | 116 | { |
119 | Config cfg("Security"); | 117 | Config cfg("Security"); |
120 | cfg.setGroup("Sync"); | 118 | cfg.setGroup("Sync"); |
121 | QString r=cfg.readEntry("serverid"); | 119 | QString r=cfg.readEntry("serverid"); |
122 | if ( r.isEmpty() ) { | 120 | if ( r.isEmpty() ) { |
123 | UidGen gen; | 121 | UidGen gen; |
124 | r = gen.uuid(); | 122 | r = gen.uuid(); |
125 | cfg.writeEntry("serverid", r ); | 123 | cfg.writeEntry("serverid", r ); |
126 | } | 124 | } |
127 | return r; | 125 | return r; |
128 | } | 126 | } |
129 | 127 | ||
130 | QString SyncAuthentication::ownerName() | 128 | QString SyncAuthentication::ownerName() |
131 | { | 129 | { |
132 | QString vfilename = Global::applicationFileName("addressbook", | 130 | QString vfilename = Global::applicationFileName("addressbook", |
133 | "businesscard.vcf"); | 131 | "businesscard.vcf"); |
134 | if (QFile::exists(vfilename)) { | 132 | if (QFile::exists(vfilename)) { |
135 | Contact c; | 133 | Contact c; |
136 | c = Contact::readVCard( vfilename )[0]; | 134 | c = Contact::readVCard( vfilename )[0]; |
137 | return c.fullName(); | 135 | return c.fullName(); |
138 | } | 136 | } |
139 | 137 | ||
140 | return ""; | 138 | return ""; |
141 | } | 139 | } |
142 | 140 | ||
143 | QString SyncAuthentication::loginName() | 141 | QString SyncAuthentication::loginName() |
144 | { | 142 | { |
145 | struct passwd *pw; | 143 | struct passwd *pw; |
146 | pw = getpwuid( geteuid() ); | 144 | pw = getpwuid( geteuid() ); |
147 | return QString::fromLocal8Bit( pw->pw_name ); | 145 | return QString::fromLocal8Bit( pw->pw_name ); |
148 | } | 146 | } |
149 | 147 | ||
150 | int SyncAuthentication::isAuthorized(QHostAddress peeraddress) | 148 | int SyncAuthentication::isAuthorized(QHostAddress peeraddress) |
151 | { | 149 | { |
152 | Config cfg("Security"); | 150 | Config cfg("Security"); |
153 | cfg.setGroup("Sync"); | 151 | cfg.setGroup("Sync"); |
154 | // QString allowedstr = cfg.readEntry("auth_peer","192.168.1.0"); | 152 | // QString allowedstr = cfg.readEntry("auth_peer","192.168.1.0"); |
155 | uint auth_peer = cfg.readNumEntry("auth_peer",0xc0a80100); | 153 | uint auth_peer = cfg.readNumEntry("auth_peer",0xc0a80100); |
156 | 154 | ||
157 | // QHostAddress allowed; | 155 | // QHostAddress allowed; |
158 | // allowed.setAddress(allowedstr); | 156 | // allowed.setAddress(allowedstr); |
159 | // uint auth_peer = allowed.ip4Addr(); | 157 | // uint auth_peer = allowed.ip4Addr(); |
160 | uint auth_peer_bits = cfg.readNumEntry("auth_peer_bits",24); | 158 | uint auth_peer_bits = cfg.readNumEntry("auth_peer_bits",24); |
161 | uint mask = auth_peer_bits >= 32 // shifting by 32 is not defined | 159 | uint mask = auth_peer_bits >= 32 // shifting by 32 is not defined |
162 | ? 0xffffffff : (((1<<auth_peer_bits)-1)<<(32-auth_peer_bits)); | 160 | ? 0xffffffff : (((1<<auth_peer_bits)-1)<<(32-auth_peer_bits)); |
163 | return (peeraddress.ip4Addr() & mask) == auth_peer; | 161 | return (peeraddress.ip4Addr() & mask) == auth_peer; |
164 | } | 162 | } |
165 | 163 | ||
166 | bool SyncAuthentication::checkUser( const QString& user ) | 164 | bool SyncAuthentication::checkUser( const QString& user ) |
167 | { | 165 | { |
168 | if ( user.isEmpty() ) return FALSE; | 166 | if ( user.isEmpty() ) return FALSE; |
169 | QString euser = loginName(); | 167 | QString euser = loginName(); |
170 | return user == euser; | 168 | return user == euser; |
171 | } | 169 | } |
172 | 170 | ||
173 | bool SyncAuthentication::checkPassword( const QString& password ) | 171 | bool SyncAuthentication::checkPassword( const QString& password ) |
174 | { | 172 | { |
175 | #ifdef ALLOW_UNIX_USER_FTP | 173 | #ifdef ALLOW_UNIX_USER_FTP |
176 | // First, check system password... | 174 | // First, check system password... |
177 | 175 | ||
178 | struct passwd *pw = 0; | 176 | struct passwd *pw = 0; |
179 | struct spwd *spw = 0; | 177 | struct spwd *spw = 0; |
180 | 178 | ||
181 | pw = getpwuid( geteuid() ); | 179 | pw = getpwuid( geteuid() ); |
182 | spw = getspnam( pw->pw_name ); | 180 | spw = getspnam( pw->pw_name ); |
183 | 181 | ||
184 | QString cpwd = QString::fromLocal8Bit( pw->pw_passwd ); | 182 | QString cpwd = QString::fromLocal8Bit( pw->pw_passwd ); |
185 | if ( cpwd == "x" && spw ) | 183 | if ( cpwd == "x" && spw ) |
186 | cpwd = QString::fromLocal8Bit( spw->sp_pwdp ); | 184 | cpwd = QString::fromLocal8Bit( spw->sp_pwdp ); |
187 | 185 | ||
188 | // Note: some systems use more than crypt for passwords. | 186 | // Note: some systems use more than crypt for passwords. |
189 | QString cpassword = QString::fromLocal8Bit( crypt( password.local8Bit(), cpwd.local8Bit() ) ); | 187 | QString cpassword = QString::fromLocal8Bit( crypt( password.local8Bit(), cpwd.local8Bit() ) ); |
190 | if ( cpwd == cpassword ) | 188 | if ( cpwd == cpassword ) |
191 | return TRUE; | 189 | return TRUE; |
192 | #endif | 190 | #endif |
193 | 191 | ||
194 | static int lastdenial=0; | 192 | static int lastdenial=0; |
195 | static int denials=0; | 193 | static int denials=0; |
196 | int now = time(0); | 194 | int now = time(0); |
197 | 195 | ||
198 | // Detect old Qtopia Desktop (no password) | 196 | // Detect old Qtopia Desktop (no password) |
199 | if ( password.isEmpty() ) { | 197 | if ( password.isEmpty() ) { |
200 | if ( denials < 1 || now > lastdenial+600 ) { | 198 | if ( denials < 1 || now > lastdenial+600 ) { |
201 | QMessageBox::warning( 0,tr("Sync Connection"), | 199 | QMessageBox::warning( 0,tr("Sync Connection"), |
202 | tr("<p>An unauthorized system is requesting access to this device." | 200 | tr("<p>An unauthorized system is requesting access to this device." |
203 | "<p>If you are using a version of Qtopia Desktop older than 1.5.1, " | 201 | "<p>If you are using a version of Qtopia Desktop older than 1.5.1, " |
204 | "please upgrade."), | 202 | "please upgrade."), |
205 | tr("Deny") ); | 203 | tr("Deny") ); |
206 | denials++; | 204 | denials++; |
207 | lastdenial=now; | 205 | lastdenial=now; |
208 | } | 206 | } |
209 | return FALSE; | 207 | return FALSE; |
210 | } | 208 | } |
211 | 209 | ||
212 | // Second, check sync password... | 210 | // Second, check sync password... |
213 | QString pass = password.left(6); | 211 | QString pass = password.left(6); |
214 | /* old QtopiaDesktops are sending | 212 | /* old QtopiaDesktops are sending |
215 | * rootme newer versions got a Qtopia | 213 | * rootme newer versions got a Qtopia |
216 | * prefixed. Qtopia prefix will suceed | 214 | * prefixed. Qtopia prefix will suceed |
217 | * until the sync software syncs up | 215 | * until the sync software syncs up |
218 | * FIXME | 216 | * FIXME |
219 | */ | 217 | */ |
220 | if ( pass == "rootme" || pass == "Qtopia") { | 218 | if ( pass == "rootme" || pass == "Qtopia") { |
221 | 219 | ||
222 | QString cpassword = QString::fromLocal8Bit( crypt( password.mid(8).local8Bit(), "qp" ) ); | 220 | QString cpassword = QString::fromLocal8Bit( crypt( password.mid(8).local8Bit(), "qp" ) ); |
223 | Config cfg("Security"); | 221 | Config cfg("Security"); |
224 | cfg.setGroup("Sync"); | 222 | cfg.setGroup("Sync"); |
225 | QString pwds = cfg.readEntry("Passwords"); | 223 | QString pwds = cfg.readEntry("Passwords"); |
226 | if ( QStringList::split(QChar(' '),pwds).contains(cpassword) ) | 224 | if ( QStringList::split(QChar(' '),pwds).contains(cpassword) ) |
227 | return TRUE; | 225 | return TRUE; |
228 | 226 | ||
229 | // Unrecognized system. Be careful... | 227 | // Unrecognized system. Be careful... |
230 | 228 | ||
231 | if ( (denials > 2 && now < lastdenial+600) | 229 | if ( (denials > 2 && now < lastdenial+600) |
232 | || QMessageBox::warning(0,tr("Sync Connection"), | 230 | || QMessageBox::warning(0,tr("Sync Connection"), |
233 | tr("<p>An unrecognized system is requesting access to this device." | 231 | tr("<p>An unrecognized system is requesting access to this device." |
234 | "<p>If you have just initiated a Sync for the first time, this is normal."), | 232 | "<p>If you have just initiated a Sync for the first time, this is normal."), |
235 | tr("Allow"),tr("Deny"))==1 ) | 233 | tr("Allow"),tr("Deny"))==1 ) |
236 | { | 234 | { |
237 | denials++; | 235 | denials++; |
238 | lastdenial=now; | 236 | lastdenial=now; |
239 | return FALSE; | 237 | return FALSE; |
240 | } else { | 238 | } else { |
241 | denials=0; | 239 | denials=0; |
242 | cfg.writeEntry("Passwords",pwds+" "+cpassword); | 240 | cfg.writeEntry("Passwords",pwds+" "+cpassword); |
243 | return TRUE; | 241 | return TRUE; |
244 | } | 242 | } |
245 | } | 243 | } |
246 | 244 | ||
247 | return FALSE; | 245 | return FALSE; |
248 | } | 246 | } |
249 | 247 | ||
250 | ServerPI::ServerPI( int socket, QObject *parent , const char* name ) | 248 | ServerPI::ServerPI( int socket, QObject *parent , const char* name ) |
251 | : QSocket( parent, name ) , dtp( 0 ), serversocket( 0 ), waitsocket( 0 ) | 249 | : QSocket( parent, name ) , dtp( 0 ), serversocket( 0 ), waitsocket( 0 ) |
252 | { | 250 | { |
253 | state = Connected; | 251 | state = Connected; |
254 | 252 | ||
255 | setSocket( socket ); | 253 | setSocket( socket ); |
256 | 254 | ||
257 | peerport = peerPort(); | 255 | peerport = peerPort(); |
258 | peeraddress = peerAddress(); | 256 | peeraddress = peerAddress(); |
259 | 257 | ||
260 | #ifndef INSECURE | 258 | #ifndef INSECURE |
261 | if ( !SyncAuthentication::isAuthorized(peeraddress) ) { | 259 | if ( !SyncAuthentication::isAuthorized(peeraddress) ) { |
262 | state = Forbidden; | 260 | state = Forbidden; |
263 | startTimer( 0 ); | 261 | startTimer( 0 ); |
264 | } else | 262 | } else |
265 | #endif | 263 | #endif |
266 | { | 264 | { |
267 | connect( this, SIGNAL( readyRead() ), SLOT( read() ) ); | 265 | connect( this, SIGNAL( readyRead() ), SLOT( read() ) ); |
268 | connect( this, SIGNAL( connectionClosed() ), SLOT( connectionClosed() ) ); | 266 | connect( this, SIGNAL( connectionClosed() ), SLOT( connectionClosed() ) ); |
269 | 267 | ||
270 | passiv = FALSE; | 268 | passiv = FALSE; |
271 | for( int i = 0; i < 4; i++ ) | 269 | for( int i = 0; i < 4; i++ ) |
272 | wait[i] = FALSE; | 270 | wait[i] = FALSE; |
273 | 271 | ||
274 | send( "220 Qtopia " QPE_VERSION " FTP Server" ); | 272 | send( "220 Qtopia " QPE_VERSION " FTP Server" ); |
275 | state = Wait_USER; | 273 | state = Wait_USER; |
276 | 274 | ||
277 | dtp = new ServerDTP( this ); | 275 | dtp = new ServerDTP( this ); |
278 | connect( dtp, SIGNAL( completed() ), SLOT( dtpCompleted() ) ); | 276 | connect( dtp, SIGNAL( completed() ), SLOT( dtpCompleted() ) ); |
279 | connect( dtp, SIGNAL( failed() ), SLOT( dtpFailed() ) ); | 277 | connect( dtp, SIGNAL( failed() ), SLOT( dtpFailed() ) ); |
280 | connect( dtp, SIGNAL( error( int ) ), SLOT( dtpError( int ) ) ); | 278 | connect( dtp, SIGNAL( error( int ) ), SLOT( dtpError( int ) ) ); |
281 | 279 | ||
282 | 280 | ||
283 | directory = QDir::currentDirPath(); | 281 | directory = QDir::currentDirPath(); |
284 | 282 | ||
285 | static int p = 1024; | 283 | static int p = 1024; |
286 | 284 | ||
287 | while ( !serversocket || !serversocket->ok() ) { | 285 | while ( !serversocket || !serversocket->ok() ) { |
288 | delete serversocket; | 286 | delete serversocket; |
289 | serversocket = new ServerSocket( ++p, this ); | 287 | serversocket = new ServerSocket( ++p, this ); |
290 | } | 288 | } |
291 | connect( serversocket, SIGNAL( newIncomming( int ) ), | 289 | connect( serversocket, SIGNAL( newIncomming( int ) ), |
292 | SLOT( newConnection( int ) ) ); | 290 | SLOT( newConnection( int ) ) ); |
293 | } | 291 | } |
294 | } | 292 | } |
295 | 293 | ||
296 | ServerPI::~ServerPI() | 294 | ServerPI::~ServerPI() |
297 | { | 295 | { |
298 | 296 | ||
299 | } | 297 | } |
300 | 298 | ||
301 | void ServerPI::connectionClosed() | 299 | void ServerPI::connectionClosed() |
302 | { | 300 | { |
303 | // qDebug( "Debug: Connection closed" ); | 301 | // qDebug( "Debug: Connection closed" ); |
304 | delete this; | 302 | delete this; |
305 | } | 303 | } |
306 | 304 | ||
307 | void ServerPI::send( const QString& msg ) | 305 | void ServerPI::send( const QString& msg ) |
308 | { | 306 | { |
309 | QTextStream os( this ); | 307 | QTextStream os( this ); |
310 | os << msg << endl; | 308 | os << msg << endl; |
311 | //qDebug( "Reply: %s", msg.latin1() ); | 309 | //qDebug( "Reply: %s", msg.latin1() ); |
312 | } | 310 | } |
313 | 311 | ||
314 | void ServerPI::read() | 312 | void ServerPI::read() |
315 | { | 313 | { |
316 | while ( canReadLine() ) | 314 | while ( canReadLine() ) |
317 | process( readLine().stripWhiteSpace() ); | 315 | process( readLine().stripWhiteSpace() ); |
318 | } | 316 | } |
319 | 317 | ||
320 | bool ServerPI::checkReadFile( const QString& file ) | 318 | bool ServerPI::checkReadFile( const QString& file ) |
321 | { | 319 | { |
322 | QString filename; | 320 | QString filename; |
323 | 321 | ||
324 | if ( file[0] != "/" ) | 322 | if ( file[0] != "/" ) |
325 | filename = directory.path() + "/" + file; | 323 | filename = directory.path() + "/" + file; |
326 | else | 324 | else |
327 | filename = file; | 325 | filename = file; |
328 | 326 | ||
329 | QFileInfo fi( filename ); | 327 | QFileInfo fi( filename ); |
330 | return ( fi.exists() && fi.isReadable() ); | 328 | return ( fi.exists() && fi.isReadable() ); |
331 | } | 329 | } |
332 | 330 | ||
333 | bool ServerPI::checkWriteFile( const QString& file ) | 331 | bool ServerPI::checkWriteFile( const QString& file ) |
334 | { | 332 | { |
335 | QString filename; | 333 | QString filename; |
336 | 334 | ||
337 | if ( file[0] != "/" ) | 335 | if ( file[0] != "/" ) |
338 | filename = directory.path() + "/" + file; | 336 | filename = directory.path() + "/" + file; |
339 | else | 337 | else |
340 | filename = file; | 338 | filename = file; |
341 | 339 | ||
342 | QFileInfo fi( filename ); | 340 | QFileInfo fi( filename ); |
343 | 341 | ||
344 | if ( fi.exists() ) | 342 | if ( fi.exists() ) |
345 | if ( !QFile( filename ).remove() ) | 343 | if ( !QFile( filename ).remove() ) |
346 | return FALSE; | 344 | return FALSE; |
347 | return TRUE; | 345 | return TRUE; |
348 | } | 346 | } |
349 | 347 | ||
350 | void ServerPI::process( const QString& message ) | 348 | void ServerPI::process( const QString& message ) |
351 | { | 349 | { |
352 | //qDebug( "Command: %s", message.latin1() ); | 350 | //qDebug( "Command: %s", message.latin1() ); |
353 | 351 | ||
354 | // split message using "," as separator | 352 | // split message using "," as separator |
355 | QStringList msg = QStringList::split( " ", message ); | 353 | QStringList msg = QStringList::split( " ", message ); |
356 | if ( msg.isEmpty() ) return; | 354 | if ( msg.isEmpty() ) return; |
357 | 355 | ||
358 | // command token | 356 | // command token |
359 | QString cmd = msg[0].upper(); | 357 | QString cmd = msg[0].upper(); |
360 | 358 | ||
361 | // argument token | 359 | // argument token |
362 | QString arg; | 360 | QString arg; |
363 | if ( msg.count() >= 2 ) | 361 | if ( msg.count() >= 2 ) |
364 | arg = msg[1]; | 362 | arg = msg[1]; |
365 | 363 | ||
366 | // full argument string | 364 | // full argument string |
367 | QString args; | 365 | QString args; |
368 | if ( msg.count() >= 2 ) { | 366 | if ( msg.count() >= 2 ) { |
369 | QStringList copy( msg ); | 367 | QStringList copy( msg ); |
370 | // FIXME: for Qt3 | 368 | // FIXME: for Qt3 |
371 | // copy.pop_front() | 369 | // copy.pop_front() |
372 | copy.remove( copy.begin() ); | 370 | copy.remove( copy.begin() ); |
373 | args = copy.join( " " ); | 371 | args = copy.join( " " ); |
374 | } | 372 | } |
375 | 373 | ||
376 | //qDebug( "args: %s", args.latin1() ); | 374 | //qDebug( "args: %s", args.latin1() ); |
377 | 375 | ||
378 | // we always respond to QUIT, regardless of state | 376 | // we always respond to QUIT, regardless of state |
379 | if ( cmd == "QUIT" ) { | 377 | if ( cmd == "QUIT" ) { |
380 | send( "211 Good bye!" ); | 378 | send( "211 Good bye!" ); |
381 | delete this; | 379 | delete this; |
382 | return; | 380 | return; |
383 | } | 381 | } |
384 | 382 | ||
385 | // connected to client | 383 | // connected to client |
386 | if ( Connected == state ) | 384 | if ( Connected == state ) |
387 | return; | 385 | return; |
388 | 386 | ||
389 | // waiting for user name | 387 | // waiting for user name |
390 | if ( Wait_USER == state ) { | 388 | if ( Wait_USER == state ) { |
391 | 389 | ||
392 | if ( cmd != "USER" || msg.count() < 2 || !SyncAuthentication::checkUser( arg ) ) { | 390 | if ( cmd != "USER" || msg.count() < 2 || !SyncAuthentication::checkUser( arg ) ) { |
393 | send( "530 Please login with USER and PASS" ); | 391 | send( "530 Please login with USER and PASS" ); |
394 | return; | 392 | return; |
395 | } | 393 | } |
396 | send( "331 User name ok, need password" ); | 394 | send( "331 User name ok, need password" ); |
397 | state = Wait_PASS; | 395 | state = Wait_PASS; |
398 | return; | 396 | return; |
399 | } | 397 | } |
400 | 398 | ||
401 | // waiting for password | 399 | // waiting for password |
402 | if ( Wait_PASS == state ) { | 400 | if ( Wait_PASS == state ) { |
403 | 401 | ||
404 | if ( cmd != "PASS" || !SyncAuthentication::checkPassword( arg ) ) { | 402 | if ( cmd != "PASS" || !SyncAuthentication::checkPassword( arg ) ) { |
405 | send( "530 Please login with USER and PASS" ); | 403 | send( "530 Please login with USER and PASS" ); |
406 | return; | 404 | return; |
407 | } | 405 | } |
408 | send( "230 User logged in, proceed" ); | 406 | send( "230 User logged in, proceed" ); |
409 | state = Ready; | 407 | state = Ready; |
410 | return; | 408 | return; |
411 | } | 409 | } |
412 | 410 | ||
413 | // ACCESS CONTROL COMMANDS | 411 | // ACCESS CONTROL COMMANDS |
414 | 412 | ||
415 | 413 | ||
416 | // account (ACCT) | 414 | // account (ACCT) |
417 | if ( cmd == "ACCT" ) { | 415 | if ( cmd == "ACCT" ) { |
418 | // even wu-ftp does not support it | 416 | // even wu-ftp does not support it |
419 | send( "502 Command not implemented" ); | 417 | send( "502 Command not implemented" ); |
420 | } | 418 | } |
421 | 419 | ||
422 | // change working directory (CWD) | 420 | // change working directory (CWD) |
423 | else if ( cmd == "CWD" ) { | 421 | else if ( cmd == "CWD" ) { |
424 | 422 | ||
425 | if ( !args.isEmpty() ) { | 423 | if ( !args.isEmpty() ) { |
426 | if ( directory.cd( args, TRUE ) ) | 424 | if ( directory.cd( args, TRUE ) ) |
427 | send( "250 Requested file action okay, completed" ); | 425 | send( "250 Requested file action okay, completed" ); |
428 | else | 426 | else |
429 | send( "550 Requested action not taken" ); | 427 | send( "550 Requested action not taken" ); |
430 | } | 428 | } |
431 | else | 429 | else |
432 | send( "500 Syntax error, command unrecognized" ); | 430 | send( "500 Syntax error, command unrecognized" ); |
433 | } | 431 | } |
434 | 432 | ||
435 | // change to parent directory (CDUP) | 433 | // change to parent directory (CDUP) |
436 | else if ( cmd == "CDUP" ) { | 434 | else if ( cmd == "CDUP" ) { |
437 | if ( directory.cdUp() ) | 435 | if ( directory.cdUp() ) |
438 | send( "250 Requested file action okay, completed" ); | 436 | send( "250 Requested file action okay, completed" ); |
439 | else | 437 | else |
440 | send( "550 Requested action not taken" ); | 438 | send( "550 Requested action not taken" ); |
441 | } | 439 | } |
442 | 440 | ||
443 | // structure mount (SMNT) | 441 | // structure mount (SMNT) |
444 | else if ( cmd == "SMNT" ) { | 442 | else if ( cmd == "SMNT" ) { |
445 | // even wu-ftp does not support it | 443 | // even wu-ftp does not support it |
446 | send( "502 Command not implemented" ); | 444 | send( "502 Command not implemented" ); |
447 | } | 445 | } |
448 | 446 | ||
449 | // reinitialize (REIN) | 447 | // reinitialize (REIN) |
450 | else if ( cmd == "REIN" ) { | 448 | else if ( cmd == "REIN" ) { |
451 | // even wu-ftp does not support it | 449 | // even wu-ftp does not support it |
452 | send( "502 Command not implemented" ); | 450 | send( "502 Command not implemented" ); |
453 | } | 451 | } |
454 | 452 | ||
455 | 453 | ||
456 | // TRANSFER PARAMETER COMMANDS | 454 | // TRANSFER PARAMETER COMMANDS |
457 | 455 | ||
458 | 456 | ||
459 | // data port (PORT) | 457 | // data port (PORT) |
460 | else if ( cmd == "PORT" ) { | 458 | else if ( cmd == "PORT" ) { |
461 | if ( parsePort( arg ) ) | 459 | if ( parsePort( arg ) ) |
462 | send( "200 Command okay" ); | 460 | send( "200 Command okay" ); |
463 | else | 461 | else |
464 | send( "500 Syntax error, command unrecognized" ); | 462 | send( "500 Syntax error, command unrecognized" ); |
465 | } | 463 | } |
466 | 464 | ||
467 | // passive (PASV) | 465 | // passive (PASV) |
468 | else if ( cmd == "PASV" ) { | 466 | else if ( cmd == "PASV" ) { |
469 | passiv = TRUE; | 467 | passiv = TRUE; |
470 | send( "227 Entering Passive Mode (" | 468 | send( "227 Entering Passive Mode (" |
471 | + address().toString().replace( QRegExp( "\\." ), "," ) + "," | 469 | + address().toString().replace( QRegExp( "\\." ), "," ) + "," |
472 | + QString::number( ( serversocket->port() ) >> 8 ) + "," | 470 | + QString::number( ( serversocket->port() ) >> 8 ) + "," |
473 | + QString::number( ( serversocket->port() ) & 0xFF ) +")" ); | 471 | + QString::number( ( serversocket->port() ) & 0xFF ) +")" ); |
474 | } | 472 | } |
475 | 473 | ||
476 | // representation type (TYPE) | 474 | // representation type (TYPE) |
477 | else if ( cmd == "TYPE" ) { | 475 | else if ( cmd == "TYPE" ) { |
478 | if ( arg.upper() == "A" || arg.upper() == "I" ) | 476 | if ( arg.upper() == "A" || arg.upper() == "I" ) |
479 | send( "200 Command okay" ); | 477 | send( "200 Command okay" ); |
480 | else | 478 | else |
481 | send( "504 Command not implemented for that parameter" ); | 479 | send( "504 Command not implemented for that parameter" ); |
482 | } | 480 | } |
483 | 481 | ||
484 | // file structure (STRU) | 482 | // file structure (STRU) |
485 | else if ( cmd == "STRU" ) { | 483 | else if ( cmd == "STRU" ) { |
486 | if ( arg.upper() == "F" ) | 484 | if ( arg.upper() == "F" ) |
487 | send( "200 Command okay" ); | 485 | send( "200 Command okay" ); |
488 | else | 486 | else |
489 | send( "504 Command not implemented for that parameter" ); | 487 | send( "504 Command not implemented for that parameter" ); |
490 | } | 488 | } |
491 | 489 | ||
492 | // transfer mode (MODE) | 490 | // transfer mode (MODE) |
493 | else if ( cmd == "MODE" ) { | 491 | else if ( cmd == "MODE" ) { |
494 | if ( arg.upper() == "S" ) | 492 | if ( arg.upper() == "S" ) |
495 | send( "200 Command okay" ); | 493 | send( "200 Command okay" ); |
496 | else | 494 | else |
497 | send( "504 Command not implemented for that parameter" ); | 495 | send( "504 Command not implemented for that parameter" ); |
498 | } | 496 | } |
499 | 497 | ||
500 | 498 | ||
501 | // FTP SERVICE COMMANDS | 499 | // FTP SERVICE COMMANDS |
502 | 500 | ||
503 | 501 | ||
504 | // retrieve (RETR) | 502 | // retrieve (RETR) |
505 | else if ( cmd == "RETR" ) | 503 | else if ( cmd == "RETR" ) |
506 | if ( !args.isEmpty() && checkReadFile( absFilePath( args ) ) | 504 | if ( !args.isEmpty() && checkReadFile( absFilePath( args ) ) |
507 | || backupRestoreGzip( absFilePath( args ) ) ) { | 505 | || backupRestoreGzip( absFilePath( args ) ) ) { |
508 | send( "150 File status okay" ); | 506 | send( "150 File status okay" ); |
509 | sendFile( absFilePath( args ) ); | 507 | sendFile( absFilePath( args ) ); |
510 | } | 508 | } |
511 | else { | 509 | else { |
512 | qDebug("550 Requested action not taken"); | 510 | qDebug("550 Requested action not taken"); |
513 | send( "550 Requested action not taken" ); | 511 | send( "550 Requested action not taken" ); |
514 | } | 512 | } |
515 | 513 | ||
516 | // store (STOR) | 514 | // store (STOR) |
517 | else if ( cmd == "STOR" ) | 515 | else if ( cmd == "STOR" ) |
518 | if ( !args.isEmpty() && checkWriteFile( absFilePath( args ) ) ) { | 516 | if ( !args.isEmpty() && checkWriteFile( absFilePath( args ) ) ) { |
519 | send( "150 File status okay" ); | 517 | send( "150 File status okay" ); |
520 | retrieveFile( absFilePath( args ) ); | 518 | retrieveFile( absFilePath( args ) ); |
521 | } | 519 | } |
522 | else | 520 | else |
523 | send( "550 Requested action not taken" ); | 521 | send( "550 Requested action not taken" ); |
524 | 522 | ||
525 | // store unique (STOU) | 523 | // store unique (STOU) |
526 | else if ( cmd == "STOU" ) { | 524 | else if ( cmd == "STOU" ) { |
527 | send( "502 Command not implemented" ); | 525 | send( "502 Command not implemented" ); |
528 | } | 526 | } |
529 | 527 | ||
530 | // append (APPE) | 528 | // append (APPE) |
531 | else if ( cmd == "APPE" ) { | 529 | else if ( cmd == "APPE" ) { |
532 | send( "502 Command not implemented" ); | 530 | send( "502 Command not implemented" ); |
533 | } | 531 | } |
534 | 532 | ||
535 | // allocate (ALLO) | 533 | // allocate (ALLO) |
536 | else if ( cmd == "ALLO" ) { | 534 | else if ( cmd == "ALLO" ) { |
537 | send( "200 Command okay" ); | 535 | send( "200 Command okay" ); |
538 | } | 536 | } |
539 | 537 | ||
540 | // restart (REST) | 538 | // restart (REST) |
541 | else if ( cmd == "REST" ) { | 539 | else if ( cmd == "REST" ) { |
542 | send( "502 Command not implemented" ); | 540 | send( "502 Command not implemented" ); |
543 | } | 541 | } |
544 | 542 | ||
545 | // rename from (RNFR) | 543 | // rename from (RNFR) |
546 | else if ( cmd == "RNFR" ) { | 544 | else if ( cmd == "RNFR" ) { |
547 | renameFrom = QString::null; | 545 | renameFrom = QString::null; |
548 | if ( args.isEmpty() ) | 546 | if ( args.isEmpty() ) |
549 | send( "500 Syntax error, command unrecognized" ); | 547 | send( "500 Syntax error, command unrecognized" ); |
550 | else { | 548 | else { |
551 | QFile file( absFilePath( args ) ); | 549 | QFile file( absFilePath( args ) ); |
552 | if ( file.exists() ) { | 550 | if ( file.exists() ) { |
553 | send( "350 File exists, ready for destination name" ); | 551 | send( "350 File exists, ready for destination name" ); |
554 | renameFrom = absFilePath( args ); | 552 | renameFrom = absFilePath( args ); |
555 | } | 553 | } |
556 | else | 554 | else |
557 | send( "550 Requested action not taken" ); | 555 | send( "550 Requested action not taken" ); |
558 | } | 556 | } |
559 | } | 557 | } |
560 | 558 | ||
561 | // rename to (RNTO) | 559 | // rename to (RNTO) |
562 | else if ( cmd == "RNTO" ) { | 560 | else if ( cmd == "RNTO" ) { |
563 | if ( lastCommand != "RNFR" ) | 561 | if ( lastCommand != "RNFR" ) |
564 | send( "503 Bad sequence of commands" ); | 562 | send( "503 Bad sequence of commands" ); |
565 | else if ( args.isEmpty() ) | 563 | else if ( args.isEmpty() ) |
566 | send( "500 Syntax error, command unrecognized" ); | 564 | send( "500 Syntax error, command unrecognized" ); |
567 | else { | 565 | else { |
568 | QDir dir( absFilePath( args ) ); | 566 | QDir dir( absFilePath( args ) ); |
569 | if ( dir.rename( renameFrom, absFilePath( args ), TRUE ) ) | 567 | if ( dir.rename( renameFrom, absFilePath( args ), TRUE ) ) |
570 | send( "250 Requested file action okay, completed." ); | 568 | send( "250 Requested file action okay, completed." ); |
571 | else | 569 | else |
572 | send( "550 Requested action not taken" ); | 570 | send( "550 Requested action not taken" ); |
573 | } | 571 | } |
574 | } | 572 | } |
575 | 573 | ||
576 | // abort (ABOR) | 574 | // abort (ABOR) |
577 | else if ( cmd.contains( "ABOR" ) ) { | 575 | else if ( cmd.contains( "ABOR" ) ) { |
578 | dtp->close(); | 576 | dtp->close(); |
579 | if ( dtp->dtpMode() != ServerDTP::Idle ) | 577 | if ( dtp->dtpMode() != ServerDTP::Idle ) |
580 | send( "426 Connection closed; transfer aborted" ); | 578 | send( "426 Connection closed; transfer aborted" ); |
581 | else | 579 | else |
582 | send( "226 Closing data connection" ); | 580 | send( "226 Closing data connection" ); |
583 | } | 581 | } |
584 | 582 | ||
585 | // delete (DELE) | 583 | // delete (DELE) |
586 | else if ( cmd == "DELE" ) { | 584 | else if ( cmd == "DELE" ) { |
587 | if ( args.isEmpty() ) | 585 | if ( args.isEmpty() ) |
588 | send( "500 Syntax error, command unrecognized" ); | 586 | send( "500 Syntax error, command unrecognized" ); |
589 | else { | 587 | else { |
590 | QFile file( absFilePath( args ) ) ; | 588 | QFile file( absFilePath( args ) ) ; |
591 | if ( file.remove() ) { | 589 | if ( file.remove() ) { |
592 | send( "250 Requested file action okay, completed" ); | 590 | send( "250 Requested file action okay, completed" ); |
593 | QCopEnvelope e("QPE/System", "linkChanged(QString)" ); | 591 | QCopEnvelope e("QPE/System", "linkChanged(QString)" ); |
594 | e << file.name(); | 592 | e << file.name(); |
595 | } else { | 593 | } else { |
596 | send( "550 Requested action not taken" ); | 594 | send( "550 Requested action not taken" ); |
597 | } | 595 | } |
598 | } | 596 | } |
599 | } | 597 | } |
600 | 598 | ||
601 | // remove directory (RMD) | 599 | // remove directory (RMD) |
602 | else if ( cmd == "RMD" ) { | 600 | else if ( cmd == "RMD" ) { |
603 | if ( args.isEmpty() ) | 601 | if ( args.isEmpty() ) |
604 | send( "500 Syntax error, command unrecognized" ); | 602 | send( "500 Syntax error, command unrecognized" ); |
605 | else { | 603 | else { |
606 | QDir dir; | 604 | QDir dir; |
607 | if ( dir.rmdir( absFilePath( args ), TRUE ) ) | 605 | if ( dir.rmdir( absFilePath( args ), TRUE ) ) |
608 | send( "250 Requested file action okay, completed" ); | 606 | send( "250 Requested file action okay, completed" ); |
609 | else | 607 | else |
610 | send( "550 Requested action not taken" ); | 608 | send( "550 Requested action not taken" ); |
611 | } | 609 | } |
612 | } | 610 | } |
613 | 611 | ||
614 | // make directory (MKD) | 612 | // make directory (MKD) |
615 | else if ( cmd == "MKD" ) { | 613 | else if ( cmd == "MKD" ) { |
616 | if ( args.isEmpty() ) { | 614 | if ( args.isEmpty() ) { |
617 | qDebug(" Error: no arg"); | 615 | qDebug(" Error: no arg"); |
618 | send( "500 Syntax error, command unrecognized" ); | 616 | send( "500 Syntax error, command unrecognized" ); |
619 | } | 617 | } |
620 | else { | 618 | else { |
621 | QDir dir; | 619 | QDir dir; |
622 | if ( dir.mkdir( absFilePath( args ), TRUE ) ) | 620 | if ( dir.mkdir( absFilePath( args ), TRUE ) ) |
623 | send( "250 Requested file action okay, completed." ); | 621 | send( "250 Requested file action okay, completed." ); |
624 | else | 622 | else |
625 | send( "550 Requested action not taken" ); | 623 | send( "550 Requested action not taken" ); |
626 | } | 624 | } |
627 | } | 625 | } |
628 | 626 | ||
629 | // print working directory (PWD) | 627 | // print working directory (PWD) |
630 | else if ( cmd == "PWD" ) { | 628 | else if ( cmd == "PWD" ) { |
631 | send( "257 \"" + directory.path() +"\"" ); | 629 | send( "257 \"" + directory.path() +"\"" ); |
632 | } | 630 | } |
633 | 631 | ||
634 | // list (LIST) | 632 | // list (LIST) |
635 | else if ( cmd == "LIST" ) { | 633 | else if ( cmd == "LIST" ) { |
636 | if ( sendList( absFilePath( args ) ) ) | 634 | if ( sendList( absFilePath( args ) ) ) |
637 | send( "150 File status okay" ); | 635 | send( "150 File status okay" ); |
638 | else | 636 | else |
639 | send( "500 Syntax error, command unrecognized" ); | 637 | send( "500 Syntax error, command unrecognized" ); |
640 | } | 638 | } |
641 | 639 | ||
642 | // size (SIZE) | 640 | // size (SIZE) |
643 | else if ( cmd == "SIZE" ) { | 641 | else if ( cmd == "SIZE" ) { |
644 | QString filePath = absFilePath( args ); | 642 | QString filePath = absFilePath( args ); |
645 | QFileInfo fi( filePath ); | 643 | QFileInfo fi( filePath ); |
646 | bool gzipfile = backupRestoreGzip( filePath ); | 644 | bool gzipfile = backupRestoreGzip( filePath ); |
647 | if ( !fi.exists() && !gzipfile ) | 645 | if ( !fi.exists() && !gzipfile ) |
648 | send( "500 Syntax error, command unrecognized" ); | 646 | send( "500 Syntax error, command unrecognized" ); |
649 | else { | 647 | else { |
650 | if ( !gzipfile ) | 648 | if ( !gzipfile ) |
651 | send( "213 " + QString::number( fi.size() ) ); | 649 | send( "213 " + QString::number( fi.size() ) ); |
652 | else { | 650 | else { |
653 | Process duproc( QString("du") ); | 651 | Process duproc( QString("du") ); |
654 | duproc.addArgument("-s"); | 652 | duproc.addArgument("-s"); |
655 | QString in, out; | 653 | QString in, out; |
656 | if ( !duproc.exec(in, out) ) { | 654 | if ( !duproc.exec(in, out) ) { |
657 | qDebug("du process failed; just sending back 1K"); | 655 | qDebug("du process failed; just sending back 1K"); |
658 | send( "213 1024"); | 656 | send( "213 1024"); |
659 | } | 657 | } |
660 | else { | 658 | else { |
661 | QString size = out.left( out.find("\t") ); | 659 | QString size = out.left( out.find("\t") ); |
662 | int guess = size.toInt()/5; | 660 | int guess = size.toInt()/5; |
663 | if ( filePath.contains("doc") ) | 661 | if ( filePath.contains("doc") ) |
664 | guess *= 1000; | 662 | guess *= 1000; |
665 | qDebug("sending back gzip guess of %d", guess); | 663 | qDebug("sending back gzip guess of %d", guess); |
666 | send( "213 " + QString::number(guess) ); | 664 | send( "213 " + QString::number(guess) ); |
667 | } | 665 | } |
668 | } | 666 | } |
669 | } | 667 | } |
670 | } | 668 | } |
671 | // name list (NLST) | 669 | // name list (NLST) |
672 | else if ( cmd == "NLST" ) { | 670 | else if ( cmd == "NLST" ) { |
673 | send( "502 Command not implemented" ); | 671 | send( "502 Command not implemented" ); |
674 | } | 672 | } |
675 | 673 | ||
676 | // site parameters (SITE) | 674 | // site parameters (SITE) |
677 | else if ( cmd == "SITE" ) { | 675 | else if ( cmd == "SITE" ) { |
678 | send( "502 Command not implemented" ); | 676 | send( "502 Command not implemented" ); |
679 | } | 677 | } |
680 | 678 | ||
681 | // system (SYST) | 679 | // system (SYST) |
682 | else if ( cmd == "SYST" ) { | 680 | else if ( cmd == "SYST" ) { |
683 | send( "215 UNIX Type: L8" ); | 681 | send( "215 UNIX Type: L8" ); |
684 | } | 682 | } |
685 | 683 | ||
686 | // status (STAT) | 684 | // status (STAT) |
687 | else if ( cmd == "STAT" ) { | 685 | else if ( cmd == "STAT" ) { |
688 | send( "502 Command not implemented" ); | 686 | send( "502 Command not implemented" ); |
689 | } | 687 | } |
690 | 688 | ||
691 | // help (HELP ) | 689 | // help (HELP ) |
692 | else if ( cmd == "HELP" ) { | 690 | else if ( cmd == "HELP" ) { |
693 | send( "502 Command not implemented" ); | 691 | send( "502 Command not implemented" ); |
694 | } | 692 | } |
695 | 693 | ||
696 | // noop (NOOP) | 694 | // noop (NOOP) |
697 | else if ( cmd == "NOOP" ) { | 695 | else if ( cmd == "NOOP" ) { |
698 | send( "200 Command okay" ); | 696 | send( "200 Command okay" ); |
699 | } | 697 | } |
700 | 698 | ||
701 | // not implemented | 699 | // not implemented |
702 | else | 700 | else |
703 | send( "502 Command not implemented" ); | 701 | send( "502 Command not implemented" ); |
704 | 702 | ||
705 | lastCommand = cmd; | 703 | lastCommand = cmd; |
706 | } | 704 | } |
707 | 705 | ||
708 | bool ServerPI::backupRestoreGzip( const QString &file ) | 706 | bool ServerPI::backupRestoreGzip( const QString &file ) |
709 | { | 707 | { |
710 | return (file.find( "backup" ) != -1 && | 708 | return (file.find( "backup" ) != -1 && |
711 | file.findRev( ".tgz" ) == (int)file.length()-4 ); | 709 | file.findRev( ".tgz" ) == (int)file.length()-4 ); |
712 | } | 710 | } |
713 | 711 | ||
714 | bool ServerPI::backupRestoreGzip( const QString &file, QStringList &targets ) | 712 | bool ServerPI::backupRestoreGzip( const QString &file, QStringList &targets ) |
715 | { | 713 | { |
716 | if ( file.find( "backup" ) != -1 && | 714 | if ( file.find( "backup" ) != -1 && |
717 | file.findRev( ".tgz" ) == (int)file.length()-4 ) { | 715 | file.findRev( ".tgz" ) == (int)file.length()-4 ) { |
718 | QFileInfo info( file ); | 716 | QFileInfo info( file ); |
719 | targets = info.dirPath( TRUE ); | 717 | targets = info.dirPath( TRUE ); |
720 | qDebug("ServerPI::backupRestoreGzip for %s = %s", file.latin1(), | 718 | qDebug("ServerPI::backupRestoreGzip for %s = %s", file.latin1(), |
721 | targets.join(" ").latin1() ); | 719 | targets.join(" ").latin1() ); |
722 | return true; | 720 | return true; |
723 | } | 721 | } |
724 | return false; | 722 | return false; |
725 | } | 723 | } |
726 | 724 | ||
727 | void ServerPI::sendFile( const QString& file ) | 725 | void ServerPI::sendFile( const QString& file ) |
728 | { | 726 | { |
729 | if ( passiv ) { | 727 | if ( passiv ) { |
730 | wait[SendFile] = TRUE; | 728 | wait[SendFile] = TRUE; |
731 | waitfile = file; | 729 | waitfile = file; |
732 | if ( waitsocket ) | 730 | if ( waitsocket ) |
733 | newConnection( waitsocket ); | 731 | newConnection( waitsocket ); |
734 | } | 732 | } |
735 | else { | 733 | else { |
736 | QStringList targets; | 734 | QStringList targets; |
737 | if ( backupRestoreGzip( file, targets ) ) | 735 | if ( backupRestoreGzip( file, targets ) ) |
738 | dtp->sendGzipFile( file, targets, peeraddress, peerport ); | 736 | dtp->sendGzipFile( file, targets, peeraddress, peerport ); |
739 | else dtp->sendFile( file, peeraddress, peerport ); | 737 | else dtp->sendFile( file, peeraddress, peerport ); |
740 | } | 738 | } |
741 | } | 739 | } |
742 | 740 | ||
743 | void ServerPI::retrieveFile( const QString& file ) | 741 | void ServerPI::retrieveFile( const QString& file ) |
744 | { | 742 | { |
745 | if ( passiv ) { | 743 | if ( passiv ) { |
746 | wait[RetrieveFile] = TRUE; | 744 | wait[RetrieveFile] = TRUE; |
747 | waitfile = file; | 745 | waitfile = file; |
748 | if ( waitsocket ) | 746 | if ( waitsocket ) |
749 | newConnection( waitsocket ); | 747 | newConnection( waitsocket ); |
750 | } | 748 | } |
751 | else { | 749 | else { |
752 | QStringList targets; | 750 | QStringList targets; |
753 | if ( backupRestoreGzip( file, targets ) ) | 751 | if ( backupRestoreGzip( file, targets ) ) |
754 | dtp->retrieveGzipFile( file, peeraddress, peerport ); | 752 | dtp->retrieveGzipFile( file, peeraddress, peerport ); |
755 | else | 753 | else |
756 | dtp->retrieveFile( file, peeraddress, peerport ); | 754 | dtp->retrieveFile( file, peeraddress, peerport ); |
757 | } | 755 | } |
758 | } | 756 | } |
759 | 757 | ||
760 | bool ServerPI::parsePort( const QString& pp ) | 758 | bool ServerPI::parsePort( const QString& pp ) |
761 | { | 759 | { |
762 | QStringList p = QStringList::split( ",", pp ); | 760 | QStringList p = QStringList::split( ",", pp ); |
763 | if ( p.count() != 6 ) return FALSE; | 761 | if ( p.count() != 6 ) return FALSE; |
764 | 762 | ||
765 | // h1,h2,h3,h4,p1,p2 | 763 | // h1,h2,h3,h4,p1,p2 |
766 | peeraddress = QHostAddress( ( p[0].toInt() << 24 ) + ( p[1].toInt() << 16 ) + | 764 | peeraddress = QHostAddress( ( p[0].toInt() << 24 ) + ( p[1].toInt() << 16 ) + |
767 | ( p[2].toInt() << 8 ) + p[3].toInt() ); | 765 | ( p[2].toInt() << 8 ) + p[3].toInt() ); |
768 | peerport = ( p[4].toInt() << 8 ) + p[5].toInt(); | 766 | peerport = ( p[4].toInt() << 8 ) + p[5].toInt(); |
769 | return TRUE; | 767 | return TRUE; |
770 | } | 768 | } |
771 | 769 | ||
772 | void ServerPI::dtpCompleted() | 770 | void ServerPI::dtpCompleted() |
773 | { | 771 | { |
774 | send( "226 Closing data connection, file transfer successful" ); | 772 | send( "226 Closing data connection, file transfer successful" ); |
775 | if ( dtp->dtpMode() == ServerDTP::RetrieveFile ) { | 773 | if ( dtp->dtpMode() == ServerDTP::RetrieveFile ) { |
776 | QString fn = dtp->fileName(); | 774 | QString fn = dtp->fileName(); |
777 | if ( fn.right(8)==".desktop" && fn.find("/Documents/")>=0 ) { | 775 | if ( fn.right(8)==".desktop" && fn.find("/Documents/")>=0 ) { |
778 | QCopEnvelope e("QPE/System", "linkChanged(QString)" ); | 776 | QCopEnvelope e("QPE/System", "linkChanged(QString)" ); |
779 | e << fn; | 777 | e << fn; |
780 | } | 778 | } |
781 | } | 779 | } |
782 | waitsocket = 0; | 780 | waitsocket = 0; |
783 | dtp->close(); | 781 | dtp->close(); |
784 | } | 782 | } |
785 | 783 | ||
786 | void ServerPI::dtpFailed() | 784 | void ServerPI::dtpFailed() |
787 | { | 785 | { |
788 | dtp->close(); | 786 | dtp->close(); |
789 | waitsocket = 0; | 787 | waitsocket = 0; |
790 | send( "451 Requested action aborted: local error in processing" ); | 788 | send( "451 Requested action aborted: local error in processing" ); |
791 | } | 789 | } |
792 | 790 | ||
793 | void ServerPI::dtpError( int ) | 791 | void ServerPI::dtpError( int ) |
794 | { | 792 | { |
795 | dtp->close(); | 793 | dtp->close(); |
796 | waitsocket = 0; | 794 | waitsocket = 0; |
797 | send( "451 Requested action aborted: local error in processing" ); | 795 | send( "451 Requested action aborted: local error in processing" ); |
798 | } | 796 | } |
799 | 797 | ||
800 | bool ServerPI::sendList( const QString& arg ) | 798 | bool ServerPI::sendList( const QString& arg ) |
801 | { | 799 | { |
802 | QByteArray listing; | 800 | QByteArray listing; |
803 | QBuffer buffer( listing ); | 801 | QBuffer buffer( listing ); |
804 | 802 | ||
805 | if ( !buffer.open( IO_WriteOnly ) ) | 803 | if ( !buffer.open( IO_WriteOnly ) ) |
806 | return FALSE; | 804 | return FALSE; |
807 | 805 | ||
808 | QTextStream ts( &buffer ); | 806 | QTextStream ts( &buffer ); |
809 | QString fn = arg; | 807 | QString fn = arg; |
810 | 808 | ||
811 | if ( fn.isEmpty() ) | 809 | if ( fn.isEmpty() ) |
812 | fn = directory.path(); | 810 | fn = directory.path(); |
813 | 811 | ||
814 | QFileInfo fi( fn ); | 812 | QFileInfo fi( fn ); |
815 | if ( !fi.exists() ) return FALSE; | 813 | if ( !fi.exists() ) return FALSE; |
816 | 814 | ||
817 | // return file listing | 815 | // return file listing |
818 | if ( fi.isFile() ) { | 816 | if ( fi.isFile() ) { |
819 | ts << fileListing( &fi ) << endl; | 817 | ts << fileListing( &fi ) << endl; |
820 | } | 818 | } |
821 | 819 | ||
822 | // return directory listing | 820 | // return directory listing |
823 | else if ( fi.isDir() ) { | 821 | else if ( fi.isDir() ) { |
824 | QDir dir( fn ); | 822 | QDir dir( fn ); |
825 | const QFileInfoList *list = dir.entryInfoList( QDir::All | QDir::Hidden ); | 823 | const QFileInfoList *list = dir.entryInfoList( QDir::All | QDir::Hidden ); |
826 | 824 | ||
827 | QFileInfoListIterator it( *list ); | 825 | QFileInfoListIterator it( *list ); |
828 | QFileInfo *info; | 826 | QFileInfo *info; |
829 | 827 | ||
830 | unsigned long total = 0; | 828 | unsigned long total = 0; |
831 | while ( ( info = it.current() ) ) { | 829 | while ( ( info = it.current() ) ) { |
832 | if ( info->fileName() != "." && info->fileName() != ".." ) | 830 | if ( info->fileName() != "." && info->fileName() != ".." ) |
833 | total += info->size(); | 831 | total += info->size(); |
834 | ++it; | 832 | ++it; |
835 | } | 833 | } |
836 | 834 | ||
837 | ts << "total " << QString::number( total / 1024 ) << endl; | 835 | ts << "total " << QString::number( total / 1024 ) << endl; |
838 | 836 | ||
839 | it.toFirst(); | 837 | it.toFirst(); |
840 | while ( ( info = it.current() ) ) { | 838 | while ( ( info = it.current() ) ) { |
841 | if ( info->fileName() == "." || info->fileName() == ".." ) { | 839 | if ( info->fileName() == "." || info->fileName() == ".." ) { |
842 | ++it; | 840 | ++it; |
843 | continue; | 841 | continue; |
844 | } | 842 | } |
845 | ts << fileListing( info ) << endl; | 843 | ts << fileListing( info ) << endl; |
846 | ++it; | 844 | ++it; |
847 | } | 845 | } |
848 | } | 846 | } |
849 | 847 | ||
850 | if ( passiv ) { | 848 | if ( passiv ) { |
851 | waitarray = buffer.buffer(); | 849 | waitarray = buffer.buffer(); |
852 | wait[SendByteArray] = TRUE; | 850 | wait[SendByteArray] = TRUE; |
853 | if ( waitsocket ) | 851 | if ( waitsocket ) |
854 | newConnection( waitsocket ); | 852 | newConnection( waitsocket ); |
855 | } | 853 | } |
856 | else | 854 | else |
857 | dtp->sendByteArray( buffer.buffer(), peeraddress, peerport ); | 855 | dtp->sendByteArray( buffer.buffer(), peeraddress, peerport ); |
858 | return TRUE; | 856 | return TRUE; |
859 | } | 857 | } |
860 | 858 | ||
861 | QString ServerPI::fileListing( QFileInfo *info ) | 859 | QString ServerPI::fileListing( QFileInfo *info ) |
862 | { | 860 | { |
863 | if ( !info ) return QString::null; | 861 | if ( !info ) return QString::null; |
864 | QString s; | 862 | QString s; |
865 | 863 | ||
866 | // type char | 864 | // type char |
867 | if ( info->isDir() ) | 865 | if ( info->isDir() ) |
868 | s += "d"; | 866 | s += "d"; |
869 | else if ( info->isSymLink() ) | 867 | else if ( info->isSymLink() ) |
870 | s += "l"; | 868 | s += "l"; |
871 | else | 869 | else |
872 | s += "-"; | 870 | s += "-"; |
873 | 871 | ||
874 | // permisson string | 872 | // permisson string |
875 | s += permissionString( info ) + " "; | 873 | s += permissionString( info ) + " "; |
876 | 874 | ||
877 | // number of hardlinks | 875 | // number of hardlinks |
878 | int subdirs = 1; | 876 | int subdirs = 1; |
879 | 877 | ||
880 | if ( info->isDir() ) | 878 | if ( info->isDir() ) |
881 | subdirs = 2; | 879 | subdirs = 2; |
882 | // FIXME : this is to slow | 880 | // FIXME : this is to slow |
883 | //if ( info->isDir() ) | 881 | //if ( info->isDir() ) |
884 | //subdirs = QDir( info->absFilePath() ).entryList( QDir::Dirs ).count(); | 882 | //subdirs = QDir( info->absFilePath() ).entryList( QDir::Dirs ).count(); |
885 | 883 | ||
886 | s += QString::number( subdirs ).rightJustify( 3, ' ', TRUE ) + " "; | 884 | s += QString::number( subdirs ).rightJustify( 3, ' ', TRUE ) + " "; |
887 | 885 | ||
888 | // owner | 886 | // owner |
889 | s += info->owner().leftJustify( 8, ' ', TRUE ) + " "; | 887 | s += info->owner().leftJustify( 8, ' ', TRUE ) + " "; |
890 | 888 | ||
891 | // group | 889 | // group |
892 | s += info->group().leftJustify( 8, ' ', TRUE ) + " "; | 890 | s += info->group().leftJustify( 8, ' ', TRUE ) + " "; |
893 | 891 | ||
894 | // file size in bytes | 892 | // file size in bytes |
895 | s += QString::number( info->size() ).rightJustify( 9, ' ', TRUE ) + " "; | 893 | s += QString::number( info->size() ).rightJustify( 9, ' ', TRUE ) + " "; |
896 | 894 | ||
897 | // last modified date | 895 | // last modified date |
898 | QDate date = info->lastModified().date(); | 896 | QDate date = info->lastModified().date(); |
899 | QTime time = info->lastModified().time(); | 897 | QTime time = info->lastModified().time(); |
900 | s += date.monthName( date.month() ) + " " | 898 | s += date.monthName( date.month() ) + " " |
901 | + QString::number( date.day() ).rightJustify( 2, ' ', TRUE ) + " " | 899 | + QString::number( date.day() ).rightJustify( 2, ' ', TRUE ) + " " |
902 | + QString::number( time.hour() ).rightJustify( 2, '0', TRUE ) + ":" | 900 | + QString::number( time.hour() ).rightJustify( 2, '0', TRUE ) + ":" |
903 | + QString::number( time.minute() ).rightJustify( 2,'0', TRUE ) + " "; | 901 | + QString::number( time.minute() ).rightJustify( 2,'0', TRUE ) + " "; |
904 | 902 | ||
905 | // file name | 903 | // file name |
906 | s += info->fileName(); | 904 | s += info->fileName(); |
907 | 905 | ||
908 | return s; | 906 | return s; |
909 | } | 907 | } |
910 | 908 | ||
911 | QString ServerPI::permissionString( QFileInfo *info ) | 909 | QString ServerPI::permissionString( QFileInfo *info ) |
912 | { | 910 | { |
913 | if ( !info ) return QString( "---------" ); | 911 | if ( !info ) return QString( "---------" ); |
914 | QString s; | 912 | QString s; |
915 | 913 | ||
916 | // user | 914 | // user |
917 | if ( info->permission( QFileInfo::ReadUser ) ) s += "r"; | 915 | if ( info->permission( QFileInfo::ReadUser ) ) s += "r"; |
918 | else s += "-"; | 916 | else s += "-"; |
919 | if ( info->permission( QFileInfo::WriteUser ) ) s += "w"; | 917 | if ( info->permission( QFileInfo::WriteUser ) ) s += "w"; |
920 | else s += "-"; | 918 | else s += "-"; |
921 | if ( info->permission( QFileInfo::ExeUser ) ) s += "x"; | 919 | if ( info->permission( QFileInfo::ExeUser ) ) s += "x"; |
922 | else s += "-"; | 920 | else s += "-"; |
923 | 921 | ||
924 | // group | 922 | // group |
925 | if ( info->permission( QFileInfo::ReadGroup ) ) s += "r"; | 923 | if ( info->permission( QFileInfo::ReadGroup ) ) s += "r"; |
926 | else s += "-"; | 924 | else s += "-"; |
927 | if ( info->permission( QFileInfo::WriteGroup ) )s += "w"; | 925 | if ( info->permission( QFileInfo::WriteGroup ) )s += "w"; |
928 | else s += "-"; | 926 | else s += "-"; |
929 | if ( info->permission( QFileInfo::ExeGroup ) ) s += "x"; | 927 | if ( info->permission( QFileInfo::ExeGroup ) ) s += "x"; |
930 | else s += "-"; | 928 | else s += "-"; |
931 | 929 | ||
932 | // exec | 930 | // exec |
933 | if ( info->permission( QFileInfo::ReadOther ) ) s += "r"; | 931 | if ( info->permission( QFileInfo::ReadOther ) ) s += "r"; |
934 | else s += "-"; | 932 | else s += "-"; |
935 | if ( info->permission( QFileInfo::WriteOther ) ) s += "w"; | 933 | if ( info->permission( QFileInfo::WriteOther ) ) s += "w"; |
936 | else s += "-"; | 934 | else s += "-"; |
937 | if ( info->permission( QFileInfo::ExeOther ) ) s += "x"; | 935 | if ( info->permission( QFileInfo::ExeOther ) ) s += "x"; |
938 | else s += "-"; | 936 | else s += "-"; |
939 | 937 | ||
940 | return s; | 938 | return s; |
941 | } | 939 | } |
942 | 940 | ||
943 | void ServerPI::newConnection( int socket ) | 941 | void ServerPI::newConnection( int socket ) |
944 | { | 942 | { |
945 | //qDebug( "New incomming connection" ); | 943 | //qDebug( "New incomming connection" ); |
946 | 944 | ||
947 | if ( !passiv ) return; | 945 | if ( !passiv ) return; |
948 | 946 | ||
949 | if ( wait[SendFile] ) { | 947 | if ( wait[SendFile] ) { |
950 | QStringList targets; | 948 | QStringList targets; |
951 | if ( backupRestoreGzip( waitfile, targets ) ) | 949 | if ( backupRestoreGzip( waitfile, targets ) ) |
952 | dtp->sendGzipFile( waitfile, targets ); | 950 | dtp->sendGzipFile( waitfile, targets ); |
953 | else | 951 | else |
954 | dtp->sendFile( waitfile ); | 952 | dtp->sendFile( waitfile ); |
955 | dtp->setSocket( socket ); | 953 | dtp->setSocket( socket ); |
956 | } | 954 | } |
957 | else if ( wait[RetrieveFile] ) { | 955 | else if ( wait[RetrieveFile] ) { |
958 | qDebug("check retrieve file"); | 956 | qDebug("check retrieve file"); |
959 | if ( backupRestoreGzip( waitfile ) ) | 957 | if ( backupRestoreGzip( waitfile ) ) |
960 | dtp->retrieveGzipFile( waitfile ); | 958 | dtp->retrieveGzipFile( waitfile ); |
961 | else | 959 | else |
962 | dtp->retrieveFile( waitfile ); | 960 | dtp->retrieveFile( waitfile ); |
963 | dtp->setSocket( socket ); | 961 | dtp->setSocket( socket ); |
964 | } | 962 | } |
965 | else if ( wait[SendByteArray] ) { | 963 | else if ( wait[SendByteArray] ) { |
966 | dtp->sendByteArray( waitarray ); | 964 | dtp->sendByteArray( waitarray ); |
967 | dtp->setSocket( socket ); | 965 | dtp->setSocket( socket ); |
968 | } | 966 | } |
969 | else if ( wait[RetrieveByteArray] ) { | 967 | else if ( wait[RetrieveByteArray] ) { |
970 | qDebug("retrieve byte array"); | 968 | qDebug("retrieve byte array"); |
971 | dtp->retrieveByteArray(); | 969 | dtp->retrieveByteArray(); |
972 | dtp->setSocket( socket ); | 970 | dtp->setSocket( socket ); |
973 | } | 971 | } |
974 | else | 972 | else |
975 | waitsocket = socket; | 973 | waitsocket = socket; |
976 | 974 | ||
977 | for( int i = 0; i < 4; i++ ) | 975 | for( int i = 0; i < 4; i++ ) |
978 | wait[i] = FALSE; | 976 | wait[i] = FALSE; |
979 | } | 977 | } |
980 | 978 | ||
981 | QString ServerPI::absFilePath( const QString& file ) | 979 | QString ServerPI::absFilePath( const QString& file ) |
982 | { | 980 | { |
983 | if ( file.isEmpty() ) return file; | 981 | if ( file.isEmpty() ) return file; |
984 | 982 | ||
985 | QString filepath( file ); | 983 | QString filepath( file ); |
986 | if ( file[0] != "/" ) | 984 | if ( file[0] != "/" ) |
987 | filepath = directory.path() + "/" + file; | 985 | filepath = directory.path() + "/" + file; |
988 | 986 | ||
989 | return filepath; | 987 | return filepath; |
990 | } | 988 | } |
991 | 989 | ||
992 | 990 | ||
993 | void ServerPI::timerEvent( QTimerEvent * ) | 991 | void ServerPI::timerEvent( QTimerEvent * ) |
994 | { | 992 | { |
995 | connectionClosed(); | 993 | connectionClosed(); |
996 | } | 994 | } |
997 | 995 | ||
998 | 996 | ||
999 | ServerDTP::ServerDTP( QObject *parent = 0, const char* name = 0) | 997 | ServerDTP::ServerDTP( QObject *parent = 0, const char* name = 0) |
1000 | : QSocket( parent, name ), mode( Idle ), createTargzProc( 0 ), | 998 | : QSocket( parent, name ), mode( Idle ), createTargzProc( 0 ), |
1001 | retrieveTargzProc( 0 ), gzipProc( 0 ) | 999 | retrieveTargzProc( 0 ), gzipProc( 0 ) |
1002 | { | 1000 | { |
1003 | 1001 | ||
1004 | connect( this, SIGNAL( connected() ), SLOT( connected() ) ); | 1002 | connect( this, SIGNAL( connected() ), SLOT( connected() ) ); |
1005 | connect( this, SIGNAL( connectionClosed() ), SLOT( connectionClosed() ) ); | 1003 | connect( this, SIGNAL( connectionClosed() ), SLOT( connectionClosed() ) ); |
1006 | connect( this, SIGNAL( bytesWritten( int ) ), SLOT( bytesWritten( int ) ) ); | 1004 | connect( this, SIGNAL( bytesWritten( int ) ), SLOT( bytesWritten( int ) ) ); |
1007 | connect( this, SIGNAL( readyRead() ), SLOT( readyRead() ) ); | 1005 | connect( this, SIGNAL( readyRead() ), SLOT( readyRead() ) ); |
1008 | 1006 | ||
1009 | gzipProc = new QProcess( this, "gzipProc" ); | 1007 | gzipProc = new QProcess( this, "gzipProc" ); |
1010 | gzipProc->setCommunication( QProcess::Stdin | QProcess::Stdout ); | 1008 | gzipProc->setCommunication( QProcess::Stdin | QProcess::Stdout ); |
1011 | 1009 | ||
1012 | createTargzProc = new QProcess( QString("tar"), this, "createTargzProc"); | 1010 | createTargzProc = new QProcess( QString("tar"), this, "createTargzProc"); |
1013 | createTargzProc->setCommunication( QProcess::Stdout ); | 1011 | createTargzProc->setCommunication( QProcess::Stdout ); |
1014 | createTargzProc->setWorkingDirectory( QDir::rootDirPath() ); | 1012 | createTargzProc->setWorkingDirectory( QDir::rootDirPath() ); |
1015 | connect( createTargzProc, SIGNAL( processExited() ), SLOT( targzDone() ) ); | 1013 | connect( createTargzProc, SIGNAL( processExited() ), SLOT( targzDone() ) ); |
1016 | 1014 | ||
1017 | QStringList args = "tar"; | 1015 | QStringList args = "tar"; |
1018 | args += "-xv"; | 1016 | args += "-xv"; |
1019 | retrieveTargzProc = new QProcess( args, this, "retrieveTargzProc" ); | 1017 | retrieveTargzProc = new QProcess( args, this, "retrieveTargzProc" ); |
1020 | retrieveTargzProc->setCommunication( QProcess::Stdin ); | 1018 | retrieveTargzProc->setCommunication( QProcess::Stdin ); |
1021 | retrieveTargzProc->setWorkingDirectory( QDir::rootDirPath() ); | 1019 | retrieveTargzProc->setWorkingDirectory( QDir::rootDirPath() ); |
1022 | connect( retrieveTargzProc, SIGNAL( processExited() ), | 1020 | connect( retrieveTargzProc, SIGNAL( processExited() ), |
1023 | SIGNAL( completed() ) ); | 1021 | SIGNAL( completed() ) ); |
1024 | connect( retrieveTargzProc, SIGNAL( processExited() ), | 1022 | connect( retrieveTargzProc, SIGNAL( processExited() ), |
1025 | SLOT( extractTarDone() ) ); | 1023 | SLOT( extractTarDone() ) ); |
1026 | } | 1024 | } |
1027 | 1025 | ||
1028 | ServerDTP::~ServerDTP() | 1026 | ServerDTP::~ServerDTP() |
1029 | { | 1027 | { |
1030 | buf.close(); | 1028 | buf.close(); |
1031 | file.close(); | 1029 | file.close(); |
1032 | createTargzProc->kill(); | 1030 | createTargzProc->kill(); |
1033 | } | 1031 | } |
1034 | 1032 | ||
1035 | void ServerDTP::extractTarDone() | 1033 | void ServerDTP::extractTarDone() |
1036 | { | 1034 | { |
1037 | qDebug("extract done"); | 1035 | qDebug("extract done"); |
1038 | #ifndef QT_NO_COP | 1036 | #ifndef QT_NO_COP |
1039 | QCopEnvelope e( "QPE/Desktop", "restoreDone(QString)" ); | 1037 | QCopEnvelope e( "QPE/Desktop", "restoreDone(QString)" ); |
1040 | e << file.name(); | 1038 | e << file.name(); |
1041 | #endif | 1039 | #endif |
1042 | } | 1040 | } |
1043 | 1041 | ||
1044 | void ServerDTP::connected() | 1042 | void ServerDTP::connected() |
1045 | { | 1043 | { |
1046 | // send file mode | 1044 | // send file mode |
1047 | switch ( mode ) { | 1045 | switch ( mode ) { |
1048 | case SendFile : | 1046 | case SendFile : |
1049 | if ( !file.exists() || !file.open( IO_ReadOnly) ) { | 1047 | if ( !file.exists() || !file.open( IO_ReadOnly) ) { |
1050 | emit failed(); | 1048 | emit failed(); |
1051 | mode = Idle; | 1049 | mode = Idle; |
1052 | return; | 1050 | return; |
1053 | } | 1051 | } |
1054 | 1052 | ||
1055 | //qDebug( "Debug: Sending file '%s'", file.name().latin1() ); | 1053 | //qDebug( "Debug: Sending file '%s'", file.name().latin1() ); |
1056 | 1054 | ||
1057 | bytes_written = 0; | 1055 | bytes_written = 0; |
1058 | if ( file.size() == 0 ) { | 1056 | if ( file.size() == 0 ) { |
1059 | //make sure it doesn't hang on empty files | 1057 | //make sure it doesn't hang on empty files |
1060 | file.close(); | 1058 | file.close(); |
1061 | emit completed(); | 1059 | emit completed(); |
1062 | mode = Idle; | 1060 | mode = Idle; |
1063 | } else { | 1061 | } else { |
1064 | 1062 | ||
1065 | if( !file.atEnd() ) { | 1063 | if( !file.atEnd() ) { |
1066 | QCString s; | 1064 | QCString s; |
1067 | s.resize( block_size ); | 1065 | s.resize( block_size ); |
1068 | int bytes = file.readBlock( s.data(), block_size ); | 1066 | int bytes = file.readBlock( s.data(), block_size ); |
1069 | writeBlock( s.data(), bytes ); | 1067 | writeBlock( s.data(), bytes ); |
1070 | } | 1068 | } |
1071 | } | 1069 | } |
1072 | break; | 1070 | break; |
1073 | case SendGzipFile: | 1071 | case SendGzipFile: |
1074 | if ( createTargzProc->isRunning() ) { | 1072 | if ( createTargzProc->isRunning() ) { |
1075 | // SHOULDN'T GET HERE, BUT DOING A SAFETY CHECK ANYWAY | 1073 | // SHOULDN'T GET HERE, BUT DOING A SAFETY CHECK ANYWAY |
1076 | qWarning("Previous tar --gzip process is still running; killing it..."); | 1074 | qWarning("Previous tar --gzip process is still running; killing it..."); |
1077 | createTargzProc->kill(); | 1075 | createTargzProc->kill(); |
1078 | } | 1076 | } |
1079 | 1077 | ||
1080 | bytes_written = 0; | 1078 | bytes_written = 0; |
1081 | qDebug("==>start send tar process"); | 1079 | qDebug("==>start send tar process"); |
1082 | if ( !createTargzProc->start() ) | 1080 | if ( !createTargzProc->start() ) |
1083 | qWarning("Error starting %s or %s", | 1081 | qWarning("Error starting %s or %s", |
1084 | createTargzProc->arguments().join(" ").latin1(), | 1082 | createTargzProc->arguments().join(" ").latin1(), |
1085 | gzipProc->arguments().join(" ").latin1() ); | 1083 | gzipProc->arguments().join(" ").latin1() ); |