summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/device/odevice.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/libopie2/opiecore/device/odevice.cpp b/libopie2/opiecore/device/odevice.cpp
index 129215b..280b0c5 100644
--- a/libopie2/opiecore/device/odevice.cpp
+++ b/libopie2/opiecore/device/odevice.cpp
@@ -1,789 +1,789 @@
1/* 1/*
2                 This file is part of the Opie Project 2                 This file is part of the Opie Project
3              Copyright (C) The Opie Team <opie-devel@handhelds.org> 3              Copyright (C) The Opie Team <opie-devel@handhelds.org>
4 =. 4 =.
5 .=l. 5 .=l.
6           .>+-= 6           .>+-=
7 _;:,     .>    :=|. This program is free software; you can 7 _;:,     .>    :=|. This program is free software; you can
8.> <`_,   >  .   <= redistribute it and/or modify it under 8.> <`_,   >  .   <= redistribute it and/or modify it under
9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 9:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
10.="- .-=="i,     .._ License as published by the Free Software 10.="- .-=="i,     .._ License as published by the Free Software
11 - .   .-<_>     .<> Foundation; either version 2 of the License, 11 - .   .-<_>     .<> Foundation; either version 2 of the License,
12     ._= =}       : or (at your option) any later version. 12     ._= =}       : or (at your option) any later version.
13    .%`+i>       _;_. 13    .%`+i>       _;_.
14    .i_,=:_.      -<s. This program is distributed in the hope that 14    .i_,=:_.      -<s. This program is distributed in the hope that
15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 15     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
16    : ..    .:,     . . . without even the implied warranty of 16    : ..    .:,     . . . without even the implied warranty of
17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 17    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 18  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
19..}^=.=       =       ; Library General Public License for more 19..}^=.=       =       ; Library General Public License for more
20++=   -.     .`     .: details. 20++=   -.     .`     .: details.
21 :     =  ...= . :.=- 21 :     =  ...= . :.=-
22 -.   .:....=;==+<; You should have received a copy of the GNU 22 -.   .:....=;==+<; You should have received a copy of the GNU
23  -_. . .   )=.  = Library General Public License along with 23  -_. . .   )=.  = Library General Public License along with
24    --        :-=` this library; see the file COPYING.LIB. 24    --        :-=` this library; see the file COPYING.LIB.
25 If not, write to the Free Software Foundation, 25 If not, write to the Free Software Foundation,
26 Inc., 59 Temple Place - Suite 330, 26 Inc., 59 Temple Place - Suite 330,
27 Boston, MA 02111-1307, USA. 27 Boston, MA 02111-1307, USA.
28*/ 28*/
29 29
30#include "odevice_ipaq.h" 30#include "odevice_ipaq.h"
31#include "odevice_jornada.h" 31#include "odevice_jornada.h"
32#include "odevice_ramses.h" 32#include "odevice_ramses.h"
33#include "odevice_simpad.h" 33#include "odevice_simpad.h"
34#include "odevice_yopy.h" 34#include "odevice_yopy.h"
35#include "odevice_zaurus.h" 35#include "odevice_zaurus.h"
36 36
37/* QT */ 37/* QT */
38#include <qapplication.h> 38#include <qapplication.h>
39#include <qfile.h> 39#include <qfile.h>
40#include <qtextstream.h> 40#include <qtextstream.h>
41#include <qwindowsystem_qws.h> 41#include <qwindowsystem_qws.h>
42 42
43/* OPIE */ 43/* OPIE */
44#include <qpe/config.h> 44#include <qpe/config.h>
45#include <qpe/resource.h> 45#include <qpe/resource.h>
46#include <qpe/sound.h> 46#include <qpe/sound.h>
47#include <qpe/qcopenvelope_qws.h> 47#include <qpe/qcopenvelope_qws.h>
48#include <qpe/sound.h> 48#include <qpe/sound.h>
49#include <opie2/okeyfilter.h> 49#include <opie2/okeyfilter.h>
50 50
51/* STD */ 51/* STD */
52#include <fcntl.h> 52#include <fcntl.h>
53#include <math.h> 53#include <math.h>
54#include <stdlib.h> 54#include <stdlib.h>
55#include <signal.h> 55#include <signal.h>
56#include <sys/ioctl.h> 56#include <sys/ioctl.h>
57#include <sys/time.h> 57#include <sys/time.h>
58#include <unistd.h> 58#include <unistd.h>
59#ifndef QT_NO_SOUND 59#ifndef QT_NO_SOUND
60#include <linux/soundcard.h> 60#include <linux/soundcard.h>
61#endif 61#endif
62 62
63namespace Opie { 63namespace Opie {
64namespace Core { 64namespace Core {
65 65
66static const char* PATH_PROC_CPUINFO = "/proc/cpuinfo"; 66static const char* PATH_PROC_CPUINFO = "/proc/cpuinfo";
67 67
68 68
69/* STATIC and common implementation */ 69/* STATIC and common implementation */
70/* EXPORT */ ODistribution distributions[] = { 70/* EXPORT */ ODistribution distributions[] = {
71 { System_Familiar, "FamiliarLinux", "/etc/familiar-version" }, 71 { System_Familiar, "FamiliarLinux", "/etc/familiar-version" },
72 { System_OpenZaurus, "OpenZaurus", "/etc/oz_version" }, 72 { System_OpenZaurus, "OpenZaurus", "/etc/oz_version" },
73 { System_OpenEmbedded, "OpenEmbedded", "/etc/oe-version" }, 73 { System_OpenEmbedded, "OpenEmbedded", "/etc/oe-version" },
74 { System_Unknown, "Linux", "/etc/issue" }, 74 { System_Unknown, "Linux", "/etc/issue" },
75}; 75};
76 76
77 77
78/* EXPORT */ bool isQWS(){ 78/* EXPORT */ bool isQWS(){
79 return qApp ? ( qApp->type() == QApplication::GuiServer ) : false; 79 return qApp ? ( qApp->type() == QApplication::GuiServer ) : false;
80} 80}
81 81
82/* EXPORT */ QCString makeChannel ( const char *str ){ 82/* EXPORT */ QCString makeChannel ( const char *str ){
83 if ( str && !::strchr ( str, '/' )) 83 if ( str && !::strchr ( str, '/' ))
84 return QCString ( "QPE/Application/" ) + str; 84 return QCString ( "QPE/Application/" ) + str;
85 else 85 else
86 return str; 86 return str;
87} 87}
88 88
89 89
90 90
91/* Now the default implementation of ODevice */ 91/* Now the default implementation of ODevice */
92 92
93struct default_button default_buttons [] = { 93struct default_button default_buttons [] = {
94 { Qt::Key_F9, QT_TRANSLATE_NOOP("Button", "Calendar Button"), 94 { Qt::Key_F9, QT_TRANSLATE_NOOP("Button", "Calendar Button"),
95 "devicebuttons/z_calendar", 95 "devicebuttons/z_calendar",
96 "datebook", "nextView()", 96 "datebook", "nextView()",
97 "today", "raise()" }, 97 "today", "raise()" },
98 { Qt::Key_F10, QT_TRANSLATE_NOOP("Button", "Contacts Button"), 98 { Qt::Key_F10, QT_TRANSLATE_NOOP("Button", "Contacts Button"),
99 "devicebuttons/z_contact", 99 "devicebuttons/z_contact",
100 "addressbook", "raise()", 100 "addressbook", "raise()",
101 "addressbook", "beamBusinessCard()" }, 101 "addressbook", "beamBusinessCard()" },
102 { Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Home Button"), 102 { Qt::Key_F12, QT_TRANSLATE_NOOP("Button", "Home Button"),
103 "devicebuttons/z_home", 103 "devicebuttons/z_home",
104 "QPE/Launcher", "home()", 104 "QPE/Launcher", "home()",
105 "buttonsettings", "raise()" }, 105 "buttonsettings", "raise()" },
106 { Qt::Key_F11, QT_TRANSLATE_NOOP("Button", "Menu Button"), 106 { Qt::Key_F11, QT_TRANSLATE_NOOP("Button", "Menu Button"),
107 "devicebuttons/z_menu", 107 "devicebuttons/z_menu",
108 "QPE/TaskBar", "toggleMenu()", 108 "QPE/TaskBar", "toggleMenu()",
109 "QPE/TaskBar", "toggleStartMenu()" }, 109 "QPE/TaskBar", "toggleStartMenu()" },
110 { Qt::Key_F13, QT_TRANSLATE_NOOP("Button", "Mail Button"), 110 { Qt::Key_F13, QT_TRANSLATE_NOOP("Button", "Mail Button"),
111 "devicebuttons/z_mail", 111 "devicebuttons/z_mail",
112 "opiemail", "raise()", 112 "opiemail", "raise()",
113 "opiemail", "newMail()" }, 113 "opiemail", "newMail()" },
114}; 114};
115 115
116ODevice *ODevice::inst() 116ODevice *ODevice::inst()
117{ 117{
118 static ODevice *dev = 0; 118 static ODevice *dev = 0;
119 119
120 // rewrite this to only use /proc/cpuinfo or so 120 // rewrite this to only use /proc/cpuinfo or so
121 QString cpu_info; 121 QString cpu_info;
122 122
123 if ( !dev ) 123 if ( !dev )
124 { 124 {
125 QFile f( PATH_PROC_CPUINFO ); 125 QFile f( PATH_PROC_CPUINFO );
126 if ( f.open( IO_ReadOnly ) ) 126 if ( f.open( IO_ReadOnly ) )
127 { 127 {
128 QTextStream s( &f ); 128 QTextStream s( &f );
129 while ( !s.atEnd() ) 129 while ( !s.atEnd() )
130 { 130 {
131 QString line; 131 QString line;
132 line = s.readLine(); 132 line = s.readLine();
133 if ( line.startsWith( "Hardware" ) ) 133 if ( line.startsWith( "Hardware" ) )
134 { 134 {
135 qDebug( "ODevice() - found '%s'", (const char*) line ); 135 qDebug( "ODevice() - found '%s'", (const char*) line );
136 cpu_info = line; 136 cpu_info = line;
137 if ( line.contains( "sharp", false ) ) dev = new Internal::Zaurus(); 137 if ( line.contains( "sharp", false ) ) dev = new Internal::Zaurus();
138 else if ( line.contains( "ipaq", false ) ) dev = new Internal::iPAQ(); 138 else if ( line.contains( "ipaq", false ) ) dev = new Internal::iPAQ();
139 else if ( line.contains( "simpad", false ) ) dev = new Internal::SIMpad(); 139 else if ( line.contains( "simpad", false ) ) dev = new Internal::SIMpad();
140 else if ( line.contains( "jornada", false ) ) dev = new Internal::Jornada(); 140 else if ( line.contains( "jornada", false ) ) dev = new Internal::Jornada();
141 else if ( line.contains( "ramses", false ) ) dev = new Internal::Ramses(); 141 else if ( line.contains( "ramses", false ) ) dev = new Internal::Ramses();
142 else qWarning( "ODevice() - unknown hardware - using default." ); 142 else qWarning( "ODevice() - unknown hardware - using default." );
143 break; 143 break;
144 } 144 }
145 } 145 }
146 } 146 }
147 else 147 else
148 { 148 {
149 qWarning( "ODevice() - can't open '%s' - unknown hardware - using default.", PATH_PROC_CPUINFO ); 149 qWarning( "ODevice() - can't open '%s' - unknown hardware - using default.", PATH_PROC_CPUINFO );
150 } 150 }
151 if ( !dev ) dev = new ODevice(); 151 if ( !dev ) dev = new ODevice();
152 dev->init(cpu_info); 152 dev->init(cpu_info);
153 } 153 }
154 return dev; 154 return dev;
155} 155}
156 156
157ODevice::ODevice() 157ODevice::ODevice()
158{ 158{
159 d = new ODeviceData; 159 d = new ODeviceData;
160 160
161 d->m_modelstr = "Unknown"; 161 d->m_modelstr = "Unknown";
162 d->m_model = Model_Unknown; 162 d->m_model = Model_Unknown;
163 d->m_vendorstr = "Unknown"; 163 d->m_vendorstr = "Unknown";
164 d->m_vendor = Vendor_Unknown; 164 d->m_vendor = Vendor_Unknown;
165 d->m_systemstr = "Unknown"; 165 d->m_systemstr = "Unknown";
166 d->m_system = System_Unknown; 166 d->m_system = System_Unknown;
167 d->m_sysverstr = "0.0"; 167 d->m_sysverstr = "0.0";
168 d->m_rotation = Rot0; 168 d->m_rotation = Rot0;
169 d->m_direction = CW; 169 d->m_direction = CW;
170 170
171 d->m_holdtime = 1000; // 1000ms 171 d->m_holdtime = 1000; // 1000ms
172 d->m_buttons = 0; 172 d->m_buttons = 0;
173 d->m_cpu_frequencies = new QStrList; 173 d->m_cpu_frequencies = new QStrList;
174 174
175 175
176 /* mixer */ 176 /* mixer */
177 d->m_sound = d->m_vol = d->m_mixer = -1; 177 d->m_sound = d->m_vol = d->m_mixer = -1;
178 178
179 // New distribution detection code first checks for legacy distributions, 179 // New distribution detection code first checks for legacy distributions,
180 // identified by /etc/familiar-version or /etc/oz_version. 180 // identified by /etc/familiar-version or /etc/oz_version.
181 // Then check for OpenEmbedded and lastly, read /etc/issue 181 // Then check for OpenEmbedded and lastly, read /etc/issue
182 182
183 for ( unsigned int i = 0; i < sizeof distributions; ++i ) 183 for ( unsigned int i = 0; i < sizeof distributions; ++i )
184 { 184 {
185 if ( QFile::exists( distributions[i].sysvfile ) ) 185 if ( QFile::exists( distributions[i].sysvfile ) )
186 { 186 {
187 d->m_systemstr = distributions[i].sysstr; 187 d->m_systemstr = distributions[i].sysstr;
188 d->m_system = distributions[i].system; 188 d->m_system = distributions[i].system;
189 d->m_sysverstr = "<Unknown>"; 189 d->m_sysverstr = "<Unknown>";
190 QFile f( distributions[i].sysvfile ); 190 QFile f( distributions[i].sysvfile );
191 if ( f.open( IO_ReadOnly ) ) 191 if ( f.open( IO_ReadOnly ) )
192 { 192 {
193 QTextStream ts( &f ); 193 QTextStream ts( &f );
194 d->m_sysverstr = ts.readLine(); 194 d->m_sysverstr = ts.readLine().replace( QRegExp( "\\\\." ), "" );
195 } 195 }
196 break; 196 break;
197 } 197 }
198 } 198 }
199} 199}
200 200
201void ODevice::systemMessage( const QCString &msg, const QByteArray & ) 201void ODevice::systemMessage( const QCString &msg, const QByteArray & )
202{ 202{
203 if ( msg == "deviceButtonMappingChanged()" ) { 203 if ( msg == "deviceButtonMappingChanged()" ) {
204 reloadButtonMapping(); 204 reloadButtonMapping();
205 } 205 }
206} 206}
207 207
208void ODevice::init(const QString&) 208void ODevice::init(const QString&)
209{ 209{
210} 210}
211 211
212/** 212/**
213* This method initialises the button mapping 213* This method initialises the button mapping
214*/ 214*/
215void ODevice::initButtons() 215void ODevice::initButtons()
216{ 216{
217 if ( d->m_buttons ) 217 if ( d->m_buttons )
218 return; 218 return;
219 219
220 qDebug ( "init Buttons" ); 220 qDebug ( "init Buttons" );
221 d->m_buttons = new QValueList <ODeviceButton>; 221 d->m_buttons = new QValueList <ODeviceButton>;
222 for ( uint i = 0; i < ( sizeof( default_buttons ) / sizeof( default_button )); i++ ) { 222 for ( uint i = 0; i < ( sizeof( default_buttons ) / sizeof( default_button )); i++ ) {
223 default_button *db = default_buttons + i; 223 default_button *db = default_buttons + i;
224 ODeviceButton b; 224 ODeviceButton b;
225 b. setKeycode ( db->code ); 225 b. setKeycode ( db->code );
226 b. setUserText ( QObject::tr ( "Button", db->utext )); 226 b. setUserText ( QObject::tr ( "Button", db->utext ));
227 b. setPixmap ( Resource::loadPixmap ( db->pix )); 227 b. setPixmap ( Resource::loadPixmap ( db->pix ));
228 b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( db->fpressedservice ), db->fpressedaction )); 228 b. setFactoryPresetPressedAction ( OQCopMessage ( makeChannel ( db->fpressedservice ), db->fpressedaction ));
229 b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( db->fheldservice ), db->fheldaction )); 229 b. setFactoryPresetHeldAction ( OQCopMessage ( makeChannel ( db->fheldservice ), db->fheldaction ));
230 d->m_buttons->append ( b ); 230 d->m_buttons->append ( b );
231 } 231 }
232 232
233 reloadButtonMapping(); 233 reloadButtonMapping();
234 234
235 QCopChannel *sysch = new QCopChannel ( "QPE/System", this ); 235 QCopChannel *sysch = new QCopChannel ( "QPE/System", this );
236 connect ( sysch, SIGNAL( received(const QCString&,const QByteArray&)), this, SLOT( systemMessage(const QCString&,const QByteArray&))); 236 connect ( sysch, SIGNAL( received(const QCString&,const QByteArray&)), this, SLOT( systemMessage(const QCString&,const QByteArray&)));
237} 237}
238 238
239ODevice::~ODevice() 239ODevice::~ODevice()
240{ 240{
241// we leak m_devicebuttons and m_cpu_frequency 241// we leak m_devicebuttons and m_cpu_frequency
242// but it's a singleton and it is not so importantant 242// but it's a singleton and it is not so importantant
243// -zecke 243// -zecke
244 delete d; 244 delete d;
245} 245}
246 246
247bool ODevice::setSoftSuspend ( bool /*soft*/ ) 247bool ODevice::setSoftSuspend ( bool /*soft*/ )
248{ 248{
249 return false; 249 return false;
250} 250}
251 251
252//#include <linux/apm_bios.h> 252//#include <linux/apm_bios.h>
253 253
254#define APM_IOC_SUSPEND OD_IO( 'A', 2 ) 254#define APM_IOC_SUSPEND OD_IO( 'A', 2 )
255 255
256/** 256/**
257* This method will try to suspend the device 257* This method will try to suspend the device
258* It only works if the user is the QWS Server and the apm application 258* It only works if the user is the QWS Server and the apm application
259* is installed. 259* is installed.
260* It tries to suspend and then waits some time cause some distributions 260* It tries to suspend and then waits some time cause some distributions
261* do have asynchronus apm implementations. 261* do have asynchronus apm implementations.
262* This method will either fail and return false or it'll suspend the 262* This method will either fail and return false or it'll suspend the
263* device and return once the device got woken up 263* device and return once the device got woken up
264* 264*
265* @return if the device got suspended 265* @return if the device got suspended
266*/ 266*/
267bool ODevice::suspend() 267bool ODevice::suspend()
268{ 268{
269 qDebug("ODevice::suspend"); 269 qDebug("ODevice::suspend");
270 if ( !isQWS( ) ) // only qwsserver is allowed to suspend 270 if ( !isQWS( ) ) // only qwsserver is allowed to suspend
271 return false; 271 return false;
272 272
273 if ( d->m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices 273 if ( d->m_model == Model_Unknown ) // better don't suspend in qvfb / on unkown devices
274 return false; 274 return false;
275 275
276 bool res = false; 276 bool res = false;
277 ODevice::sendSuspendmsg(); 277 ODevice::sendSuspendmsg();
278 278
279 struct timeval tvs, tvn; 279 struct timeval tvs, tvn;
280 ::gettimeofday ( &tvs, 0 ); 280 ::gettimeofday ( &tvs, 0 );
281 281
282 ::sync(); // flush fs caches 282 ::sync(); // flush fs caches
283 res = ( ::system ( "apm --suspend" ) == 0 ); 283 res = ( ::system ( "apm --suspend" ) == 0 );
284 284
285 // This is needed because the iPAQ apm implementation is asynchronous and we 285 // This is needed because the iPAQ apm implementation is asynchronous and we
286 // can not be sure when exactly the device is really suspended 286 // can not be sure when exactly the device is really suspended
287 // This can be deleted as soon as a stable familiar with a synchronous apm implementation exists. 287 // This can be deleted as soon as a stable familiar with a synchronous apm implementation exists.
288 288
289 if ( res ) { 289 if ( res ) {
290 do { // wait at most 1.5 sec: either suspend didn't work or the device resumed 290 do { // wait at most 1.5 sec: either suspend didn't work or the device resumed
291 ::usleep ( 200 * 1000 ); 291 ::usleep ( 200 * 1000 );
292 ::gettimeofday ( &tvn, 0 ); 292 ::gettimeofday ( &tvn, 0 );
293 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 ); 293 } while ((( tvn. tv_sec - tvs. tv_sec ) * 1000 + ( tvn. tv_usec - tvs. tv_usec ) / 1000 ) < 1500 );
294 } 294 }
295 295
296 return res; 296 return res;
297} 297}
298 298
299//#include <linux/fb.h> better not rely on kernel headers in userspace ... 299//#include <linux/fb.h> better not rely on kernel headers in userspace ...
300 300
301#define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611 301#define FBIOBLANK OD_IO( 'F', 0x11 ) // 0x4611
302 302
303/* VESA Blanking Levels */ 303/* VESA Blanking Levels */
304#define VESA_NO_BLANKING 0 304#define VESA_NO_BLANKING 0
305#define VESA_VSYNC_SUSPEND 1 305#define VESA_VSYNC_SUSPEND 1
306#define VESA_HSYNC_SUSPEND 2 306#define VESA_HSYNC_SUSPEND 2
307#define VESA_POWERDOWN 3 307#define VESA_POWERDOWN 3
308 308
309/** 309/**
310* This sets the display on or off 310* This sets the display on or off
311*/ 311*/
312bool ODevice::setDisplayStatus ( bool on ) 312bool ODevice::setDisplayStatus ( bool on )
313{ 313{
314 qDebug("ODevice::setDisplayStatus(%d)", on); 314 qDebug("ODevice::setDisplayStatus(%d)", on);
315 315
316 if ( d->m_model == Model_Unknown ) 316 if ( d->m_model == Model_Unknown )
317 return false; 317 return false;
318 318
319 bool res = false; 319 bool res = false;
320 int fd; 320 int fd;
321 321
322 if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) { 322 if (( fd = ::open ( "/dev/fb0", O_RDWR )) >= 0 ) {
323 res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 ); 323 res = ( ::ioctl ( fd, FBIOBLANK, on ? VESA_NO_BLANKING : VESA_POWERDOWN ) == 0 );
324 ::close ( fd ); 324 ::close ( fd );
325 } 325 }
326 return res; 326 return res;
327} 327}
328 328
329/** 329/**
330* This sets the display brightness 330* This sets the display brightness
331* 331*
332* @param p The brightness to be set on a scale from 0 to 255 332* @param p The brightness to be set on a scale from 0 to 255
333* @return success or failure 333* @return success or failure
334*/ 334*/
335bool ODevice::setDisplayBrightness ( int p) 335bool ODevice::setDisplayBrightness ( int p)
336{ 336{
337 Q_UNUSED( p ) 337 Q_UNUSED( p )
338 return false; 338 return false;
339} 339}
340 340
341/** 341/**
342* @return returns the number of steppings on the brightness slider 342* @return returns the number of steppings on the brightness slider
343* in the Light-'n-Power settings. 343* in the Light-'n-Power settings.
344*/ 344*/
345int ODevice::displayBrightnessResolution() const 345int ODevice::displayBrightnessResolution() const
346{ 346{
347 return 16; 347 return 16;
348} 348}
349 349
350/** 350/**
351* This sets the display contrast 351* This sets the display contrast
352* @param p The contrast to be set on a scale from 0 to 255 352* @param p The contrast to be set on a scale from 0 to 255
353* @return success or failure 353* @return success or failure
354*/ 354*/
355bool ODevice::setDisplayContrast ( int p) 355bool ODevice::setDisplayContrast ( int p)
356{ 356{
357 Q_UNUSED( p ) 357 Q_UNUSED( p )
358 return false; 358 return false;
359} 359}
360 360
361/** 361/**
362* @return return the max value for the brightness settings slider 362* @return return the max value for the brightness settings slider
363* or 0 if the device doesn't support setting of a contrast 363* or 0 if the device doesn't support setting of a contrast
364*/ 364*/
365int ODevice::displayContrastResolution() const 365int ODevice::displayContrastResolution() const
366{ 366{
367 return 0; 367 return 0;
368} 368}
369 369
370/** 370/**
371* This returns the vendor as string 371* This returns the vendor as string
372* @return Vendor as QString 372* @return Vendor as QString
373*/ 373*/
374QString ODevice::vendorString() const 374QString ODevice::vendorString() const
375{ 375{
376 return d->m_vendorstr; 376 return d->m_vendorstr;
377} 377}
378 378
379/** 379/**
380* This returns the vendor as one of the values of OVendor 380* This returns the vendor as one of the values of OVendor
381* @return OVendor 381* @return OVendor
382*/ 382*/
383OVendor ODevice::vendor() const 383OVendor ODevice::vendor() const
384{ 384{
385 return d->m_vendor; 385 return d->m_vendor;
386} 386}
387 387
388/** 388/**
389* This returns the model as a string 389* This returns the model as a string
390* @return A string representing the model 390* @return A string representing the model
391*/ 391*/
392QString ODevice::modelString() const 392QString ODevice::modelString() const
393{ 393{
394 return d->m_modelstr; 394 return d->m_modelstr;
395} 395}
396 396
397/** 397/**
398* This does return the OModel used 398* This does return the OModel used
399*/ 399*/
400OModel ODevice::model() const 400OModel ODevice::model() const
401{ 401{
402 return d->m_model; 402 return d->m_model;
403} 403}
404 404
405/** 405/**
406* This does return the systen name 406* This does return the systen name
407*/ 407*/
408QString ODevice::systemString() const 408QString ODevice::systemString() const
409{ 409{
410 return d->m_systemstr; 410 return d->m_systemstr;
411} 411}
412 412
413/** 413/**
414* Return System as OSystem value 414* Return System as OSystem value
415*/ 415*/
416OSystem ODevice::system() const 416OSystem ODevice::system() const
417{ 417{
418 return d->m_system; 418 return d->m_system;
419} 419}
420 420
421/** 421/**
422* @return the version string of the base system 422* @return the version string of the base system
423*/ 423*/
424QString ODevice::systemVersionString() const 424QString ODevice::systemVersionString() const
425{ 425{
426 return d->m_sysverstr; 426 return d->m_sysverstr;
427} 427}
428 428
429/** 429/**
430* @return the current Transformation 430* @return the current Transformation
431*/ 431*/
432Transformation ODevice::rotation() const 432Transformation ODevice::rotation() const
433{ 433{
434 return d->m_rotation; 434 return d->m_rotation;
435} 435}
436 436
437/** 437/**
438* @return the current rotation direction 438* @return the current rotation direction
439*/ 439*/
440ODirection ODevice::direction() const 440ODirection ODevice::direction() const
441{ 441{
442 return d->m_direction; 442 return d->m_direction;
443} 443}
444 444
445/** 445/**
446* This plays an alarm sound 446* This plays an alarm sound
447*/ 447*/
448void ODevice::playAlarmSound() 448void ODevice::playAlarmSound()
449{ 449{
450#ifndef QT_NO_SOUND 450#ifndef QT_NO_SOUND
451 static Sound snd ( "alarm" ); 451 static Sound snd ( "alarm" );
452 452
453 if ( snd. isFinished()) 453 if ( snd. isFinished())
454 snd. play(); 454 snd. play();
455#endif 455#endif
456} 456}
457 457
458/** 458/**
459* This plays a key sound 459* This plays a key sound
460*/ 460*/
461void ODevice::playKeySound() 461void ODevice::playKeySound()
462{ 462{
463#ifndef QT_NO_SOUND 463#ifndef QT_NO_SOUND
464 static Sound snd ( "keysound" ); 464 static Sound snd ( "keysound" );
465 465
466 if ( snd. isFinished()) 466 if ( snd. isFinished())
467 snd. play(); 467 snd. play();
468#endif 468#endif
469} 469}
470 470
471/** 471/**
472* This plays a touch sound 472* This plays a touch sound
473*/ 473*/
474void ODevice::playTouchSound() 474void ODevice::playTouchSound()
475{ 475{
476#ifndef QT_NO_SOUND 476#ifndef QT_NO_SOUND
477 static Sound snd ( "touchsound" ); 477 static Sound snd ( "touchsound" );
478 478
479 if ( snd. isFinished()) 479 if ( snd. isFinished())
480 snd. play(); 480 snd. play();
481#endif 481#endif
482} 482}
483 483
484/** 484/**
485* This method will return a list of leds 485* This method will return a list of leds
486* available on this device 486* available on this device
487* @return a list of LEDs. 487* @return a list of LEDs.
488*/ 488*/
489QValueList <OLed> ODevice::ledList() const 489QValueList <OLed> ODevice::ledList() const
490{ 490{
491 return QValueList <OLed>(); 491 return QValueList <OLed>();
492} 492}
493 493
494/** 494/**
495* This does return the state of the LEDs 495* This does return the state of the LEDs
496*/ 496*/
497QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const 497QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const
498{ 498{
499 return QValueList <OLedState>(); 499 return QValueList <OLedState>();
500} 500}
501 501
502/** 502/**
503* @return the state for a given OLed 503* @return the state for a given OLed
504*/ 504*/
505OLedState ODevice::ledState ( OLed /*which*/ ) const 505OLedState ODevice::ledState ( OLed /*which*/ ) const
506{ 506{
507 return Led_Off; 507 return Led_Off;
508} 508}
509 509
510/** 510/**
511* Set the state for a LED 511* Set the state for a LED
512* @param which Which OLed to use 512* @param which Which OLed to use
513* @param st The state to set 513* @param st The state to set
514* @return success or failure 514* @return success or failure
515*/ 515*/
516bool ODevice::setLedState ( OLed which, OLedState st ) 516bool ODevice::setLedState ( OLed which, OLedState st )
517{ 517{
518 Q_UNUSED( which ) 518 Q_UNUSED( which )
519 Q_UNUSED( st ) 519 Q_UNUSED( st )
520 return false; 520 return false;
521} 521}
522 522
523/** 523/**
524* @return if the device has a light sensor 524* @return if the device has a light sensor
525*/ 525*/
526bool ODevice::hasLightSensor() const 526bool ODevice::hasLightSensor() const
527{ 527{
528 return false; 528 return false;
529} 529}
530 530
531/** 531/**
532* @return a value from the light sensor 532* @return a value from the light sensor
533*/ 533*/
534int ODevice::readLightSensor() 534int ODevice::readLightSensor()
535{ 535{
536 return -1; 536 return -1;
537} 537}
538 538
539/** 539/**
540* @return the light sensor resolution 540* @return the light sensor resolution
541*/ 541*/
542int ODevice::lightSensorResolution() const 542int ODevice::lightSensorResolution() const
543{ 543{
544 return 0; 544 return 0;
545} 545}
546 546
547/** 547/**
548* @return if the device has a hinge sensor 548* @return if the device has a hinge sensor
549*/ 549*/
550bool ODevice::hasHingeSensor() const 550bool ODevice::hasHingeSensor() const
551{ 551{
552 return false; 552 return false;
553} 553}
554 554
555/** 555/**
556* @return a value from the hinge sensor 556* @return a value from the hinge sensor
557*/ 557*/
558OHingeStatus ODevice::readHingeSensor() 558OHingeStatus ODevice::readHingeSensor()
559{ 559{
560 return CASE_UNKNOWN; 560 return CASE_UNKNOWN;
561} 561}
562 562
563/** 563/**
564* @return a list with CPU frequencies supported by the hardware 564* @return a list with CPU frequencies supported by the hardware
565*/ 565*/
566const QStrList &ODevice::allowedCpuFrequencies() const 566const QStrList &ODevice::allowedCpuFrequencies() const
567{ 567{
568 return *d->m_cpu_frequencies; 568 return *d->m_cpu_frequencies;
569} 569}
570 570
571 571
572/** 572/**
573* Set desired CPU frequency 573* Set desired CPU frequency
574* 574*
575* @param index index into d->m_cpu_frequencies of the frequency to be set 575* @param index index into d->m_cpu_frequencies of the frequency to be set
576*/ 576*/
577bool ODevice::setCurrentCpuFrequency(uint index) 577bool ODevice::setCurrentCpuFrequency(uint index)
578{ 578{
579 if (index >= d->m_cpu_frequencies->count()) 579 if (index >= d->m_cpu_frequencies->count())
580 return false; 580 return false;
581 581
582 char *freq = d->m_cpu_frequencies->at(index); 582 char *freq = d->m_cpu_frequencies->at(index);
583 qWarning("set freq to %s", freq); 583 qWarning("set freq to %s", freq);
584 584
585 int fd; 585 int fd;
586 586
587 if ((fd = ::open("/proc/sys/cpu/0/speed", O_WRONLY)) >= 0) { 587 if ((fd = ::open("/proc/sys/cpu/0/speed", O_WRONLY)) >= 0) {
588 char writeCommand[50]; 588 char writeCommand[50];
589 const int count = sprintf(writeCommand, "%s\n", freq); 589 const int count = sprintf(writeCommand, "%s\n", freq);
590 int res = (::write(fd, writeCommand, count) != -1); 590 int res = (::write(fd, writeCommand, count) != -1);
591 ::close(fd); 591 ::close(fd);
592 return res; 592 return res;
593 } 593 }
594 594
595 return false; 595 return false;
596} 596}
597 597
598 598
599/** 599/**
600* @return a list of hardware buttons 600* @return a list of hardware buttons
601*/ 601*/
602const QValueList <ODeviceButton> &ODevice::buttons() 602const QValueList <ODeviceButton> &ODevice::buttons()
603{ 603{
604 initButtons(); 604 initButtons();
605 605
606 return *d->m_buttons; 606 return *d->m_buttons;
607} 607}
608 608
609/** 609/**
610* @return The amount of time that would count as a hold 610* @return The amount of time that would count as a hold
611*/ 611*/
612uint ODevice::buttonHoldTime() const 612uint ODevice::buttonHoldTime() const
613{ 613{
614 return d->m_holdtime; 614 return d->m_holdtime;
615} 615}
616 616
617/** 617/**
618* This method return a ODeviceButton for a key code 618* This method return a ODeviceButton for a key code
619* or 0 if no special hardware button is available for the device 619* or 0 if no special hardware button is available for the device
620* 620*
621* @return The devicebutton or 0l 621* @return The devicebutton or 0l
622* @see ODeviceButton 622* @see ODeviceButton
623*/ 623*/
624const ODeviceButton *ODevice::buttonForKeycode ( ushort code ) 624const ODeviceButton *ODevice::buttonForKeycode ( ushort code )
625{ 625{
626 initButtons(); 626 initButtons();
627 627
628 for ( QValueListConstIterator<ODeviceButton> it = d->m_buttons->begin(); it != d->m_buttons->end(); ++it ) { 628 for ( QValueListConstIterator<ODeviceButton> it = d->m_buttons->begin(); it != d->m_buttons->end(); ++it ) {
629 if ( (*it). keycode() == code ) 629 if ( (*it). keycode() == code )
630 return &(*it); 630 return &(*it);
631 } 631 }
632 return 0; 632 return 0;
633} 633}
634 634
635void ODevice::reloadButtonMapping() 635void ODevice::reloadButtonMapping()
636{ 636{
637 initButtons(); 637 initButtons();
638 638
639 Config cfg ( "ButtonSettings" ); 639 Config cfg ( "ButtonSettings" );
640 640
641 for ( uint i = 0; i < d->m_buttons->count(); i++ ) { 641 for ( uint i = 0; i < d->m_buttons->count(); i++ ) {
642 ODeviceButton &b = ( *d->m_buttons ) [i]; 642 ODeviceButton &b = ( *d->m_buttons ) [i];
643 QString group = "Button" + QString::number ( i ); 643 QString group = "Button" + QString::number ( i );
644 644
645 QCString pch, hch; 645 QCString pch, hch;
646 QCString pm, hm; 646 QCString pm, hm;
647 QByteArray pdata, hdata; 647 QByteArray pdata, hdata;
648 648
649 if ( cfg. hasGroup ( group )) { 649 if ( cfg. hasGroup ( group )) {
650 cfg. setGroup ( group ); 650 cfg. setGroup ( group );
651 pch = cfg. readEntry ( "PressedActionChannel" ). latin1(); 651 pch = cfg. readEntry ( "PressedActionChannel" ). latin1();
652 pm = cfg. readEntry ( "PressedActionMessage" ). latin1(); 652 pm = cfg. readEntry ( "PressedActionMessage" ). latin1();
653 // pdata = decodeBase64 ( buttonFile. readEntry ( "PressedActionArgs" )); 653 // pdata = decodeBase64 ( buttonFile. readEntry ( "PressedActionArgs" ));
654 654
655 hch = cfg. readEntry ( "HeldActionChannel" ). latin1(); 655 hch = cfg. readEntry ( "HeldActionChannel" ). latin1();
656 hm = cfg. readEntry ( "HeldActionMessage" ). latin1(); 656 hm = cfg. readEntry ( "HeldActionMessage" ). latin1();
657 // hdata = decodeBase64 ( buttonFile. readEntry ( "HeldActionArgs" )); 657 // hdata = decodeBase64 ( buttonFile. readEntry ( "HeldActionArgs" ));
658 } 658 }
659 659
660 b. setPressedAction ( OQCopMessage ( pch, pm, pdata )); 660 b. setPressedAction ( OQCopMessage ( pch, pm, pdata ));
661 661
662 b. setHeldAction ( OQCopMessage ( hch, hm, hdata )); 662 b. setHeldAction ( OQCopMessage ( hch, hm, hdata ));
663 } 663 }
664} 664}
665 665
666void ODevice::remapPressedAction ( int button, const OQCopMessage &action ) 666void ODevice::remapPressedAction ( int button, const OQCopMessage &action )
667{ 667{
668 initButtons(); 668 initButtons();
669 669
670 QString mb_chan; 670 QString mb_chan;
671 671
672 if ( button >= (int) d->m_buttons->count()) 672 if ( button >= (int) d->m_buttons->count())
673 return; 673 return;
674 674
675 ODeviceButton &b = ( *d->m_buttons ) [button]; 675 ODeviceButton &b = ( *d->m_buttons ) [button];
676 b. setPressedAction ( action ); 676 b. setPressedAction ( action );
677 677
678 mb_chan=b. pressedAction(). channel(); 678 mb_chan=b. pressedAction(). channel();
679 679
680 Config buttonFile ( "ButtonSettings" ); 680 Config buttonFile ( "ButtonSettings" );
681 buttonFile. setGroup ( "Button" + QString::number ( button )); 681 buttonFile. setGroup ( "Button" + QString::number ( button ));
682 buttonFile. writeEntry ( "PressedActionChannel", (const char*) mb_chan); 682 buttonFile. writeEntry ( "PressedActionChannel", (const char*) mb_chan);
683 buttonFile. writeEntry ( "PressedActionMessage", (const char*) b. pressedAction(). message()); 683 buttonFile. writeEntry ( "PressedActionMessage", (const char*) b. pressedAction(). message());
684 684
685// buttonFile. writeEntry ( "PressedActionArgs", encodeBase64 ( b. pressedAction(). data())); 685// buttonFile. writeEntry ( "PressedActionArgs", encodeBase64 ( b. pressedAction(). data()));
686 686
687 QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); 687 QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" );
688} 688}
689 689
690void ODevice::remapHeldAction ( int button, const OQCopMessage &action ) 690void ODevice::remapHeldAction ( int button, const OQCopMessage &action )
691{ 691{
692 initButtons(); 692 initButtons();
693 693
694 if ( button >= (int) d->m_buttons->count()) 694 if ( button >= (int) d->m_buttons->count())
695 return; 695 return;
696 696
697 ODeviceButton &b = ( *d->m_buttons ) [button]; 697 ODeviceButton &b = ( *d->m_buttons ) [button];
698 b. setHeldAction ( action ); 698 b. setHeldAction ( action );
699 699
700 Config buttonFile ( "ButtonSettings" ); 700 Config buttonFile ( "ButtonSettings" );
701 buttonFile. setGroup ( "Button" + QString::number ( button )); 701 buttonFile. setGroup ( "Button" + QString::number ( button ));
702 buttonFile. writeEntry ( "HeldActionChannel", (const char *) b. heldAction(). channel()); 702 buttonFile. writeEntry ( "HeldActionChannel", (const char *) b. heldAction(). channel());
703 buttonFile. writeEntry ( "HeldActionMessage", (const char *) b. heldAction(). message()); 703 buttonFile. writeEntry ( "HeldActionMessage", (const char *) b. heldAction(). message());
704 704
705// buttonFile. writeEntry ( "HeldActionArgs", decodeBase64 ( b. heldAction(). data())); 705// buttonFile. writeEntry ( "HeldActionArgs", decodeBase64 ( b. heldAction(). data()));
706 706
707 QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" ); 707 QCopEnvelope ( "QPE/System", "deviceButtonMappingChanged()" );
708} 708}
709void ODevice::virtual_hook(int, void* ){ 709void ODevice::virtual_hook(int, void* ){
710 710
711} 711}
712 712
713/** 713/**
714 * Sends a QCOP message to channel QPE/System 714 * Sends a QCOP message to channel QPE/System
715 * with the message "aboutToSuspend()" if this 715 * with the message "aboutToSuspend()" if this
716 * is the windowing server 716 * is the windowing server
717 */ 717 */
718void ODevice::sendSuspendmsg() 718void ODevice::sendSuspendmsg()
719{ 719{
720 if ( isQWS() ) 720 if ( isQWS() )
721 return; 721 return;
722 722
723 QCopEnvelope ( "QPE/System", "aboutToSuspend()" ); 723 QCopEnvelope ( "QPE/System", "aboutToSuspend()" );
724} 724}
725 725
726/** 726/**
727 * \brief Prepend the QWSServer::KeyboardFilter to the list of installed KeyFilters 727 * \brief Prepend the QWSServer::KeyboardFilter to the list of installed KeyFilters
728 * 728 *
729 * Prepend a QWSServer::KeyboardFilter to the List of Keyboard 729 * Prepend a QWSServer::KeyboardFilter to the List of Keyboard
730 * Filters. This function is the only way to prepend a KeyFilter. 730 * Filters. This function is the only way to prepend a KeyFilter.
731 * 731 *
732 * @param aFilter The KeyFilter to be prepended to the list of filters 732 * @param aFilter The KeyFilter to be prepended to the list of filters
733 * 733 *
734 * @see Opie::Core::OKeyFilter 734 * @see Opie::Core::OKeyFilter
735 * @see Opie::Core::OKeyFilter::inst() 735 * @see Opie::Core::OKeyFilter::inst()
736 */ 736 */
737void ODevice::addPreHandler(QWSServer::KeyboardFilter*aFilter) 737void ODevice::addPreHandler(QWSServer::KeyboardFilter*aFilter)
738{ 738{
739 Opie::Core::OKeyFilter::inst()->addPreHandler(aFilter); 739 Opie::Core::OKeyFilter::inst()->addPreHandler(aFilter);
740} 740}
741 741
742/** 742/**
743 * \brief Remove the QWSServer::KeyboardFilter in the param from the list 743 * \brief Remove the QWSServer::KeyboardFilter in the param from the list
744 * 744 *
745 * Remove the QWSServer::KeyboardFilter \par aFilter from the List 745 * Remove the QWSServer::KeyboardFilter \par aFilter from the List
746 * of Keyfilters. Call this when you delete the KeyFilter! 746 * of Keyfilters. Call this when you delete the KeyFilter!
747 * 747 *
748 * @param aFilter The filter to be removed from the Opie::Core::OKeyFilter 748 * @param aFilter The filter to be removed from the Opie::Core::OKeyFilter
749 * @see Opie::Core::ODevice::addPreHandler 749 * @see Opie::Core::ODevice::addPreHandler
750 */ 750 */
751void ODevice::remPreHandler(QWSServer::KeyboardFilter*aFilter) 751void ODevice::remPreHandler(QWSServer::KeyboardFilter*aFilter)
752{ 752{
753 Opie::Core::OKeyFilter::inst()->remPreHandler(aFilter); 753 Opie::Core::OKeyFilter::inst()->remPreHandler(aFilter);
754} 754}
755 755
756void ODevice::playingStopped() { 756void ODevice::playingStopped() {
757 const_cast<QObject*>(sender())->disconnect( this ); 757 const_cast<QObject*>(sender())->disconnect( this );
758#ifndef QT_NO_SOUND 758#ifndef QT_NO_SOUND
759 if ( d->m_sound >= 0 ) { 759 if ( d->m_sound >= 0 ) {
760 ::ioctl ( d->m_sound, MIXER_WRITE( d->m_mixer ), &d->m_vol ); 760 ::ioctl ( d->m_sound, MIXER_WRITE( d->m_mixer ), &d->m_vol );
761 ::close ( d->m_sound ); 761 ::close ( d->m_sound );
762 } 762 }
763#endif 763#endif
764} 764}
765 765
766void ODevice::changeMixerForAlarm( int mixer, const char* file, Sound *snd ) { 766void ODevice::changeMixerForAlarm( int mixer, const char* file, Sound *snd ) {
767#ifndef QT_NO_SOUND 767#ifndef QT_NO_SOUND
768 if (( d->m_sound = ::open ( file, O_RDWR )) >= 0 ) { 768 if (( d->m_sound = ::open ( file, O_RDWR )) >= 0 ) {
769 if ( ::ioctl ( d->m_sound, MIXER_READ( mixer ), &d->m_vol ) >= 0 ) { 769 if ( ::ioctl ( d->m_sound, MIXER_READ( mixer ), &d->m_vol ) >= 0 ) {
770 Config cfg ( "qpe" ); 770 Config cfg ( "qpe" );
771 cfg. setGroup ( "Volume" ); 771 cfg. setGroup ( "Volume" );
772 772
773 int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 ); 773 int volalarm = cfg. readNumEntry ( "AlarmPercent", 50 );
774 if ( volalarm < 0 ) 774 if ( volalarm < 0 )
775 volalarm = 0; 775 volalarm = 0;
776 else if ( volalarm > 100 ) 776 else if ( volalarm > 100 )
777 volalarm = 100; 777 volalarm = 100;
778 volalarm |= ( volalarm << 8 ); 778 volalarm |= ( volalarm << 8 );
779 779
780 if ( ::ioctl ( d->m_sound, MIXER_WRITE( mixer ), &volalarm ) >= 0 ) 780 if ( ::ioctl ( d->m_sound, MIXER_WRITE( mixer ), &volalarm ) >= 0 )
781 register_qpe_sound_finished(snd, this, SLOT(playingStopped())); 781 register_qpe_sound_finished(snd, this, SLOT(playingStopped()));
782 } 782 }
783 d->m_mixer = mixer; 783 d->m_mixer = mixer;
784 } 784 }
785#endif 785#endif
786} 786}
787 787
788} 788}
789} 789}