summaryrefslogtreecommitdiff
authorschurig <schurig>2003-06-17 12:06:32 (UTC)
committer schurig <schurig>2003-06-17 12:06:32 (UTC)
commit507b9d90b2efb68abb58cb93b9647239df99dfb7 (patch) (unidiff)
treee8438478bf24704a9d8ee6237ebda39fa6357a86
parent930291d6f7ed63862c9500faf4cddc89e6ee634f (diff)
downloadopie-507b9d90b2efb68abb58cb93b9647239df99dfb7.zip
opie-507b9d90b2efb68abb58cb93b9647239df99dfb7.tar.gz
opie-507b9d90b2efb68abb58cb93b9647239df99dfb7.tar.bz2
removed a warning
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/inputmethods.cpp12
1 files changed, 6 insertions, 6 deletions
diff --git a/core/launcher/inputmethods.cpp b/core/launcher/inputmethods.cpp
index acd0d59..765dfe9 100644
--- a/core/launcher/inputmethods.cpp
+++ b/core/launcher/inputmethods.cpp
@@ -1,317 +1,317 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000 Trolltech AS. All rights reserved. 2** Copyright (C) 2000 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of Qtopia Environment. 4** This file is part of Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#define QTOPIA_INTERNAL_LANGLIST 21#define QTOPIA_INTERNAL_LANGLIST
22#include "inputmethods.h" 22#include "inputmethods.h"
23 23
24#include <qpe/config.h> 24#include <qpe/config.h>
25#include <qpe/qpeapplication.h> 25#include <qpe/qpeapplication.h>
26#include <qpe/inputmethodinterface.h> 26#include <qpe/inputmethodinterface.h>
27#include <qpe/qlibrary.h> 27#include <qpe/qlibrary.h>
28#include <qpe/global.h> 28#include <qpe/global.h>
29 29
30#include <qpopupmenu.h> 30#include <qpopupmenu.h>
31#include <qpushbutton.h> 31#include <qpushbutton.h>
32#include <qtoolbutton.h> 32#include <qtoolbutton.h>
33#include <qwidget.h> 33#include <qwidget.h>
34#include <qlayout.h> 34#include <qlayout.h>
35#include <qtimer.h> 35#include <qtimer.h>
36#include <qdir.h> 36#include <qdir.h>
37#include <stdlib.h> 37#include <stdlib.h>
38#include <qtranslator.h> 38#include <qtranslator.h>
39 39
40#ifdef Q_WS_QWS 40#ifdef Q_WS_QWS
41#include <qwindowsystem_qws.h> 41#include <qwindowsystem_qws.h>
42#include <qwsevent_qws.h> 42#include <qwsevent_qws.h>
43#endif 43#endif
44 44
45#ifdef SINGLE_APP 45#ifdef SINGLE_APP
46#include "handwritingimpl.h" 46#include "handwritingimpl.h"
47#include "keyboardimpl.h" 47#include "keyboardimpl.h"
48#include "pickboardimpl.h" 48#include "pickboardimpl.h"
49#endif 49#endif
50 50
51 51
52/* XPM */ 52/* XPM */
53static const char * tri_xpm[]={ 53static const char * tri_xpm[]={
54"9 9 2 1", 54"9 9 2 1",
55"a c #000000", 55"a c #000000",
56". c None", 56". c None",
57".........", 57".........",
58".........", 58".........",
59".........", 59".........",
60"....a....", 60"....a....",
61"...aaa...", 61"...aaa...",
62"..aaaaa..", 62"..aaaaa..",
63".aaaaaaa.", 63".aaaaaaa.",
64".........", 64".........",
65"........."}; 65"........."};
66 66
67static const int inputWidgetStyle = QWidget::WStyle_Customize | 67static const int inputWidgetStyle = QWidget::WStyle_Customize |
68 QWidget::WStyle_Tool | 68 QWidget::WStyle_Tool |
69 QWidget::WStyle_StaysOnTop | 69 QWidget::WStyle_StaysOnTop |
70 QWidget::WGroupLeader; 70 QWidget::WGroupLeader;
71 71
72InputMethods::InputMethods( QWidget *parent ) : 72InputMethods::InputMethods( QWidget *parent ) :
73 QWidget( parent, "InputMethods", WStyle_Tool | WStyle_Customize ) 73 QWidget( parent, "InputMethods", WStyle_Tool | WStyle_Customize )
74{ 74{
75 method = NULL; 75 method = NULL;
76 76
77 setBackgroundMode ( PaletteBackground ); 77 setBackgroundMode ( PaletteBackground );
78 78
79 QHBoxLayout *hbox = new QHBoxLayout( this ); 79 QHBoxLayout *hbox = new QHBoxLayout( this );
80 80
81 kbdButton = new QToolButton( this ); 81 kbdButton = new QToolButton( this );
82 kbdButton->setFocusPolicy(NoFocus); 82 kbdButton->setFocusPolicy(NoFocus);
83 kbdButton->setToggleButton( TRUE ); 83 kbdButton->setToggleButton( TRUE );
84 kbdButton->setFixedHeight( 17 ); 84 kbdButton->setFixedHeight( 17 );
85 kbdButton->setFixedWidth( 32 ); 85 kbdButton->setFixedWidth( 32 );
86 kbdButton->setAutoRaise( TRUE ); 86 kbdButton->setAutoRaise( TRUE );
87 kbdButton->setUsesBigPixmap( TRUE ); 87 kbdButton->setUsesBigPixmap( TRUE );
88 hbox->addWidget( kbdButton ); 88 hbox->addWidget( kbdButton );
89 connect( kbdButton, SIGNAL(toggled(bool)), this, SLOT(showKbd(bool)) ); 89 connect( kbdButton, SIGNAL(toggled(bool)), this, SLOT(showKbd(bool)) );
90 90
91 kbdChoice = new QToolButton( this ); 91 kbdChoice = new QToolButton( this );
92 kbdChoice->setFocusPolicy(NoFocus); 92 kbdChoice->setFocusPolicy(NoFocus);
93 kbdChoice->setPixmap( QPixmap( (const char **)tri_xpm ) ); 93 kbdChoice->setPixmap( QPixmap( (const char **)tri_xpm ) );
94 kbdChoice->setFixedHeight( 17 ); 94 kbdChoice->setFixedHeight( 17 );
95 kbdChoice->setFixedWidth( 12 ); 95 kbdChoice->setFixedWidth( 12 );
96 kbdChoice->setAutoRaise( TRUE ); 96 kbdChoice->setAutoRaise( TRUE );
97 hbox->addWidget( kbdChoice ); 97 hbox->addWidget( kbdChoice );
98 connect( kbdChoice, SIGNAL(clicked()), this, SLOT(chooseKbd()) ); 98 connect( kbdChoice, SIGNAL(clicked()), this, SLOT(chooseKbd()) );
99 99
100 connect( (QPEApplication*)qApp, SIGNAL(clientMoused()), 100 connect( (QPEApplication*)qApp, SIGNAL(clientMoused()),
101 this, SLOT(resetStates()) ); 101 this, SLOT(resetStates()) );
102 102
103 loadInputMethods(); 103 loadInputMethods();
104} 104}
105 105
106InputMethods::~InputMethods() 106InputMethods::~InputMethods()
107{ 107{
108#ifndef SINGLE_APP 108#ifndef SINGLE_APP
109 QValueList<InputMethod>::Iterator mit; 109 QValueList<InputMethod>::Iterator mit;
110 for ( mit = inputMethodList.begin(); mit != inputMethodList.end(); ++mit ) { 110 for ( mit = inputMethodList.begin(); mit != inputMethodList.end(); ++mit ) {
111 int i = (*mit).interface->release(); 111 (void) (*mit).interface->release();
112 (*mit).library->unload(); 112 (*mit).library->unload();
113 delete (*mit).library; 113 delete (*mit).library;
114 } 114 }
115#endif 115#endif
116} 116}
117 117
118void InputMethods::hideInputMethod() 118void InputMethods::hideInputMethod()
119{ 119{
120 kbdButton->setOn( FALSE ); 120 kbdButton->setOn( FALSE );
121} 121}
122 122
123void InputMethods::showInputMethod() 123void InputMethods::showInputMethod()
124{ 124{
125 kbdButton->setOn( TRUE ); 125 kbdButton->setOn( TRUE );
126} 126}
127 127
128void InputMethods::showInputMethod(const QString& name) 128void InputMethods::showInputMethod(const QString& name)
129{ 129{
130 int i = 0; 130 int i = 0;
131 QValueList<InputMethod>::Iterator it; 131 QValueList<InputMethod>::Iterator it;
132 InputMethod *im = 0; 132 InputMethod *im = 0;
133 for ( it = inputMethodList.begin(); it != inputMethodList.end(); ++it, i++ ) { 133 for ( it = inputMethodList.begin(); it != inputMethodList.end(); ++it, i++ ) {
134 if ( (*it).interface->name() == name ) { 134 if ( (*it).interface->name() == name ) {
135 im = &(*it); 135 im = &(*it);
136 break; 136 break;
137 } 137 }
138 } 138 }
139 if ( im ) 139 if ( im )
140 chooseMethod(im); 140 chooseMethod(im);
141} 141}
142 142
143void InputMethods::resetStates() 143void InputMethods::resetStates()
144{ 144{
145 if ( method ) 145 if ( method )
146 method->interface->resetState(); 146 method->interface->resetState();
147} 147}
148 148
149QRect InputMethods::inputRect() const 149QRect InputMethods::inputRect() const
150{ 150{
151 if ( !method || !method->widget->isVisible() ) 151 if ( !method || !method->widget->isVisible() )
152 return QRect(); 152 return QRect();
153 else 153 else
154 return method->widget->geometry(); 154 return method->widget->geometry();
155} 155}
156 156
157void InputMethods::loadInputMethods() 157void InputMethods::loadInputMethods()
158{ 158{
159#ifndef SINGLE_APP 159#ifndef SINGLE_APP
160 hideInputMethod(); 160 hideInputMethod();
161 method = 0; 161 method = 0;
162 162
163 QValueList<InputMethod>::Iterator mit; 163 QValueList<InputMethod>::Iterator mit;
164 for ( mit = inputMethodList.begin(); mit != inputMethodList.end(); ++mit ) { 164 for ( mit = inputMethodList.begin(); mit != inputMethodList.end(); ++mit ) {
165 (*mit).interface->release(); 165 (*mit).interface->release();
166 (*mit).library->unload(); 166 (*mit).library->unload();
167 delete (*mit).library; 167 delete (*mit).library;
168 } 168 }
169 inputMethodList.clear(); 169 inputMethodList.clear();
170 170
171 QString path = QPEApplication::qpeDir() + "/plugins/inputmethods"; 171 QString path = QPEApplication::qpeDir() + "/plugins/inputmethods";
172 QDir dir( path, "lib*.so" ); 172 QDir dir( path, "lib*.so" );
173 QStringList list = dir.entryList(); 173 QStringList list = dir.entryList();
174 QStringList::Iterator it; 174 QStringList::Iterator it;
175 for ( it = list.begin(); it != list.end(); ++it ) { 175 for ( it = list.begin(); it != list.end(); ++it ) {
176 InputMethodInterface *iface = 0; 176 InputMethodInterface *iface = 0;
177 QLibrary *lib = new QLibrary( path + "/" + *it ); 177 QLibrary *lib = new QLibrary( path + "/" + *it );
178 if ( lib->queryInterface( IID_InputMethod, (QUnknownInterface**)&iface ) == QS_OK ) { 178 if ( lib->queryInterface( IID_InputMethod, (QUnknownInterface**)&iface ) == QS_OK ) {
179 InputMethod input; 179 InputMethod input;
180 input.library = lib; 180 input.library = lib;
181 input.interface = iface; 181 input.interface = iface;
182 input.widget = input.interface->inputMethod( 0, inputWidgetStyle ); 182 input.widget = input.interface->inputMethod( 0, inputWidgetStyle );
183 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) ); 183 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) );
184 inputMethodList.append( input ); 184 inputMethodList.append( input );
185 185
186 QString type = (*it).left( (*it).find(".") ); 186 QString type = (*it).left( (*it).find(".") );
187 QStringList langs = Global::languageList(); 187 QStringList langs = Global::languageList();
188 for (QStringList::ConstIterator lit = langs.begin(); lit!=langs.end(); ++lit) { 188 for (QStringList::ConstIterator lit = langs.begin(); lit!=langs.end(); ++lit) {
189 QString lang = *lit; 189 QString lang = *lit;
190 QTranslator * trans = new QTranslator(qApp); 190 QTranslator * trans = new QTranslator(qApp);
191 QString tfn = QPEApplication::qpeDir()+"/i18n/"+lang+"/"+type+".qm"; 191 QString tfn = QPEApplication::qpeDir()+"/i18n/"+lang+"/"+type+".qm";
192 if ( trans->load( tfn )) 192 if ( trans->load( tfn ))
193 qApp->installTranslator( trans ); 193 qApp->installTranslator( trans );
194 else 194 else
195 delete trans; 195 delete trans;
196 } 196 }
197 } else { 197 } else {
198 delete lib; 198 delete lib;
199 } 199 }
200 } 200 }
201#else 201#else
202 InputMethod input; 202 InputMethod input;
203 input.interface = new HandwritingImpl(); 203 input.interface = new HandwritingImpl();
204 input.widget = input.interface->inputMethod( 0, inputWidgetStyle ); 204 input.widget = input.interface->inputMethod( 0, inputWidgetStyle );
205 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) ); 205 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) );
206 inputMethodList.append( input ); 206 inputMethodList.append( input );
207 input.interface = new KeyboardImpl(); 207 input.interface = new KeyboardImpl();
208 input.widget = input.interface->inputMethod( 0, inputWidgetStyle ); 208 input.widget = input.interface->inputMethod( 0, inputWidgetStyle );
209 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) ); 209 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) );
210 inputMethodList.append( input ); 210 inputMethodList.append( input );
211 input.interface = new PickboardImpl(); 211 input.interface = new PickboardImpl();
212 input.widget = input.interface->inputMethod( 0, inputWidgetStyle ); 212 input.widget = input.interface->inputMethod( 0, inputWidgetStyle );
213 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) ); 213 input.interface->onKeyPress( this, SLOT(sendKey(ushort,ushort,ushort,bool,bool)) );
214 inputMethodList.append( input ); 214 inputMethodList.append( input );
215#endif 215#endif
216 if ( !inputMethodList.isEmpty() ) { 216 if ( !inputMethodList.isEmpty() ) {
217 method = &inputMethodList[0]; 217 method = &inputMethodList[0];
218 Config cfg("qpe"); 218 Config cfg("qpe");
219 cfg.setGroup("InputMethod"); 219 cfg.setGroup("InputMethod");
220 QString curMethod = cfg.readEntry("current",""); 220 QString curMethod = cfg.readEntry("current","");
221 int i = 0; 221 int i = 0;
222 QValueList<InputMethod>::Iterator it; 222 QValueList<InputMethod>::Iterator it;
223 for ( it = inputMethodList.begin(); it != inputMethodList.end(); ++it, i++ ) { 223 for ( it = inputMethodList.begin(); it != inputMethodList.end(); ++it, i++ ) {
224 if((*it).interface->name() == curMethod) { 224 if((*it).interface->name() == curMethod) {
225 method = &inputMethodList[i]; 225 method = &inputMethodList[i];
226 } 226 }
227 } 227 }
228 kbdButton->setPixmap( *method->interface->icon() ); 228 kbdButton->setPixmap( *method->interface->icon() );
229 } 229 }
230 if ( !inputMethodList.isEmpty() ) 230 if ( !inputMethodList.isEmpty() )
231 kbdButton->show(); 231 kbdButton->show();
232 else 232 else
233 kbdButton->hide(); 233 kbdButton->hide();
234 if ( inputMethodList.count() > 1 ) 234 if ( inputMethodList.count() > 1 )
235 kbdChoice->show(); 235 kbdChoice->show();
236 else 236 else
237 kbdChoice->hide(); 237 kbdChoice->hide();
238} 238}
239 239
240void InputMethods::chooseKbd() 240void InputMethods::chooseKbd()
241{ 241{
242 QPopupMenu pop( this ); 242 QPopupMenu pop( this );
243 243
244 int i = 0; 244 int i = 0;
245 QValueList<InputMethod>::Iterator it; 245 QValueList<InputMethod>::Iterator it;
246 for ( it = inputMethodList.begin(); it != inputMethodList.end(); ++it, i++ ) { 246 for ( it = inputMethodList.begin(); it != inputMethodList.end(); ++it, i++ ) {
247 pop.insertItem( (*it).interface->name(), i ); 247 pop.insertItem( (*it).interface->name(), i );
248 if ( method == &(*it) ) 248 if ( method == &(*it) )
249 pop.setItemChecked( i, TRUE ); 249 pop.setItemChecked( i, TRUE );
250 } 250 }
251 251
252 QPoint pt = mapToGlobal(kbdChoice->geometry().topRight()); 252 QPoint pt = mapToGlobal(kbdChoice->geometry().topRight());
253 QSize s = pop.sizeHint(); 253 QSize s = pop.sizeHint();
254 pt.ry() -= s.height(); 254 pt.ry() -= s.height();
255 pt.rx() -= s.width(); 255 pt.rx() -= s.width();
256 i = pop.exec( pt ); 256 i = pop.exec( pt );
257 if ( i == -1 ) 257 if ( i == -1 )
258 return; 258 return;
259 InputMethod *im = &inputMethodList[i]; 259 InputMethod *im = &inputMethodList[i];
260 chooseMethod(im); 260 chooseMethod(im);
261} 261}
262 262
263void InputMethods::chooseMethod(InputMethod* im) 263void InputMethods::chooseMethod(InputMethod* im)
264{ 264{
265 if ( im != method ) { 265 if ( im != method ) {
266 if ( method && method->widget->isVisible() ) 266 if ( method && method->widget->isVisible() )
267 method->widget->hide(); 267 method->widget->hide();
268 method = im; 268 method = im;
269 Config cfg("qpe"); 269 Config cfg("qpe");
270 cfg.setGroup("InputMethod"); 270 cfg.setGroup("InputMethod");
271 cfg.writeEntry("current", method->interface->name()); 271 cfg.writeEntry("current", method->interface->name());
272 kbdButton->setPixmap( *method->interface->icon() ); 272 kbdButton->setPixmap( *method->interface->icon() );
273 } 273 }
274 if ( !kbdButton->isOn() ) 274 if ( !kbdButton->isOn() )
275 kbdButton->setOn( TRUE ); 275 kbdButton->setOn( TRUE );
276 else 276 else
277 showKbd( TRUE ); 277 showKbd( TRUE );
278} 278}
279 279
280 280
281void InputMethods::showKbd( bool on ) 281void InputMethods::showKbd( bool on )
282{ 282{
283 if ( !method ) 283 if ( !method )
284 return; 284 return;
285 285
286 if ( on ) { 286 if ( on ) {
287 method->interface->resetState(); 287 method->interface->resetState();
288 // HACK... Make the texteditor fit with all input methods 288 // HACK... Make the texteditor fit with all input methods
289 // Input methods should also never use more than about 40% of the screen 289 // Input methods should also never use more than about 40% of the screen
290 int height = QMIN( method->widget->sizeHint().height(), 134 ); 290 int height = QMIN( method->widget->sizeHint().height(), 134 );
291 method->widget->resize( qApp->desktop()->width(), height ); 291 method->widget->resize( qApp->desktop()->width(), height );
292 method->widget->move( 0, mapToGlobal( QPoint() ).y() - height ); 292 method->widget->move( 0, mapToGlobal( QPoint() ).y() - height );
293 method->widget->show(); 293 method->widget->show();
294 } else { 294 } else {
295 method->widget->hide(); 295 method->widget->hide();
296 } 296 }
297 297
298 emit inputToggled( on ); 298 emit inputToggled( on );
299} 299}
300 300
301bool InputMethods::shown() const 301bool InputMethods::shown() const
302{ 302{
303 return method && method->widget->isVisible(); 303 return method && method->widget->isVisible();
304} 304}
305 305
306QString InputMethods::currentShown() const 306QString InputMethods::currentShown() const
307{ 307{
308 return method && method->widget->isVisible() 308 return method && method->widget->isVisible()
309 ? method->interface->name() : QString::null; 309 ? method->interface->name() : QString::null;
310} 310}
311 311
312void InputMethods::sendKey( ushort unicode, ushort scancode, ushort mod, bool press, bool repeat ) 312void InputMethods::sendKey( ushort unicode, ushort scancode, ushort mod, bool press, bool repeat )
313{ 313{
314#if defined(Q_WS_QWS) 314#if defined(Q_WS_QWS)
315 QWSServer::sendKeyEvent( unicode, scancode, mod, press, repeat ); 315 QWSServer::sendKeyEvent( unicode, scancode, mod, press, repeat );
316#endif 316#endif
317} 317}