-rw-r--r-- | core/launcher/desktop.cpp | 4 | ||||
-rw-r--r-- | core/launcher/launcher.cpp | 2 |
2 files changed, 1 insertions, 5 deletions
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index 1fd3f6a..3546e28 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp | |||
@@ -122,562 +122,558 @@ public: | |||
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 | class QPEScreenSaver : public QWSScreenSaver | 155 | class QPEScreenSaver : public QWSScreenSaver |
156 | { | 156 | { |
157 | private: | 157 | private: |
158 | int LcdOn; | 158 | int LcdOn; |
159 | 159 | ||
160 | public: | 160 | public: |
161 | QPEScreenSaver() | 161 | QPEScreenSaver() |
162 | { | 162 | { |
163 | m_disable_suspend = 100; | 163 | m_disable_suspend = 100; |
164 | m_enable_dim = false; | 164 | m_enable_dim = false; |
165 | m_enable_lightoff = false; | 165 | m_enable_lightoff = false; |
166 | m_enable_onlylcdoff = false; | 166 | m_enable_onlylcdoff = false; |
167 | 167 | ||
168 | m_lcd_status = true; | 168 | m_lcd_status = true; |
169 | 169 | ||
170 | m_backlight_bright = -1; | 170 | m_backlight_bright = -1; |
171 | m_backlight_forcedoff = false; | 171 | m_backlight_forcedoff = false; |
172 | 172 | ||
173 | // 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) |
174 | ODevice::inst ( ) -> setDisplayStatus ( true ); | 174 | ODevice::inst ( ) -> setDisplayStatus ( true ); |
175 | } | 175 | } |
176 | void restore() | 176 | void restore() |
177 | { | 177 | { |
178 | if ( !m_lcd_status ) { // We must have turned it off | 178 | if ( !m_lcd_status ) { // We must have turned it off |
179 | ODevice::inst ( ) -> setDisplayStatus ( true ); | 179 | ODevice::inst ( ) -> setDisplayStatus ( true ); |
180 | m_lcd_status = true; | 180 | m_lcd_status = true; |
181 | } | 181 | } |
182 | 182 | ||
183 | setBacklight ( -1 ); | 183 | setBacklight ( -1 ); |
184 | } | 184 | } |
185 | bool save( int level ) | 185 | bool save( int level ) |
186 | { | 186 | { |
187 | switch ( level ) { | 187 | switch ( level ) { |
188 | case 0: | 188 | case 0: |
189 | if ( m_disable_suspend > 0 && m_enable_dim ) { | 189 | if ( m_disable_suspend > 0 && m_enable_dim ) { |
190 | if ( backlight() > 1 ) | 190 | if ( backlight() > 1 ) |
191 | setBacklight( 1 ); // lowest non-off | 191 | setBacklight( 1 ); // lowest non-off |
192 | } | 192 | } |
193 | return true; | 193 | return true; |
194 | break; | 194 | break; |
195 | case 1: | 195 | case 1: |
196 | if ( m_disable_suspend > 1 && m_enable_lightoff ) { | 196 | if ( m_disable_suspend > 1 && m_enable_lightoff ) { |
197 | setBacklight( 0 ); // off | 197 | setBacklight( 0 ); // off |
198 | } | 198 | } |
199 | return true; | 199 | return true; |
200 | break; | 200 | break; |
201 | case 2: | 201 | case 2: |
202 | if ( m_enable_onlylcdoff ) { | 202 | if ( m_enable_onlylcdoff ) { |
203 | ODevice::inst ( ) -> setDisplayStatus ( false ); | 203 | ODevice::inst ( ) -> setDisplayStatus ( false ); |
204 | m_lcd_status = false; | 204 | m_lcd_status = false; |
205 | return true; | 205 | return true; |
206 | } | 206 | } |
207 | else // We're going to suspend the whole machine | 207 | else // We're going to suspend the whole machine |
208 | { | 208 | { |
209 | if ( ( m_disable_suspend > 2 ) && | 209 | if ( ( m_disable_suspend > 2 ) && |
210 | ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && | 210 | ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && |
211 | ( !Network::networkOnline ( ) ) ) { | 211 | ( !Network::networkOnline ( ) ) ) { |
212 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); | 212 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); |
213 | return true; | 213 | return true; |
214 | } | 214 | } |
215 | } | 215 | } |
216 | break; | 216 | break; |
217 | } | 217 | } |
218 | return false; | 218 | return false; |
219 | } | 219 | } |
220 | 220 | ||
221 | private: | 221 | private: |
222 | 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 ) |
223 | { | 223 | { |
224 | if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) | 224 | if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) |
225 | return 0; | 225 | return 0; |
226 | 226 | ||
227 | if ( interval < 0 ) { | 227 | if ( interval < 0 ) { |
228 | // Restore screen blanking and power saving state | 228 | // Restore screen blanking and power saving state |
229 | interval = config.readNumEntry( value, def ); | 229 | interval = config.readNumEntry( value, def ); |
230 | } | 230 | } |
231 | return interval; | 231 | return interval; |
232 | } | 232 | } |
233 | 233 | ||
234 | public: | 234 | public: |
235 | void setIntervals( int i1, int i2, int i3 ) | 235 | void setIntervals( int i1, int i2, int i3 ) |
236 | { | 236 | { |
237 | Config config( "qpe" ); | 237 | Config config( "qpe" ); |
238 | config.setGroup( "Screensaver" ); | 238 | config.setGroup( "Screensaver" ); |
239 | 239 | ||
240 | int v[ 4 ]; | 240 | int v[ 4 ]; |
241 | i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 ); | 241 | i1 = ssi( i1, config, "Dim", "Interval_Dim", 30 ); |
242 | i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 ); | 242 | i2 = ssi( i2, config, "LightOff", "Interval_LightOff", 20 ); |
243 | i3 = ssi( i3, config, "", "Interval", 60 ); | 243 | i3 = ssi( i3, config, "", "Interval", 60 ); |
244 | 244 | ||
245 | //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); | 245 | //qDebug("screen saver intervals: %d %d %d", i1, i2, i3); |
246 | 246 | ||
247 | v [ 0 ] = QMAX( 1000 * i1, 100 ); | 247 | v [ 0 ] = QMAX( 1000 * i1, 100 ); |
248 | v [ 1 ] = QMAX( 1000 * i2, 100 ); | 248 | v [ 1 ] = QMAX( 1000 * i2, 100 ); |
249 | v [ 2 ] = QMAX( 1000 * i3, 100 ); | 249 | v [ 2 ] = QMAX( 1000 * i3, 100 ); |
250 | v [ 3 ] = 0; | 250 | v [ 3 ] = 0; |
251 | m_enable_dim = ( ( i1 != 0 ) ? config. readNumEntry ( "Dim", 1 ) : false ); | 251 | m_enable_dim = ( ( i1 != 0 ) ? config. readNumEntry ( "Dim", 1 ) : false ); |
252 | m_enable_lightoff = ( ( i2 != 0 ) ? config. readNumEntry ( "LightOff", 1 ) : false ); | 252 | m_enable_lightoff = ( ( i2 != 0 ) ? config. readNumEntry ( "LightOff", 1 ) : false ); |
253 | m_enable_onlylcdoff = config. readNumEntry ( "LcdOffOnly", 0 ); | 253 | m_enable_onlylcdoff = config. readNumEntry ( "LcdOffOnly", 0 ); |
254 | 254 | ||
255 | if ( !i1 && !i2 && !i3 ) | 255 | if ( !i1 && !i2 && !i3 ) |
256 | QWSServer::setScreenSaverInterval( 0 ); | 256 | QWSServer::setScreenSaverInterval( 0 ); |
257 | else | 257 | else |
258 | QWSServer::setScreenSaverIntervals( v ); | 258 | QWSServer::setScreenSaverIntervals( v ); |
259 | } | 259 | } |
260 | 260 | ||
261 | void setInterval ( int interval ) | 261 | void setInterval ( int interval ) |
262 | { | 262 | { |
263 | setIntervals ( -1, -1, interval ); | 263 | setIntervals ( -1, -1, interval ); |
264 | } | 264 | } |
265 | 265 | ||
266 | void setMode ( int mode ) | 266 | void setMode ( int mode ) |
267 | { | 267 | { |
268 | if ( mode > m_disable_suspend ) | 268 | if ( mode > m_disable_suspend ) |
269 | setInterval( -1 ); | 269 | setInterval( -1 ); |
270 | m_disable_suspend = mode; | 270 | m_disable_suspend = mode; |
271 | } | 271 | } |
272 | 272 | ||
273 | int backlight ( ) | 273 | int backlight ( ) |
274 | { | 274 | { |
275 | if ( m_backlight_bright == -1 ) { | 275 | if ( m_backlight_bright == -1 ) { |
276 | // Read from config | 276 | // Read from config |
277 | Config config ( "qpe" ); | 277 | Config config ( "qpe" ); |
278 | config. setGroup ( "Screensaver" ); | 278 | config. setGroup ( "Screensaver" ); |
279 | m_backlight_bright = config. readNumEntry ( "Brightness", 255 ); | 279 | m_backlight_bright = config. readNumEntry ( "Brightness", 255 ); |
280 | } | 280 | } |
281 | return m_backlight_bright; | 281 | return m_backlight_bright; |
282 | } | 282 | } |
283 | 283 | ||
284 | void setBacklight ( int bright ) | 284 | void setBacklight ( int bright ) |
285 | { | 285 | { |
286 | if ( bright == -3 ) { | 286 | if ( bright == -3 ) { |
287 | // Forced on | 287 | // Forced on |
288 | m_backlight_forcedoff = false; | 288 | m_backlight_forcedoff = false; |
289 | bright = -1; | 289 | bright = -1; |
290 | } | 290 | } |
291 | if ( m_backlight_forcedoff && bright != -2 ) | 291 | if ( m_backlight_forcedoff && bright != -2 ) |
292 | return ; | 292 | return ; |
293 | if ( bright == -2 ) { | 293 | if ( bright == -2 ) { |
294 | // Toggle between off and on | 294 | // Toggle between off and on |
295 | bright = m_backlight_bright ? 0 : -1; | 295 | bright = m_backlight_bright ? 0 : -1; |
296 | m_backlight_forcedoff = !bright; | 296 | m_backlight_forcedoff = !bright; |
297 | } | 297 | } |
298 | 298 | ||
299 | m_backlight_bright = bright; | 299 | m_backlight_bright = bright; |
300 | 300 | ||
301 | bright = backlight ( ); | 301 | bright = backlight ( ); |
302 | ODevice::inst ( ) -> setDisplayBrightness ( bright ); | 302 | ODevice::inst ( ) -> setDisplayBrightness ( bright ); |
303 | 303 | ||
304 | m_backlight_bright = bright; | 304 | m_backlight_bright = bright; |
305 | } | 305 | } |
306 | 306 | ||
307 | void setDisplayState ( bool on ) | 307 | void setDisplayState ( bool on ) |
308 | { | 308 | { |
309 | if ( m_lcd_status != on ) { | 309 | if ( m_lcd_status != on ) { |
310 | ODevice::inst ( ) -> setDisplayStatus ( on ); | 310 | ODevice::inst ( ) -> setDisplayStatus ( on ); |
311 | m_lcd_status = on; | 311 | m_lcd_status = on; |
312 | } | 312 | } |
313 | } | 313 | } |
314 | 314 | ||
315 | private: | 315 | private: |
316 | int m_disable_suspend; | 316 | int m_disable_suspend; |
317 | bool m_enable_dim; | 317 | bool m_enable_dim; |
318 | bool m_enable_lightoff; | 318 | bool m_enable_lightoff; |
319 | bool m_enable_onlylcdoff; | 319 | bool m_enable_onlylcdoff; |
320 | 320 | ||
321 | bool m_lcd_status; | 321 | bool m_lcd_status; |
322 | 322 | ||
323 | int m_backlight_bright; | 323 | int m_backlight_bright; |
324 | bool m_backlight_forcedoff; | 324 | bool m_backlight_forcedoff; |
325 | }; | 325 | }; |
326 | 326 | ||
327 | void DesktopApplication::switchLCD ( bool on ) | 327 | void DesktopApplication::switchLCD ( bool on ) |
328 | { | 328 | { |
329 | if ( qApp ) { | 329 | if ( qApp ) { |
330 | DesktopApplication *dapp = (DesktopApplication *) qApp; | 330 | DesktopApplication *dapp = (DesktopApplication *) qApp; |
331 | 331 | ||
332 | if ( dapp-> m_screensaver ) { | 332 | if ( dapp-> m_screensaver ) { |
333 | if ( on ) { | 333 | if ( on ) { |
334 | dapp-> m_screensaver-> setDisplayState ( true ); | 334 | dapp-> m_screensaver-> setDisplayState ( true ); |
335 | dapp-> m_screensaver-> setBacklight ( -3 ); | 335 | dapp-> m_screensaver-> setBacklight ( -3 ); |
336 | } | 336 | } |
337 | else { | 337 | else { |
338 | dapp-> m_screensaver-> setDisplayState ( false ); | 338 | dapp-> m_screensaver-> setDisplayState ( false ); |
339 | } | 339 | } |
340 | } | 340 | } |
341 | } | 341 | } |
342 | } | 342 | } |
343 | 343 | ||
344 | 344 | ||
345 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) | 345 | DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) |
346 | : QPEApplication( argc, argv, appType ) | 346 | : QPEApplication( argc, argv, appType ) |
347 | { | 347 | { |
348 | 348 | ||
349 | QTimer * t = new QTimer( this ); | 349 | QTimer * t = new QTimer( this ); |
350 | connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); | 350 | connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); |
351 | t->start( 10000 ); | 351 | t->start( 10000 ); |
352 | ps = new PowerStatus; | 352 | ps = new PowerStatus; |
353 | pa = new DesktopPowerAlerter( 0 ); | 353 | pa = new DesktopPowerAlerter( 0 ); |
354 | 354 | ||
355 | channel = new QCopChannel( "QPE/Desktop", this ); | 355 | channel = new QCopChannel( "QPE/Desktop", this ); |
356 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 356 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
357 | this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); | 357 | this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); |
358 | 358 | ||
359 | channel = new QCopChannel( "QPE/System", this ); | 359 | channel = new QCopChannel( "QPE/System", this ); |
360 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), | 360 | connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), |
361 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); | 361 | this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); |
362 | 362 | ||
363 | m_screensaver = new QPEScreenSaver; | 363 | m_screensaver = new QPEScreenSaver; |
364 | 364 | ||
365 | m_screensaver-> setInterval ( -1 ); | 365 | m_screensaver-> setInterval ( -1 ); |
366 | QWSServer::setScreenSaver( m_screensaver ); | 366 | QWSServer::setScreenSaver( m_screensaver ); |
367 | } | 367 | } |
368 | 368 | ||
369 | 369 | ||
370 | DesktopApplication::~DesktopApplication() | 370 | DesktopApplication::~DesktopApplication() |
371 | { | 371 | { |
372 | delete ps; | 372 | delete ps; |
373 | delete pa; | 373 | delete pa; |
374 | } | 374 | } |
375 | 375 | ||
376 | void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) | 376 | void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) |
377 | { | 377 | { |
378 | #ifdef Q_WS_QWS | ||
379 | QDataStream stream( data, IO_ReadOnly ); | 378 | QDataStream stream( data, IO_ReadOnly ); |
380 | if ( msg == "keyRegister(int key, QString channel, QString message)" ) { | 379 | if ( msg == "keyRegister(int key, QString channel, QString message)" ) { |
381 | int k; | 380 | int k; |
382 | QString c, m; | 381 | QString c, m; |
383 | stream >> k; | 382 | stream >> k; |
384 | stream >> c; | 383 | stream >> c; |
385 | stream >> m; | 384 | stream >> m; |
386 | 385 | ||
387 | qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); | 386 | qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); |
388 | keyRegisterList.append( QCopKeyRegister( k, c, m ) ); | 387 | keyRegisterList.append( QCopKeyRegister( k, c, m ) ); |
389 | } | 388 | } |
390 | #endif | ||
391 | } | 389 | } |
392 | 390 | ||
393 | 391 | ||
394 | void DesktopApplication::systemMessage( const QCString & msg, const QByteArray & data ) | 392 | void DesktopApplication::systemMessage( const QCString & msg, const QByteArray & data ) |
395 | { | 393 | { |
396 | #ifdef Q_WS_QWS | ||
397 | QDataStream stream ( data, IO_ReadOnly ); | 394 | QDataStream stream ( data, IO_ReadOnly ); |
398 | 395 | ||
399 | if ( msg == "setScreenSaverInterval(int)" ) { | 396 | if ( msg == "setScreenSaverInterval(int)" ) { |
400 | int time; | 397 | int time; |
401 | stream >> time; | 398 | stream >> time; |
402 | m_screensaver-> setInterval( time ); | 399 | m_screensaver-> setInterval( time ); |
403 | } | 400 | } |
404 | else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { | 401 | else if ( msg == "setScreenSaverIntervals(int,int,int)" ) { |
405 | int t1, t2, t3; | 402 | int t1, t2, t3; |
406 | stream >> t1 >> t2 >> t3; | 403 | stream >> t1 >> t2 >> t3; |
407 | m_screensaver-> setIntervals( t1, t2, t3 ); | 404 | m_screensaver-> setIntervals( t1, t2, t3 ); |
408 | } | 405 | } |
409 | else if ( msg == "setBacklight(int)" ) { | 406 | else if ( msg == "setBacklight(int)" ) { |
410 | int bright; | 407 | int bright; |
411 | stream >> bright; | 408 | stream >> bright; |
412 | m_screensaver-> setBacklight( bright ); | 409 | m_screensaver-> setBacklight( bright ); |
413 | } | 410 | } |
414 | else if ( msg == "setScreenSaverMode(int)" ) { | 411 | else if ( msg == "setScreenSaverMode(int)" ) { |
415 | int mode; | 412 | int mode; |
416 | stream >> mode; | 413 | stream >> mode; |
417 | m_screensaver-> setMode ( mode ); | 414 | m_screensaver-> setMode ( mode ); |
418 | } | 415 | } |
419 | else if ( msg == "setDisplayState(int)" ) { | 416 | else if ( msg == "setDisplayState(int)" ) { |
420 | int state; | 417 | int state; |
421 | stream >> state; | 418 | stream >> state; |
422 | m_screensaver-> setDisplayState ( state != 0 ); | 419 | m_screensaver-> setDisplayState ( state != 0 ); |
423 | } | 420 | } |
424 | else if ( msg == "suspend()" ) { | 421 | else if ( msg == "suspend()" ) { |
425 | emit power(); | 422 | emit power(); |
426 | } | 423 | } |
427 | #endif | ||
428 | } | 424 | } |
429 | 425 | ||
430 | enum MemState { Unknown, VeryLow, Low, Normal } memstate = Unknown; | 426 | enum MemState { Unknown, VeryLow, Low, Normal } memstate = Unknown; |
431 | 427 | ||
432 | #ifdef Q_WS_QWS | 428 | #ifdef Q_WS_QWS |
433 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) | 429 | bool DesktopApplication::qwsEventFilter( QWSEvent *e ) |
434 | { | 430 | { |
435 | qpedesktop->checkMemory(); | 431 | qpedesktop->checkMemory(); |
436 | 432 | ||
437 | if ( e->type == QWSEvent::Key ) { | 433 | if ( e->type == QWSEvent::Key ) { |
438 | QWSKeyEvent * ke = ( QWSKeyEvent * ) e; | 434 | QWSKeyEvent * ke = ( QWSKeyEvent * ) e; |
439 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) | 435 | if ( !loggedin && ke->simpleData.keycode != Key_F34 ) |
440 | return TRUE; | 436 | return TRUE; |
441 | bool press = ke->simpleData.is_press; | 437 | bool press = ke->simpleData.is_press; |
442 | bool autoRepeat = ke->simpleData.is_auto_repeat; | 438 | bool autoRepeat = ke->simpleData.is_auto_repeat; |
443 | 439 | ||
444 | /* | 440 | /* |
445 | app that registers key/message to be sent back to the app, when it doesn't have focus, | 441 | app that registers key/message to be sent back to the app, when it doesn't have focus, |
446 | when user presses key, unless keyboard has been requested from app. | 442 | when user presses key, unless keyboard has been requested from app. |
447 | will not send multiple repeats if user holds key | 443 | will not send multiple repeats if user holds key |
448 | i.e. one shot | 444 | i.e. one shot |
449 | */ | 445 | */ |
450 | if ( !keyRegisterList.isEmpty() && ke->simpleData.keycode !=0 && press) { | 446 | if ( !keyRegisterList.isEmpty() && ke->simpleData.keycode !=0 && press) { |
451 | // qDebug("<<<<<<<<<<<<<keycode %d", ke->simpleData.keycode); | 447 | // qDebug("<<<<<<<<<<<<<keycode %d", ke->simpleData.keycode); |
452 | KeyRegisterList::Iterator it; | 448 | KeyRegisterList::Iterator it; |
453 | for ( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { | 449 | for ( it = keyRegisterList.begin(); it != keyRegisterList.end(); ++it ) { |
454 | if ( ( *it ).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() ) { | 450 | if ( ( *it ).getKeyCode() == ke->simpleData.keycode && !autoRepeat && !keyboardGrabbed() ) { |
455 | if ( press ) | 451 | if ( press ) |
456 | qDebug( "press" ); | 452 | qDebug( "press" ); |
457 | else | 453 | else |
458 | qDebug( "release" ); | 454 | qDebug( "release" ); |
459 | QCopEnvelope( ( *it ).getChannel().utf8(), ( *it ).getMessage().utf8() ); | 455 | QCopEnvelope( ( *it ).getChannel().utf8(), ( *it ).getMessage().utf8() ); |
460 | } | 456 | } |
461 | } | 457 | } |
462 | } | 458 | } |
463 | 459 | ||
464 | if ( !keyboardGrabbed() ) { | 460 | if ( !keyboardGrabbed() ) { |
465 | if ( ke->simpleData.keycode == Key_F9 ) { | 461 | if ( ke->simpleData.keycode == Key_F9 ) { |
466 | if ( press ) | 462 | if ( press ) |
467 | emit datebook(); | 463 | emit datebook(); |
468 | return TRUE; | 464 | return TRUE; |
469 | } | 465 | } |
470 | if ( ke->simpleData.keycode == Key_F10 ) { | 466 | if ( ke->simpleData.keycode == Key_F10 ) { |
471 | if ( !press && cardSendTimer ) { | 467 | if ( !press && cardSendTimer ) { |
472 | emit contacts(); | 468 | emit contacts(); |
473 | delete cardSendTimer; | 469 | delete cardSendTimer; |
474 | } | 470 | } |
475 | else if ( press ) { | 471 | else if ( press ) { |
476 | cardSendTimer = new QTimer(); | 472 | cardSendTimer = new QTimer(); |
477 | cardSendTimer->start( 2000, TRUE ); | 473 | cardSendTimer->start( 2000, TRUE ); |
478 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); | 474 | connect( cardSendTimer, SIGNAL( timeout() ), this, SLOT( sendCard() ) ); |
479 | } | 475 | } |
480 | return TRUE; | 476 | return TRUE; |
481 | } | 477 | } |
482 | /* menu key now opens application menu/toolbar | 478 | /* menu key now opens application menu/toolbar |
483 | if ( ke->simpleData.keycode == Key_F11 ) { | 479 | if ( ke->simpleData.keycode == Key_F11 ) { |
484 | if ( press ) emit menu(); | 480 | if ( press ) emit menu(); |
485 | return TRUE; | 481 | return TRUE; |
486 | } | 482 | } |
487 | */ | 483 | */ |
488 | if ( ke->simpleData.keycode == Key_F12 ) { | 484 | if ( ke->simpleData.keycode == Key_F12 ) { |
489 | while ( activePopupWidget() ) | 485 | while ( activePopupWidget() ) |
490 | activePopupWidget() ->close(); | 486 | activePopupWidget() ->close(); |
491 | if ( press ) | 487 | if ( press ) |
492 | emit launch(); | 488 | emit launch(); |
493 | return TRUE; | 489 | return TRUE; |
494 | } | 490 | } |
495 | if ( ke->simpleData.keycode == Key_F13 ) { | 491 | if ( ke->simpleData.keycode == Key_F13 ) { |
496 | if ( press ) | 492 | if ( press ) |
497 | emit email(); | 493 | emit email(); |
498 | return TRUE; | 494 | return TRUE; |
499 | } | 495 | } |
500 | } | 496 | } |
501 | 497 | ||
502 | if ( ke->simpleData.keycode == Key_F34 ) { | 498 | if ( ke->simpleData.keycode == Key_F34 ) { |
503 | if ( press ) | 499 | if ( press ) |
504 | emit power(); | 500 | emit power(); |
505 | return TRUE; | 501 | return TRUE; |
506 | } | 502 | } |
507 | // This was used for the iPAQ PowerButton | 503 | // This was used for the iPAQ PowerButton |
508 | // See main.cpp for new KeyboardFilter | 504 | // See main.cpp for new KeyboardFilter |
509 | // | 505 | // |
510 | // if ( ke->simpleData.keycode == Key_SysReq ) { | 506 | // if ( ke->simpleData.keycode == Key_SysReq ) { |
511 | // if ( press ) emit power(); | 507 | // if ( press ) emit power(); |
512 | // return TRUE; | 508 | // return TRUE; |
513 | // } | 509 | // } |
514 | if ( ke->simpleData.keycode == Key_F35 ) { | 510 | if ( ke->simpleData.keycode == Key_F35 ) { |
515 | if ( press ) | 511 | if ( press ) |
516 | emit backlight(); | 512 | emit backlight(); |
517 | return TRUE; | 513 | return TRUE; |
518 | } | 514 | } |
519 | if ( ke->simpleData.keycode == Key_F32 ) { | 515 | if ( ke->simpleData.keycode == Key_F32 ) { |
520 | if ( press ) | 516 | if ( press ) |
521 | QCopEnvelope e( "QPE/Desktop", "startSync()" ); | 517 | QCopEnvelope e( "QPE/Desktop", "startSync()" ); |
522 | return TRUE; | 518 | return TRUE; |
523 | } | 519 | } |
524 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { | 520 | if ( ke->simpleData.keycode == Key_F31 && !ke->simpleData.modifiers ) { |
525 | if ( press ) | 521 | if ( press ) |
526 | emit symbol(); | 522 | emit symbol(); |
527 | return TRUE; | 523 | return TRUE; |
528 | } | 524 | } |
529 | if ( ke->simpleData.keycode == Key_NumLock ) { | 525 | if ( ke->simpleData.keycode == Key_NumLock ) { |
530 | if ( press ) | 526 | if ( press ) |
531 | emit numLockStateToggle(); | 527 | emit numLockStateToggle(); |
532 | } | 528 | } |
533 | if ( ke->simpleData.keycode == Key_CapsLock ) { | 529 | if ( ke->simpleData.keycode == Key_CapsLock ) { |
534 | if ( press ) | 530 | if ( press ) |
535 | emit capsLockStateToggle(); | 531 | emit capsLockStateToggle(); |
536 | } | 532 | } |
537 | if ( ( press && !autoRepeat ) || ( !press && autoRepeat ) ) | 533 | if ( ( press && !autoRepeat ) || ( !press && autoRepeat ) ) |
538 | qpedesktop->keyClick(); | 534 | qpedesktop->keyClick(); |
539 | } | 535 | } |
540 | else { | 536 | else { |
541 | if ( e->type == QWSEvent::Mouse ) { | 537 | if ( e->type == QWSEvent::Mouse ) { |
542 | QWSMouseEvent * me = ( QWSMouseEvent * ) e; | 538 | QWSMouseEvent * me = ( QWSMouseEvent * ) e; |
543 | static bool up = TRUE; | 539 | static bool up = TRUE; |
544 | if ( me->simpleData.state & LeftButton ) { | 540 | if ( me->simpleData.state & LeftButton ) { |
545 | if ( up ) { | 541 | if ( up ) { |
546 | up = FALSE; | 542 | up = FALSE; |
547 | qpedesktop->screenClick(); | 543 | qpedesktop->screenClick(); |
548 | } | 544 | } |
549 | } | 545 | } |
550 | else { | 546 | else { |
551 | up = TRUE; | 547 | up = TRUE; |
552 | } | 548 | } |
553 | } | 549 | } |
554 | } | 550 | } |
555 | 551 | ||
556 | return QPEApplication::qwsEventFilter( e ); | 552 | return QPEApplication::qwsEventFilter( e ); |
557 | } | 553 | } |
558 | #endif | 554 | #endif |
559 | 555 | ||
560 | void DesktopApplication::psTimeout() | 556 | void DesktopApplication::psTimeout() |
561 | { | 557 | { |
562 | qpedesktop->checkMemory(); // in case no events are being generated | 558 | qpedesktop->checkMemory(); // in case no events are being generated |
563 | 559 | ||
564 | *ps = PowerStatusManager::readStatus(); | 560 | *ps = PowerStatusManager::readStatus(); |
565 | 561 | ||
566 | if ( ( ps->batteryStatus() == PowerStatus::VeryLow ) ) { | 562 | if ( ( ps->batteryStatus() == PowerStatus::VeryLow ) ) { |
567 | pa->alert( tr( "Battery is running very low." ), 6 ); | 563 | pa->alert( tr( "Battery is running very low." ), 6 ); |
568 | } | 564 | } |
569 | 565 | ||
570 | if ( ps->batteryStatus() == PowerStatus::Critical ) { | 566 | if ( ps->batteryStatus() == PowerStatus::Critical ) { |
571 | pa->alert( tr( "Battery level is critical!\n" | 567 | pa->alert( tr( "Battery level is critical!\n" |
572 | "Keep power off until power restored!" ), 1 ); | 568 | "Keep power off until power restored!" ), 1 ); |
573 | } | 569 | } |
574 | 570 | ||
575 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { | 571 | if ( ps->backupBatteryStatus() == PowerStatus::VeryLow ) { |
576 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); | 572 | pa->alert( tr( "The Back-up battery is very low.\nPlease charge the back-up battery." ), 3 ); |
577 | } | 573 | } |
578 | } | 574 | } |
579 | 575 | ||
580 | 576 | ||
581 | void DesktopApplication::sendCard() | 577 | void DesktopApplication::sendCard() |
582 | { | 578 | { |
583 | delete cardSendTimer; | 579 | delete cardSendTimer; |
584 | cardSendTimer = 0; | 580 | cardSendTimer = 0; |
585 | QString card = getenv( "HOME" ); | 581 | QString card = getenv( "HOME" ); |
586 | card += "/Applications/addressbook/businesscard.vcf"; | 582 | card += "/Applications/addressbook/businesscard.vcf"; |
587 | 583 | ||
588 | if ( QFile::exists( card ) ) { | 584 | if ( QFile::exists( card ) ) { |
589 | QCopEnvelope e( "QPE/Obex", "send(QString,QString,QString)" ); | 585 | QCopEnvelope e( "QPE/Obex", "send(QString,QString,QString)" ); |
590 | QString mimetype = "text/x-vCard"; | 586 | QString mimetype = "text/x-vCard"; |
591 | e << tr( "business card" ) << card << mimetype; | 587 | e << tr( "business card" ) << card << mimetype; |
592 | } | 588 | } |
593 | } | 589 | } |
594 | 590 | ||
595 | #if defined(QPE_HAVE_MEMALERTER) | 591 | #if defined(QPE_HAVE_MEMALERTER) |
596 | QPE_MEMALERTER_IMPL | 592 | QPE_MEMALERTER_IMPL |
597 | #endif | 593 | #endif |
598 | 594 | ||
599 | //=========================================================================== | 595 | //=========================================================================== |
600 | 596 | ||
601 | Desktop::Desktop() : | 597 | Desktop::Desktop() : |
602 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), | 598 | QWidget( 0, 0, WStyle_Tool | WStyle_Customize ), |
603 | qcopBridge( 0 ), | 599 | qcopBridge( 0 ), |
604 | transferServer( 0 ), | 600 | transferServer( 0 ), |
605 | packageSlave( 0 ) | 601 | packageSlave( 0 ) |
606 | { | 602 | { |
607 | qpedesktop = this; | 603 | qpedesktop = this; |
608 | 604 | ||
609 | // bg = new Info( this ); | 605 | // bg = new Info( this ); |
610 | tb = new TaskBar; | 606 | tb = new TaskBar; |
611 | 607 | ||
612 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); | 608 | launcher = new Launcher( 0, 0, WStyle_Customize | QWidget::WGroupLeader ); |
613 | 609 | ||
614 | connect( launcher, SIGNAL( busy() ), tb, SLOT( startWait() ) ); | 610 | connect( launcher, SIGNAL( busy() ), tb, SLOT( startWait() ) ); |
615 | connect( launcher, SIGNAL( notBusy( const QString& ) ), tb, SLOT( stopWait( const QString& ) ) ); | 611 | connect( launcher, SIGNAL( notBusy( const QString& ) ), tb, SLOT( stopWait( const QString& ) ) ); |
616 | 612 | ||
617 | int displayw = qApp->desktop() ->width(); | 613 | int displayw = qApp->desktop() ->width(); |
618 | int displayh = qApp->desktop() ->height(); | 614 | int displayh = qApp->desktop() ->height(); |
619 | 615 | ||
620 | 616 | ||
621 | QSize sz = tb->sizeHint(); | 617 | QSize sz = tb->sizeHint(); |
622 | 618 | ||
623 | setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); | 619 | setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); |
624 | tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); | 620 | tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); |
625 | 621 | ||
626 | tb->show(); | 622 | tb->show(); |
627 | launcher->showMaximized(); | 623 | launcher->showMaximized(); |
628 | launcher->show(); | 624 | launcher->show(); |
629 | launcher->raise(); | 625 | launcher->raise(); |
630 | #if defined(QPE_HAVE_MEMALERTER) | 626 | #if defined(QPE_HAVE_MEMALERTER) |
631 | 627 | ||
632 | initMemalerter(); | 628 | initMemalerter(); |
633 | #endif | 629 | #endif |
634 | // start services | 630 | // start services |
635 | startTransferServer(); | 631 | startTransferServer(); |
636 | ( void ) new IrServer( this ); | 632 | ( void ) new IrServer( this ); |
637 | rereadVolumes(); | 633 | rereadVolumes(); |
638 | 634 | ||
639 | packageSlave = new PackageSlave( this ); | 635 | packageSlave = new PackageSlave( this ); |
640 | connect( qApp, SIGNAL( volumeChanged( bool ) ), this, SLOT( rereadVolumes() ) ); | 636 | connect( qApp, SIGNAL( volumeChanged( bool ) ), this, SLOT( rereadVolumes() ) ); |
641 | 637 | ||
642 | qApp->installEventFilter( this ); | 638 | qApp->installEventFilter( this ); |
643 | 639 | ||
644 | qApp-> setMainWidget ( launcher ); | 640 | qApp-> setMainWidget ( launcher ); |
645 | } | 641 | } |
646 | 642 | ||
647 | void Desktop::show() | 643 | void Desktop::show() |
648 | { | 644 | { |
649 | login( TRUE ); | 645 | login( TRUE ); |
650 | QWidget::show(); | 646 | QWidget::show(); |
651 | } | 647 | } |
652 | 648 | ||
653 | Desktop::~Desktop() | 649 | Desktop::~Desktop() |
654 | { | 650 | { |
655 | delete launcher; | 651 | delete launcher; |
656 | delete tb; | 652 | delete tb; |
657 | delete qcopBridge; | 653 | delete qcopBridge; |
658 | delete transferServer; | 654 | delete transferServer; |
659 | } | 655 | } |
660 | 656 | ||
661 | bool Desktop::recoverMemory() | 657 | bool Desktop::recoverMemory() |
662 | { | 658 | { |
663 | return tb->recoverMemory(); | 659 | return tb->recoverMemory(); |
664 | } | 660 | } |
665 | 661 | ||
666 | void Desktop::checkMemory() | 662 | void Desktop::checkMemory() |
667 | { | 663 | { |
668 | #if defined(QPE_HAVE_MEMALERTER) | 664 | #if defined(QPE_HAVE_MEMALERTER) |
669 | static bool ignoreNormal = FALSE; | 665 | static bool ignoreNormal = FALSE; |
670 | static bool existingMessage = FALSE; | 666 | static bool existingMessage = FALSE; |
671 | 667 | ||
672 | if ( existingMessage ) | 668 | if ( existingMessage ) |
673 | return ; // don't show a second message while still on first | 669 | return ; // don't show a second message while still on first |
674 | 670 | ||
675 | existingMessage = TRUE; | 671 | existingMessage = TRUE; |
676 | switch ( memstate ) { | 672 | switch ( memstate ) { |
677 | case Unknown: | 673 | case Unknown: |
678 | break; | 674 | break; |
679 | case Low: | 675 | case Low: |
680 | memstate = Unknown; | 676 | memstate = Unknown; |
681 | if ( recoverMemory() ) | 677 | if ( recoverMemory() ) |
682 | ignoreNormal = TRUE; | 678 | ignoreNormal = TRUE; |
683 | else | 679 | else |
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp index a5955a4..5a9ee1b 100644 --- a/core/launcher/launcher.cpp +++ b/core/launcher/launcher.cpp | |||
@@ -371,513 +371,513 @@ LauncherView *CategoryTabWidget::view( const QString &id ) | |||
371 | int idx = ids.findIndex( id ); | 371 | int idx = ids.findIndex( id ); |
372 | return (LauncherView *)stack->widget(idx); | 372 | return (LauncherView *)stack->widget(idx); |
373 | } | 373 | } |
374 | 374 | ||
375 | void CategoryTabWidget::setBusyIndicatorType ( const QString &type ) | 375 | void CategoryTabWidget::setBusyIndicatorType ( const QString &type ) |
376 | { | 376 | { |
377 | for ( QStringList::Iterator it = ids. begin ( ); it != ids. end ( ); ++it ) | 377 | for ( QStringList::Iterator it = ids. begin ( ); it != ids. end ( ); ++it ) |
378 | view ( *it )-> setBusyIndicatorType ( type ); | 378 | view ( *it )-> setBusyIndicatorType ( type ); |
379 | } | 379 | } |
380 | 380 | ||
381 | //=========================================================================== | 381 | //=========================================================================== |
382 | 382 | ||
383 | CategoryTabBar::CategoryTabBar( QWidget *parent, const char *name ) | 383 | CategoryTabBar::CategoryTabBar( QWidget *parent, const char *name ) |
384 | : QTabBar( parent, name ) | 384 | : QTabBar( parent, name ) |
385 | { | 385 | { |
386 | setFocusPolicy( NoFocus ); | 386 | setFocusPolicy( NoFocus ); |
387 | connect( this, SIGNAL( selected(int) ), this, SLOT( layoutTabs() ) ); | 387 | connect( this, SIGNAL( selected(int) ), this, SLOT( layoutTabs() ) ); |
388 | } | 388 | } |
389 | 389 | ||
390 | CategoryTabBar::~CategoryTabBar() | 390 | CategoryTabBar::~CategoryTabBar() |
391 | { | 391 | { |
392 | } | 392 | } |
393 | 393 | ||
394 | void CategoryTabBar::layoutTabs() | 394 | void CategoryTabBar::layoutTabs() |
395 | { | 395 | { |
396 | if ( !count() ) | 396 | if ( !count() ) |
397 | return; | 397 | return; |
398 | 398 | ||
399 | // int percentFalloffTable[] = { 100, 70, 40, 12, 6, 3, 1, 0 }; | 399 | // int percentFalloffTable[] = { 100, 70, 40, 12, 6, 3, 1, 0 }; |
400 | int available = width()-1; | 400 | int available = width()-1; |
401 | QFontMetrics fm = fontMetrics(); | 401 | QFontMetrics fm = fontMetrics(); |
402 | int hiddenTabWidth = -7; | 402 | int hiddenTabWidth = -7; |
403 | int middleTab = currentTab(); | 403 | int middleTab = currentTab(); |
404 | int hframe, vframe, overlap; | 404 | int hframe, vframe, overlap; |
405 | style().tabbarMetrics( this, hframe, vframe, overlap ); | 405 | style().tabbarMetrics( this, hframe, vframe, overlap ); |
406 | int x = 0; | 406 | int x = 0; |
407 | QRect r; | 407 | QRect r; |
408 | QTab *t; | 408 | QTab *t; |
409 | int required = 0; | 409 | int required = 0; |
410 | int eventabwidth = (width()-1)/count(); | 410 | int eventabwidth = (width()-1)/count(); |
411 | enum Mode { HideBackText, Pack, Even } mode=Even; | 411 | enum Mode { HideBackText, Pack, Even } mode=Even; |
412 | for ( int i = 0; i < count(); i++ ) { | 412 | for ( int i = 0; i < count(); i++ ) { |
413 | t = tab(i); | 413 | t = tab(i); |
414 | int iw = fm.width( t->text() ) + hframe - overlap; | 414 | int iw = fm.width( t->text() ) + hframe - overlap; |
415 | if ( i != middleTab ) { | 415 | if ( i != middleTab ) { |
416 | available -= hiddenTabWidth + hframe - overlap; | 416 | available -= hiddenTabWidth + hframe - overlap; |
417 | if ( t->iconSet() != 0 ) | 417 | if ( t->iconSet() != 0 ) |
418 | available -= t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 418 | available -= t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
419 | } | 419 | } |
420 | if ( t->iconSet() != 0 ) | 420 | if ( t->iconSet() != 0 ) |
421 | iw += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 421 | iw += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
422 | required += iw; | 422 | required += iw; |
423 | // 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. |
424 | if ( iw >= eventabwidth-10 ) | 424 | if ( iw >= eventabwidth-10 ) |
425 | mode = Pack; | 425 | mode = Pack; |
426 | } | 426 | } |
427 | if ( mode == Pack && required > width()-1 ) | 427 | if ( mode == Pack && required > width()-1 ) |
428 | mode = HideBackText; | 428 | mode = HideBackText; |
429 | for ( int i = 0; i < count(); i++ ) { | 429 | for ( int i = 0; i < count(); i++ ) { |
430 | t = tab(i); | 430 | t = tab(i); |
431 | if ( mode != HideBackText ) { | 431 | if ( mode != HideBackText ) { |
432 | int w = fm.width( t->text() ); | 432 | int w = fm.width( t->text() ); |
433 | int ih = 0; | 433 | int ih = 0; |
434 | if ( t->iconSet() != 0 ) { | 434 | if ( t->iconSet() != 0 ) { |
435 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 435 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
436 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 436 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
437 | } | 437 | } |
438 | int h = QMAX( fm.height(), ih ); | 438 | int h = QMAX( fm.height(), ih ); |
439 | h = QMAX( h, QApplication::globalStrut().height() ); | 439 | h = QMAX( h, QApplication::globalStrut().height() ); |
440 | 440 | ||
441 | h += vframe; | 441 | h += vframe; |
442 | w += hframe; | 442 | w += hframe; |
443 | 443 | ||
444 | QRect tr(x, 0, | 444 | QRect tr(x, 0, |
445 | mode == Even ? eventabwidth : w * (width()-1)/required, h); | 445 | mode == Even ? eventabwidth : w * (width()-1)/required, h); |
446 | t->setRect(tr); | 446 | t->setRect(tr); |
447 | x += tr.width() - overlap; | 447 | x += tr.width() - overlap; |
448 | r = r.unite(tr); | 448 | r = r.unite(tr); |
449 | } else if ( i != middleTab ) { | 449 | } else if ( i != middleTab ) { |
450 | int w = hiddenTabWidth; | 450 | int w = hiddenTabWidth; |
451 | int ih = 0; | 451 | int ih = 0; |
452 | if ( t->iconSet() != 0 ) { | 452 | if ( t->iconSet() != 0 ) { |
453 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); | 453 | w += t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width(); |
454 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 454 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
455 | } | 455 | } |
456 | int h = QMAX( fm.height(), ih ); | 456 | int h = QMAX( fm.height(), ih ); |
457 | h = QMAX( h, QApplication::globalStrut().height() ); | 457 | h = QMAX( h, QApplication::globalStrut().height() ); |
458 | 458 | ||
459 | h += vframe; | 459 | h += vframe; |
460 | w += hframe; | 460 | w += hframe; |
461 | 461 | ||
462 | t->setRect( QRect(x, 0, w, h) ); | 462 | t->setRect( QRect(x, 0, w, h) ); |
463 | x += t->rect().width() - overlap; | 463 | x += t->rect().width() - overlap; |
464 | r = r.unite( t->rect() ); | 464 | r = r.unite( t->rect() ); |
465 | } else { | 465 | } else { |
466 | int ih = 0; | 466 | int ih = 0; |
467 | if ( t->iconSet() != 0 ) { | 467 | if ( t->iconSet() != 0 ) { |
468 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 468 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
469 | } | 469 | } |
470 | int h = QMAX( fm.height(), ih ); | 470 | int h = QMAX( fm.height(), ih ); |
471 | h = QMAX( h, QApplication::globalStrut().height() ); | 471 | h = QMAX( h, QApplication::globalStrut().height() ); |
472 | 472 | ||
473 | h += vframe; | 473 | h += vframe; |
474 | 474 | ||
475 | t->setRect( QRect(x, 0, available, h) ); | 475 | t->setRect( QRect(x, 0, available, h) ); |
476 | x += t->rect().width() - overlap; | 476 | x += t->rect().width() - overlap; |
477 | r = r.unite( t->rect() ); | 477 | r = r.unite( t->rect() ); |
478 | } | 478 | } |
479 | } | 479 | } |
480 | 480 | ||
481 | QRect rr = tab(count()-1)->rect(); | 481 | QRect rr = tab(count()-1)->rect(); |
482 | rr.setRight(width()-1); | 482 | rr.setRight(width()-1); |
483 | tab(count()-1)->setRect( rr ); | 483 | tab(count()-1)->setRect( rr ); |
484 | 484 | ||
485 | for ( t = tabList()->first(); t; t = tabList()->next() ) { | 485 | for ( t = tabList()->first(); t; t = tabList()->next() ) { |
486 | QRect tr = t->rect(); | 486 | QRect tr = t->rect(); |
487 | tr.setHeight( r.height() ); | 487 | tr.setHeight( r.height() ); |
488 | t->setRect( tr ); | 488 | t->setRect( tr ); |
489 | } | 489 | } |
490 | 490 | ||
491 | update(); | 491 | update(); |
492 | } | 492 | } |
493 | 493 | ||
494 | 494 | ||
495 | void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const | 495 | void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const |
496 | { | 496 | { |
497 | CategoryTabBar *that = (CategoryTabBar *) this; | 497 | CategoryTabBar *that = (CategoryTabBar *) this; |
498 | CategoryTab *ct = (CategoryTab *)t; | 498 | CategoryTab *ct = (CategoryTab *)t; |
499 | QPalette pal = palette(); | 499 | QPalette pal = palette(); |
500 | bool setPal = FALSE; | 500 | bool setPal = FALSE; |
501 | if ( ct->bgColor.isValid() ) { | 501 | if ( ct->bgColor.isValid() ) { |
502 | pal.setColor( QPalette::Active, QColorGroup::Background, ct->bgColor ); | 502 | pal.setColor( QPalette::Active, QColorGroup::Background, ct->bgColor ); |
503 | pal.setColor( QPalette::Active, QColorGroup::Button, ct->bgColor ); | 503 | pal.setColor( QPalette::Active, QColorGroup::Button, ct->bgColor ); |
504 | pal.setColor( QPalette::Inactive, QColorGroup::Background, ct->bgColor ); | 504 | pal.setColor( QPalette::Inactive, QColorGroup::Background, ct->bgColor ); |
505 | pal.setColor( QPalette::Inactive, QColorGroup::Button, ct->bgColor ); | 505 | pal.setColor( QPalette::Inactive, QColorGroup::Button, ct->bgColor ); |
506 | that->setUpdatesEnabled( FALSE ); | 506 | that->setUpdatesEnabled( FALSE ); |
507 | that->setPalette( pal ); | 507 | that->setPalette( pal ); |
508 | setPal = TRUE; | 508 | setPal = TRUE; |
509 | } | 509 | } |
510 | #if QT_VERSION >= 300 | 510 | #if QT_VERSION >= 300 |
511 | QStyle::SFlags flags = QStyle::Style_Default; | 511 | QStyle::SFlags flags = QStyle::Style_Default; |
512 | if ( selected ) | 512 | if ( selected ) |
513 | flags |= QStyle::Style_Selected; | 513 | flags |= QStyle::Style_Selected; |
514 | style().drawControl( QStyle::CE_TabBarTab, p, this, t->rect(), | 514 | style().drawControl( QStyle::CE_TabBarTab, p, this, t->rect(), |
515 | colorGroup(), flags, QStyleOption(t) ); | 515 | colorGroup(), flags, QStyleOption(t) ); |
516 | #else | 516 | #else |
517 | style().drawTab( p, this, t, selected ); | 517 | style().drawTab( p, this, t, selected ); |
518 | #endif | 518 | #endif |
519 | 519 | ||
520 | QRect r( t->rect() ); | 520 | QRect r( t->rect() ); |
521 | QFont f( font() ); | 521 | QFont f( font() ); |
522 | if ( selected ) | 522 | if ( selected ) |
523 | f.setBold( TRUE ); | 523 | f.setBold( TRUE ); |
524 | p->setFont( f ); | 524 | p->setFont( f ); |
525 | 525 | ||
526 | if ( ct->fgColor.isValid() ) { | 526 | if ( ct->fgColor.isValid() ) { |
527 | pal.setColor( QPalette::Active, QColorGroup::Foreground, ct->fgColor ); | 527 | pal.setColor( QPalette::Active, QColorGroup::Foreground, ct->fgColor ); |
528 | pal.setColor( QPalette::Inactive, QColorGroup::Foreground, ct->fgColor ); | 528 | pal.setColor( QPalette::Inactive, QColorGroup::Foreground, ct->fgColor ); |
529 | that->setUpdatesEnabled( FALSE ); | 529 | that->setUpdatesEnabled( FALSE ); |
530 | that->setPalette( pal ); | 530 | that->setPalette( pal ); |
531 | setPal = TRUE; | 531 | setPal = TRUE; |
532 | } | 532 | } |
533 | int iw = 0; | 533 | int iw = 0; |
534 | int ih = 0; | 534 | int ih = 0; |
535 | if ( t->iconSet() != 0 ) { | 535 | if ( t->iconSet() != 0 ) { |
536 | iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; | 536 | iw = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).width() + 2; |
537 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); | 537 | ih = t->iconSet()->pixmap( QIconSet::Small, QIconSet::Normal ).height(); |
538 | } | 538 | } |
539 | int w = iw + p->fontMetrics().width( t->text() ) + 4; | 539 | int w = iw + p->fontMetrics().width( t->text() ) + 4; |
540 | int h = QMAX(p->fontMetrics().height() + 4, ih ); | 540 | int h = QMAX(p->fontMetrics().height() + 4, ih ); |
541 | paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, | 541 | paintLabel( p, QRect( r.left() + (r.width()-w)/2 - 3, |
542 | r.top() + (r.height()-h)/2, w, h ), t, | 542 | r.top() + (r.height()-h)/2, w, h ), t, |
543 | #if QT_VERSION >= 300 | 543 | #if QT_VERSION >= 300 |
544 | t->identifier() == keyboardFocusTab() | 544 | t->identifier() == keyboardFocusTab() |
545 | #else | 545 | #else |
546 | t->identitifer() == keyboardFocusTab() | 546 | t->identitifer() == keyboardFocusTab() |
547 | #endif | 547 | #endif |
548 | ); | 548 | ); |
549 | if ( setPal ) { | 549 | if ( setPal ) { |
550 | that->unsetPalette(); | 550 | that->unsetPalette(); |
551 | that->setUpdatesEnabled( TRUE ); | 551 | that->setUpdatesEnabled( TRUE ); |
552 | } | 552 | } |
553 | } | 553 | } |
554 | 554 | ||
555 | 555 | ||
556 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, | 556 | void CategoryTabBar::paintLabel( QPainter* p, const QRect&, |
557 | QTab* t, bool has_focus ) const | 557 | QTab* t, bool has_focus ) const |
558 | { | 558 | { |
559 | QRect r = t->rect(); | 559 | QRect r = t->rect(); |
560 | // if ( t->id != currentTab() ) | 560 | // if ( t->id != currentTab() ) |
561 | //r.moveBy( 1, 1 ); | 561 | //r.moveBy( 1, 1 ); |
562 | // | 562 | // |
563 | if ( t->iconSet() ) { | 563 | if ( t->iconSet() ) { |
564 | // the tab has an iconset, draw it in the right mode | 564 | // the tab has an iconset, draw it in the right mode |
565 | QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; | 565 | QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; |
566 | if ( mode == QIconSet::Normal && has_focus ) | 566 | if ( mode == QIconSet::Normal && has_focus ) |
567 | mode = QIconSet::Active; | 567 | mode = QIconSet::Active; |
568 | QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); | 568 | QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); |
569 | int pixw = pixmap.width(); | 569 | int pixw = pixmap.width(); |
570 | int pixh = pixmap.height(); | 570 | int pixh = pixmap.height(); |
571 | 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 ); |
572 | r.setLeft( r.left() + pixw + 5 ); | 572 | r.setLeft( r.left() + pixw + 5 ); |
573 | } | 573 | } |
574 | 574 | ||
575 | QRect tr = r; | 575 | QRect tr = r; |
576 | 576 | ||
577 | if ( r.width() < 20 ) | 577 | if ( r.width() < 20 ) |
578 | return; | 578 | return; |
579 | 579 | ||
580 | if ( t->isEnabled() && isEnabled() ) { | 580 | if ( t->isEnabled() && isEnabled() ) { |
581 | #if defined(_WS_WIN32_) | 581 | #if defined(_WS_WIN32_) |
582 | if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) | 582 | if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) |
583 | p->setPen( colorGroup().buttonText() ); | 583 | p->setPen( colorGroup().buttonText() ); |
584 | else | 584 | else |
585 | p->setPen( colorGroup().foreground() ); | 585 | p->setPen( colorGroup().foreground() ); |
586 | #else | 586 | #else |
587 | p->setPen( colorGroup().foreground() ); | 587 | p->setPen( colorGroup().foreground() ); |
588 | #endif | 588 | #endif |
589 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); | 589 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); |
590 | } else { | 590 | } else { |
591 | p->setPen( palette().disabled().foreground() ); | 591 | p->setPen( palette().disabled().foreground() ); |
592 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); | 592 | p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); |
593 | } | 593 | } |
594 | } | 594 | } |
595 | 595 | ||
596 | //--------------------------------------------------------------------------- | 596 | //--------------------------------------------------------------------------- |
597 | 597 | ||
598 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) | 598 | Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) |
599 | : QMainWindow( parent, name, fl ) | 599 | : QMainWindow( parent, name, fl ) |
600 | { | 600 | { |
601 | setCaption( tr("Launcher") ); | 601 | setCaption( tr("Launcher") ); |
602 | 602 | ||
603 | syncDialog = 0; | 603 | syncDialog = 0; |
604 | 604 | ||
605 | // we have a pretty good idea how big we'll be | 605 | // we have a pretty good idea how big we'll be |
606 | setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); | 606 | setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); |
607 | 607 | ||
608 | tabs = 0; | 608 | tabs = 0; |
609 | rootFolder = 0; | 609 | rootFolder = 0; |
610 | docsFolder = 0; | 610 | docsFolder = 0; |
611 | 611 | ||
612 | 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 |
613 | //uidgen.store( stamp ); | 613 | //uidgen.store( stamp ); |
614 | m_timeStamp = QString::number( stamp ); | 614 | m_timeStamp = QString::number( stamp ); |
615 | 615 | ||
616 | tabs = new CategoryTabWidget( this ); | 616 | tabs = new CategoryTabWidget( this ); |
617 | tabs->setMaximumWidth( qApp->desktop()->width() ); | 617 | tabs->setMaximumWidth( qApp->desktop()->width() ); |
618 | setCentralWidget( tabs ); | 618 | setCentralWidget( tabs ); |
619 | 619 | ||
620 | connect( tabs, SIGNAL(selected(const QString&)), | 620 | connect( tabs, SIGNAL(selected(const QString&)), |
621 | this, SLOT(viewSelected(const QString&)) ); | 621 | this, SLOT(viewSelected(const QString&)) ); |
622 | connect( tabs, SIGNAL(clicked(const AppLnk*)), | 622 | connect( tabs, SIGNAL(clicked(const AppLnk*)), |
623 | this, SLOT(select(const AppLnk*))); | 623 | this, SLOT(select(const AppLnk*))); |
624 | connect( tabs, SIGNAL(rightPressed(AppLnk*)), | 624 | connect( tabs, SIGNAL(rightPressed(AppLnk*)), |
625 | this, SLOT(properties(AppLnk*))); | 625 | this, SLOT(properties(AppLnk*))); |
626 | 626 | ||
627 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 627 | #if !defined(QT_NO_COP) |
628 | QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); | 628 | QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); |
629 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 629 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
630 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); | 630 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); |
631 | QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); | 631 | QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); |
632 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 632 | connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
633 | this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); | 633 | this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); |
634 | #endif | 634 | #endif |
635 | 635 | ||
636 | storage = new StorageInfo( this ); | 636 | storage = new StorageInfo( this ); |
637 | connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); | 637 | connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); |
638 | 638 | ||
639 | updateTabs(); | 639 | updateTabs(); |
640 | 640 | ||
641 | preloadApps(); | 641 | preloadApps(); |
642 | 642 | ||
643 | in_lnk_props = FALSE; | 643 | in_lnk_props = FALSE; |
644 | got_lnk_change = FALSE; | 644 | got_lnk_change = FALSE; |
645 | } | 645 | } |
646 | 646 | ||
647 | Launcher::~Launcher() | 647 | Launcher::~Launcher() |
648 | { | 648 | { |
649 | delete rootFolder; | 649 | delete rootFolder; |
650 | delete docsFolder; | 650 | delete docsFolder; |
651 | } | 651 | } |
652 | 652 | ||
653 | static bool isVisibleWindow(int wid) | 653 | static bool isVisibleWindow(int wid) |
654 | { | 654 | { |
655 | #ifdef QWS | 655 | #ifdef QWS |
656 | const QList<QWSWindow> &list = qwsServer->clientWindows(); | 656 | const QList<QWSWindow> &list = qwsServer->clientWindows(); |
657 | QWSWindow* w; | 657 | QWSWindow* w; |
658 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { | 658 | for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { |
659 | if ( w->winId() == wid ) | 659 | if ( w->winId() == wid ) |
660 | return !w->isFullyObscured(); | 660 | return !w->isFullyObscured(); |
661 | } | 661 | } |
662 | #endif | 662 | #endif |
663 | return FALSE; | 663 | return FALSE; |
664 | } | 664 | } |
665 | 665 | ||
666 | void Launcher::showMaximized() | 666 | void Launcher::showMaximized() |
667 | { | 667 | { |
668 | if ( isVisibleWindow( winId() ) ) | 668 | if ( isVisibleWindow( winId() ) ) |
669 | doMaximize(); | 669 | doMaximize(); |
670 | else | 670 | else |
671 | QTimer::singleShot( 20, this, SLOT(doMaximize()) ); | 671 | QTimer::singleShot( 20, this, SLOT(doMaximize()) ); |
672 | } | 672 | } |
673 | 673 | ||
674 | void Launcher::doMaximize() | 674 | void Launcher::doMaximize() |
675 | { | 675 | { |
676 | QMainWindow::showMaximized(); | 676 | QMainWindow::showMaximized(); |
677 | } | 677 | } |
678 | 678 | ||
679 | void Launcher::updateMimeTypes() | 679 | void Launcher::updateMimeTypes() |
680 | { | 680 | { |
681 | MimeType::clear(); | 681 | MimeType::clear(); |
682 | updateMimeTypes(rootFolder); | 682 | updateMimeTypes(rootFolder); |
683 | } | 683 | } |
684 | 684 | ||
685 | void Launcher::updateMimeTypes(AppLnkSet* folder) | 685 | void Launcher::updateMimeTypes(AppLnkSet* folder) |
686 | { | 686 | { |
687 | for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { | 687 | for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { |
688 | AppLnk *app = it.current(); | 688 | AppLnk *app = it.current(); |
689 | if ( app->type() == "Folder" ) // No tr | 689 | if ( app->type() == "Folder" ) // No tr |
690 | updateMimeTypes((AppLnkSet *)app); | 690 | updateMimeTypes((AppLnkSet *)app); |
691 | else { | 691 | else { |
692 | MimeType::registerApp(*app); | 692 | MimeType::registerApp(*app); |
693 | } | 693 | } |
694 | } | 694 | } |
695 | } | 695 | } |
696 | 696 | ||
697 | /** This is a HACK.... | 697 | /** This is a HACK.... |
698 | * Reason: scanning huge mediums, microdirvers for examples | 698 | * Reason: scanning huge mediums, microdirvers for examples |
699 | * consomes time. To avoid that we invented the MediumMountCheck | 699 | * consomes time. To avoid that we invented the MediumMountCheck |
700 | * | 700 | * |
701 | * a) the user globally disabled medium checking. We can ignore | 701 | * a) the user globally disabled medium checking. We can ignore |
702 | * all removable medium | 702 | * all removable medium |
703 | * 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 |
704 | * c) the user enabled medium checking on a per medium bases | 704 | * c) the user enabled medium checking on a per medium bases |
705 | * c1) we already checked and its not ask again turns | 705 | * c1) we already checked and its not ask again turns |
706 | * c2) we need to ask and then apply the mimefilter | 706 | * c2) we need to ask and then apply the mimefilter |
707 | */ | 707 | */ |
708 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: | 708 | void Launcher::loadDocs() // ok here comes a hack belonging to Global:: |
709 | { | 709 | { |
710 | delete docsFolder; | 710 | delete docsFolder; |
711 | docsFolder = new DocLnkSet; | 711 | docsFolder = new DocLnkSet; |
712 | 712 | ||
713 | DocLnkSet *tmp = 0; | 713 | DocLnkSet *tmp = 0; |
714 | QString home = QString(getenv("HOME")) + "/Documents"; | 714 | QString home = QString(getenv("HOME")) + "/Documents"; |
715 | tmp = new DocLnkSet( home , QString::null); | 715 | tmp = new DocLnkSet( home , QString::null); |
716 | docsFolder->appendFrom( *tmp ); | 716 | docsFolder->appendFrom( *tmp ); |
717 | delete tmp; | 717 | delete tmp; |
718 | 718 | ||
719 | // RAM documents | 719 | // RAM documents |
720 | StorageInfo storage; | 720 | StorageInfo storage; |
721 | const QList<FileSystem> &fileSystems = storage.fileSystems(); | 721 | const QList<FileSystem> &fileSystems = storage.fileSystems(); |
722 | QListIterator<FileSystem> it ( fileSystems ); | 722 | QListIterator<FileSystem> it ( fileSystems ); |
723 | 723 | ||
724 | for ( ; it.current(); ++it ) { | 724 | for ( ; it.current(); ++it ) { |
725 | if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { | 725 | if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { |
726 | tmp = new DocLnkSet( (*it)->path(), QString::null ); | 726 | tmp = new DocLnkSet( (*it)->path(), QString::null ); |
727 | docsFolder->appendFrom( *tmp ); | 727 | docsFolder->appendFrom( *tmp ); |
728 | delete tmp; | 728 | delete tmp; |
729 | } | 729 | } |
730 | } | 730 | } |
731 | 731 | ||
732 | Config mediumCfg( "medium"); | 732 | Config mediumCfg( "medium"); |
733 | mediumCfg.setGroup("main"); | 733 | mediumCfg.setGroup("main"); |
734 | // a) -zecke we don't want to check | 734 | // a) -zecke we don't want to check |
735 | if(!mediumCfg.readBoolEntry("use", true ) ) | 735 | if(!mediumCfg.readBoolEntry("use", true ) ) |
736 | return; | 736 | return; |
737 | 737 | ||
738 | // find out wich filesystems are new in this round | 738 | // find out wich filesystems are new in this round |
739 | // We will do this by having a timestamp inside each mountpoint | 739 | // We will do this by having a timestamp inside each mountpoint |
740 | // 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 |
741 | // come up with our MediumMountGui :) let the hacking begin | 741 | // come up with our MediumMountGui :) let the hacking begin |
742 | int stamp = uidgen.generate(); | 742 | int stamp = uidgen.generate(); |
743 | 743 | ||
744 | QString newStamp = QString::number( stamp ); // generates newtime Stamp | 744 | QString newStamp = QString::number( stamp ); // generates newtime Stamp |
745 | 745 | ||
746 | // b) | 746 | // b) |
747 | if( mediumCfg.readBoolEntry("global", true ) ){ | 747 | if( mediumCfg.readBoolEntry("global", true ) ){ |
748 | QString mime = configToMime(&mediumCfg).join(";"); | 748 | QString mime = configToMime(&mediumCfg).join(";"); |
749 | for( it.toFirst(); it.current(); ++it ){ | 749 | for( it.toFirst(); it.current(); ++it ){ |
750 | if( (*it)->isRemovable() ){ | 750 | if( (*it)->isRemovable() ){ |
751 | tmp = new DocLnkSet( (*it)->path(), mime ); | 751 | tmp = new DocLnkSet( (*it)->path(), mime ); |
752 | docsFolder->appendFrom( *tmp ); | 752 | docsFolder->appendFrom( *tmp ); |
753 | delete tmp; | 753 | delete tmp; |
754 | } | 754 | } |
755 | } // done | 755 | } // done |
756 | return; // save the else | 756 | return; // save the else |
757 | } | 757 | } |
758 | // c) zecke | 758 | // c) zecke |
759 | for ( it.toFirst(); it.current(); ++it ) { | 759 | for ( it.toFirst(); it.current(); ++it ) { |
760 | 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 |
761 | Config cfg( (*it)->path() + "/.opiestorage.cf", Config::File); | 761 | Config cfg( (*it)->path() + "/.opiestorage.cf", Config::File); |
762 | cfg.setGroup("main"); | 762 | cfg.setGroup("main"); |
763 | QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); | 763 | QString stamp = cfg.readEntry("timestamp", QDateTime::currentDateTime().toString() ); |
764 | /** This medium is uptodate | 764 | /** This medium is uptodate |
765 | */ | 765 | */ |
766 | if( stamp == m_timeStamp ){ // ok we know this card | 766 | if( stamp == m_timeStamp ){ // ok we know this card |
767 | cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp | 767 | cfg.writeEntry("timestamp", newStamp ); //just write a new timestamp |
768 | // 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 |
769 | // read the mimetypes from the config and search for documents | 769 | // read the mimetypes from the config and search for documents |
770 | QStringList mimetypes = configToMime( &cfg); | 770 | QStringList mimetypes = configToMime( &cfg); |
771 | tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); | 771 | tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); |
772 | docsFolder->appendFrom( *tmp ); | 772 | docsFolder->appendFrom( *tmp ); |
773 | delete tmp; | 773 | delete tmp; |
774 | 774 | ||
775 | }else{ // come up with the gui cause this a new card | 775 | }else{ // come up with the gui cause this a new card |
776 | MediumMountGui medium(&cfg, (*it)->path() ); | 776 | MediumMountGui medium(&cfg, (*it)->path() ); |
777 | 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 |
778 | /** c2) */ | 778 | /** c2) */ |
779 | if( medium.exec() ){ // he clicked yes so search it | 779 | if( medium.exec() ){ // he clicked yes so search it |
780 | // speicher | 780 | // speicher |
781 | //cfg.read(); // cause of a race we need to reread - fixed | 781 | //cfg.read(); // cause of a race we need to reread - fixed |
782 | cfg.setGroup("main"); | 782 | cfg.setGroup("main"); |
783 | cfg.writeEntry("timestamp", newStamp ); | 783 | cfg.writeEntry("timestamp", newStamp ); |
784 | cfg.write(); | 784 | cfg.write(); |
785 | tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); | 785 | tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); |
786 | docsFolder->appendFrom( *tmp ); | 786 | docsFolder->appendFrom( *tmp ); |
787 | delete tmp; | 787 | delete tmp; |
788 | }// no else | 788 | }// no else |
789 | /** c1) */ | 789 | /** c1) */ |
790 | }else{ // we checked | 790 | }else{ // we checked |
791 | // do something different see what we need to do | 791 | // do something different see what we need to do |
792 | // let's see if we should check the device | 792 | // let's see if we should check the device |
793 | cfg.setGroup("main" ); | 793 | cfg.setGroup("main" ); |
794 | bool check = cfg.readBoolEntry("autocheck", true ); | 794 | bool check = cfg.readBoolEntry("autocheck", true ); |
795 | if( check ){ // find the documents | 795 | if( check ){ // find the documents |
796 | tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); | 796 | tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); |
797 | docsFolder->appendFrom( *tmp ); | 797 | docsFolder->appendFrom( *tmp ); |
798 | delete tmp; | 798 | delete tmp; |
799 | } | 799 | } |
800 | } | 800 | } |
801 | } | 801 | } |
802 | } | 802 | } |
803 | } | 803 | } |
804 | m_timeStamp = newStamp; | 804 | m_timeStamp = newStamp; |
805 | } | 805 | } |
806 | 806 | ||
807 | void Launcher::updateTabs() | 807 | void Launcher::updateTabs() |
808 | { | 808 | { |
809 | MimeType::updateApplications(); // ### reads all applnks twice | 809 | MimeType::updateApplications(); // ### reads all applnks twice |
810 | 810 | ||
811 | delete rootFolder; | 811 | delete rootFolder; |
812 | rootFolder = new AppLnkSet( MimeType::appsFolderName() ); | 812 | rootFolder = new AppLnkSet( MimeType::appsFolderName() ); |
813 | 813 | ||
814 | loadDocs(); | 814 | loadDocs(); |
815 | 815 | ||
816 | tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); | 816 | tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); |
817 | } | 817 | } |
818 | 818 | ||
819 | void Launcher::updateDocs() | 819 | void Launcher::updateDocs() |
820 | { | 820 | { |
821 | loadDocs(); | 821 | loadDocs(); |
822 | tabs->updateDocs(docsFolder,storage->fileSystems()); | 822 | tabs->updateDocs(docsFolder,storage->fileSystems()); |
823 | } | 823 | } |
824 | 824 | ||
825 | void Launcher::viewSelected(const QString& s) | 825 | void Launcher::viewSelected(const QString& s) |
826 | { | 826 | { |
827 | setCaption( s + tr(" - Launcher") ); | 827 | setCaption( s + tr(" - Launcher") ); |
828 | } | 828 | } |
829 | 829 | ||
830 | void Launcher::nextView() | 830 | void Launcher::nextView() |
831 | { | 831 | { |
832 | tabs->nextTab(); | 832 | tabs->nextTab(); |
833 | } | 833 | } |
834 | 834 | ||
835 | 835 | ||
836 | void Launcher::select( const AppLnk *appLnk ) | 836 | void Launcher::select( const AppLnk *appLnk ) |
837 | { | 837 | { |
838 | if ( appLnk->type() == "Folder" ) { // No tr | 838 | if ( appLnk->type() == "Folder" ) { // No tr |
839 | // Not supported: flat is simpler for the user | 839 | // Not supported: flat is simpler for the user |
840 | } else { | 840 | } else { |
841 | if ( appLnk->exec().isNull() ) { | 841 | if ( appLnk->exec().isNull() ) { |
842 | QMessageBox::information(this,tr("No application"), | 842 | QMessageBox::information(this,tr("No application"), |
843 | tr("<p>No application is defined for this document." | 843 | tr("<p>No application is defined for this document." |
844 | "<p>Type is %1.").arg(appLnk->type())); | 844 | "<p>Type is %1.").arg(appLnk->type())); |
845 | return; | 845 | return; |
846 | } | 846 | } |
847 | tabs->setBusy(TRUE); | 847 | tabs->setBusy(TRUE); |
848 | emit executing( appLnk ); | 848 | emit executing( appLnk ); |
849 | appLnk->execute(); | 849 | appLnk->execute(); |
850 | } | 850 | } |
851 | } | 851 | } |
852 | 852 | ||
853 | void Launcher::externalSelected(const AppLnk *appLnk) | 853 | void Launcher::externalSelected(const AppLnk *appLnk) |
854 | { | 854 | { |
855 | tabs->setBusy(TRUE); | 855 | tabs->setBusy(TRUE); |
856 | emit executing( appLnk ); | 856 | emit executing( appLnk ); |
857 | } | 857 | } |
858 | 858 | ||
859 | void Launcher::properties( AppLnk *appLnk ) | 859 | void Launcher::properties( AppLnk *appLnk ) |
860 | { | 860 | { |
861 | if ( appLnk->type() == "Folder" ) { // No tr | 861 | if ( appLnk->type() == "Folder" ) { // No tr |
862 | // Not supported: flat is simpler for the user | 862 | // Not supported: flat is simpler for the user |
863 | } else { | 863 | } else { |
864 | in_lnk_props = TRUE; | 864 | in_lnk_props = TRUE; |
865 | got_lnk_change = FALSE; | 865 | got_lnk_change = FALSE; |
866 | LnkProperties prop(appLnk); | 866 | LnkProperties prop(appLnk); |
867 | connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); | 867 | connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); |
868 | prop.showMaximized(); | 868 | prop.showMaximized(); |
869 | prop.exec(); | 869 | prop.exec(); |
870 | in_lnk_props = FALSE; | 870 | in_lnk_props = FALSE; |
871 | if ( got_lnk_change ) { | 871 | if ( got_lnk_change ) { |
872 | updateLink(lnk_change); | 872 | updateLink(lnk_change); |
873 | } | 873 | } |
874 | } | 874 | } |
875 | } | 875 | } |
876 | 876 | ||
877 | void Launcher::updateLink(const QString& link) | 877 | void Launcher::updateLink(const QString& link) |
878 | { | 878 | { |
879 | if (link.isNull()) | 879 | if (link.isNull()) |
880 | updateTabs(); | 880 | updateTabs(); |
881 | else if (link.isEmpty()) | 881 | else if (link.isEmpty()) |
882 | updateDocs(); | 882 | updateDocs(); |
883 | else | 883 | else |