author | kergoth <kergoth> | 2003-04-21 17:15:01 (UTC) |
---|---|---|
committer | kergoth <kergoth> | 2003-04-21 17:15:01 (UTC) |
commit | b3ec819dfed40b05b2bea1b1392de774bc1f572d (patch) (unidiff) | |
tree | c0e30307ba6623f49cda10ce35e7f3323b4062f8 | |
parent | eecb4b6d3c22466f273c3498b6370b1e1c67c726 (diff) | |
download | opie-b3ec819dfed40b05b2bea1b1392de774bc1f572d.zip opie-b3ec819dfed40b05b2bea1b1392de774bc1f572d.tar.gz opie-b3ec819dfed40b05b2bea1b1392de774bc1f572d.tar.bz2 |
Final fix for the suspend bug
-rw-r--r-- | libopie/odevice.cpp | 20 |
1 files changed, 6 insertions, 14 deletions
diff --git a/libopie/odevice.cpp b/libopie/odevice.cpp index 501b601..62e3569 100644 --- a/libopie/odevice.cpp +++ b/libopie/odevice.cpp | |||
@@ -27,66 +27,64 @@ | |||
27 | #include <math.h> | 27 | #include <math.h> |
28 | 28 | ||
29 | #include <qapplication.h> | 29 | #include <qapplication.h> |
30 | 30 | ||
31 | #include <qfile.h> | 31 | #include <qfile.h> |
32 | #include <qtextstream.h> | 32 | #include <qtextstream.h> |
33 | #include <qpe/sound.h> | 33 | #include <qpe/sound.h> |
34 | #include <qpe/resource.h> | 34 | #include <qpe/resource.h> |
35 | #include <qpe/config.h> | 35 | #include <qpe/config.h> |
36 | #include <qpe/qcopenvelope_qws.h> | 36 | #include <qpe/qcopenvelope_qws.h> |
37 | 37 | ||
38 | #include "odevice.h" | 38 | #include "odevice.h" |
39 | 39 | ||
40 | #include <qwindowsystem_qws.h> | 40 | #include <qwindowsystem_qws.h> |
41 | 41 | ||
42 | #ifndef ARRAY_SIZE | 42 | #ifndef ARRAY_SIZE |
43 | #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) | 43 | #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) |
44 | #endif | 44 | #endif |
45 | 45 | ||
46 | // _IO and friends are only defined in kernel headers ... | 46 | // _IO and friends are only defined in kernel headers ... |
47 | 47 | ||
48 | #define OD_IOC(dir,type,number,size) (( dir << 30 ) | ( type << 8 ) | ( number ) | ( size << 16 )) | 48 | #define OD_IOC(dir,type,number,size) (( dir << 30 ) | ( type << 8 ) | ( number ) | ( size << 16 )) |
49 | 49 | ||
50 | #define OD_IO(type,number) OD_IOC(0,type,number,0) | 50 | #define OD_IO(type,number) OD_IOC(0,type,number,0) |
51 | #define OD_IOW(type,number,size) OD_IOC(1,type,number,sizeof(size)) | 51 | #define OD_IOW(type,number,size) OD_IOC(1,type,number,sizeof(size)) |
52 | #define OD_IOR(type,number,size) OD_IOC(2,type,number,sizeof(size)) | 52 | #define OD_IOR(type,number,size) OD_IOC(2,type,number,sizeof(size)) |
53 | #define OD_IORW(type,number,size) OD_IOC(3,type,number,sizeof(size)) | 53 | #define OD_IORW(type,number,size) OD_IOC(3,type,number,sizeof(size)) |
54 | 54 | ||
55 | using namespace Opie; | 55 | using namespace Opie; |
56 | 56 | ||
57 | class ODeviceData { | 57 | class ODeviceData { |
58 | public: | 58 | public: |
59 | bool m_qwsserver : 1; | ||
60 | |||
61 | QString m_vendorstr; | 59 | QString m_vendorstr; |
62 | OVendor m_vendor; | 60 | OVendor m_vendor; |
63 | 61 | ||
64 | QString m_modelstr; | 62 | QString m_modelstr; |
65 | OModel m_model; | 63 | OModel m_model; |
66 | 64 | ||
67 | QString m_systemstr; | 65 | QString m_systemstr; |
68 | OSystem m_system; | 66 | OSystem m_system; |
69 | 67 | ||
70 | QString m_sysverstr; | 68 | QString m_sysverstr; |
71 | 69 | ||
72 | Transformation m_rotation; | 70 | Transformation m_rotation; |
73 | ODirection m_direction; | 71 | ODirection m_direction; |
74 | 72 | ||
75 | QValueList <ODeviceButton> *m_buttons; | 73 | QValueList <ODeviceButton> *m_buttons; |
76 | uint m_holdtime; | 74 | uint m_holdtime; |
77 | }; | 75 | }; |
78 | 76 | ||
79 | 77 | ||
80 | class iPAQ : public ODevice, public QWSServer::KeyboardFilter { | 78 | class iPAQ : public ODevice, public QWSServer::KeyboardFilter { |
81 | protected: | 79 | protected: |
82 | virtual void init ( ); | 80 | virtual void init ( ); |
83 | virtual void initButtons ( ); | 81 | virtual void initButtons ( ); |
84 | 82 | ||
85 | public: | 83 | public: |
86 | virtual bool setSoftSuspend ( bool soft ); | 84 | virtual bool setSoftSuspend ( bool soft ); |
87 | 85 | ||
88 | virtual bool setDisplayBrightness ( int b ); | 86 | virtual bool setDisplayBrightness ( int b ); |
89 | virtual int displayBrightnessResolution ( ) const; | 87 | virtual int displayBrightnessResolution ( ) const; |
90 | 88 | ||
91 | virtual void alarmSound ( ); | 89 | virtual void alarmSound ( ); |
92 | 90 | ||
@@ -210,185 +208,183 @@ struct z_button { | |||
210 | 208 | ||
211 | struct z_button z_buttons_c700 [] = { | 209 | struct z_button z_buttons_c700 [] = { |
212 | { Qt::Key_F9, QT_TRANSLATE_NOOP("Button", "Calendar Button"), | 210 | { Qt::Key_F9, QT_TRANSLATE_NOOP("Button", "Calendar Button"), |
213 | "devicebuttons/z_calendar", | 211 | "devicebuttons/z_calendar", |
214 | "datebook", "nextView()", | 212 | "datebook", "nextView()", |
215 | "today", "raise()" }, | 213 | "today", "raise()" }, |
216 | { Qt::Key_F10, QT_TRANSLATE_NOOP("Button", "Contacts Button"), | 214 | { Qt::Key_F10, QT_TRANSLATE_NOOP("Button", "Contacts Button"), |
217 | "devicebuttons/z_contact", | 215 | "devicebuttons/z_contact", |
218 | "addressbook", "raise()", | 216 | "addressbook", "raise()", |
219 | "addressbook", "beamBusinessCard()" }, | 217 | "addressbook", "beamBusinessCard()" }, |
220 | { Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Home Button"), | 218 | { Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Home Button"), |
221 | "devicebuttons/z_home", | 219 | "devicebuttons/z_home", |
222 | "QPE/Launcher", "home()", | 220 | "QPE/Launcher", "home()", |
223 | "buttonsettings", "raise()" }, | 221 | "buttonsettings", "raise()" }, |
224 | { Qt::Key_F11, QT_TRANSLATE_NOOP("Button", "Menu Button"), | 222 | { Qt::Key_F11, QT_TRANSLATE_NOOP("Button", "Menu Button"), |
225 | "devicebuttons/z_menu", | 223 | "devicebuttons/z_menu", |
226 | "QPE/TaskBar", "toggleMenu()", | 224 | "QPE/TaskBar", "toggleMenu()", |
227 | "QPE/TaskBar", "toggleStartMenu()" }, | 225 | "QPE/TaskBar", "toggleStartMenu()" }, |
228 | { Qt::Key_F13, QT_TRANSLATE_NOOP("Button", "Display Rotate"), | 226 | { Qt::Key_F13, QT_TRANSLATE_NOOP("Button", "Display Rotate"), |
229 | "", | 227 | "", |
230 | "QPE/Rotation", "flip()", | 228 | "QPE/Rotation", "flip()", |
231 | "QPE/Rotation", "flip()" }, | 229 | "QPE/Rotation", "flip()" }, |
232 | }; | 230 | }; |
233 | 231 | ||
234 | static QCString makeChannel ( const char *str ) | 232 | static QCString makeChannel ( const char *str ) |
235 | { | 233 | { |
236 | if ( str && !::strchr ( str, '/' )) | 234 | if ( str && !::strchr ( str, '/' )) |
237 | return QCString ( "QPE/Application/" ) + str; | 235 | return QCString ( "QPE/Application/" ) + str; |
238 | else | 236 | else |
239 | return str; | 237 | return str; |
240 | } | 238 | } |
241 | 239 | ||
242 | 240 | static inline bool isQWS() | |
243 | 241 | { | |
242 | return qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; | ||
243 | } | ||
244 | 244 | ||
245 | ODevice *ODevice::inst ( ) | 245 | ODevice *ODevice::inst ( ) |
246 | { | 246 | { |
247 | static ODevice *dev = 0; | 247 | static ODevice *dev = 0; |
248 | 248 | ||
249 | if ( !dev ) { | 249 | if ( !dev ) { |
250 | if ( QFile::exists ( "/proc/hal/model" )) | 250 | if ( QFile::exists ( "/proc/hal/model" )) |
251 | dev = new iPAQ ( ); | 251 | dev = new iPAQ ( ); |
252 | else if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) | 252 | else if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) |
253 | dev = new Zaurus ( ); | 253 | dev = new Zaurus ( ); |
254 | else | 254 | else |
255 | dev = new ODevice ( ); | 255 | dev = new ODevice ( ); |
256 | 256 | ||
257 | dev-> init ( ); | 257 | dev-> init ( ); |
258 | } | 258 | } |
259 | return dev; | 259 | return dev; |
260 | } | 260 | } |
261 | 261 | ||
262 | 262 | ||
263 | /************************************************** | 263 | /************************************************** |
264 | * | 264 | * |
265 | * common | 265 | * common |
266 | * | 266 | * |
267 | **************************************************/ | 267 | **************************************************/ |
268 | 268 | ||
269 | 269 | ||
270 | ODevice::ODevice ( ) | 270 | ODevice::ODevice ( ) |
271 | { | 271 | { |
272 | d = new ODeviceData; | 272 | d = new ODeviceData; |
273 | 273 | ||
274 | d-> m_qwsserver = qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; | ||
275 | |||
276 | d-> m_modelstr = "Unknown"; | 274 | d-> m_modelstr = "Unknown"; |
277 | d-> m_model = Model_Unknown; | 275 | d-> m_model = Model_Unknown; |
278 | d-> m_vendorstr = "Unknown"; | 276 | d-> m_vendorstr = "Unknown"; |
279 | d-> m_vendor = Vendor_Unknown; | 277 | d-> m_vendor = Vendor_Unknown; |
280 | d-> m_systemstr = "Unknown"; | 278 | d-> m_systemstr = "Unknown"; |
281 | d-> m_system = System_Unknown; | 279 | d-> m_system = System_Unknown; |
282 | d-> m_sysverstr = "0.0"; | 280 | d-> m_sysverstr = "0.0"; |
283 | d-> m_rotation = Rot0; | 281 | d-> m_rotation = Rot0; |
284 | d-> m_direction = CW; | 282 | d-> m_direction = CW; |
285 | 283 | ||
286 | d-> m_holdtime = 1000; // 1000ms | 284 | d-> m_holdtime = 1000; // 1000ms |
287 | d-> m_buttons = 0; | 285 | d-> m_buttons = 0; |
288 | } | 286 | } |
289 | 287 | ||
290 | void ODevice::systemMessage ( const QCString &msg, const QByteArray & ) | 288 | void ODevice::systemMessage ( const QCString &msg, const QByteArray & ) |
291 | { | 289 | { |
292 | if ( msg == "deviceButtonMappingChanged()" ) { | 290 | if ( msg == "deviceButtonMappingChanged()" ) { |
293 | reloadButtonMapping ( ); | 291 | reloadButtonMapping ( ); |
294 | } | 292 | } |
295 | } | 293 | } |
296 | 294 | ||
297 | void ODevice::init ( ) | 295 | void ODevice::init ( ) |
298 | { | 296 | { |
299 | } | 297 | } |
300 | 298 | ||
301 | /** | 299 | /** |
302 | * This method initialises the button mapping | 300 | * This method initialises the button mapping |
303 | */ | 301 | */ |
304 | void ODevice::initButtons ( ) | 302 | void ODevice::initButtons ( ) |
305 | { | 303 | { |
306 | if ( d-> m_buttons ) | 304 | if ( d-> m_buttons ) |
307 | return; | 305 | return; |
308 | 306 | ||
309 | d-> m_qwsserver = qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; | ||
310 | |||
311 | // Simulation uses iPAQ 3660 device buttons | 307 | // Simulation uses iPAQ 3660 device buttons |
312 | 308 | ||
313 | qDebug ( "init Buttons" ); | 309 | qDebug ( "init Buttons" ); |
314 | d-> m_buttons = new QValueList <ODeviceButton>; | 310 | d-> m_buttons = new QValueList <ODeviceButton>; |
315 | 311 | ||
316 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { | 312 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { |
317 | i_button *ib = ipaq_buttons + i; | 313 | i_button *ib = ipaq_buttons + i; |
318 | ODeviceButton b; | 314 | ODeviceButton b; |
319 | 315 | ||
320 | if (( ib-> model & Model_iPAQ_H36xx ) == Model_iPAQ_H36xx ) { | 316 | if (( ib-> model & Model_iPAQ_H36xx ) == Model_iPAQ_H36xx ) { |
321 | b. setKeycode ( ib-> code ); | 317 | b. setKeycode ( ib-> code ); |
322 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); | 318 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); |
323 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); | 319 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); |
324 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); | 320 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); |
325 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); | 321 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); |
326 | d-> m_buttons-> append ( b ); | 322 | d-> m_buttons-> append ( b ); |
327 | } | 323 | } |
328 | } | 324 | } |
329 | reloadButtonMapping ( ); | 325 | reloadButtonMapping ( ); |
330 | 326 | ||
331 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | 327 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
332 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | 328 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); |
333 | } | 329 | } |
334 | 330 | ||
335 | ODevice::~ODevice ( ) | 331 | ODevice::~ODevice ( ) |
336 | { | 332 | { |
337 | delete d; | 333 | delete d; |
338 | } | 334 | } |
339 | 335 | ||
340 | bool ODevice::setSoftSuspend ( bool /*soft*/ ) | 336 | bool ODevice::setSoftSuspend ( bool /*soft*/ ) |
341 | { | 337 | { |
342 | return false; | 338 | return false; |
343 | } | 339 | } |
344 | 340 | ||
345 | //#include <linux/apm_bios.h> | 341 | //#include <linux/apm_bios.h> |
346 | 342 | ||
347 | #define APM_IOC_SUSPEND OD_IO( 'A', 2 ) | 343 | #define APM_IOC_SUSPEND OD_IO( 'A', 2 ) |
348 | 344 | ||
349 | /** | 345 | /** |
350 | * This method will try to suspend the device | 346 | * This method will try to suspend the device |
351 | * It only works if the user is the QWS Server and the apm application | 347 | * It only works if the user is the QWS Server and the apm application |
352 | * is installed. | 348 | * is installed. |
353 | * It tries to suspend and then waits some time cause some distributions | 349 | * It tries to suspend and then waits some time cause some distributions |
354 | * do have asynchronus apm implementations. | 350 | * do have asynchronus apm implementations. |
355 | * This method will either fail and return false or it'll suspend the | 351 | * This method will either fail and return false or it'll suspend the |
356 | * device and return once the device got woken up | 352 | * device and return once the device got woken up |
357 | * | 353 | * |
358 | * @return if the device got suspended | 354 | * @return if the device got suspended |
359 | */ | 355 | */ |
360 | bool ODevice::suspend ( ) | 356 | bool ODevice::suspend ( ) |
361 | { | 357 | { |
362 | if ( !d-> m_qwsserver ) // only qwsserver is allowed to suspend | 358 | if ( !isQWS( ) ) // only qwsserver is allowed to suspend |
363 | return false; | 359 | return false; |
364 | 360 | ||
365 | if ( d-> m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices | 361 | if ( d-> m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices |
366 | return false; | 362 | return false; |
367 | 363 | ||
368 | bool res = false; | 364 | bool res = false; |
369 | 365 | ||
370 | struct timeval tvs, tvn; | 366 | struct timeval tvs, tvn; |
371 | ::gettimeofday ( &tvs, 0 ); | 367 | ::gettimeofday ( &tvs, 0 ); |
372 | 368 | ||
373 | ::sync ( ); // flush fs caches | 369 | ::sync ( ); // flush fs caches |
374 | res = ( ::system ( "apm --suspend" ) == 0 ); | 370 | res = ( ::system ( "apm --suspend" ) == 0 ); |
375 | 371 | ||
376 | // This is needed because the iPAQ apm implementation is asynchronous and we | 372 | // This is needed because the iPAQ apm implementation is asynchronous and we |
377 | // can not be sure when exactly the device is really suspended | 373 | // can not be sure when exactly the device is really suspended |
378 | // This can be deleted as soon as a stable familiar with a synchronous apm implementation exists. | 374 | // This can be deleted as soon as a stable familiar with a synchronous apm implementation exists. |
379 | 375 | ||
380 | if ( res ) { | 376 | if ( res ) { |
381 | do { // wait at most 1.5 sec: either suspend didn't work or the device resumed | 377 | do { // wait at most 1.5 sec: either suspend didn't work or the device resumed |
382 | ::usleep ( 200 * 1000 ); | 378 | ::usleep ( 200 * 1000 ); |
383 | ::gettimeofday ( &tvn, 0 ); | 379 | ::gettimeofday ( &tvn, 0 ); |
384 | } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); | 380 | } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); |
385 | } | 381 | } |
386 | 382 | ||
387 | return res; | 383 | return res; |
388 | } | 384 | } |
389 | 385 | ||
390 | //#include <linux/fb.h> better not rely on kernel headers in userspace ... | 386 | //#include <linux/fb.h> better not rely on kernel headers in userspace ... |
391 | 387 | ||
392 | #define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 | 388 | #define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 |
393 | 389 | ||
394 | /* VESA Blanking Levels */ | 390 | /* VESA Blanking Levels */ |
@@ -778,67 +774,65 @@ void iPAQ::init ( ) | |||
778 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); | 774 | d-> m_sysverstr = ts. readLine ( ). mid ( 10 ); |
779 | 775 | ||
780 | f. close ( ); | 776 | f. close ( ); |
781 | } else { | 777 | } else { |
782 | f. setName ( "/etc/oz_version" ); | 778 | f. setName ( "/etc/oz_version" ); |
783 | 779 | ||
784 | if ( f. open ( IO_ReadOnly )) { | 780 | if ( f. open ( IO_ReadOnly )) { |
785 | d-> m_systemstr = "OpenEmbedded/iPaq"; | 781 | d-> m_systemstr = "OpenEmbedded/iPaq"; |
786 | d-> m_system = System_Familiar; | 782 | d-> m_system = System_Familiar; |
787 | 783 | ||
788 | QTextStream ts ( &f ); | 784 | QTextStream ts ( &f ); |
789 | ts.setDevice ( &f ); | 785 | ts.setDevice ( &f ); |
790 | d-> m_sysverstr = ts. readLine ( ); | 786 | d-> m_sysverstr = ts. readLine ( ); |
791 | f. close ( ); | 787 | f. close ( ); |
792 | } | 788 | } |
793 | } | 789 | } |
794 | 790 | ||
795 | 791 | ||
796 | 792 | ||
797 | 793 | ||
798 | 794 | ||
799 | m_leds [0] = m_leds [1] = Led_Off; | 795 | m_leds [0] = m_leds [1] = Led_Off; |
800 | 796 | ||
801 | m_power_timer = 0; | 797 | m_power_timer = 0; |
802 | 798 | ||
803 | } | 799 | } |
804 | 800 | ||
805 | void iPAQ::initButtons ( ) | 801 | void iPAQ::initButtons ( ) |
806 | { | 802 | { |
807 | if ( d-> m_buttons ) | 803 | if ( d-> m_buttons ) |
808 | return; | 804 | return; |
809 | 805 | ||
810 | d-> m_qwsserver = qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; | 806 | if ( isQWS( ) ) |
811 | |||
812 | if ( d-> m_qwsserver ) | ||
813 | QWSServer::setKeyboardFilter ( this ); | 807 | QWSServer::setKeyboardFilter ( this ); |
814 | 808 | ||
815 | d-> m_buttons = new QValueList <ODeviceButton>; | 809 | d-> m_buttons = new QValueList <ODeviceButton>; |
816 | 810 | ||
817 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { | 811 | for ( uint i = 0; i < ( sizeof( ipaq_buttons ) / sizeof( i_button )); i++ ) { |
818 | i_button *ib = ipaq_buttons + i; | 812 | i_button *ib = ipaq_buttons + i; |
819 | ODeviceButton b; | 813 | ODeviceButton b; |
820 | 814 | ||
821 | if (( ib-> model & d-> m_model ) == d-> m_model ) { | 815 | if (( ib-> model & d-> m_model ) == d-> m_model ) { |
822 | b. setKeycode ( ib-> code ); | 816 | b. setKeycode ( ib-> code ); |
823 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); | 817 | b. setUserText ( QObject::tr ( "Button", ib-> utext )); |
824 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); | 818 | b. setPixmap ( Resource::loadPixmap ( ib-> pix )); |
825 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); | 819 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( ib-> fpressedservice ), ib-> fpressedaction )); |
826 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); | 820 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( ib-> fheldservice ), ib-> fheldaction )); |
827 | 821 | ||
828 | d-> m_buttons-> append ( b ); | 822 | d-> m_buttons-> append ( b ); |
829 | } | 823 | } |
830 | } | 824 | } |
831 | reloadButtonMapping ( ); | 825 | reloadButtonMapping ( ); |
832 | 826 | ||
833 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | 827 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
834 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | 828 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); |
835 | } | 829 | } |
836 | 830 | ||
837 | 831 | ||
838 | //#include <linux/h3600_ts.h> // including kernel headers is evil ... | 832 | //#include <linux/h3600_ts.h> // including kernel headers is evil ... |
839 | 833 | ||
840 | typedef struct { | 834 | typedef struct { |
841 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ | 835 | unsigned char OffOnBlink; /* 0=off 1=on 2=Blink */ |
842 | unsigned char TotalTime; /* Units of 5 seconds */ | 836 | unsigned char TotalTime; /* Units of 5 seconds */ |
843 | unsigned char OnTime; /* units of 100m/s */ | 837 | unsigned char OnTime; /* units of 100m/s */ |
844 | unsigned char OffTime; /* units of 100m/s */ | 838 | unsigned char OffTime; /* units of 100m/s */ |
@@ -1178,66 +1172,64 @@ void Zaurus::init ( ) | |||
1178 | d-> m_rotation = Rot0; | 1172 | d-> m_rotation = Rot0; |
1179 | break; | 1173 | break; |
1180 | case Model_Zaurus_SLC700: | 1174 | case Model_Zaurus_SLC700: |
1181 | // Note: need to 1) set flipstate based on physical screen orientation | 1175 | // Note: need to 1) set flipstate based on physical screen orientation |
1182 | // and 2) check to see if the user overrode the rotation direction | 1176 | // and 2) check to see if the user overrode the rotation direction |
1183 | // using appearance, and if so, remove that item from the Config to | 1177 | // using appearance, and if so, remove that item from the Config to |
1184 | // ensure the rotate applet flips us back to the previous state. | 1178 | // ensure the rotate applet flips us back to the previous state. |
1185 | if ( flipstate ) { | 1179 | if ( flipstate ) { |
1186 | // 480x640 | 1180 | // 480x640 |
1187 | d-> m_rotation = Rot0; | 1181 | d-> m_rotation = Rot0; |
1188 | d-> m_direction = CW; | 1182 | d-> m_direction = CW; |
1189 | } else { | 1183 | } else { |
1190 | // 640x480 | 1184 | // 640x480 |
1191 | d-> m_rotation = Rot270; | 1185 | d-> m_rotation = Rot270; |
1192 | d-> m_direction = CCW; | 1186 | d-> m_direction = CCW; |
1193 | } | 1187 | } |
1194 | break; | 1188 | break; |
1195 | case Model_Zaurus_SLB600: | 1189 | case Model_Zaurus_SLB600: |
1196 | case Model_Zaurus_SL5500: | 1190 | case Model_Zaurus_SL5500: |
1197 | case Model_Zaurus_SL5000: | 1191 | case Model_Zaurus_SL5000: |
1198 | default: | 1192 | default: |
1199 | d-> m_rotation = Rot270; | 1193 | d-> m_rotation = Rot270; |
1200 | break; | 1194 | break; |
1201 | } | 1195 | } |
1202 | m_leds [0] = Led_Off; | 1196 | m_leds [0] = Led_Off; |
1203 | } | 1197 | } |
1204 | 1198 | ||
1205 | void Zaurus::initButtons ( ) | 1199 | void Zaurus::initButtons ( ) |
1206 | { | 1200 | { |
1207 | if ( d-> m_buttons ) | 1201 | if ( d-> m_buttons ) |
1208 | return; | 1202 | return; |
1209 | 1203 | ||
1210 | d-> m_qwsserver = qApp ? ( qApp-> type ( ) == QApplication::GuiServer ) : false; | ||
1211 | |||
1212 | d-> m_buttons = new QValueList <ODeviceButton>; | 1204 | d-> m_buttons = new QValueList <ODeviceButton>; |
1213 | 1205 | ||
1214 | struct z_button * pz_buttons; | 1206 | struct z_button * pz_buttons; |
1215 | int buttoncount; | 1207 | int buttoncount; |
1216 | switch ( d-> m_model ) { | 1208 | switch ( d-> m_model ) { |
1217 | case Model_Zaurus_SLC700: | 1209 | case Model_Zaurus_SLC700: |
1218 | pz_buttons = z_buttons_c700; | 1210 | pz_buttons = z_buttons_c700; |
1219 | buttoncount = ARRAY_SIZE(z_buttons_c700); | 1211 | buttoncount = ARRAY_SIZE(z_buttons_c700); |
1220 | break; | 1212 | break; |
1221 | default: | 1213 | default: |
1222 | pz_buttons = z_buttons; | 1214 | pz_buttons = z_buttons; |
1223 | buttoncount = ARRAY_SIZE(z_buttons); | 1215 | buttoncount = ARRAY_SIZE(z_buttons); |
1224 | break; | 1216 | break; |
1225 | } | 1217 | } |
1226 | 1218 | ||
1227 | for ( int i = 0; i < buttoncount; i++ ) { | 1219 | for ( int i = 0; i < buttoncount; i++ ) { |
1228 | struct z_button *zb = pz_buttons + i; | 1220 | struct z_button *zb = pz_buttons + i; |
1229 | ODeviceButton b; | 1221 | ODeviceButton b; |
1230 | 1222 | ||
1231 | b. setKeycode ( zb-> code ); | 1223 | b. setKeycode ( zb-> code ); |
1232 | b. setUserText ( QObject::tr ( "Button", zb-> utext )); | 1224 | b. setUserText ( QObject::tr ( "Button", zb-> utext )); |
1233 | b. setPixmap ( Resource::loadPixmap ( zb-> pix )); | 1225 | b. setPixmap ( Resource::loadPixmap ( zb-> pix )); |
1234 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( zb-> fpressedservice ), zb-> fpressedaction )); | 1226 | b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( zb-> fpressedservice ), zb-> fpressedaction )); |
1235 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( zb-> fheldservice ), zb-> fheldaction )); | 1227 | b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( zb-> fheldservice ), zb-> fheldaction )); |
1236 | 1228 | ||
1237 | d-> m_buttons-> append ( b ); | 1229 | d-> m_buttons-> append ( b ); |
1238 | } | 1230 | } |
1239 | 1231 | ||
1240 | reloadButtonMapping ( ); | 1232 | reloadButtonMapping ( ); |
1241 | 1233 | ||
1242 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); | 1234 | QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); |
1243 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); | 1235 | connect ( sysch, SIGNAL( received( const QCString &, const QByteArray & )), this, SLOT( systemMessage ( const QCString &, const QByteArray & ))); |