summaryrefslogtreecommitdiff
authorar <ar>2005-03-10 16:21:07 (UTC)
committer ar <ar>2005-03-10 16:21:07 (UTC)
commit3bf4809c4f2263f0130472c41aa6c85e46e61db9 (patch) (unidiff)
tree82c34fddb63bb6ca8cbd53709ab2642795241d38
parent95a99e7b75eddc5629e839698b762f594be42b9f (diff)
downloadopie-3bf4809c4f2263f0130472c41aa6c85e46e61db9.zip
opie-3bf4809c4f2263f0130472c41aa6c85e46e61db9.tar.gz
opie-3bf4809c4f2263f0130472c41aa6c85e46e61db9.tar.bz2
- implement nomax.patch from openembedded
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--library/qpeapplication.cpp8
-rw-r--r--library/widget_showing.cpp4
2 files changed, 9 insertions, 3 deletions
diff --git a/library/qpeapplication.cpp b/library/qpeapplication.cpp
index 953f9d0..0f3e4a4 100644
--- a/library/qpeapplication.cpp
+++ b/library/qpeapplication.cpp
@@ -1,1112 +1,1114 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of the Qtopia Environment. 4** This file is part of the 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#define QTOPIA_INTERNAL_LANGLIST 20#define QTOPIA_INTERNAL_LANGLIST
21#include <stdlib.h> 21#include <stdlib.h>
22#include <unistd.h> 22#include <unistd.h>
23#ifndef Q_OS_MACX 23#ifndef Q_OS_MACX
24#include <linux/limits.h> // needed for some toolchains (PATH_MAX) 24#include <linux/limits.h> // needed for some toolchains (PATH_MAX)
25#endif 25#endif
26#include <qfile.h> 26#include <qfile.h>
27#include <qqueue.h> 27#include <qqueue.h>
28#ifdef Q_WS_QWS 28#ifdef Q_WS_QWS
29#ifndef QT_NO_COP 29#ifndef QT_NO_COP
30#if QT_VERSION <= 231 30#if QT_VERSION <= 231
31#define private public 31#define private public
32#define sendLocally processEvent 32#define sendLocally processEvent
33#include "qcopenvelope_qws.h" 33#include "qcopenvelope_qws.h"
34#undef private 34#undef private
35#else 35#else
36#include "qcopenvelope_qws.h" 36#include "qcopenvelope_qws.h"
37#endif 37#endif
38#endif 38#endif
39#include <qwindowsystem_qws.h> 39#include <qwindowsystem_qws.h>
40#endif 40#endif
41#include <qtextstream.h> 41#include <qtextstream.h>
42#include <qpalette.h> 42#include <qpalette.h>
43#include <qbuffer.h> 43#include <qbuffer.h>
44#include <qptrdict.h> 44#include <qptrdict.h>
45#include <qregexp.h> 45#include <qregexp.h>
46#include <qdir.h> 46#include <qdir.h>
47#include <qlabel.h> 47#include <qlabel.h>
48#include <qdialog.h> 48#include <qdialog.h>
49#include <qdragobject.h> 49#include <qdragobject.h>
50#include <qtextcodec.h> 50#include <qtextcodec.h>
51#include <qevent.h> 51#include <qevent.h>
52#include <qtooltip.h> 52#include <qtooltip.h>
53#include <qsignal.h> 53#include <qsignal.h>
54#include <qmainwindow.h> 54#include <qmainwindow.h>
55#include <qwidgetlist.h> 55#include <qwidgetlist.h>
56#include <qpixmapcache.h> 56#include <qpixmapcache.h>
57 57
58#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 58#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
59#define QTOPIA_INTERNAL_INITAPP 59#define QTOPIA_INTERNAL_INITAPP
60#include "qpeapplication.h" 60#include "qpeapplication.h"
61#include "qpestyle.h" 61#include "qpestyle.h"
62#include "styleinterface.h" 62#include "styleinterface.h"
63#if QT_VERSION >= 0x030000 63#if QT_VERSION >= 0x030000
64#include <qstylefactory.h> 64#include <qstylefactory.h>
65#else 65#else
66#include <qplatinumstyle.h> 66#include <qplatinumstyle.h>
67#include <qwindowsstyle.h> 67#include <qwindowsstyle.h>
68#include <qmotifstyle.h> 68#include <qmotifstyle.h>
69#include <qmotifplusstyle.h> 69#include <qmotifplusstyle.h>
70#include "lightstyle.h" 70#include "lightstyle.h"
71 71
72#include <qpe/qlibrary.h> 72#include <qpe/qlibrary.h>
73#endif 73#endif
74#include "global.h" 74#include "global.h"
75#include "resource.h" 75#include "resource.h"
76#if QT_VERSION <= 230 && defined(QT_NO_CODECS) 76#if QT_VERSION <= 230 && defined(QT_NO_CODECS)
77#include "qutfcodec.h" 77#include "qutfcodec.h"
78#endif 78#endif
79#include "config.h" 79#include "config.h"
80#include "network.h" 80#include "network.h"
81#ifdef QWS 81#ifdef QWS
82#include "fontmanager.h" 82#include "fontmanager.h"
83#include "fontdatabase.h" 83#include "fontdatabase.h"
84#endif 84#endif
85 85
86#include "alarmserver.h" 86#include "alarmserver.h"
87#include "applnk.h" 87#include "applnk.h"
88#include "qpemenubar.h" 88#include "qpemenubar.h"
89#include "textcodecinterface.h" 89#include "textcodecinterface.h"
90#include "imagecodecinterface.h" 90#include "imagecodecinterface.h"
91#include <qtopia/qpeglobal.h> 91#include <qtopia/qpeglobal.h>
92 92
93#include <unistd.h> 93#include <unistd.h>
94#include <sys/file.h> 94#include <sys/file.h>
95#include <sys/ioctl.h> 95#include <sys/ioctl.h>
96#ifndef QT_NO_SOUND 96#ifndef QT_NO_SOUND
97#include <sys/soundcard.h> 97#include <sys/soundcard.h>
98#endif 98#endif
99 99
100#include <backend/rohfeedback.h> 100#include <backend/rohfeedback.h>
101 101
102 102
103static bool useBigPixmaps = 0; 103static bool useBigPixmaps = 0;
104 104
105class HackWidget : public QWidget 105class HackWidget : public QWidget
106{ 106{
107public: 107public:
108 bool needsOk() 108 bool needsOk()
109 { return (getWState() & WState_Reserved1 ); } 109 { return (getWState() & WState_Reserved1 ); }
110 110
111 QRect normalGeometry() 111 QRect normalGeometry()
112 { return topData()->normalGeometry; }; 112 { return topData()->normalGeometry; };
113}; 113};
114 114
115class QPEApplicationData 115class QPEApplicationData
116{ 116{
117public: 117public:
118 QPEApplicationData ( ) : 118 QPEApplicationData ( ) :
119 presstimer( 0 ), presswidget( 0 ), rightpressed( false ), kbgrabbed( false ), 119 presstimer( 0 ), presswidget( 0 ), rightpressed( false ), kbgrabbed( false ),
120 notbusysent( false ), preloaded( false ), forceshow( false ), nomaximize( false ), 120 notbusysent( false ), preloaded( false ), forceshow( false ), nomaximize( false ),
121 keep_running( true ), qcopQok( false ), 121 keep_running( true ), qcopQok( false ),
122 fontFamily( "Vera" ), fontSize( 10 ), smallIconSize( 14 ), 122 fontFamily( "Vera" ), fontSize( 10 ), smallIconSize( 14 ),
123 bigIconSize( 32 ), qpe_main_widget( 0 ) 123 bigIconSize( 32 ), qpe_main_widget( 0 )
124 { 124 {
125 Config cfg( "qpe" ); 125 Config cfg( "qpe" );
126 cfg.setGroup( "Appearance" ); 126 cfg.setGroup( "Appearance" );
127 useBigPixmaps = cfg.readBoolEntry( "useBigPixmaps", false ); 127 useBigPixmaps = cfg.readBoolEntry( "useBigPixmaps", false );
128 fontFamily = cfg.readEntry( "FontFamily", "Vera" ); 128 fontFamily = cfg.readEntry( "FontFamily", "Vera" );
129 fontSize = cfg.readNumEntry( "FontSize", 10 ); 129 fontSize = cfg.readNumEntry( "FontSize", 10 );
130 smallIconSize = cfg.readNumEntry( "SmallIconSize", 14 ); 130 smallIconSize = cfg.readNumEntry( "SmallIconSize", 14 );
131 bigIconSize = cfg.readNumEntry( "BigIconSize", 32 ); 131 bigIconSize = cfg.readNumEntry( "BigIconSize", 32 );
132#ifdef OPIE_WITHROHFEEDBACK 132#ifdef OPIE_WITHROHFEEDBACK
133 RoH = 0; 133 RoH = 0;
134#endif 134#endif
135 } 135 }
136 136
137 int presstimer; 137 int presstimer;
138 QWidget* presswidget; 138 QWidget* presswidget;
139 QPoint presspos; 139 QPoint presspos;
140#ifdef OPIE_WITHROHFEEDBACK 140#ifdef OPIE_WITHROHFEEDBACK
141 Opie::Internal::RoHFeedback *RoH; 141 Opie::Internal::RoHFeedback *RoH;
142#endif 142#endif
143 143
144 bool rightpressed : 1; 144 bool rightpressed : 1;
145 bool kbgrabbed : 1; 145 bool kbgrabbed : 1;
146 bool notbusysent : 1; 146 bool notbusysent : 1;
147 bool preloaded : 1; 147 bool preloaded : 1;
148 bool forceshow : 1; 148 bool forceshow : 1;
149 bool nomaximize : 1; 149 bool nomaximize : 1;
150 bool keep_running : 1; 150 bool keep_running : 1;
151 bool qcopQok : 1; 151 bool qcopQok : 1;
152 152
153 QCString fontFamily; 153 QCString fontFamily;
154 int fontSize; 154 int fontSize;
155 int smallIconSize; 155 int smallIconSize;
156 int bigIconSize; 156 int bigIconSize;
157 157
158 QString appName; 158 QString appName;
159 struct QCopRec 159 struct QCopRec
160 { 160 {
161 QCopRec( const QCString &ch, const QCString &msg, 161 QCopRec( const QCString &ch, const QCString &msg,
162 const QByteArray &d ) : 162 const QByteArray &d ) :
163 channel( ch ), message( msg ), data( d ) 163 channel( ch ), message( msg ), data( d )
164 { } 164 { }
165 165
166 QCString channel; 166 QCString channel;
167 QCString message; 167 QCString message;
168 QByteArray data; 168 QByteArray data;
169 }; 169 };
170 QGuardedPtr<QWidget> qpe_main_widget; 170 QGuardedPtr<QWidget> qpe_main_widget;
171 QGuardedPtr<QWidget> lastraised; 171 QGuardedPtr<QWidget> lastraised;
172 QQueue<QCopRec> qcopq; 172 QQueue<QCopRec> qcopq;
173 QString styleName; 173 QString styleName;
174 QString decorationName; 174 QString decorationName;
175 175
176 void enqueueQCop( const QCString &ch, const QCString &msg, 176 void enqueueQCop( const QCString &ch, const QCString &msg,
177 const QByteArray &data ) 177 const QByteArray &data )
178 { 178 {
179 qcopq.enqueue( new QCopRec( ch, msg, data ) ); 179 qcopq.enqueue( new QCopRec( ch, msg, data ) );
180 } 180 }
181 void sendQCopQ() 181 void sendQCopQ()
182 { 182 {
183 if (!qcopQok ) 183 if (!qcopQok )
184 return; 184 return;
185 185
186 QCopRec * r; 186 QCopRec * r;
187 187
188 while((r=qcopq.dequeue())) { 188 while((r=qcopq.dequeue())) {
189 // remove from queue before sending... 189 // remove from queue before sending...
190 // event loop can come around again before getting 190 // event loop can come around again before getting
191 // back from sendLocally 191 // back from sendLocally
192#ifndef QT_NO_COP 192#ifndef QT_NO_COP
193 QCopChannel::sendLocally( r->channel, r->message, r->data ); 193 QCopChannel::sendLocally( r->channel, r->message, r->data );
194#endif 194#endif
195 195
196 delete r; 196 delete r;
197 } 197 }
198 } 198 }
199 199
200 static void show_mx(QWidget* mw, bool nomaximize, QString &strName) { 200 static void show_mx(QWidget* mw, bool nomaximize, QString &strName) {
201 if ( mw->inherits("QMainWindow") || mw->isA("QMainWindow") ) 201 if ( mw->inherits("QMainWindow") || mw->isA("QMainWindow") )
202 { 202 {
203 ( ( QMainWindow* ) mw )->setUsesBigPixmaps( useBigPixmaps ); 203 ( ( QMainWindow* ) mw )->setUsesBigPixmaps( useBigPixmaps );
204 } 204 }
205 QPoint p; 205 QPoint p;
206 QSize s; 206 QSize s;
207 bool max; 207 bool max;
208 208
209 if ( mw->isVisible() ) { 209 if ( mw->isVisible() ) {
210 if ( read_widget_rect(strName, max, p, s) && validate_widget_size(mw, p, s) ) { 210 if ( read_widget_rect(strName, max, p, s) && validate_widget_size(mw, p, s) ) {
211 mw->resize(s); 211 mw->resize(s);
212 mw->move(p); 212 mw->move(p);
213 } 213 }
214 mw->raise(); 214 mw->raise();
215 } else { 215 } else {
216 216
217 if ( mw->layout() && mw->inherits("QDialog") ) { 217 if ( mw->layout() && mw->inherits("QDialog") ) {
218 if ( read_widget_rect(strName, max, p, s) && validate_widget_size(mw, p, s) ) { 218 if ( read_widget_rect(strName, max, p, s) && validate_widget_size(mw, p, s) ) {
219 mw->resize(s); 219 mw->resize(s);
220 mw->move(p); 220 mw->move(p);
221 221
222 if ( max && !nomaximize ) { 222 if ( max && !nomaximize ) {
223 mw->showMaximized(); 223 mw->showMaximized();
224 } else { 224 } else {
225 mw->show(); 225 mw->show();
226 } 226 }
227 } else { 227 } else {
228 QPEApplication::showDialog((QDialog*)mw,nomaximize); 228 QPEApplication::showDialog((QDialog*)mw,nomaximize);
229 } 229 }
230 } else { 230 } else {
231 if ( read_widget_rect(strName, max, p, s) && validate_widget_size(mw, p, s) ) { 231 if ( read_widget_rect(strName, max, p, s) && validate_widget_size(mw, p, s) ) {
232 mw->resize(s); 232 mw->resize(s);
233 mw->move(p); 233 mw->move(p);
234 } else { //no stored rectangle, make an estimation 234 } else { //no stored rectangle, make an estimation
235 int x = (qApp->desktop()->width()-mw->frameGeometry().width())/2; 235 int x = (qApp->desktop()->width()-mw->frameGeometry().width())/2;
236 int y = (qApp->desktop()->height()-mw->frameGeometry().height())/2; 236 int y = (qApp->desktop()->height()-mw->frameGeometry().height())/2;
237 mw->move( QMAX(x,0), QMAX(y,0) ); 237 mw->move( QMAX(x,0), QMAX(y,0) );
238#ifdef Q_WS_QWS 238#ifdef Q_WS_QWS
239 if ( !nomaximize ) 239 if ( !nomaximize )
240 mw->showMaximized(); 240 mw->showMaximized();
241#endif 241#endif
242 } 242 }
243 if ( max && !nomaximize ) 243 if ( max && !nomaximize )
244 mw->showMaximized(); 244 mw->showMaximized();
245 else 245 else
246 mw->show(); 246 mw->show();
247 } 247 }
248 } 248 }
249 } 249 }
250 250
251 static bool read_widget_rect(const QString &app, bool &maximized, QPoint &p, QSize &s) 251 static bool read_widget_rect(const QString &app, bool &maximized, QPoint &p, QSize &s)
252 { 252 {
253#ifndef OPIE_NO_WINDOWED
253 maximized = TRUE; 254 maximized = TRUE;
254 // 350 is the trigger in qwsdefaultdecoration for providing a resize button 255 // 350 is the trigger in qwsdefaultdecoration for providing a resize button
255 if ( qApp->desktop()->width() <= 350 ) 256 if ( qApp->desktop()->width() <= 350 )
256 return FALSE; 257 return FALSE;
257 258
258 Config cfg( "qpe" ); 259 Config cfg( "qpe" );
259 cfg.setGroup("ApplicationPositions"); 260 cfg.setGroup("ApplicationPositions");
260 QString str = cfg.readEntry( app, QString::null ); 261 QString str = cfg.readEntry( app, QString::null );
261 QStringList l = QStringList::split(",", str); 262 QStringList l = QStringList::split(",", str);
262 263
263 if ( l.count() == 5) { 264 if ( l.count() == 5) {
264 p.setX( l[0].toInt() ); 265 p.setX( l[0].toInt() );
265 p.setY( l[1].toInt() ); 266 p.setY( l[1].toInt() );
266 267
267 s.setWidth( l[2].toInt() ); 268 s.setWidth( l[2].toInt() );
268 s.setHeight( l[3].toInt() ); 269 s.setHeight( l[3].toInt() );
269 270
270 maximized = l[4].toInt(); 271 maximized = l[4].toInt();
271 272
272 return TRUE; 273 return TRUE;
273 } 274 }
274 275#endif
275 return FALSE; 276 return FALSE;
276 } 277 }
277 278
278 279
279 static bool validate_widget_size(const QWidget *w, QPoint &p, QSize &s) 280 static bool validate_widget_size(const QWidget *w, QPoint &p, QSize &s)
280 { 281 {
281#ifndef Q_WS_QWS 282#ifndef Q_WS_QWS
282 QRect qt_maxWindowRect = qApp->desktop()->geometry(); 283 QRect qt_maxWindowRect = qApp->desktop()->geometry();
283#endif 284#endif
284 int maxX = qt_maxWindowRect.width(); 285 int maxX = qt_maxWindowRect.width();
285 int maxY = qt_maxWindowRect.height(); 286 int maxY = qt_maxWindowRect.height();
286 int wWidth = s.width() + ( w->frameGeometry().width() - w->geometry().width() ); 287 int wWidth = s.width() + ( w->frameGeometry().width() - w->geometry().width() );
287 int wHeight = s.height() + ( w->frameGeometry().height() - w->geometry().height() ); 288 int wHeight = s.height() + ( w->frameGeometry().height() - w->geometry().height() );
288 289
289 // total window size is not allowed to be larger than desktop window size 290 // total window size is not allowed to be larger than desktop window size
290 if ( ( wWidth >= maxX ) && ( wHeight >= maxY ) ) 291 if ( ( wWidth >= maxX ) && ( wHeight >= maxY ) )
291 return FALSE; 292 return FALSE;
292 293
293 if ( wWidth > maxX ) { 294 if ( wWidth > maxX ) {
294 s.setWidth( maxX - (w->frameGeometry().width() - w->geometry().width() ) ); 295 s.setWidth( maxX - (w->frameGeometry().width() - w->geometry().width() ) );
295 wWidth = maxX; 296 wWidth = maxX;
296 } 297 }
297 298
298 if ( wHeight > maxY ) { 299 if ( wHeight > maxY ) {
299 s.setHeight( maxY - (w->frameGeometry().height() - w->geometry().height() ) ); 300 s.setHeight( maxY - (w->frameGeometry().height() - w->geometry().height() ) );
300 wHeight = maxY; 301 wHeight = maxY;
301 } 302 }
302 303
303 // any smaller than this and the maximize/close/help buttons will be overlapping 304 // any smaller than this and the maximize/close/help buttons will be overlapping
304 if ( wWidth < 80 || wHeight < 60 ) 305 if ( wWidth < 80 || wHeight < 60 )
305 return FALSE; 306 return FALSE;
306 307
307 if ( p.x() < 0 ) 308 if ( p.x() < 0 )
308 p.setX(0); 309 p.setX(0);
309 if ( p.y() < 0 ) 310 if ( p.y() < 0 )
310 p.setY(0); 311 p.setY(0);
311 312
312 if ( p.x() + wWidth > maxX ) 313 if ( p.x() + wWidth > maxX )
313 p.setX( maxX - wWidth ); 314 p.setX( maxX - wWidth );
314 if ( p.y() + wHeight > maxY ) 315 if ( p.y() + wHeight > maxY )
315 p.setY( maxY - wHeight ); 316 p.setY( maxY - wHeight );
316 317
317 return TRUE; 318 return TRUE;
318 } 319 }
319 320
320 static void store_widget_rect(QWidget *w, QString &app) 321 static void store_widget_rect(QWidget *w, QString &app)
321 { 322 {
322 if( !w ) 323 if( !w )
323 return; 324 return;
324 325#ifndef OPIE_NO_WINDOWED
325 // 350 is the trigger in qwsdefaultdecoration for providing a resize button 326 // 350 is the trigger in qwsdefaultdecoration for providing a resize button
326 if ( qApp->desktop()->width() <= 350 ) 327 if ( qApp->desktop()->width() <= 350 )
327 return; 328 return;
328 // we use these to map the offset of geometry and pos. ( we can only use normalGeometry to 329 // we use these to map the offset of geometry and pos. ( we can only use normalGeometry to
329 // get the non-maximized version, so we have to do it the hard way ) 330 // get the non-maximized version, so we have to do it the hard way )
330 int offsetX = w->x() - w->geometry().left(); 331 int offsetX = w->x() - w->geometry().left();
331 int offsetY = w->y() - w->geometry().top(); 332 int offsetY = w->y() - w->geometry().top();
332 333
333 QRect r; 334 QRect r;
334 if ( w->isMaximized() ) 335 if ( w->isMaximized() )
335 r = ( (HackWidget *) w)->normalGeometry(); 336 r = ( (HackWidget *) w)->normalGeometry();
336 else 337 else
337 r = w->geometry(); 338 r = w->geometry();
338 339
339 // Stores the window placement as pos(), size() (due to the offset mapping) 340 // Stores the window placement as pos(), size() (due to the offset mapping)
340 Config cfg( "qpe" ); 341 Config cfg( "qpe" );
341 cfg.setGroup("ApplicationPositions"); 342 cfg.setGroup("ApplicationPositions");
342 QString s; 343 QString s;
343 s.sprintf("%d,%d,%d,%d,%d", r.left() + offsetX, r.top() + offsetY, r.width(), r.height(), w->isMaximized() ); 344 s.sprintf("%d,%d,%d,%d,%d", r.left() + offsetX, r.top() + offsetY, r.width(), r.height(), w->isMaximized() );
344 cfg.writeEntry( app, s ); 345 cfg.writeEntry( app, s );
346#endif
345 } 347 }
346 348
347 static bool setWidgetCaptionFromAppName( QWidget* /*mw*/, const QString& /*appName*/, const QString& /*appsPath*/ ) 349 static bool setWidgetCaptionFromAppName( QWidget* /*mw*/, const QString& /*appName*/, const QString& /*appsPath*/ )
348 { 350 {
349 /* 351 /*
350 // This works but disable it for now until it is safe to apply 352 // This works but disable it for now until it is safe to apply
351 // What is does is scan the .desktop files of all the apps for 353 // What is does is scan the .desktop files of all the apps for
352 // the applnk that has the corresponding argv[0] as this program 354 // the applnk that has the corresponding argv[0] as this program
353 // then it uses the name stored in the .desktop file as the caption 355 // then it uses the name stored in the .desktop file as the caption
354 // for the main widget. This saves duplicating translations for 356 // for the main widget. This saves duplicating translations for
355 // the app name in the program and in the .desktop files. 357 // the app name in the program and in the .desktop files.
356 358
357 AppLnkSet apps( appsPath ); 359 AppLnkSet apps( appsPath );
358 360
359 QList<AppLnk> appsList = apps.children(); 361 QList<AppLnk> appsList = apps.children();
360 for ( QListIterator<AppLnk> it(appsList); it.current(); ++it ) { 362 for ( QListIterator<AppLnk> it(appsList); it.current(); ++it ) {
361 if ( (*it)->exec() == appName ) { 363 if ( (*it)->exec() == appName ) {
362 mw->setCaption( (*it)->name() ); 364 mw->setCaption( (*it)->name() );
363 return TRUE; 365 return TRUE;
364 } 366 }
365 } 367 }
366 */ 368 */
367 return FALSE; 369 return FALSE;
368 } 370 }
369 371
370 372
371 void show(QWidget* mw, bool nomax) 373 void show(QWidget* mw, bool nomax)
372 { 374 {
373 setWidgetCaptionFromAppName( mw, appName, QPEApplication::qpeDir() + "apps" ); 375 setWidgetCaptionFromAppName( mw, appName, QPEApplication::qpeDir() + "apps" );
374 nomaximize = nomax; 376 nomaximize = nomax;
375 qpe_main_widget = mw; 377 qpe_main_widget = mw;
376 qcopQok = TRUE; 378 qcopQok = TRUE;
377#ifndef QT_NO_COP 379#ifndef QT_NO_COP
378 380
379 sendQCopQ(); 381 sendQCopQ();
380#endif 382#endif
381 383
382 if ( preloaded ) { 384 if ( preloaded ) {
383 if (forceshow) 385 if (forceshow)
384 show_mx(mw, nomax, appName); 386 show_mx(mw, nomax, appName);
385 } 387 }
386 else if ( keep_running ) { 388 else if ( keep_running ) {
387 show_mx(mw, nomax, appName); 389 show_mx(mw, nomax, appName);
388 } 390 }
389 } 391 }
390 392
391 void loadTextCodecs() 393 void loadTextCodecs()
392 { 394 {
393 QString path = QPEApplication::qpeDir() + "plugins/textcodecs"; 395 QString path = QPEApplication::qpeDir() + "plugins/textcodecs";
394#ifdef Q_OS_MACX 396#ifdef Q_OS_MACX
395 QDir dir( path, "lib*.dylib" ); 397 QDir dir( path, "lib*.dylib" );
396#else 398#else
397 QDir dir( path, "lib*.so" ); 399 QDir dir( path, "lib*.so" );
398#endif 400#endif
399 QStringList list; 401 QStringList list;
400 if ( dir. exists ( )) 402 if ( dir. exists ( ))
401 list = dir.entryList(); 403 list = dir.entryList();
402 QStringList::Iterator it; 404 QStringList::Iterator it;
403 for ( it = list.begin(); it != list.end(); ++it ) { 405 for ( it = list.begin(); it != list.end(); ++it ) {
404 TextCodecInterface *iface = 0; 406 TextCodecInterface *iface = 0;
405 QLibrary *lib = new QLibrary( path + "/" + *it ); 407 QLibrary *lib = new QLibrary( path + "/" + *it );
406 if ( lib->queryInterface( IID_QtopiaTextCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) { 408 if ( lib->queryInterface( IID_QtopiaTextCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) {
407 QValueList<int> mibs = iface->mibEnums(); 409 QValueList<int> mibs = iface->mibEnums();
408 for (QValueList<int>::ConstIterator i = mibs.begin(); i != mibs.end(); ++i) { 410 for (QValueList<int>::ConstIterator i = mibs.begin(); i != mibs.end(); ++i) {
409 (void)iface->createForMib(*i); 411 (void)iface->createForMib(*i);
410 // ### it exists now; need to remember if we can delete it 412 // ### it exists now; need to remember if we can delete it
411 } 413 }
412 } 414 }
413 else { 415 else {
414 lib->unload(); 416 lib->unload();
415 delete lib; 417 delete lib;
416 } 418 }
417 } 419 }
418 } 420 }
419 421
420 void loadImageCodecs() 422 void loadImageCodecs()
421 { 423 {
422 QString path = QPEApplication::qpeDir() + "plugins/imagecodecs"; 424 QString path = QPEApplication::qpeDir() + "plugins/imagecodecs";
423#ifdef Q_OS_MACX 425#ifdef Q_OS_MACX
424 QDir dir( path, "lib*.dylib" ); 426 QDir dir( path, "lib*.dylib" );
425#else 427#else
426 QDir dir( path, "lib*.so" ); 428 QDir dir( path, "lib*.so" );
427#endif 429#endif
428 QStringList list; 430 QStringList list;
429 if ( dir. exists ( )) 431 if ( dir. exists ( ))
430 list = dir.entryList(); 432 list = dir.entryList();
431 QStringList::Iterator it; 433 QStringList::Iterator it;
432 for ( it = list.begin(); it != list.end(); ++it ) { 434 for ( it = list.begin(); it != list.end(); ++it ) {
433 ImageCodecInterface *iface = 0; 435 ImageCodecInterface *iface = 0;
434 QLibrary *lib = new QLibrary( path + "/" + *it ); 436 QLibrary *lib = new QLibrary( path + "/" + *it );
435 if ( lib->queryInterface( IID_QtopiaImageCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) { 437 if ( lib->queryInterface( IID_QtopiaImageCodec, (QUnknownInterface**)&iface ) == QS_OK && iface ) {
436 QStringList formats = iface->keys(); 438 QStringList formats = iface->keys();
437 for (QStringList::ConstIterator i = formats.begin(); i != formats.end(); ++i) { 439 for (QStringList::ConstIterator i = formats.begin(); i != formats.end(); ++i) {
438 (void)iface->installIOHandler(*i); 440 (void)iface->installIOHandler(*i);
439 // ### it exists now; need to remember if we can delete it 441 // ### it exists now; need to remember if we can delete it
440 } 442 }
441 } 443 }
442 else { 444 else {
443 lib->unload(); 445 lib->unload();
444 delete lib; 446 delete lib;
445 } 447 }
446 } 448 }
447 } 449 }
448 450
449}; 451};
450 452
451class ResourceMimeFactory : public QMimeSourceFactory 453class ResourceMimeFactory : public QMimeSourceFactory
452{ 454{
453public: 455public:
454 ResourceMimeFactory() : resImage( 0 ) 456 ResourceMimeFactory() : resImage( 0 )
455 { 457 {
456 setFilePath( Global::helpPath() ); 458 setFilePath( Global::helpPath() );
457 setExtensionType( "html", "text/html;charset=UTF-8" ); 459 setExtensionType( "html", "text/html;charset=UTF-8" );
458 } 460 }
459 ~ResourceMimeFactory() { 461 ~ResourceMimeFactory() {
460 delete resImage; 462 delete resImage;
461 } 463 }
462 464
463 const QMimeSource* data( const QString& abs_name ) const 465 const QMimeSource* data( const QString& abs_name ) const
464 { 466 {
465 const QMimeSource * r = QMimeSourceFactory::data( abs_name ); 467 const QMimeSource * r = QMimeSourceFactory::data( abs_name );
466 if ( !r ) { 468 if ( !r ) {
467 int sl = abs_name.length(); 469 int sl = abs_name.length();
468 do { 470 do {
469 sl = abs_name.findRev( '/', sl - 1 ); 471 sl = abs_name.findRev( '/', sl - 1 );
470 QString name = sl >= 0 ? abs_name.mid( sl + 1 ) : abs_name; 472 QString name = sl >= 0 ? abs_name.mid( sl + 1 ) : abs_name;
471 int dot = name.findRev( '.' ); 473 int dot = name.findRev( '.' );
472 if ( dot >= 0 ) 474 if ( dot >= 0 )
473 name = name.left( dot ); 475 name = name.left( dot );
474 QImage img = Resource::loadImage( name ); 476 QImage img = Resource::loadImage( name );
475 if ( !img.isNull() ) { 477 if ( !img.isNull() ) {
476 delete resImage; 478 delete resImage;
477 resImage = new QImageDrag( img ); 479 resImage = new QImageDrag( img );
478 r = resImage; 480 r = resImage;
479 } 481 }
480 } 482 }
481 while ( !r && sl > 0 ); 483 while ( !r && sl > 0 );
482 } 484 }
483 return r; 485 return r;
484 } 486 }
485private: 487private:
486 mutable QImageDrag *resImage; 488 mutable QImageDrag *resImage;
487}; 489};
488 490
489static int& hack(int& i) 491static int& hack(int& i)
490{ 492{
491#if QT_VERSION <= 230 && defined(QT_NO_CODECS) 493#if QT_VERSION <= 230 && defined(QT_NO_CODECS)
492 // These should be created, but aren't in Qt 2.3.0 494 // These should be created, but aren't in Qt 2.3.0
493 (void)new QUtf8Codec; 495 (void)new QUtf8Codec;
494 (void)new QUtf16Codec; 496 (void)new QUtf16Codec;
495#endif 497#endif
496 return i; 498 return i;
497} 499}
498 500
499static int muted = 0; 501static int muted = 0;
500static int micMuted = 0; 502static int micMuted = 0;
501 503
502static void setVolume( int t = 0, int percent = -1 ) 504static void setVolume( int t = 0, int percent = -1 )
503{ 505{
504 switch ( t ) { 506 switch ( t ) {
505 case 0: { 507 case 0: {
506 Config cfg( "qpe" ); 508 Config cfg( "qpe" );
507 cfg.setGroup( "Volume" ); 509 cfg.setGroup( "Volume" );
508 if ( percent < 0 ) 510 if ( percent < 0 )
509 percent = cfg.readNumEntry( "VolumePercent", 50 ); 511 percent = cfg.readNumEntry( "VolumePercent", 50 );
510#ifndef QT_NO_SOUND 512#ifndef QT_NO_SOUND
511 int fd = 0; 513 int fd = 0;
512#ifdef QT_QWS_DEVFS 514#ifdef QT_QWS_DEVFS
513 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) { 515 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) {
514#else 516#else
515 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 517 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
516#endif 518#endif
517 int vol = muted ? 0 : percent; 519 int vol = muted ? 0 : percent;
518 // set both channels to same volume 520 // set both channels to same volume
519 vol |= vol << 8; 521 vol |= vol << 8;
520 ioctl( fd, MIXER_WRITE( SOUND_MIXER_VOLUME ), &vol ); 522 ioctl( fd, MIXER_WRITE( SOUND_MIXER_VOLUME ), &vol );
521 ::close( fd ); 523 ::close( fd );
522 } 524 }
523#endif 525#endif
524 } 526 }
525 break; 527 break;
526 } 528 }
527} 529}
528 530
529static void setMic( int t = 0, int percent = -1 ) 531static void setMic( int t = 0, int percent = -1 )
530{ 532{
531 switch ( t ) { 533 switch ( t ) {
532 case 0: { 534 case 0: {
533 Config cfg( "qpe" ); 535 Config cfg( "qpe" );
534 cfg.setGroup( "Volume" ); 536 cfg.setGroup( "Volume" );
535 if ( percent < 0 ) 537 if ( percent < 0 )
536 percent = cfg.readNumEntry( "Mic", 50 ); 538 percent = cfg.readNumEntry( "Mic", 50 );
537 539
538#ifndef QT_NO_SOUND 540#ifndef QT_NO_SOUND
539 int fd = 0; 541 int fd = 0;
540 int mic = micMuted ? 0 : percent; 542 int mic = micMuted ? 0 : percent;
541#ifdef QT_QWS_DEVFS 543#ifdef QT_QWS_DEVFS
542 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) { 544 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) {
543#else 545#else
544 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 546 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
545#endif 547#endif
546 ioctl( fd, MIXER_WRITE( SOUND_MIXER_MIC ), &mic ); 548 ioctl( fd, MIXER_WRITE( SOUND_MIXER_MIC ), &mic );
547 ::close( fd ); 549 ::close( fd );
548 } 550 }
549#endif 551#endif
550 } 552 }
551 break; 553 break;
552 } 554 }
553} 555}
554 556
555 557
556static void setBass( int t = 0, int percent = -1 ) 558static void setBass( int t = 0, int percent = -1 )
557{ 559{
558 switch ( t ) { 560 switch ( t ) {
559 case 0: { 561 case 0: {
560 Config cfg( "qpe" ); 562 Config cfg( "qpe" );
561 cfg.setGroup( "Volume" ); 563 cfg.setGroup( "Volume" );
562 if ( percent < 0 ) 564 if ( percent < 0 )
563 percent = cfg.readNumEntry( "BassPercent", 50 ); 565 percent = cfg.readNumEntry( "BassPercent", 50 );
564 566
565#ifndef QT_NO_SOUND 567#ifndef QT_NO_SOUND
566 int fd = 0; 568 int fd = 0;
567 int bass = percent; 569 int bass = percent;
568#ifdef QT_QWS_DEVFS 570#ifdef QT_QWS_DEVFS
569 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) { 571 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) {
570#else 572#else
571 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 573 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
572#endif 574#endif
573 ioctl( fd, MIXER_WRITE( SOUND_MIXER_BASS ), &bass ); 575 ioctl( fd, MIXER_WRITE( SOUND_MIXER_BASS ), &bass );
574 ::close( fd ); 576 ::close( fd );
575 } 577 }
576#endif 578#endif
577 } 579 }
578 break; 580 break;
579 } 581 }
580} 582}
581 583
582 584
583static void setTreble( int t = 0, int percent = -1 ) 585static void setTreble( int t = 0, int percent = -1 )
584{ 586{
585 switch ( t ) { 587 switch ( t ) {
586 case 0: { 588 case 0: {
587 Config cfg( "qpe" ); 589 Config cfg( "qpe" );
588 cfg.setGroup( "Volume" ); 590 cfg.setGroup( "Volume" );
589 if ( percent < 0 ) 591 if ( percent < 0 )
590 percent = cfg.readNumEntry( "TreblePercent", 50 ); 592 percent = cfg.readNumEntry( "TreblePercent", 50 );
591 593
592#ifndef QT_NO_SOUND 594#ifndef QT_NO_SOUND
593 int fd = 0; 595 int fd = 0;
594 int treble = percent; 596 int treble = percent;
595#ifdef QT_QWS_DEVFS 597#ifdef QT_QWS_DEVFS
596 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) { 598 if ( ( fd = open( "/dev/sound/mixer", O_RDWR ) ) >= 0 ) {
597#else 599#else
598 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) { 600 if ( ( fd = open( "/dev/mixer", O_RDWR ) ) >= 0 ) {
599#endif 601#endif
600 ioctl( fd, MIXER_WRITE( SOUND_MIXER_TREBLE ), &treble ); 602 ioctl( fd, MIXER_WRITE( SOUND_MIXER_TREBLE ), &treble );
601 ::close( fd ); 603 ::close( fd );
602 } 604 }
603#endif 605#endif
604 } 606 }
605 break; 607 break;
606 } 608 }
607} 609}
608 610
609 611
610/** 612/**
611 \class QPEApplication 613 \class QPEApplication
612 \brief The QPEApplication class implements various system services 614 \brief The QPEApplication class implements various system services
613 that are available to all Qtopia applications. 615 that are available to all Qtopia applications.
614 616
615 Simply by using QPEApplication instead of QApplication, a standard Qt 617 Simply by using QPEApplication instead of QApplication, a standard Qt
616 application becomes a Qtopia application. It automatically follows 618 application becomes a Qtopia application. It automatically follows
617 style changes, quits and raises, and in the 619 style changes, quits and raises, and in the
618 case of \link docwidget.html document-oriented\endlink applications, 620 case of \link docwidget.html document-oriented\endlink applications,
619 changes the currently displayed document in response to the environment. 621 changes the currently displayed document in response to the environment.
620 622
621 To create a \link docwidget.html document-oriented\endlink 623 To create a \link docwidget.html document-oriented\endlink
622 application use showMainDocumentWidget(); to create a 624 application use showMainDocumentWidget(); to create a
623 non-document-oriented application use showMainWidget(). The 625 non-document-oriented application use showMainWidget(). The
624 keepRunning() function indicates whether the application will 626 keepRunning() function indicates whether the application will
625 continue running after it's processed the last \link qcop.html 627 continue running after it's processed the last \link qcop.html
626 QCop\endlink message. This can be changed using setKeepRunning(). 628 QCop\endlink message. This can be changed using setKeepRunning().
627 629
628 A variety of signals are emitted when certain events occur, for 630 A variety of signals are emitted when certain events occur, for
629 example, timeChanged(), clockChanged(), weekChanged(), 631 example, timeChanged(), clockChanged(), weekChanged(),
630 dateFormatChanged() and volumeChanged(). If the application receives 632 dateFormatChanged() and volumeChanged(). If the application receives
631 a \link qcop.html QCop\endlink message on the application's 633 a \link qcop.html QCop\endlink message on the application's
632 QPE/Application/\e{appname} channel, the appMessage() signal is 634 QPE/Application/\e{appname} channel, the appMessage() signal is
633 emitted. There are also flush() and reload() signals, which 635 emitted. There are also flush() and reload() signals, which
634 are emitted when synching begins and ends respectively - upon these 636 are emitted when synching begins and ends respectively - upon these
635 signals, the application should save and reload any data 637 signals, the application should save and reload any data
636 files that are involved in synching. Most of these signals will initially 638 files that are involved in synching. Most of these signals will initially
637 be received and unfiltered through the appMessage() signal. 639 be received and unfiltered through the appMessage() signal.
638 640
639 This class also provides a set of useful static functions. The 641 This class also provides a set of useful static functions. The
640 qpeDir() and documentDir() functions return the respective paths. 642 qpeDir() and documentDir() functions return the respective paths.
641 The grabKeyboard() and ungrabKeyboard() functions are used to 643 The grabKeyboard() and ungrabKeyboard() functions are used to
642 control whether the application takes control of the device's 644 control whether the application takes control of the device's
643 physical buttons (e.g. application launch keys). The stylus' mode of 645 physical buttons (e.g. application launch keys). The stylus' mode of
644 operation is set with setStylusOperation() and retrieved with 646 operation is set with setStylusOperation() and retrieved with
645 stylusOperation(). There are also setInputMethodHint() and 647 stylusOperation(). There are also setInputMethodHint() and
646 inputMethodHint() functions. 648 inputMethodHint() functions.
647 649
648 \ingroup qtopiaemb 650 \ingroup qtopiaemb
649*/ 651*/
650 652
651/*! 653/*!
652 \fn void QPEApplication::clientMoused() 654 \fn void QPEApplication::clientMoused()
653 655
654 \internal 656 \internal
655*/ 657*/
656 658
657/*! 659/*!
658 \fn void QPEApplication::timeChanged(); 660 \fn void QPEApplication::timeChanged();
659 This signal is emitted when the time changes outside the normal 661 This signal is emitted when the time changes outside the normal
660 passage of time, i.e. if the time is set backwards or forwards. 662 passage of time, i.e. if the time is set backwards or forwards.
661*/ 663*/
662 664
663/*! 665/*!
664 \fn void QPEApplication::clockChanged( bool ampm ); 666 \fn void QPEApplication::clockChanged( bool ampm );
665 667
666 This signal is emitted when the user changes the clock's style. If 668 This signal is emitted when the user changes the clock's style. If
667 \a ampm is TRUE, the user wants a 12-hour AM/PM clock, otherwise, 669 \a ampm is TRUE, the user wants a 12-hour AM/PM clock, otherwise,
668 they want a 24-hour clock. 670 they want a 24-hour clock.
669*/ 671*/
670 672
671/*! 673/*!
672 \fn void QPEApplication::volumeChanged( bool muted ) 674 \fn void QPEApplication::volumeChanged( bool muted )
673 675
674 This signal is emitted whenever the mute state is changed. If \a 676 This signal is emitted whenever the mute state is changed. If \a
675 muted is TRUE, then sound output has been muted. 677 muted is TRUE, then sound output has been muted.
676*/ 678*/
677 679
678/*! 680/*!
679 \fn void QPEApplication::weekChanged( bool startOnMonday ) 681 \fn void QPEApplication::weekChanged( bool startOnMonday )
680 682
681 This signal is emitted if the week start day is changed. If \a 683 This signal is emitted if the week start day is changed. If \a
682 startOnMonday is TRUE then the first day of the week is Monday; if 684 startOnMonday is TRUE then the first day of the week is Monday; if
683 \a startOnMonday is FALSE then the first day of the week is 685 \a startOnMonday is FALSE then the first day of the week is
684 Sunday. 686 Sunday.
685*/ 687*/
686 688
687/*! 689/*!
688 \fn void QPEApplication::dateFormatChanged(DateFormat) 690 \fn void QPEApplication::dateFormatChanged(DateFormat)
689 691
690 This signal is emitted whenever the date format is changed. 692 This signal is emitted whenever the date format is changed.
691*/ 693*/
692 694
693/*! 695/*!
694 \fn void QPEApplication::flush() 696 \fn void QPEApplication::flush()
695 697
696 ### 698 ###
697*/ 699*/
698 700
699/*! 701/*!
700 \fn void QPEApplication::reload() 702 \fn void QPEApplication::reload()
701 703
702*/ 704*/
703 705
704 706
705 707
706void QPEApplication::processQCopFile() 708void QPEApplication::processQCopFile()
707{ 709{
708 QString qcopfn("/tmp/qcop-msg-"); 710 QString qcopfn("/tmp/qcop-msg-");
709 qcopfn += d->appName; // append command name 711 qcopfn += d->appName; // append command name
710 712
711 QFile f(qcopfn); 713 QFile f(qcopfn);
712 if ( f.open(IO_ReadWrite) ) { 714 if ( f.open(IO_ReadWrite) ) {
713#ifndef Q_OS_WIN32 715#ifndef Q_OS_WIN32
714 flock(f.handle(), LOCK_EX); 716 flock(f.handle(), LOCK_EX);
715#endif 717#endif
716 QDataStream ds(&f); 718 QDataStream ds(&f);
717 QCString channel, message; 719 QCString channel, message;
718 QByteArray data; 720 QByteArray data;
719 while(!ds.atEnd()) { 721 while(!ds.atEnd()) {
720 ds >> channel >> message >> data; 722 ds >> channel >> message >> data;
721 d->enqueueQCop(channel,message,data); 723 d->enqueueQCop(channel,message,data);
722 } 724 }
723 ::ftruncate(f.handle(), 0); 725 ::ftruncate(f.handle(), 0);
724#ifndef Q_OS_WIN32 726#ifndef Q_OS_WIN32
725 f.flush(); 727 f.flush();
726 flock(f.handle(), LOCK_UN); 728 flock(f.handle(), LOCK_UN);
727#endif 729#endif
728 } 730 }
729#endif 731#endif
730} 732}
731 733
732 734
733/*! 735/*!
734 \fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data ) 736 \fn void QPEApplication::appMessage( const QCString& msg, const QByteArray& data )
735 737
736 This signal is emitted when a message is received on this 738 This signal is emitted when a message is received on this
737 application's QPE/Application/<i>appname</i> \link qcop.html 739 application's QPE/Application/<i>appname</i> \link qcop.html
738 QCop\endlink channel. 740 QCop\endlink channel.
739 741
740 The slot to which you connect this signal uses \a msg and \a data 742 The slot to which you connect this signal uses \a msg and \a data
741 in the following way: 743 in the following way:
742 744
743\code 745\code
744 void MyWidget::receive( const QCString& msg, const QByteArray& data ) 746 void MyWidget::receive( const QCString& msg, const QByteArray& data )
745 { 747 {
746 QDataStream stream( data, IO_ReadOnly ); 748 QDataStream stream( data, IO_ReadOnly );
747 if ( msg == "someMessage(int,int,int)" ) { 749 if ( msg == "someMessage(int,int,int)" ) {
748 int a,b,c; 750 int a,b,c;
749 stream >> a >> b >> c; 751 stream >> a >> b >> c;
750 ... 752 ...
751 } else if ( msg == "otherMessage(QString)" ) { 753 } else if ( msg == "otherMessage(QString)" ) {
752 ... 754 ...
753 } 755 }
754 } 756 }
755\endcode 757\endcode
756 758
757 \sa qcop.html 759 \sa qcop.html
758 Note that messages received here may be processed by qpe application 760 Note that messages received here may be processed by qpe application
759 and emitted as signals, such as flush() and reload(). 761 and emitted as signals, such as flush() and reload().
760*/ 762*/
761 763
762#ifndef QT_NO_TRANSLATION 764#ifndef QT_NO_TRANSLATION
763static void qtopia_loadTranslations( const QStringList& qms ) 765static void qtopia_loadTranslations( const QStringList& qms )
764{ 766{
765 QStringList langs = Global::languageList(); 767 QStringList langs = Global::languageList();
766 768
767 for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) { 769 for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) {
768 QString lang = *it; 770 QString lang = *it;
769 771
770 QTranslator * trans; 772 QTranslator * trans;
771 QString tfn; 773 QString tfn;
772 774
773 for (QStringList::ConstIterator qmit = qms.begin(); qmit!=qms.end(); ++qmit) { 775 for (QStringList::ConstIterator qmit = qms.begin(); qmit!=qms.end(); ++qmit) {
774 trans = new QTranslator(qApp); 776 trans = new QTranslator(qApp);
775 tfn = QPEApplication::qpeDir() + "i18n/" + lang + "/" + *qmit + ".qm"; 777 tfn = QPEApplication::qpeDir() + "i18n/" + lang + "/" + *qmit + ".qm";
776 if ( trans->load( tfn )) 778 if ( trans->load( tfn ))
777 qApp->installTranslator( trans ); 779 qApp->installTranslator( trans );
778 else 780 else
779 delete trans; 781 delete trans;
780 } 782 }
781 } 783 }
782} 784}
783#endif 785#endif
784 786
785/* 787/*
786 Turn off qDebug in release mode 788 Turn off qDebug in release mode
787 */ 789 */
788static void qtopiaMsgHandler(QtMsgType type, const char* msg) 790static void qtopiaMsgHandler(QtMsgType type, const char* msg)
789{ 791{
790 switch ( type ) { 792 switch ( type ) {
791 case QtDebugMsg: 793 case QtDebugMsg:
792#ifdef QT_DEBUG 794#ifdef QT_DEBUG
793 fprintf( stderr, "Debug: %s\n", msg ); 795 fprintf( stderr, "Debug: %s\n", msg );
794#endif 796#endif
795 break; 797 break;
796 case QtWarningMsg: 798 case QtWarningMsg:
797#ifdef QT_DEBUG 799#ifdef QT_DEBUG
798 fprintf( stderr, "Warning: %s\n", msg ); 800 fprintf( stderr, "Warning: %s\n", msg );
799#endif 801#endif
800 break; 802 break;
801 case QtFatalMsg: 803 case QtFatalMsg:
802 fprintf( stderr, "Fatal: %s\n", msg ); 804 fprintf( stderr, "Fatal: %s\n", msg );
803 abort(); 805 abort();
804 } 806 }
805} 807}
806 808
807/*! 809/*!
808 Constructs a QPEApplication just as you would construct 810 Constructs a QPEApplication just as you would construct
809 a QApplication, passing \a argc, \a argv, and \a t. 811 a QApplication, passing \a argc, \a argv, and \a t.
810 812
811 For applications, \a t should be the default, GuiClient. Only 813 For applications, \a t should be the default, GuiClient. Only
812 the Qtopia server passes GuiServer. 814 the Qtopia server passes GuiServer.
813*/ 815*/
814QPEApplication::QPEApplication( int & argc, char **argv, Type t ) 816QPEApplication::QPEApplication( int & argc, char **argv, Type t )
815 : QApplication( hack(argc), argv, t ), pidChannel( 0 ) 817 : QApplication( hack(argc), argv, t ), pidChannel( 0 )
816{ 818{
817 QPixmapCache::setCacheLimit(256); // sensible default for smaller devices. 819 QPixmapCache::setCacheLimit(256); // sensible default for smaller devices.
818 qInstallMsgHandler(qtopiaMsgHandler); 820 qInstallMsgHandler(qtopiaMsgHandler);
819 821
820 d = new QPEApplicationData; 822 d = new QPEApplicationData;
821 d->loadTextCodecs(); 823 d->loadTextCodecs();
822 d->loadImageCodecs(); 824 d->loadImageCodecs();
823 825
824 setFont( QFont( d->fontFamily, d->fontSize ) ); 826 setFont( QFont( d->fontFamily, d->fontSize ) );
825 AppLnk::setSmallIconSize( d->smallIconSize ); 827 AppLnk::setSmallIconSize( d->smallIconSize );
826 AppLnk::setBigIconSize( d->bigIconSize ); 828 AppLnk::setBigIconSize( d->bigIconSize );
827 829
828 QMimeSourceFactory::setDefaultFactory( new ResourceMimeFactory ); 830 QMimeSourceFactory::setDefaultFactory( new ResourceMimeFactory );
829 831
830 connect( this, SIGNAL( lastWindowClosed() ), this, SLOT( hideOrQuit() ) ); 832 connect( this, SIGNAL( lastWindowClosed() ), this, SLOT( hideOrQuit() ) );
831 833
832 834
833 sysChannel = new QCopChannel( "QPE/System", this ); 835 sysChannel = new QCopChannel( "QPE/System", this );
834 connect( sysChannel, SIGNAL( received(const QCString&,const QByteArray&) ), 836 connect( sysChannel, SIGNAL( received(const QCString&,const QByteArray&) ),
835 this, SLOT( systemMessage(const QCString&,const QByteArray&) ) ); 837 this, SLOT( systemMessage(const QCString&,const QByteArray&) ) );
836 838
837/* COde now in initapp */ 839/* COde now in initapp */
838#if 0 840#if 0
839#if defined(Q_WS_QWS) && !defined(QT_NO_COP) 841#if defined(Q_WS_QWS) && !defined(QT_NO_COP)
840 842
841 QString qcopfn( "/tmp/qcop-msg-" ); 843 QString qcopfn( "/tmp/qcop-msg-" );
842 qcopfn += QString( argv[ 0 ] ); // append command name 844 qcopfn += QString( argv[ 0 ] ); // append command name
843 845
844 QFile f( qcopfn ); 846 QFile f( qcopfn );
845 if ( f.open( IO_ReadOnly ) ) { 847 if ( f.open( IO_ReadOnly ) ) {
846 flock( f.handle(), LOCK_EX ); 848 flock( f.handle(), LOCK_EX );
847 } 849 }
848 850
849 851
850 852
851 QCString channel = QCString( argv[ 0 ] ); 853 QCString channel = QCString( argv[ 0 ] );
852 channel.replace( QRegExp( ".*/" ), "" ); 854 channel.replace( QRegExp( ".*/" ), "" );
853 d->appName = channel; 855 d->appName = channel;
854 channel = "QPE/Application/" + channel; 856 channel = "QPE/Application/" + channel;
855 pidChannel = new QCopChannel( channel, this ); 857 pidChannel = new QCopChannel( channel, this );
856 connect( pidChannel, SIGNAL( received(const QCString&,const QByteArray&) ), 858 connect( pidChannel, SIGNAL( received(const QCString&,const QByteArray&) ),
857 this, SLOT( pidMessage(const QCString&,const QByteArray&) ) ); 859 this, SLOT( pidMessage(const QCString&,const QByteArray&) ) );
858 860
859 if ( f.isOpen() ) { 861 if ( f.isOpen() ) {
860 d->keep_running = FALSE; 862 d->keep_running = FALSE;
861 QDataStream ds( &f ); 863 QDataStream ds( &f );
862 QCString channel, message; 864 QCString channel, message;
863 QByteArray data; 865 QByteArray data;
864 while ( !ds.atEnd() ) { 866 while ( !ds.atEnd() ) {
865 ds >> channel >> message >> data; 867 ds >> channel >> message >> data;
866 d->enqueueQCop( channel, message, data ); 868 d->enqueueQCop( channel, message, data );
867 } 869 }
868 870
869 flock( f.handle(), LOCK_UN ); 871 flock( f.handle(), LOCK_UN );
870 f.close(); 872 f.close();
871 f.remove(); 873 f.remove();
872 } 874 }
873 875
874 for ( int a = 0; a < argc; a++ ) { 876 for ( int a = 0; a < argc; a++ ) {
875 if ( qstrcmp( argv[ a ], "-preload" ) == 0 ) { 877 if ( qstrcmp( argv[ a ], "-preload" ) == 0 ) {
876 argv[ a ] = argv[ a + 1 ]; 878 argv[ a ] = argv[ a + 1 ];
877 a++; 879 a++;
878 d->preloaded = TRUE; 880 d->preloaded = TRUE;
879 argc -= 1; 881 argc -= 1;
880 } 882 }
881 else if ( qstrcmp( argv[ a ], "-preload-show" ) == 0 ) { 883 else if ( qstrcmp( argv[ a ], "-preload-show" ) == 0 ) {
882 argv[ a ] = argv[ a + 1 ]; 884 argv[ a ] = argv[ a + 1 ];
883 a++; 885 a++;
884 d->preloaded = TRUE; 886 d->preloaded = TRUE;
885 d->forceshow = TRUE; 887 d->forceshow = TRUE;
886 argc -= 1; 888 argc -= 1;
887 } 889 }
888 } 890 }
889 891
890 /* overide stored arguments */ 892 /* overide stored arguments */
891 setArgs( argc, argv ); 893 setArgs( argc, argv );
892 894
893#endif 895#endif
894#else 896#else
895 initApp( argc, argv ); 897 initApp( argc, argv );
896#endif 898#endif
897#ifdef Q_WS_QWS 899#ifdef Q_WS_QWS
898 /* load the font renderer factories */ 900 /* load the font renderer factories */
899 FontDatabase::loadRenderers(); 901 FontDatabase::loadRenderers();
900#endif 902#endif
901#ifndef QT_NO_TRANSLATION 903#ifndef QT_NO_TRANSLATION
902 QStringList qms; 904 QStringList qms;
903 qms << "libqpe"; 905 qms << "libqpe";
904 qms << "libopie"; 906 qms << "libopie";
905 qms << d->appName; 907 qms << d->appName;
906 908
907 qtopia_loadTranslations(qms); 909 qtopia_loadTranslations(qms);
908#endif 910#endif
909 911
910 applyStyle(); 912 applyStyle();
911 913
912 if ( type() == GuiServer ) { 914 if ( type() == GuiServer ) {
913 setVolume(); 915 setVolume();
914 } 916 }
915 917
916 installEventFilter( this ); 918 installEventFilter( this );
917 919
918 QPEMenuToolFocusManager::initialize(); 920 QPEMenuToolFocusManager::initialize();
919 921
920#ifdef QT_NO_QWS_CURSOR 922#ifdef QT_NO_QWS_CURSOR
921 // if we have no cursor, probably don't want tooltips 923 // if we have no cursor, probably don't want tooltips
922 QToolTip::setEnabled( FALSE ); 924 QToolTip::setEnabled( FALSE );
923#endif 925#endif
924} 926}
925 927
926 928
927#ifdef QTOPIA_INTERNAL_INITAPP 929#ifdef QTOPIA_INTERNAL_INITAPP
928void QPEApplication::initApp( int argc, char **argv ) 930void QPEApplication::initApp( int argc, char **argv )
929{ 931{
930 delete pidChannel; 932 delete pidChannel;
931 d->keep_running = TRUE; 933 d->keep_running = TRUE;
932 d->preloaded = FALSE; 934 d->preloaded = FALSE;
933 d->forceshow = FALSE; 935 d->forceshow = FALSE;
934 936
935 QCString channel = QCString(argv[0]); 937 QCString channel = QCString(argv[0]);
936 938
937 channel.replace(QRegExp(".*/"),""); 939 channel.replace(QRegExp(".*/"),"");
938 d->appName = channel; 940 d->appName = channel;
939 941
940#ifndef QT_NO_TRANSLATION 942#ifndef QT_NO_TRANSLATION
941 qtopia_loadTranslations( QStringList()<<channel ); 943 qtopia_loadTranslations( QStringList()<<channel );
942#endif 944#endif
943 945
944 #if QT_VERSION > 235 946 #if QT_VERSION > 235
945 qt_fbdpy->setIdentity( channel ); // In Qt/E 2.3.6 947 qt_fbdpy->setIdentity( channel ); // In Qt/E 2.3.6
946 #endif 948 #endif
947 949
948 channel = "QPE/Application/" + channel; 950 channel = "QPE/Application/" + channel;
949 pidChannel = new QCopChannel( channel, this); 951 pidChannel = new QCopChannel( channel, this);
950 connect( pidChannel, SIGNAL(received(const QCString&,const QByteArray&)), 952 connect( pidChannel, SIGNAL(received(const QCString&,const QByteArray&)),
951 this, SLOT(pidMessage(const QCString&,const QByteArray&))); 953 this, SLOT(pidMessage(const QCString&,const QByteArray&)));
952 954
953 955
954 956
955 processQCopFile(); 957 processQCopFile();
956 d->keep_running = d->qcopq.isEmpty(); 958 d->keep_running = d->qcopq.isEmpty();
957 959
958 for (int a=0; a<argc; a++) { 960 for (int a=0; a<argc; a++) {
959 if ( qstrcmp(argv[a],"-preload")==0 ) { 961 if ( qstrcmp(argv[a],"-preload")==0 ) {
960 argv[a] = argv[a+1]; 962 argv[a] = argv[a+1];
961 a++; 963 a++;
962 d->preloaded = TRUE; 964 d->preloaded = TRUE;
963 argc-=1; 965 argc-=1;
964 } else if ( qstrcmp(argv[a],"-preload-show")==0 ) { 966 } else if ( qstrcmp(argv[a],"-preload-show")==0 ) {
965 argv[a] = argv[a+1]; 967 argv[a] = argv[a+1];
966 a++; 968 a++;
967 d->preloaded = TRUE; 969 d->preloaded = TRUE;
968 d->forceshow = TRUE; 970 d->forceshow = TRUE;
969 argc-=1; 971 argc-=1;
970 } 972 }
971 } 973 }
972 974
973 /* overide stored arguments */ 975 /* overide stored arguments */
974 setArgs(argc, argv); 976 setArgs(argc, argv);
975} 977}
976#endif 978#endif
977 979
978 980
979static QPtrDict<void>* inputMethodDict = 0; 981static QPtrDict<void>* inputMethodDict = 0;
980static void createInputMethodDict() 982static void createInputMethodDict()
981{ 983{
982 if ( !inputMethodDict ) 984 if ( !inputMethodDict )
983 inputMethodDict = new QPtrDict<void>; 985 inputMethodDict = new QPtrDict<void>;
984} 986}
985 987
986/*! 988/*!
987 Returns the currently set hint to the system as to whether 989 Returns the currently set hint to the system as to whether
988 widget \a w has any use for text input methods. 990 widget \a w has any use for text input methods.
989 991
990 992
991 \sa setInputMethodHint() InputMethodHint 993 \sa setInputMethodHint() InputMethodHint
992*/ 994*/
993QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget * w ) 995QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget * w )
994{ 996{
995 if ( inputMethodDict && w ) 997 if ( inputMethodDict && w )
996 return ( InputMethodHint ) ( int ) inputMethodDict->find( w ); 998 return ( InputMethodHint ) ( int ) inputMethodDict->find( w );
997 return Normal; 999 return Normal;
998} 1000}
999 1001
1000/*! 1002/*!
1001 \enum QPEApplication::InputMethodHint 1003 \enum QPEApplication::InputMethodHint
1002 1004
1003 \value Normal the application sometimes needs text input (the default). 1005 \value Normal the application sometimes needs text input (the default).
1004 \value AlwaysOff the application never needs text input. 1006 \value AlwaysOff the application never needs text input.
1005 \value AlwaysOn the application always needs text input. 1007 \value AlwaysOn the application always needs text input.
1006*/ 1008*/
1007 1009
1008/*! 1010/*!
1009 Hints to the system that widget \a w has use for text input methods 1011 Hints to the system that widget \a w has use for text input methods
1010 as specified by \a mode. 1012 as specified by \a mode.
1011 1013
1012 \sa inputMethodHint() InputMethodHint 1014 \sa inputMethodHint() InputMethodHint
1013*/ 1015*/
1014void QPEApplication::setInputMethodHint( QWidget * w, InputMethodHint mode ) 1016void QPEApplication::setInputMethodHint( QWidget * w, InputMethodHint mode )
1015{ 1017{
1016 createInputMethodDict(); 1018 createInputMethodDict();
1017 if ( mode == Normal ) { 1019 if ( mode == Normal ) {
1018 inputMethodDict->remove 1020 inputMethodDict->remove
1019 ( w ); 1021 ( w );
1020 } 1022 }
1021 else { 1023 else {
1022 inputMethodDict->insert( w, ( void* ) mode ); 1024 inputMethodDict->insert( w, ( void* ) mode );
1023 } 1025 }
1024} 1026}
1025 1027
1026class HackDialog : public QDialog 1028class HackDialog : public QDialog
1027{ 1029{
1028public: 1030public:
1029 void acceptIt() 1031 void acceptIt()
1030 { 1032 {
1031 accept(); 1033 accept();
1032 } 1034 }
1033 void rejectIt() 1035 void rejectIt()
1034 { 1036 {
1035 reject(); 1037 reject();
1036 } 1038 }
1037}; 1039};
1038 1040
1039 1041
1040void QPEApplication::mapToDefaultAction( QWSKeyEvent * ke, int key ) 1042void QPEApplication::mapToDefaultAction( QWSKeyEvent * ke, int key )
1041{ 1043{
1042 // specialised actions for certain widgets. May want to 1044 // specialised actions for certain widgets. May want to
1043 // add more stuff here. 1045 // add more stuff here.
1044 if ( activePopupWidget() && activePopupWidget() ->inherits( "QListBox" ) 1046 if ( activePopupWidget() && activePopupWidget() ->inherits( "QListBox" )
1045 && activePopupWidget() ->parentWidget() 1047 && activePopupWidget() ->parentWidget()
1046 && activePopupWidget() ->parentWidget() ->inherits( "QComboBox" ) ) 1048 && activePopupWidget() ->parentWidget() ->inherits( "QComboBox" ) )
1047 key = Qt::Key_Return; 1049 key = Qt::Key_Return;
1048 1050
1049 if ( activePopupWidget() && activePopupWidget() ->inherits( "QPopupMenu" ) ) 1051 if ( activePopupWidget() && activePopupWidget() ->inherits( "QPopupMenu" ) )
1050 key = Qt::Key_Return; 1052 key = Qt::Key_Return;
1051 1053
1052#ifdef QWS 1054#ifdef QWS
1053 1055
1054 ke->simpleData.keycode = key; 1056 ke->simpleData.keycode = key;
1055#endif 1057#endif
1056} 1058}
1057 1059
1058 1060
1059/*! 1061/*!
1060 \internal 1062 \internal
1061*/ 1063*/
1062 1064
1063#ifdef QWS 1065#ifdef QWS
1064bool QPEApplication::qwsEventFilter( QWSEvent * e ) 1066bool QPEApplication::qwsEventFilter( QWSEvent * e )
1065{ 1067{
1066 if ( !d->notbusysent && e->type == QWSEvent::Focus ) { 1068 if ( !d->notbusysent && e->type == QWSEvent::Focus ) {
1067 if ( qApp->type() != QApplication::GuiServer ) { 1069 if ( qApp->type() != QApplication::GuiServer ) {
1068 QCopEnvelope e( "QPE/System", "notBusy(QString)" ); 1070 QCopEnvelope e( "QPE/System", "notBusy(QString)" );
1069 e << d->appName; 1071 e << d->appName;
1070 } 1072 }
1071 d->notbusysent = TRUE; 1073 d->notbusysent = TRUE;
1072 } 1074 }
1073 if ( type() == GuiServer ) { 1075 if ( type() == GuiServer ) {
1074 switch ( e->type ) { 1076 switch ( e->type ) {
1075 case QWSEvent::Mouse: 1077 case QWSEvent::Mouse:
1076 if ( e->asMouse() ->simpleData.state && !QWidget::find( e->window() ) ) 1078 if ( e->asMouse() ->simpleData.state && !QWidget::find( e->window() ) )
1077 emit clientMoused(); 1079 emit clientMoused();
1078 break; 1080 break;
1079 default: 1081 default:
1080 break; 1082 break;
1081 } 1083 }
1082 } 1084 }
1083 if ( e->type == QWSEvent::Key ) { 1085 if ( e->type == QWSEvent::Key ) {
1084 QWSKeyEvent *ke = ( QWSKeyEvent * ) e; 1086 QWSKeyEvent *ke = ( QWSKeyEvent * ) e;
1085 if ( ke->simpleData.keycode == Qt::Key_F33 ) { 1087 if ( ke->simpleData.keycode == Qt::Key_F33 ) {
1086 // Use special "OK" key to press "OK" on top level widgets 1088 // Use special "OK" key to press "OK" on top level widgets
1087 QWidget * active = activeWindow(); 1089 QWidget * active = activeWindow();
1088 QWidget *popup = 0; 1090 QWidget *popup = 0;
1089 if ( active && active->isPopup() ) { 1091 if ( active && active->isPopup() ) {
1090 popup = active; 1092 popup = active;
1091 active = active->parentWidget(); 1093 active = active->parentWidget();
1092 } 1094 }
1093 if ( active && ( int ) active->winId() == ke->simpleData.window && 1095 if ( active && ( int ) active->winId() == ke->simpleData.window &&
1094 !active->testWFlags( WStyle_Customize | WType_Popup | WType_Desktop ) ) { 1096 !active->testWFlags( WStyle_Customize | WType_Popup | WType_Desktop ) ) {
1095 if ( ke->simpleData.is_press ) { 1097 if ( ke->simpleData.is_press ) {
1096 if ( popup ) 1098 if ( popup )
1097 popup->close(); 1099 popup->close();
1098 if ( active->inherits( "QDialog" ) ) { 1100 if ( active->inherits( "QDialog" ) ) {
1099 HackDialog * d = ( HackDialog * ) active; 1101 HackDialog * d = ( HackDialog * ) active;
1100 d->acceptIt(); 1102 d->acceptIt();
1101 return TRUE; 1103 return TRUE;
1102 } 1104 }
1103 else if ( ( ( HackWidget * ) active ) ->needsOk() ) { 1105 else if ( ( ( HackWidget * ) active ) ->needsOk() ) {
1104 QSignal s; 1106 QSignal s;
1105 s.connect( active, SLOT( accept() ) ); 1107 s.connect( active, SLOT( accept() ) );
1106 s.activate(); 1108 s.activate();
1107 } 1109 }
1108 else { 1110 else {
1109 // do the same as with the select key: Map to the default action of the widget: 1111 // do the same as with the select key: Map to the default action of the widget:
1110 mapToDefaultAction( ke, Qt::Key_Return ); 1112 mapToDefaultAction( ke, Qt::Key_Return );
1111 } 1113 }
1112 } 1114 }
diff --git a/library/widget_showing.cpp b/library/widget_showing.cpp
index 43ece64..43d19b0 100644
--- a/library/widget_showing.cpp
+++ b/library/widget_showing.cpp
@@ -1,74 +1,78 @@
1/* 1/*
2 This file is part of the OPIE Project 2 This file is part of the OPIE Project
3 Copyright (c) 2004 Andreas Richter <ar@handhelds.org> 3 Copyright (c) 2004 Andreas Richter <ar@handhelds.org>
4 Copyright (c) 2004 Holger Hans Peter Freyther <freyther@handhelds.org> 4 Copyright (c) 2004 Holger Hans Peter Freyther <freyther@handhelds.org>
5               =. 5               =.
6             .=l. 6             .=l.
7           .>+-= 7           .>+-=
8 _;:,     .>    :=|. This library is free software; you can 8 _;:,     .>    :=|. This library is free software; you can
9.> <`_,   >  .   <= redistribute it and/or modify it under 9.> <`_,   >  .   <= redistribute it and/or modify it under
10:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 10:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
11.="- .-=="i,     .._ License as published by the Free Software 11.="- .-=="i,     .._ License as published by the Free Software
12 - .   .-<_>     .<> Foundation; either version 2 of the License, 12 - .   .-<_>     .<> Foundation; either version 2 of the License,
13     ._= =}       : or (at your option) any later version. 13     ._= =}       : or (at your option) any later version.
14    .%`+i>       _;_. 14    .%`+i>       _;_.
15    .i_,=:_.      -<s. This library is distributed in the hope that 15    .i_,=:_.      -<s. This library is distributed in the hope that
16     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 16     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
17    : ..    .:,     . . . without even the implied warranty of 17    : ..    .:,     . . . without even the implied warranty of
18    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 18    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
19  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 19  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
20..}^=.=       =       ; Library General Public License for more 20..}^=.=       =       ; Library General Public License for more
21++=   -.     .`     .: details. 21++=   -.     .`     .: details.
22 :     =  ...= . :.=- 22 :     =  ...= . :.=-
23 -.   .:....=;==+<; You should have received a copy of the GNU 23 -.   .:....=;==+<; You should have received a copy of the GNU
24  -_. . .   )=.  = Library General Public License along with 24  -_. . .   )=.  = Library General Public License along with
25    --        :-=` this library; see the file COPYING.LIB. 25    --        :-=` this library; see the file COPYING.LIB.
26 If not, write to the Free Software Foundation, 26 If not, write to the Free Software Foundation,
27 Inc., 59 Temple Place - Suite 330, 27 Inc., 59 Temple Place - Suite 330,
28 Boston, MA 02111-1307, USA. 28 Boston, MA 02111-1307, USA.
29 29
30*/ 30*/
31 31
32#include <qtopia/qpeapplication.h> 32#include <qtopia/qpeapplication.h>
33 33
34#ifdef Q_WS_QWS 34#ifdef Q_WS_QWS
35extern Q_EXPORT QRect qt_maxWindowRect; 35extern Q_EXPORT QRect qt_maxWindowRect;
36#endif 36#endif
37 37
38void QPEApplication::showDialog( QDialog* d, bool nomax ) 38void QPEApplication::showDialog( QDialog* d, bool nomax )
39{ 39{
40 showWidget( d, nomax ); 40 showWidget( d, nomax );
41} 41}
42 42
43int QPEApplication::execDialog( QDialog* d, bool nomax ) 43int QPEApplication::execDialog( QDialog* d, bool nomax )
44{ 44{
45 showDialog( d, nomax ); 45 showDialog( d, nomax );
46 return d->exec(); 46 return d->exec();
47} 47}
48 48
49void QPEApplication::showWidget( QWidget* wg, bool nomax ) { 49void QPEApplication::showWidget( QWidget* wg, bool nomax ) {
50 if ( wg->isVisible() ) { 50 if ( wg->isVisible() ) {
51 wg->show(); 51 wg->show();
52 return; 52 return;
53 } 53 }
54 54
55#ifndef OPIE_NO_WINDOWED
56 if ( TRUE ) {
57#else
55 if ( !nomax 58 if ( !nomax
56 && ( qApp->desktop()->width() <= 320 ) ){ 59 && ( qApp->desktop()->width() <= 320 ) ){
60#endif
57 wg->showMaximized(); 61 wg->showMaximized();
58 } else { 62 } else {
59#ifdef Q_WS_QWS 63#ifdef Q_WS_QWS
60 QSize desk = QSize( qApp->desktop()->width(), qApp->desktop()->height() ); 64 QSize desk = QSize( qApp->desktop()->width(), qApp->desktop()->height() );
61#else 65#else
62 QSize desk = QSize( qt_maxWindowRect.width(), qt_maxWindowRect.height() ); 66 QSize desk = QSize( qt_maxWindowRect.width(), qt_maxWindowRect.height() );
63#endif 67#endif
64 68
65 QSize sh = wg->sizeHint(); 69 QSize sh = wg->sizeHint();
66 int w = QMAX( sh.width(), wg->width() ); 70 int w = QMAX( sh.width(), wg->width() );
67 int h = QMAX( sh.height(), wg->height() ); 71 int h = QMAX( sh.height(), wg->height() );
68// desktop widget-frame taskbar 72// desktop widget-frame taskbar
69 w = QMIN( w, ( desk.width() - ( wg->frameGeometry().width() - wg->geometry().width() ) - 25 ) ); 73 w = QMIN( w, ( desk.width() - ( wg->frameGeometry().width() - wg->geometry().width() ) - 25 ) );
70 h = QMIN( h, ( desk.height() - ( wg->frameGeometry().height() - wg->geometry().height() ) - 25 ) ); 74 h = QMIN( h, ( desk.height() - ( wg->frameGeometry().height() - wg->geometry().height() ) - 25 ) );
71 wg->resize( w, h ); 75 wg->resize( w, h );
72 wg->show(); 76 wg->show();
73 } 77 }
74} 78}