-rw-r--r-- | libopie2/opiecore/device/odevice.cpp | 2 |
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 | ||
63 | namespace Opie { | 63 | namespace Opie { |
64 | namespace Core { | 64 | namespace Core { |
65 | 65 | ||
66 | static const char* PATH_PROC_CPUINFO = "/proc/cpuinfo"; | 66 | static 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 | ||
93 | struct default_button default_buttons [] = { | 93 | struct 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 | ||
116 | ODevice *ODevice::inst() | 116 | ODevice *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 | ||
157 | ODevice::ODevice() | 157 | ODevice::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 | ||
201 | void ODevice::systemMessage( const QCString &msg, const QByteArray & ) | 201 | void 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 | ||
208 | void ODevice::init(const QString&) | 208 | void 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 | */ |
215 | void ODevice::initButtons() | 215 | void 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 | ||
239 | ODevice::~ODevice() | 239 | ODevice::~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 | ||
247 | bool ODevice::setSoftSuspend ( bool /*soft*/ ) | 247 | bool 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 | */ |
267 | bool ODevice::suspend() | 267 | bool 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 | */ |
312 | bool ODevice::setDisplayStatus ( bool on ) | 312 | bool 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 | */ |
335 | bool ODevice::setDisplayBrightness ( int p) | 335 | bool 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 | */ |
345 | int ODevice::displayBrightnessResolution() const | 345 | int 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 | */ |
355 | bool ODevice::setDisplayContrast ( int p) | 355 | bool 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 | */ |
365 | int ODevice::displayContrastResolution() const | 365 | int 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 | */ |
374 | QString ODevice::vendorString() const | 374 | QString 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 | */ |
383 | OVendor ODevice::vendor() const | 383 | OVendor 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 | */ |
392 | QString ODevice::modelString() const | 392 | QString 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 | */ |
400 | OModel ODevice::model() const | 400 | OModel 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 | */ |
408 | QString ODevice::systemString() const | 408 | QString 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 | */ |
416 | OSystem ODevice::system() const | 416 | OSystem 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 | */ |
424 | QString ODevice::systemVersionString() const | 424 | QString 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 | */ |
432 | Transformation ODevice::rotation() const | 432 | Transformation 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 | */ |
440 | ODirection ODevice::direction() const | 440 | ODirection 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 | */ |
448 | void ODevice::playAlarmSound() | 448 | void 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 | */ |
461 | void ODevice::playKeySound() | 461 | void 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 | */ |
474 | void ODevice::playTouchSound() | 474 | void 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 | */ |
489 | QValueList <OLed> ODevice::ledList() const | 489 | QValueList <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 | */ |
497 | QValueList <OLedState> ODevice::ledStateList ( OLed /*which*/ ) const | 497 | QValueList <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 | */ |
505 | OLedState ODevice::ledState ( OLed /*which*/ ) const | 505 | OLedState 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 | */ |
516 | bool ODevice::setLedState ( OLed which, OLedState st ) | 516 | bool 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 | */ |
526 | bool ODevice::hasLightSensor() const | 526 | bool 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 | */ |
534 | int ODevice::readLightSensor() | 534 | int 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 | */ |
542 | int ODevice::lightSensorResolution() const | 542 | int 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 | */ |
550 | bool ODevice::hasHingeSensor() const | 550 | bool 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 | */ |
558 | OHingeStatus ODevice::readHingeSensor() | 558 | OHingeStatus 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 | */ |
566 | const QStrList &ODevice::allowedCpuFrequencies() const | 566 | const 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 | */ |
577 | bool ODevice::setCurrentCpuFrequency(uint index) | 577 | bool 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 | */ |
602 | const QValueList <ODeviceButton> &ODevice::buttons() | 602 | const 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 | */ |
612 | uint ODevice::buttonHoldTime() const | 612 | uint 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 | */ |
624 | const ODeviceButton *ODevice::buttonForKeycode ( ushort code ) | 624 | const 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 | ||
635 | void ODevice::reloadButtonMapping() | 635 | void 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 | ||
666 | void ODevice::remapPressedAction ( int button, const OQCopMessage &action ) | 666 | void 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 | ||
690 | void ODevice::remapHeldAction ( int button, const OQCopMessage &action ) | 690 | void 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 | } |
709 | void ODevice::virtual_hook(int, void* ){ | 709 | void 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 | */ |
718 | void ODevice::sendSuspendmsg() | 718 | void 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 | */ |
737 | void ODevice::addPreHandler(QWSServer::KeyboardFilter*aFilter) | 737 | void 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 | */ |
751 | void ODevice::remPreHandler(QWSServer::KeyboardFilter*aFilter) | 751 | void 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 | ||
756 | void ODevice::playingStopped() { | 756 | void 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 | ||
766 | void ODevice::changeMixerForAlarm( int mixer, const char* file, Sound *snd ) { | 766 | void 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 | } |