-rw-r--r-- | library/global.cpp | 55 | ||||
-rw-r--r-- | library/qpeapplication.cpp | 40 | ||||
-rwxr-xr-x | mkipks | 2 | ||||
-rw-r--r-- | noncore/games/minesweep/Makefile.in | 18 |
4 files changed, 71 insertions, 44 deletions
diff --git a/library/global.cpp b/library/global.cpp index fd7579a..dd15eb7 100644 --- a/library/global.cpp +++ b/library/global.cpp | |||
@@ -1,274 +1,281 @@ | |||
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 | #define QTOPIA_INTERNAL_LANGLIST | ||
20 | #include <qpe/qpedebug.h> | 21 | #include <qpe/qpedebug.h> |
21 | #include <qpe/global.h> | 22 | #include <qpe/global.h> |
22 | #include <qpe/qdawg.h> | 23 | #include <qpe/qdawg.h> |
23 | #include <qpe/qpeapplication.h> | 24 | #include <qpe/qpeapplication.h> |
24 | #include <qpe/resource.h> | 25 | #include <qpe/resource.h> |
25 | #include <qpe/storage.h> | 26 | #include <qpe/storage.h> |
26 | #include <qpe/applnk.h> | 27 | #include <qpe/applnk.h> |
27 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 28 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
28 | #include "qpe/qcopenvelope_qws.h" | 29 | #include "qpe/qcopenvelope_qws.h" |
29 | #endif | 30 | #endif |
30 | 31 | ||
31 | #include <qfile.h> | 32 | #include <qfile.h> |
32 | #include <qlabel.h> | 33 | #include <qlabel.h> |
33 | #include <qtimer.h> | 34 | #include <qtimer.h> |
34 | #include <qmap.h> | 35 | #include <qmap.h> |
35 | #include <qdict.h> | 36 | #include <qdict.h> |
36 | #include <qdir.h> | 37 | #include <qdir.h> |
37 | #include <qmessagebox.h> | 38 | #include <qmessagebox.h> |
38 | #include <qregexp.h> | 39 | #include <qregexp.h> |
39 | 40 | ||
40 | #include <stdlib.h> | 41 | #include <stdlib.h> |
41 | #include <sys/stat.h> | 42 | #include <sys/stat.h> |
42 | #include <sys/wait.h> | 43 | #include <sys/wait.h> |
43 | #include <sys/types.h> | 44 | #include <sys/types.h> |
44 | #include <fcntl.h> | 45 | #include <fcntl.h> |
45 | #include <unistd.h> | 46 | #include <unistd.h> |
46 | 47 | ||
47 | #include <qwindowsystem_qws.h> // for qwsServer | 48 | #include <qwindowsystem_qws.h> // for qwsServer |
48 | #include <qdatetime.h> | 49 | #include <qdatetime.h> |
49 | 50 | ||
50 | //#include "quickexec_p.h" | 51 | //#include "quickexec_p.h" |
51 | 52 | ||
52 | class Emitter : public QObject { | 53 | class Emitter : public QObject { |
53 | Q_OBJECT | 54 | Q_OBJECT |
54 | public: | 55 | public: |
55 | Emitter( QWidget* receiver, const QString& document ) | 56 | Emitter( QWidget* receiver, const QString& document ) |
56 | { | 57 | { |
57 | connect(this, SIGNAL(setDocument(const QString&)), | 58 | connect(this, SIGNAL(setDocument(const QString&)), |
58 | receiver, SLOT(setDocument(const QString&))); | 59 | receiver, SLOT(setDocument(const QString&))); |
59 | emit setDocument(document); | 60 | emit setDocument(document); |
60 | disconnect(this, SIGNAL(setDocument(const QString&)), | 61 | disconnect(this, SIGNAL(setDocument(const QString&)), |
61 | receiver, SLOT(setDocument(const QString&))); | 62 | receiver, SLOT(setDocument(const QString&))); |
62 | } | 63 | } |
63 | 64 | ||
64 | signals: | 65 | signals: |
65 | void setDocument(const QString&); | 66 | void setDocument(const QString&); |
66 | }; | 67 | }; |
67 | 68 | ||
68 | 69 | ||
69 | class StartingAppList : public QObject { | 70 | class StartingAppList : public QObject { |
70 | Q_OBJECT | 71 | Q_OBJECT |
71 | public: | 72 | public: |
72 | static void add( const QString& name ); | 73 | static void add( const QString& name ); |
73 | static bool isStarting( const QString name ); | 74 | static bool isStarting( const QString name ); |
74 | private slots: | 75 | private slots: |
75 | void handleNewChannel( const QString &); | 76 | void handleNewChannel( const QString &); |
76 | private: | 77 | private: |
77 | StartingAppList( QObject *parent=0, const char* name=0 ) ; | 78 | StartingAppList( QObject *parent=0, const char* name=0 ) ; |
78 | 79 | ||
79 | QDict<QTime> dict; | 80 | QDict<QTime> dict; |
80 | static StartingAppList *appl; | 81 | static StartingAppList *appl; |
81 | }; | 82 | }; |
82 | 83 | ||
83 | StartingAppList* StartingAppList::appl = 0; | 84 | StartingAppList* StartingAppList::appl = 0; |
84 | 85 | ||
85 | StartingAppList::StartingAppList( QObject *parent, const char* name ) | 86 | StartingAppList::StartingAppList( QObject *parent, const char* name ) |
86 | :QObject( parent, name ) | 87 | :QObject( parent, name ) |
87 | { | 88 | { |
88 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 89 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
89 | connect( qwsServer, SIGNAL( newChannel(const QString&)), | 90 | connect( qwsServer, SIGNAL( newChannel(const QString&)), |
90 | this, SLOT( handleNewChannel(const QString&)) ); | 91 | this, SLOT( handleNewChannel(const QString&)) ); |
91 | dict.setAutoDelete( TRUE ); | 92 | dict.setAutoDelete( TRUE ); |
92 | #endif | 93 | #endif |
93 | } | 94 | } |
94 | 95 | ||
95 | void StartingAppList::add( const QString& name ) | 96 | void StartingAppList::add( const QString& name ) |
96 | { | 97 | { |
97 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 98 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
98 | if ( !appl ) | 99 | if ( !appl ) |
99 | appl = new StartingAppList; | 100 | appl = new StartingAppList; |
100 | QTime *t = new QTime; | 101 | QTime *t = new QTime; |
101 | t->start(); | 102 | t->start(); |
102 | appl->dict.insert( "QPE/Application/" + name, t ); | 103 | appl->dict.insert( "QPE/Application/" + name, t ); |
103 | #endif | 104 | #endif |
104 | } | 105 | } |
105 | 106 | ||
106 | bool StartingAppList::isStarting( const QString name ) | 107 | bool StartingAppList::isStarting( const QString name ) |
107 | { | 108 | { |
108 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 109 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
109 | if ( appl ) { | 110 | if ( appl ) { |
110 | QTime *t = appl->dict.find( "QPE/Application/" + name ); | 111 | QTime *t = appl->dict.find( "QPE/Application/" + name ); |
111 | if ( !t ) | 112 | if ( !t ) |
112 | return FALSE; | 113 | return FALSE; |
113 | if ( t->elapsed() > 10000 ) { | 114 | if ( t->elapsed() > 10000 ) { |
114 | // timeout in case of crash or something | 115 | // timeout in case of crash or something |
115 | appl->dict.remove( "QPE/Application/" + name ); | 116 | appl->dict.remove( "QPE/Application/" + name ); |
116 | return FALSE; | 117 | return FALSE; |
117 | } | 118 | } |
118 | return TRUE; | 119 | return TRUE; |
119 | } | 120 | } |
120 | #endif | 121 | #endif |
121 | return FALSE; | 122 | return FALSE; |
122 | } | 123 | } |
123 | 124 | ||
124 | void StartingAppList::handleNewChannel( const QString & name ) | 125 | void StartingAppList::handleNewChannel( const QString & name ) |
125 | { | 126 | { |
126 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) | 127 | #if QT_VERSION >= 232 && !defined(QT_NO_COP) |
127 | dict.remove( name ); | 128 | dict.remove( name ); |
128 | #endif | 129 | #endif |
129 | } | 130 | } |
130 | 131 | ||
131 | static bool docDirCreated = FALSE; | 132 | static bool docDirCreated = FALSE; |
132 | static QDawg* fixed_dawg = 0; | 133 | static QDawg* fixed_dawg = 0; |
133 | static QDict<QDawg> *named_dawg = 0; | 134 | static QDict<QDawg> *named_dawg = 0; |
134 | 135 | ||
135 | static QString qpeDir() | 136 | static QString qpeDir() |
136 | { | 137 | { |
137 | QString dir = getenv("OPIEDIR"); | 138 | QString dir = getenv("OPIEDIR"); |
138 | if ( dir.isEmpty() ) dir = ".."; | 139 | if ( dir.isEmpty() ) dir = ".."; |
139 | return dir; | 140 | return dir; |
140 | } | 141 | } |
141 | 142 | ||
142 | static QString dictDir() | 143 | static QString dictDir() |
143 | { | 144 | { |
144 | return qpeDir() + "/etc/dict"; | 145 | return qpeDir() + "/etc/dict"; |
145 | } | 146 | } |
146 | 147 | ||
147 | /*! | 148 | /*! |
148 | \class Global global.h | 149 | \class Global global.h |
149 | \brief The Global class collects application-wide global functions. | 150 | \brief The Global class collects application-wide global functions. |
150 | */ | 151 | */ |
151 | 152 | ||
152 | /*! | 153 | /*! |
153 | \internal | 154 | \internal |
154 | */ | 155 | */ |
155 | Global::Global() | 156 | Global::Global() |
156 | { | 157 | { |
157 | } | 158 | } |
158 | 159 | ||
159 | /*! | 160 | /*! |
160 | Returns the unchangeable QDawg that contains general | 161 | Returns the unchangeable QDawg that contains general |
161 | words for the current locale. | 162 | words for the current locale. |
162 | 163 | ||
163 | \sa addedDawg() | 164 | \sa addedDawg() |
164 | */ | 165 | */ |
165 | const QDawg& Global::fixedDawg() | 166 | const QDawg& Global::fixedDawg() |
166 | { | 167 | { |
167 | if ( !fixed_dawg ) { | 168 | if ( !fixed_dawg ) { |
168 | if ( !docDirCreated ) | 169 | if ( !docDirCreated ) |
169 | createDocDir(); | 170 | createDocDir(); |
170 | 171 | ||
171 | fixed_dawg = new QDawg; | 172 | fixed_dawg = new QDawg; |
172 | QString dawgfilename = dictDir() + "/dawg"; | 173 | QString dawgfilename = dictDir() + "/dawg"; |
173 | QString lang = getenv( "LANG" ); | 174 | QString words_lang; |
174 | QString dawgfilename_lang = dawgfilename + "." + lang; | 175 | QStringList langs = Global::languageList(); |
175 | QString words_lang = dictDir() + "/words." + lang; | 176 | for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) { |
176 | if ( QFile::exists(dawgfilename_lang) || | 177 | QString lang = *it; |
177 | QFile::exists(words_lang) ) | 178 | words_lang = dictDir() + "/words." + lang; |
178 | dawgfilename = dawgfilename_lang; | 179 | QString dawgfilename_lang = dawgfilename + "." + lang; |
180 | if ( QFile::exists(dawgfilename_lang) || | ||
181 | QFile::exists(words_lang) ) { | ||
182 | dawgfilename = dawgfilename_lang; | ||
183 | break; | ||
184 | } | ||
185 | } | ||
179 | QFile dawgfile(dawgfilename); | 186 | QFile dawgfile(dawgfilename); |
180 | 187 | ||
181 | if ( !dawgfile.exists() ) { | 188 | if ( !dawgfile.exists() ) { |
182 | QString fn = dictDir() + "/words"; | 189 | QString fn = dictDir() + "/words"; |
183 | if ( QFile::exists(words_lang) ) | 190 | if ( QFile::exists(words_lang) ) |
184 | fn = words_lang; | 191 | fn = words_lang; |
185 | QFile in(fn); | 192 | QFile in(fn); |
186 | if ( in.open(IO_ReadOnly) ) { | 193 | if ( in.open(IO_ReadOnly) ) { |
187 | fixed_dawg->createFromWords(&in); | 194 | fixed_dawg->createFromWords(&in); |
188 | dawgfile.open(IO_WriteOnly); | 195 | dawgfile.open(IO_WriteOnly); |
189 | fixed_dawg->write(&dawgfile); | 196 | fixed_dawg->write(&dawgfile); |
190 | dawgfile.close(); | 197 | dawgfile.close(); |
191 | } | 198 | } |
192 | } else { | 199 | } else { |
193 | fixed_dawg->readFile(dawgfilename); | 200 | fixed_dawg->readFile(dawgfilename); |
194 | } | 201 | } |
195 | } | 202 | } |
196 | 203 | ||
197 | return *fixed_dawg; | 204 | return *fixed_dawg; |
198 | } | 205 | } |
199 | 206 | ||
200 | /*! | 207 | /*! |
201 | Returns the changeable QDawg that contains general | 208 | Returns the changeable QDawg that contains general |
202 | words for the current locale. | 209 | words for the current locale. |
203 | 210 | ||
204 | \sa fixedDawg() | 211 | \sa fixedDawg() |
205 | */ | 212 | */ |
206 | const QDawg& Global::addedDawg() | 213 | const QDawg& Global::addedDawg() |
207 | { | 214 | { |
208 | return dawg("local"); | 215 | return dawg("local"); |
209 | } | 216 | } |
210 | 217 | ||
211 | /*! | 218 | /*! |
212 | Returns the QDawg with the given \a name. | 219 | Returns the QDawg with the given \a name. |
213 | This is an application-specific word list. | 220 | This is an application-specific word list. |
214 | 221 | ||
215 | \a name should not contain "/". | 222 | \a name should not contain "/". |
216 | */ | 223 | */ |
217 | const QDawg& Global::dawg(const QString& name) | 224 | const QDawg& Global::dawg(const QString& name) |
218 | { | 225 | { |
219 | createDocDir(); | 226 | createDocDir(); |
220 | if ( !named_dawg ) | 227 | if ( !named_dawg ) |
221 | named_dawg = new QDict<QDawg>; | 228 | named_dawg = new QDict<QDawg>; |
222 | QDawg* r = named_dawg->find(name); | 229 | QDawg* r = named_dawg->find(name); |
223 | if ( !r ) { | 230 | if ( !r ) { |
224 | r = new QDawg; | 231 | r = new QDawg; |
225 | named_dawg->insert(name,r); | 232 | named_dawg->insert(name,r); |
226 | QString dawgfilename = dictDir() + "/" + name + ".dawg"; | 233 | QString dawgfilename = dictDir() + "/" + name + ".dawg"; |
227 | QFile dawgfile(dawgfilename); | 234 | QFile dawgfile(dawgfilename); |
228 | if ( dawgfile.open(IO_ReadOnly) ) | 235 | if ( dawgfile.open(IO_ReadOnly) ) |
229 | r->readFile(dawgfilename); | 236 | r->readFile(dawgfilename); |
230 | } | 237 | } |
231 | return *r; | 238 | return *r; |
232 | } | 239 | } |
233 | 240 | ||
234 | /*! | 241 | /*! |
235 | Adds \a wordlist to the addedDawg(). | 242 | Adds \a wordlist to the addedDawg(). |
236 | */ | 243 | */ |
237 | void Global::addWords(const QStringList& wordlist) | 244 | void Global::addWords(const QStringList& wordlist) |
238 | { | 245 | { |
239 | addWords("local",wordlist); | 246 | addWords("local",wordlist); |
240 | } | 247 | } |
241 | 248 | ||
242 | /*! | 249 | /*! |
243 | Adds \a wordlist to the dawg() named \a dictname. | 250 | Adds \a wordlist to the dawg() named \a dictname. |
244 | */ | 251 | */ |
245 | void Global::addWords(const QString& dictname, const QStringList& wordlist) | 252 | void Global::addWords(const QString& dictname, const QStringList& wordlist) |
246 | { | 253 | { |
247 | QDawg& d = (QDawg&)dawg(dictname); | 254 | QDawg& d = (QDawg&)dawg(dictname); |
248 | QStringList all = d.allWords() + wordlist; | 255 | QStringList all = d.allWords() + wordlist; |
249 | d.createFromWords(all); | 256 | d.createFromWords(all); |
250 | 257 | ||
251 | QString dawgfilename = dictDir() + "/" + dictname + ".dawg"; | 258 | QString dawgfilename = dictDir() + "/" + dictname + ".dawg"; |
252 | QFile dawgfile(dawgfilename); | 259 | QFile dawgfile(dawgfilename); |
253 | if ( dawgfile.open(IO_WriteOnly) ) { | 260 | if ( dawgfile.open(IO_WriteOnly) ) { |
254 | d.write(&dawgfile); | 261 | d.write(&dawgfile); |
255 | dawgfile.close(); | 262 | dawgfile.close(); |
256 | } | 263 | } |
257 | 264 | ||
258 | // #### Re-read the dawg here if we use mmap(). | 265 | // #### Re-read the dawg here if we use mmap(). |
259 | 266 | ||
260 | // #### Signal other processes to re-read. | 267 | // #### Signal other processes to re-read. |
261 | } | 268 | } |
262 | 269 | ||
263 | 270 | ||
264 | /*! | 271 | /*! |
265 | Returns a full path for the application named \a appname, with the | 272 | Returns a full path for the application named \a appname, with the |
266 | given \a filename or QString::null if there was a problem creating | 273 | given \a filename or QString::null if there was a problem creating |
267 | the directory tree for \a appname. | 274 | the directory tree for \a appname. |
268 | If \a filename contains "/", it is the caller's responsibility to | 275 | If \a filename contains "/", it is the caller's responsibility to |
269 | ensure those directories exist. | 276 | ensure those directories exist. |
270 | */ | 277 | */ |
271 | QString Global::applicationFileName(const QString& appname, const QString& filename) | 278 | QString Global::applicationFileName(const QString& appname, const QString& filename) |
272 | { | 279 | { |
273 | QDir d; | 280 | QDir d; |
274 | QString r = getenv("HOME"); | 281 | QString r = getenv("HOME"); |
@@ -546,99 +553,135 @@ void Global::execute( const QString &c, const QString& document ) | |||
546 | running[i]->show(); | 553 | running[i]->show(); |
547 | running[i]->setActiveWindow(); | 554 | running[i]->setActiveWindow(); |
548 | } else { | 555 | } else { |
549 | running[i] = builtin[i].func( builtin[i].maximized ); | 556 | running[i] = builtin[i].func( builtin[i].maximized ); |
550 | } | 557 | } |
551 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); | 558 | QCopEnvelope e("QPE/System", "notBusy(QString)" ); |
552 | e << c; // that was quick ;-) | 559 | e << c; // that was quick ;-) |
553 | return; | 560 | return; |
554 | } | 561 | } |
555 | } | 562 | } |
556 | } | 563 | } |
557 | 564 | ||
558 | //Global::invoke(c, document); | 565 | //Global::invoke(c, document); |
559 | 566 | ||
560 | // Convert the command line in to a list of arguments | 567 | // Convert the command line in to a list of arguments |
561 | QStringList list = QStringList::split(QRegExp(" *"),c); | 568 | QStringList list = QStringList::split(QRegExp(" *"),c); |
562 | 569 | ||
563 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 570 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
564 | QString ap=list[0]; | 571 | QString ap=list[0]; |
565 | 572 | ||
566 | qDebug("executing %s", ap.latin1() ); | 573 | qDebug("executing %s", ap.latin1() ); |
567 | if ( ap == "suspend" ) { | 574 | if ( ap == "suspend" ) { |
568 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); | 575 | QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); |
569 | return; | 576 | return; |
570 | } | 577 | } |
571 | 578 | ||
572 | /* if need be, sending a qcop message will result in an invoke, see | 579 | /* if need be, sending a qcop message will result in an invoke, see |
573 | preceeding function */ | 580 | preceeding function */ |
574 | { QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } | 581 | { QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "raise()" ); } |
575 | if ( !document.isEmpty() ) { | 582 | if ( !document.isEmpty() ) { |
576 | QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "setDocument(QString)" ); | 583 | QCopEnvelope env( ("QPE/Application/" + ap).latin1(), "setDocument(QString)" ); |
577 | env << document; | 584 | env << document; |
578 | } | 585 | } |
579 | #endif | 586 | #endif |
580 | } | 587 | } |
581 | 588 | ||
582 | /*! | 589 | /*! |
583 | Returns the string \a s with the characters backslash, ", and $ | 590 | Returns the string \a s with the characters backslash, ", and $ |
584 | quoted by a preceeding backslash. | 591 | quoted by a preceeding backslash. |
585 | */ | 592 | */ |
586 | QString Global::shellQuote(const QString& s) | 593 | QString Global::shellQuote(const QString& s) |
587 | { | 594 | { |
588 | QString r="\""; | 595 | QString r="\""; |
589 | for (int i=0; i<(int)s.length(); i++) { | 596 | for (int i=0; i<(int)s.length(); i++) { |
590 | char c = s[i].latin1(); | 597 | char c = s[i].latin1(); |
591 | switch (c) { | 598 | switch (c) { |
592 | case '\\': case '"': case '$': | 599 | case '\\': case '"': case '$': |
593 | r+="\\"; | 600 | r+="\\"; |
594 | } | 601 | } |
595 | r += s[i]; | 602 | r += s[i]; |
596 | } | 603 | } |
597 | r += "\""; | 604 | r += "\""; |
598 | return r; | 605 | return r; |
599 | } | 606 | } |
600 | 607 | ||
601 | /*! | 608 | /*! |
602 | Returns the string \a s with the characters backslash and " | 609 | Returns the string \a s with the characters backslash and " |
603 | quoted by a preceeding backslash. | 610 | quoted by a preceeding backslash. |
604 | */ | 611 | */ |
605 | QString Global::stringQuote(const QString& s) | 612 | QString Global::stringQuote(const QString& s) |
606 | { | 613 | { |
607 | QString r="\""; | 614 | QString r="\""; |
608 | for (int i=0; i<(int)s.length(); i++) { | 615 | for (int i=0; i<(int)s.length(); i++) { |
609 | char c = s[i].latin1(); | 616 | char c = s[i].latin1(); |
610 | switch (c) { | 617 | switch (c) { |
611 | case '\\': case '"': | 618 | case '\\': case '"': |
612 | r+="\\"; | 619 | r+="\\"; |
613 | } | 620 | } |
614 | r += s[i]; | 621 | r += s[i]; |
615 | } | 622 | } |
616 | r += "\""; | 623 | r += "\""; |
617 | return r; | 624 | return r; |
618 | } | 625 | } |
619 | 626 | ||
620 | /*! | 627 | /*! |
621 | Finds all documents on the system's document directories which | 628 | Finds all documents on the system's document directories which |
622 | match the filter \a mimefilter, and appends the resulting DocLnk | 629 | match the filter \a mimefilter, and appends the resulting DocLnk |
623 | objects to \a folder. | 630 | objects to \a folder. |
624 | */ | 631 | */ |
625 | void Global::findDocuments(DocLnkSet* folder, const QString &mimefilter) | 632 | void Global::findDocuments(DocLnkSet* folder, const QString &mimefilter) |
626 | { | 633 | { |
627 | QString homedocs = QString(getenv("HOME")) + "/Documents"; | 634 | QString homedocs = QString(getenv("HOME")) + "/Documents"; |
628 | DocLnkSet d(homedocs,mimefilter); | 635 | DocLnkSet d(homedocs,mimefilter); |
629 | folder->appendFrom(d); | 636 | folder->appendFrom(d); |
630 | StorageInfo storage; | 637 | StorageInfo storage; |
631 | const QList<FileSystem> &fs = storage.fileSystems(); | 638 | const QList<FileSystem> &fs = storage.fileSystems(); |
632 | QListIterator<FileSystem> it ( fs ); | 639 | QListIterator<FileSystem> it ( fs ); |
633 | for ( ; it.current(); ++it ) { | 640 | for ( ; it.current(); ++it ) { |
634 | if ( (*it)->isRemovable() ) { | 641 | if ( (*it)->isRemovable() ) { |
635 | QString path = (*it)->path(); | 642 | QString path = (*it)->path(); |
636 | DocLnkSet ide( path, mimefilter ); | 643 | DocLnkSet ide( path, mimefilter ); |
637 | folder->appendFrom(ide); | 644 | folder->appendFrom(ide); |
638 | } | 645 | } |
639 | } | 646 | } |
640 | } | 647 | } |
641 | 648 | ||
649 | QStringList Global::languageList() | ||
650 | { | ||
651 | QString lang = getenv("LANG"); | ||
652 | QStringList langs; | ||
653 | langs.append(lang); | ||
654 | int i = lang.find("."); | ||
655 | if ( i > 0 ) | ||
656 | lang = lang.left( i ); | ||
657 | i = lang.find( "_" ); | ||
658 | if ( i > 0 ) | ||
659 | langs.append(lang.left(i)); | ||
660 | return langs; | ||
661 | } | ||
662 | |||
663 | QStringList Global::helpPath() | ||
664 | { | ||
665 | QStringList path; | ||
666 | QStringList langs = Global::languageList(); | ||
667 | for (QStringList::ConstIterator it = langs.fromLast(); it!=langs.end(); --it) { | ||
668 | QString lang = *it; | ||
669 | if ( !lang.isEmpty() ) | ||
670 | path += QPEApplication::qpeDir() + "/help/" + lang + "/html"; | ||
671 | } | ||
672 | path += QPEApplication::qpeDir() + "/pics"; | ||
673 | path += QPEApplication::qpeDir() + "/help/en/html"; | ||
674 | path += QPEApplication::qpeDir() + "/docs"; | ||
675 | QString dir = QDir::current().canonicalPath(); | ||
676 | if ( dir == "/" ) | ||
677 | dir += "/docs"; | ||
678 | else { | ||
679 | path += dir + "/../pics"; | ||
680 | dir += "/../docs"; | ||
681 | path += dir; | ||
682 | } | ||
683 | return path; | ||
684 | } | ||
642 | 685 | ||
643 | 686 | ||
644 | #include "global.moc" | 687 | #include "global.moc" |
diff --git a/library/qpeapplication.cpp b/library/qpeapplication.cpp index 70ffec1..4dbfbd8 100644 --- a/library/qpeapplication.cpp +++ b/library/qpeapplication.cpp | |||
@@ -1,251 +1,237 @@ | |||
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 | ** $Id$ | 19 | ** $Id$ |
20 | ** | 20 | ** |
21 | **********************************************************************/ | 21 | **********************************************************************/ |
22 | #define QTOPIA_INTERNAL_LANGLIST | ||
22 | #include <stdlib.h> | 23 | #include <stdlib.h> |
23 | #include <unistd.h> | 24 | #include <unistd.h> |
24 | #include <qfile.h> | 25 | #include <qfile.h> |
25 | #ifdef Q_WS_QWS | 26 | #ifdef Q_WS_QWS |
26 | #ifndef QT_NO_COP | 27 | #ifndef QT_NO_COP |
27 | #if QT_VERSION <= 231 | 28 | #if QT_VERSION <= 231 |
28 | #define private public | 29 | #define private public |
29 | #define sendLocally processEvent | 30 | #define sendLocally processEvent |
30 | #include "qcopenvelope_qws.h" | 31 | #include "qcopenvelope_qws.h" |
31 | #undef private | 32 | #undef private |
32 | #else | 33 | #else |
33 | #include "qcopenvelope_qws.h" | 34 | #include "qcopenvelope_qws.h" |
34 | #endif | 35 | #endif |
35 | #endif | 36 | #endif |
36 | #include <qwindowsystem_qws.h> | 37 | #include <qwindowsystem_qws.h> |
37 | #endif | 38 | #endif |
38 | #include <qtextstream.h> | 39 | #include <qtextstream.h> |
39 | #include <qpalette.h> | 40 | #include <qpalette.h> |
40 | #include <qbuffer.h> | 41 | #include <qbuffer.h> |
41 | #include <qptrdict.h> | 42 | #include <qptrdict.h> |
42 | #include <qregexp.h> | 43 | #include <qregexp.h> |
43 | #include <qdir.h> | 44 | #include <qdir.h> |
44 | #include <qlabel.h> | 45 | #include <qlabel.h> |
45 | #include <qdialog.h> | 46 | #include <qdialog.h> |
46 | #include <qdragobject.h> | 47 | #include <qdragobject.h> |
47 | #include <qevent.h> | 48 | #include <qevent.h> |
48 | #include <qtooltip.h> | 49 | #include <qtooltip.h> |
49 | #include <qsignal.h> | 50 | #include <qsignal.h> |
50 | #include "qpeapplication.h" | 51 | #include "qpeapplication.h" |
51 | #include "qpestyle.h" | 52 | #include "qpestyle.h" |
52 | #if QT_VERSION >= 300 | 53 | #if QT_VERSION >= 300 |
53 | #include <qstylefactory.h> | 54 | #include <qstylefactory.h> |
54 | #else | 55 | #else |
55 | #include <qplatinumstyle.h> | 56 | #include <qplatinumstyle.h> |
56 | #include <qwindowsstyle.h> | 57 | #include <qwindowsstyle.h> |
57 | #include <qmotifstyle.h> | 58 | #include <qmotifstyle.h> |
58 | #include <qmotifplusstyle.h> | 59 | #include <qmotifplusstyle.h> |
59 | #include "lightstyle.h" | 60 | #include "lightstyle.h" |
60 | #endif | 61 | #endif |
61 | #include "global.h" | 62 | #include "global.h" |
62 | #include "resource.h" | 63 | #include "resource.h" |
63 | #if QT_VERSION <= 230 && defined(QT_NO_CODECS) | 64 | #if QT_VERSION <= 230 && defined(QT_NO_CODECS) |
64 | #include "qutfcodec.h" | 65 | #include "qutfcodec.h" |
65 | #endif | 66 | #endif |
66 | #include "config.h" | 67 | #include "config.h" |
67 | #include "network.h" | 68 | #include "network.h" |
68 | #include "fontmanager.h" | 69 | #include "fontmanager.h" |
69 | #include "power.h" | 70 | #include "power.h" |
70 | #include "alarmserver.h" | 71 | #include "alarmserver.h" |
71 | #include "applnk.h" | 72 | #include "applnk.h" |
72 | #include "qpemenubar.h" | 73 | #include "qpemenubar.h" |
73 | 74 | ||
74 | #include <unistd.h> | 75 | #include <unistd.h> |
75 | #include <sys/file.h> | 76 | #include <sys/file.h> |
76 | #include <sys/ioctl.h> | 77 | #include <sys/ioctl.h> |
77 | #include <sys/soundcard.h> | 78 | #include <sys/soundcard.h> |
78 | 79 | ||
79 | // for setBacklight() | 80 | // for setBacklight() |
80 | #if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) | 81 | #if defined(QT_QWS_IPAQ) || defined(QT_QWS_EBX) |
81 | #include <linux/fb.h> | 82 | #include <linux/fb.h> |
82 | #include <sys/types.h> | 83 | #include <sys/types.h> |
83 | #include <sys/stat.h> | 84 | #include <sys/stat.h> |
84 | #endif | 85 | #endif |
85 | #include <stdlib.h> | 86 | #include <stdlib.h> |
86 | 87 | ||
87 | 88 | ||
88 | class QPEApplicationData { | 89 | class QPEApplicationData { |
89 | public: | 90 | public: |
90 | QPEApplicationData() : presstimer(0), presswidget(0), rightpressed(FALSE), | 91 | QPEApplicationData() : presstimer(0), presswidget(0), rightpressed(FALSE), |
91 | kbgrabber(0), kbregrab(FALSE), notbusysent(FALSE), preloaded(FALSE), | 92 | kbgrabber(0), kbregrab(FALSE), notbusysent(FALSE), preloaded(FALSE), |
92 | forceshow(FALSE), nomaximize(FALSE), qpe_main_widget(0), | 93 | forceshow(FALSE), nomaximize(FALSE), qpe_main_widget(0), |
93 | keep_running(TRUE) | 94 | keep_running(TRUE) |
94 | { | 95 | { |
95 | qcopq.setAutoDelete(TRUE); | 96 | qcopq.setAutoDelete(TRUE); |
96 | } | 97 | } |
97 | 98 | ||
98 | int presstimer; | 99 | int presstimer; |
99 | QWidget* presswidget; | 100 | QWidget* presswidget; |
100 | QPoint presspos; | 101 | QPoint presspos; |
101 | bool rightpressed; | 102 | bool rightpressed; |
102 | int kbgrabber; | 103 | int kbgrabber; |
103 | bool kbregrab; | 104 | bool kbregrab; |
104 | bool notbusysent; | 105 | bool notbusysent; |
105 | QString appName; | 106 | QString appName; |
106 | struct QCopRec { | 107 | struct QCopRec { |
107 | QCopRec(const QCString &ch, const QCString &msg, | 108 | QCopRec(const QCString &ch, const QCString &msg, |
108 | const QByteArray &d) : | 109 | const QByteArray &d) : |
109 | channel(ch), message(msg), data(d) { } | 110 | channel(ch), message(msg), data(d) { } |
110 | 111 | ||
111 | QCString channel; | 112 | QCString channel; |
112 | QCString message; | 113 | QCString message; |
113 | QByteArray data; | 114 | QByteArray data; |
114 | }; | 115 | }; |
115 | bool preloaded; | 116 | bool preloaded; |
116 | bool forceshow; | 117 | bool forceshow; |
117 | bool nomaximize; | 118 | bool nomaximize; |
118 | QWidget* qpe_main_widget; | 119 | QWidget* qpe_main_widget; |
119 | bool keep_running; | 120 | bool keep_running; |
120 | QList<QCopRec> qcopq; | 121 | QList<QCopRec> qcopq; |
121 | 122 | ||
122 | void enqueueQCop(const QCString &ch, const QCString &msg, | 123 | void enqueueQCop(const QCString &ch, const QCString &msg, |
123 | const QByteArray &data) | 124 | const QByteArray &data) |
124 | { | 125 | { |
125 | qcopq.append(new QCopRec(ch,msg,data)); | 126 | qcopq.append(new QCopRec(ch,msg,data)); |
126 | } | 127 | } |
127 | void sendQCopQ() | 128 | void sendQCopQ() |
128 | { | 129 | { |
129 | QCopRec* r; | 130 | QCopRec* r; |
130 | for (QListIterator<QCopRec> it(qcopq); (r=it.current()); ++it) | 131 | for (QListIterator<QCopRec> it(qcopq); (r=it.current()); ++it) |
131 | QCopChannel::sendLocally(r->channel,r->message,r->data); | 132 | QCopChannel::sendLocally(r->channel,r->message,r->data); |
132 | qcopq.clear(); | 133 | qcopq.clear(); |
133 | } | 134 | } |
134 | }; | 135 | }; |
135 | 136 | ||
136 | class ResourceMimeFactory : public QMimeSourceFactory { | 137 | class ResourceMimeFactory : public QMimeSourceFactory { |
137 | public: | 138 | public: |
138 | ResourceMimeFactory() | 139 | ResourceMimeFactory() |
139 | { | 140 | { |
140 | QStringList path; | 141 | setFilePath( Global::helpPath() ); |
141 | QString lang = getenv("LANG"); | ||
142 | if ( !lang.isEmpty() ) | ||
143 | path += QPEApplication::qpeDir() + "/help/" + lang + "/html"; | ||
144 | path += QPEApplication::qpeDir() + "/pics"; | ||
145 | path += QPEApplication::qpeDir() + "/help/en/html"; | ||
146 | path += QPEApplication::qpeDir() + "/docs"; | ||
147 | QString dir = QDir::current().canonicalPath(); | ||
148 | if ( dir == "/" ) | ||
149 | dir += "/docs"; | ||
150 | else { | ||
151 | path += dir + "/../pics"; | ||
152 | dir += "/../docs"; | ||
153 | path += dir; | ||
154 | } | ||
155 | setFilePath( path ); | ||
156 | setExtensionType("html","text/html;charset=UTF-8"); | 142 | setExtensionType("html","text/html;charset=UTF-8"); |
157 | } | 143 | } |
158 | 144 | ||
159 | const QMimeSource* data(const QString& abs_name) const | 145 | const QMimeSource* data(const QString& abs_name) const |
160 | { | 146 | { |
161 | const QMimeSource* r = QMimeSourceFactory::data(abs_name); | 147 | const QMimeSource* r = QMimeSourceFactory::data(abs_name); |
162 | if ( !r ) { | 148 | if ( !r ) { |
163 | int sl = abs_name.length(); | 149 | int sl = abs_name.length(); |
164 | do { | 150 | do { |
165 | sl = abs_name.findRev('/',sl-1); | 151 | sl = abs_name.findRev('/',sl-1); |
166 | QString name = sl>=0 ? abs_name.mid(sl+1) : abs_name; | 152 | QString name = sl>=0 ? abs_name.mid(sl+1) : abs_name; |
167 | int dot = name.findRev('.'); | 153 | int dot = name.findRev('.'); |
168 | if ( dot >= 0 ) | 154 | if ( dot >= 0 ) |
169 | name = name.left(dot); | 155 | name = name.left(dot); |
170 | QImage img = Resource::loadImage(name); | 156 | QImage img = Resource::loadImage(name); |
171 | if ( !img.isNull() ) | 157 | if ( !img.isNull() ) |
172 | r = new QImageDrag(img); | 158 | r = new QImageDrag(img); |
173 | } while (!r && sl>0); | 159 | } while (!r && sl>0); |
174 | } | 160 | } |
175 | return r; | 161 | return r; |
176 | } | 162 | } |
177 | }; | 163 | }; |
178 | 164 | ||
179 | static int muted=0; | 165 | static int muted=0; |
180 | 166 | ||
181 | static void setVolume(int t=0, int percent=-1) | 167 | static void setVolume(int t=0, int percent=-1) |
182 | { | 168 | { |
183 | switch (t) { | 169 | switch (t) { |
184 | case 0: { | 170 | case 0: { |
185 | Config cfg("Sound"); | 171 | Config cfg("Sound"); |
186 | cfg.setGroup("System"); | 172 | cfg.setGroup("System"); |
187 | if ( percent < 0 ) | 173 | if ( percent < 0 ) |
188 | percent = cfg.readNumEntry("Volume",50); | 174 | percent = cfg.readNumEntry("Volume",50); |
189 | int fd = 0; | 175 | int fd = 0; |
190 | if ((fd = open("/dev/mixer", O_RDWR))>=0) { | 176 | if ((fd = open("/dev/mixer", O_RDWR))>=0) { |
191 | int vol = muted ? 0 : percent; | 177 | int vol = muted ? 0 : percent; |
192 | // set both channels to same volume | 178 | // set both channels to same volume |
193 | vol |= vol << 8; | 179 | vol |= vol << 8; |
194 | ioctl(fd, MIXER_WRITE(0), &vol); | 180 | ioctl(fd, MIXER_WRITE(0), &vol); |
195 | ::close(fd); | 181 | ::close(fd); |
196 | } | 182 | } |
197 | } break; | 183 | } break; |
198 | } | 184 | } |
199 | } | 185 | } |
200 | 186 | ||
201 | int qpe_sysBrightnessSteps() | 187 | int qpe_sysBrightnessSteps() |
202 | { | 188 | { |
203 | #if defined(QT_QWS_IPAQ) | 189 | #if defined(QT_QWS_IPAQ) |
204 | return 255; | 190 | return 255; |
205 | #elif defined(QT_QWS_EBX) | 191 | #elif defined(QT_QWS_EBX) |
206 | return 4; | 192 | return 4; |
207 | #else | 193 | #else |
208 | return 255; // ? | 194 | return 255; // ? |
209 | #endif | 195 | #endif |
210 | } | 196 | } |
211 | 197 | ||
212 | 198 | ||
213 | static int& hack(int& i) | 199 | static int& hack(int& i) |
214 | { | 200 | { |
215 | #if QT_VERSION <= 230 && defined(QT_NO_CODECS) | 201 | #if QT_VERSION <= 230 && defined(QT_NO_CODECS) |
216 | // These should be created, but aren't in Qt 2.3.0 | 202 | // These should be created, but aren't in Qt 2.3.0 |
217 | (void)new QUtf8Codec; | 203 | (void)new QUtf8Codec; |
218 | (void)new QUtf16Codec; | 204 | (void)new QUtf16Codec; |
219 | #endif | 205 | #endif |
220 | return i; | 206 | return i; |
221 | } | 207 | } |
222 | 208 | ||
223 | static bool forced_off = FALSE; | 209 | static bool forced_off = FALSE; |
224 | static int curbl=-1; | 210 | static int curbl=-1; |
225 | 211 | ||
226 | static int backlight() | 212 | static int backlight() |
227 | { | 213 | { |
228 | if ( curbl == -1 ) { | 214 | if ( curbl == -1 ) { |
229 | // Read from config | 215 | // Read from config |
230 | Config config( "qpe" ); | 216 | Config config( "qpe" ); |
231 | config.setGroup( "Screensaver" ); | 217 | config.setGroup( "Screensaver" ); |
232 | curbl = config.readNumEntry("Brightness",255); | 218 | curbl = config.readNumEntry("Brightness",255); |
233 | } | 219 | } |
234 | return curbl; | 220 | return curbl; |
235 | } | 221 | } |
236 | 222 | ||
237 | static void setBacklight(int bright) | 223 | static void setBacklight(int bright) |
238 | { | 224 | { |
239 | if ( bright == -3 ) { | 225 | if ( bright == -3 ) { |
240 | // Forced on | 226 | // Forced on |
241 | forced_off = FALSE; | 227 | forced_off = FALSE; |
242 | bright = -1; | 228 | bright = -1; |
243 | } | 229 | } |
244 | if ( forced_off && bright != -2 ) | 230 | if ( forced_off && bright != -2 ) |
245 | return; | 231 | return; |
246 | if ( bright == -2 ) { | 232 | if ( bright == -2 ) { |
247 | // Toggle between off and on | 233 | // Toggle between off and on |
248 | bright = curbl ? 0 : -1; | 234 | bright = curbl ? 0 : -1; |
249 | forced_off = !bright; | 235 | forced_off = !bright; |
250 | } | 236 | } |
251 | if ( bright == -1 ) { | 237 | if ( bright == -1 ) { |
@@ -444,218 +430,214 @@ static void setScreenSaverInterval(int interval) | |||
444 | 430 | ||
445 | \code | 431 | \code |
446 | void MyWidget::receive( const QCString& msg, const QByteArray& data ) | 432 | void MyWidget::receive( const QCString& msg, const QByteArray& data ) |
447 | { | 433 | { |
448 | QDataStream stream( data, IO_ReadOnly ); | 434 | QDataStream stream( data, IO_ReadOnly ); |
449 | if ( msg == "someMessage(int,int,int)" ) { | 435 | if ( msg == "someMessage(int,int,int)" ) { |
450 | int a,b,c; | 436 | int a,b,c; |
451 | stream >> a >> b >> c; | 437 | stream >> a >> b >> c; |
452 | ... | 438 | ... |
453 | } else if ( msg == "otherMessage(QString)" ) { | 439 | } else if ( msg == "otherMessage(QString)" ) { |
454 | ... | 440 | ... |
455 | } | 441 | } |
456 | } | 442 | } |
457 | \endcode | 443 | \endcode |
458 | 444 | ||
459 | \sa qcop.html | 445 | \sa qcop.html |
460 | */ | 446 | */ |
461 | 447 | ||
462 | /*! | 448 | /*! |
463 | Constructs a QPEApplication just as you would construct | 449 | Constructs a QPEApplication just as you would construct |
464 | a QApplication, passing \a argc, \a argv, and \a t. | 450 | a QApplication, passing \a argc, \a argv, and \a t. |
465 | */ | 451 | */ |
466 | QPEApplication::QPEApplication( int& argc, char **argv, Type t ) | 452 | QPEApplication::QPEApplication( int& argc, char **argv, Type t ) |
467 | : QApplication( hack(argc), argv, t ) | 453 | : QApplication( hack(argc), argv, t ) |
468 | { | 454 | { |
469 | int dw = desktop()->width(); | 455 | int dw = desktop()->width(); |
470 | if ( dw < 200 ) { | 456 | if ( dw < 200 ) { |
471 | setFont( QFont( "helvetica", 8 ) ); | 457 | setFont( QFont( "helvetica", 8 ) ); |
472 | AppLnk::setSmallIconSize(10); | 458 | AppLnk::setSmallIconSize(10); |
473 | AppLnk::setBigIconSize(28); | 459 | AppLnk::setBigIconSize(28); |
474 | } | 460 | } |
475 | 461 | ||
476 | d = new QPEApplicationData; | 462 | d = new QPEApplicationData; |
477 | QMimeSourceFactory::setDefaultFactory(new ResourceMimeFactory); | 463 | QMimeSourceFactory::setDefaultFactory(new ResourceMimeFactory); |
478 | 464 | ||
479 | connect(this, SIGNAL(lastWindowClosed()), this, SLOT(hideOrQuit())); | 465 | connect(this, SIGNAL(lastWindowClosed()), this, SLOT(hideOrQuit())); |
480 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) | 466 | #if defined(Q_WS_QWS) && !defined(QT_NO_COP) |
481 | 467 | ||
482 | QString qcopfn("/tmp/qcop-msg-"); | 468 | QString qcopfn("/tmp/qcop-msg-"); |
483 | qcopfn += QString(argv[0]); // append command name | 469 | qcopfn += QString(argv[0]); // append command name |
484 | 470 | ||
485 | QFile f(qcopfn); | 471 | QFile f(qcopfn); |
486 | if ( f.open(IO_ReadOnly) ) { | 472 | if ( f.open(IO_ReadOnly) ) { |
487 | flock(f.handle(), LOCK_EX); | 473 | flock(f.handle(), LOCK_EX); |
488 | } | 474 | } |
489 | 475 | ||
490 | sysChannel = new QCopChannel( "QPE/System", this ); | 476 | sysChannel = new QCopChannel( "QPE/System", this ); |
491 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 477 | connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
492 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); | 478 | this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); |
493 | 479 | ||
494 | QCString channel = QCString(argv[0]); | 480 | QCString channel = QCString(argv[0]); |
495 | channel.replace(QRegExp(".*/"),""); | 481 | channel.replace(QRegExp(".*/"),""); |
496 | d->appName = channel; | 482 | d->appName = channel; |
497 | channel = "QPE/Application/" + channel; | 483 | channel = "QPE/Application/" + channel; |
498 | pidChannel = new QCopChannel( channel, this); | 484 | pidChannel = new QCopChannel( channel, this); |
499 | connect( pidChannel, SIGNAL(received(const QCString &, const QByteArray &)), | 485 | connect( pidChannel, SIGNAL(received(const QCString &, const QByteArray &)), |
500 | this, SLOT(pidMessage(const QCString &, const QByteArray &))); | 486 | this, SLOT(pidMessage(const QCString &, const QByteArray &))); |
501 | 487 | ||
502 | if ( f.isOpen() ) { | 488 | if ( f.isOpen() ) { |
503 | d->keep_running = FALSE; | 489 | d->keep_running = FALSE; |
504 | QDataStream ds(&f); | 490 | QDataStream ds(&f); |
505 | QCString channel, message; | 491 | QCString channel, message; |
506 | QByteArray data; | 492 | QByteArray data; |
507 | while(!ds.atEnd()) { | 493 | while(!ds.atEnd()) { |
508 | ds >> channel >> message >> data; | 494 | ds >> channel >> message >> data; |
509 | d->enqueueQCop(channel,message,data); | 495 | d->enqueueQCop(channel,message,data); |
510 | } | 496 | } |
511 | 497 | ||
512 | flock(f.handle(), LOCK_UN); | 498 | flock(f.handle(), LOCK_UN); |
513 | f.close(); | 499 | f.close(); |
514 | f.remove(); | 500 | f.remove(); |
515 | } | 501 | } |
516 | 502 | ||
517 | for (int a=0; a<argc; a++) { | 503 | for (int a=0; a<argc; a++) { |
518 | if ( qstrcmp(argv[a],"-preload")==0 ) { | 504 | if ( qstrcmp(argv[a],"-preload")==0 ) { |
519 | argv[a] = argv[a+1]; | 505 | argv[a] = argv[a+1]; |
520 | a++; | 506 | a++; |
521 | d->preloaded = TRUE; | 507 | d->preloaded = TRUE; |
522 | argc-=1; | 508 | argc-=1; |
523 | } else if ( qstrcmp(argv[a],"-preload-show")==0 ) { | 509 | } else if ( qstrcmp(argv[a],"-preload-show")==0 ) { |
524 | argv[a] = argv[a+1]; | 510 | argv[a] = argv[a+1]; |
525 | a++; | 511 | a++; |
526 | d->preloaded = TRUE; | 512 | d->preloaded = TRUE; |
527 | d->forceshow = TRUE; | 513 | d->forceshow = TRUE; |
528 | argc-=1; | 514 | argc-=1; |
529 | } | 515 | } |
530 | } | 516 | } |
531 | 517 | ||
532 | /* overide stored arguments */ | 518 | /* overide stored arguments */ |
533 | setArgs(argc, argv); | 519 | setArgs(argc, argv); |
534 | 520 | ||
535 | #endif | 521 | #endif |
536 | 522 | ||
537 | qwsSetDecoration( new QPEDecoration() ); | 523 | qwsSetDecoration( new QPEDecoration() ); |
538 | 524 | ||
539 | #ifndef QT_NO_TRANSLATION | 525 | #ifndef QT_NO_TRANSLATION |
540 | char *l = getenv( "LANG" ); | 526 | QStringList langs = Global::languageList(); |
541 | QString lang; | 527 | for (QStringList::ConstIterator it = langs.begin(); it!=langs.end(); ++it) { |
542 | if ( l ) { | 528 | QString lang = *it; |
543 | lang = l; | ||
544 | 529 | ||
545 | /* | 530 | QTranslator * trans; |
546 | Config config("qpe"); | 531 | QString tfn; |
547 | config.setGroup( "Appearance" ); | ||
548 | lang = config.readEntry( "Language", lang ); | ||
549 | */ | ||
550 | 532 | ||
551 | QTranslator * trans = new QTranslator(this); | 533 | trans = new QTranslator(this); |
552 | QString tfn = qpeDir()+"/i18n/"+lang+"/"+d->appName+".qm"; | 534 | tfn = qpeDir()+"/i18n/"+lang+"/libqpe.qm"; |
553 | if ( trans->load( tfn )) | 535 | if ( trans->load( tfn )) |
554 | installTranslator( trans ); | 536 | installTranslator( trans ); |
555 | else | 537 | else |
556 | delete trans; | 538 | delete trans; |
557 | 539 | ||
558 | trans = new QTranslator(this); | 540 | trans = new QTranslator(this); |
559 | tfn = qpeDir()+"/i18n/"+lang+"/libqpe.qm"; | 541 | tfn = qpeDir()+"/i18n/"+lang+"/"+d->appName+".qm"; |
560 | if ( trans->load( tfn )) | 542 | if ( trans->load( tfn )) |
561 | installTranslator( trans ); | 543 | installTranslator( trans ); |
562 | else | 544 | else |
563 | delete trans; | 545 | delete trans; |
564 | 546 | ||
565 | //###language/font hack; should look it up somewhere | 547 | //###language/font hack; should look it up somewhere |
566 | if ( lang == "ja" || lang == "zh_CN" || lang == "zh_TW" || lang == "ko" ) { | 548 | if ( lang == "ja" || lang == "zh_CN" || lang == "zh_TW" || lang == "ko" ) { |
567 | QFont fn = FontManager::unicodeFont( FontManager::Proportional ); | 549 | QFont fn = FontManager::unicodeFont( FontManager::Proportional ); |
568 | setFont( fn ); | 550 | setFont( fn ); |
569 | } | 551 | } |
570 | } | 552 | } |
571 | #endif | 553 | #endif |
572 | 554 | ||
573 | applyStyle(); | 555 | applyStyle(); |
574 | 556 | ||
575 | if ( type() == GuiServer ) { | 557 | if ( type() == GuiServer ) { |
576 | setScreenSaverInterval(-1); | 558 | setScreenSaverInterval(-1); |
577 | setVolume(); | 559 | setVolume(); |
578 | QWSServer::setScreenSaver(new QPEScreenSaver); | 560 | QWSServer::setScreenSaver(new QPEScreenSaver); |
579 | } | 561 | } |
580 | 562 | ||
581 | installEventFilter( this ); | 563 | installEventFilter( this ); |
582 | 564 | ||
583 | QPEMenuToolFocusManager::initialize(); | 565 | QPEMenuToolFocusManager::initialize(); |
584 | 566 | ||
585 | #ifdef QT_NO_QWS_CURSOR | 567 | #ifdef QT_NO_QWS_CURSOR |
586 | // if we have no cursor, probably don't want tooltips | 568 | // if we have no cursor, probably don't want tooltips |
587 | QToolTip::setEnabled( FALSE ); | 569 | QToolTip::setEnabled( FALSE ); |
588 | #endif | 570 | #endif |
589 | } | 571 | } |
590 | 572 | ||
591 | static QPtrDict<void>* inputMethodDict=0; | 573 | static QPtrDict<void>* inputMethodDict=0; |
592 | static void createInputMethodDict() | 574 | static void createInputMethodDict() |
593 | { | 575 | { |
594 | if ( !inputMethodDict ) | 576 | if ( !inputMethodDict ) |
595 | inputMethodDict = new QPtrDict<void>; | 577 | inputMethodDict = new QPtrDict<void>; |
596 | } | 578 | } |
597 | 579 | ||
598 | /*! | 580 | /*! |
599 | Returns the currently set hint to the system as to whether | 581 | Returns the currently set hint to the system as to whether |
600 | \a w has any use for text input methods. | 582 | \a w has any use for text input methods. |
601 | 583 | ||
602 | \sa setInputMethodHint() | 584 | \sa setInputMethodHint() |
603 | */ | 585 | */ |
604 | QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w ) | 586 | QPEApplication::InputMethodHint QPEApplication::inputMethodHint( QWidget* w ) |
605 | { | 587 | { |
606 | if ( inputMethodDict && w ) | 588 | if ( inputMethodDict && w ) |
607 | return (InputMethodHint)(int)inputMethodDict->find(w); | 589 | return (InputMethodHint)(int)inputMethodDict->find(w); |
608 | return Normal; | 590 | return Normal; |
609 | } | 591 | } |
610 | 592 | ||
611 | /*! | 593 | /*! |
612 | \enum QPEApplication::InputMethodHint | 594 | \enum QPEApplication::InputMethodHint |
613 | 595 | ||
614 | \value Normal the application sometimes needs text input (the default). | 596 | \value Normal the application sometimes needs text input (the default). |
615 | \value AlwaysOff the application never needs text input. | 597 | \value AlwaysOff the application never needs text input. |
616 | \value AlwaysOn the application always needs text input. | 598 | \value AlwaysOn the application always needs text input. |
617 | */ | 599 | */ |
618 | 600 | ||
619 | /*! | 601 | /*! |
620 | Hints to the system that \a w has use for text input methods | 602 | Hints to the system that \a w has use for text input methods |
621 | as specified by \a mode. | 603 | as specified by \a mode. |
622 | 604 | ||
623 | \sa inputMethodHint() | 605 | \sa inputMethodHint() |
624 | */ | 606 | */ |
625 | void QPEApplication::setInputMethodHint( QWidget* w, InputMethodHint mode ) | 607 | void QPEApplication::setInputMethodHint( QWidget* w, InputMethodHint mode ) |
626 | { | 608 | { |
627 | createInputMethodDict(); | 609 | createInputMethodDict(); |
628 | if ( mode == Normal ) { | 610 | if ( mode == Normal ) { |
629 | inputMethodDict->remove(w); | 611 | inputMethodDict->remove(w); |
630 | } else { | 612 | } else { |
631 | inputMethodDict->insert(w,(void*)mode); | 613 | inputMethodDict->insert(w,(void*)mode); |
632 | } | 614 | } |
633 | } | 615 | } |
634 | 616 | ||
635 | class HackDialog : public QDialog | 617 | class HackDialog : public QDialog |
636 | { | 618 | { |
637 | public: | 619 | public: |
638 | void acceptIt() { accept(); } | 620 | void acceptIt() { accept(); } |
639 | void rejectIt() { reject(); } | 621 | void rejectIt() { reject(); } |
640 | }; | 622 | }; |
641 | 623 | ||
642 | 624 | ||
643 | void QPEApplication::mapToDefaultAction( QWSKeyEvent *ke, int key ) | 625 | void QPEApplication::mapToDefaultAction( QWSKeyEvent *ke, int key ) |
644 | { | 626 | { |
645 | // specialised actions for certain widgets. May want to | 627 | // specialised actions for certain widgets. May want to |
646 | // add more stuff here. | 628 | // add more stuff here. |
647 | if ( activePopupWidget() && activePopupWidget()->inherits( "QListBox" ) | 629 | if ( activePopupWidget() && activePopupWidget()->inherits( "QListBox" ) |
648 | && activePopupWidget()->parentWidget() | 630 | && activePopupWidget()->parentWidget() |
649 | && activePopupWidget()->parentWidget()->inherits( "QComboBox" ) ) | 631 | && activePopupWidget()->parentWidget()->inherits( "QComboBox" ) ) |
650 | key = Qt::Key_Return; | 632 | key = Qt::Key_Return; |
651 | 633 | ||
652 | if ( activePopupWidget() && activePopupWidget()->inherits( "QPopupMenu" ) ) | 634 | if ( activePopupWidget() && activePopupWidget()->inherits( "QPopupMenu" ) ) |
653 | key = Qt::Key_Return; | 635 | key = Qt::Key_Return; |
654 | 636 | ||
655 | ke->simpleData.keycode = key; | 637 | ke->simpleData.keycode = key; |
656 | } | 638 | } |
657 | 639 | ||
658 | class HackWidget : public QWidget | 640 | class HackWidget : public QWidget |
659 | { | 641 | { |
660 | public: | 642 | public: |
661 | bool needsOk() | 643 | bool needsOk() |
@@ -83,139 +83,139 @@ do | |||
83 | 83 | ||
84 | mkdir -p $DATADIR | 84 | mkdir -p $DATADIR |
85 | mkdir -p $CTRLDIR | 85 | mkdir -p $CTRLDIR |
86 | 86 | ||
87 | packagename=${i##*/}; packagename=${packagename%.control} | 87 | packagename=${i##*/}; packagename=${packagename%.control} |
88 | version=$(eval echo '"'$(sed -n -e "s/^Version: *//p" $i)'"') | 88 | version=$(eval echo '"'$(sed -n -e "s/^Version: *//p" $i)'"') |
89 | depends=$(eval echo '"'$(sed -n -e "s/^Depends: *//p" $i)'"') | 89 | depends=$(eval echo '"'$(sed -n -e "s/^Depends: *//p" $i)'"') |
90 | files=$(eval echo $(sed -n -e "s/^Files://p" $i)) | 90 | files=$(eval echo $(sed -n -e "s/^Files://p" $i)) |
91 | arch=$(eval echo $(sed -n -e "s/^Arch://p" $i)) | 91 | arch=$(eval echo $(sed -n -e "s/^Arch://p" $i)) |
92 | section=$(sed -n -e "s/^Section: *//p" $i) | 92 | section=$(sed -n -e "s/^Section: *//p" $i) |
93 | license=$(sed -n -e "s/^License: *//p" $i) | 93 | license=$(sed -n -e "s/^License: *//p" $i) |
94 | summary=$(sed -n -e "s/^Description: *//p" $i) | 94 | summary=$(sed -n -e "s/^Description: *//p" $i) |
95 | package=${packagename}_${version}_$ARCH | 95 | package=${packagename}_${version}_$ARCH |
96 | ERROR= | 96 | ERROR= |
97 | if [ -z "$files" ] | 97 | if [ -z "$files" ] |
98 | then | 98 | then |
99 | mkdir -p $DATADIR/usr/share/doc/$packagename | 99 | mkdir -p $DATADIR/usr/share/doc/$packagename |
100 | else | 100 | else |
101 | for f in $files | 101 | for f in $files |
102 | do | 102 | do |
103 | if [ -d $f ] | 103 | if [ -d $f ] |
104 | then | 104 | then |
105 | ffiles=$(find $f -type f -o -type b -o -type c -o -type l) | 105 | ffiles=$(find $f -type f -o -type b -o -type c -o -type l) |
106 | else | 106 | else |
107 | ffiles=$f | 107 | ffiles=$f |
108 | fi | 108 | fi |
109 | for ff in $ffiles | 109 | for ff in $ffiles |
110 | do | 110 | do |
111 | case $ff in | 111 | case $ff in |
112 | */CVS/*) | 112 | */CVS/*) |
113 | continue | 113 | continue |
114 | ;;*~) | 114 | ;;*~) |
115 | continue | 115 | continue |
116 | ;;*.control) | 116 | ;;*.control) |
117 | continue | 117 | continue |
118 | ;; $QTDIR/*) | 118 | ;; $QTDIR/*) |
119 | BASE=$(dirname /usr/${ff#$QTDIR/}) | 119 | BASE=$(dirname /usr/${ff#$QTDIR/}) |
120 | ;; etc/*.d/*) | 120 | ;; etc/*.d/*) |
121 | BASE=$(dirname /$ff) | 121 | BASE=$(dirname /$ff) |
122 | ;; ipaq/*) | 122 | ;; ipaq/*) |
123 | BASE=$(dirname ${ff#ipaq}) | 123 | BASE=$(dirname ${ff#ipaq}) |
124 | ;; *) | 124 | ;; *) |
125 | # For SHARP ROM compatibility. Should change to Qtopia. | 125 | # For SHARP ROM compatibility. Should change to Qtopia. |
126 | BASE=/opt/QtPalmtop/$(dirname $ff) | 126 | BASE=/opt/QtPalmtop/$(dirname $ff) |
127 | esac | 127 | esac |
128 | 128 | ||
129 | if [ -f $ff -o -b $ff -o -c $ff ] | 129 | if [ -f $ff -o -b $ff -o -c $ff ] |
130 | then | 130 | then |
131 | D=$DATADIR$BASE | 131 | D=$DATADIR$BASE |
132 | if [ -x $ff -a -n "$STRIP" ] | 132 | if [ -x $ff -a -n "$STRIP" ] |
133 | then | 133 | then |
134 | case $(file $ff) in | 134 | case $(file $ff) in |
135 | $STRIP_FILES) | 135 | $STRIP_FILES) |
136 | $STRIP $ff | 136 | $STRIP $ff |
137 | ;; *) | 137 | ;; *) |
138 | esac | 138 | esac |
139 | fi | 139 | fi |
140 | if [ -n "$RPM" ] | 140 | if [ -n "$RPM" ] |
141 | then | 141 | then |
142 | case "$ff" in | 142 | case "$ff" in |
143 | /*) RPMFILES="$RPMFILES $ff" | 143 | /*) RPMFILES="$RPMFILES $ff" |
144 | ;; *) RPMFILES="$RPMFILES $OPIEDIR/$ff" | 144 | ;; *) RPMFILES="$RPMFILES $OPIEDIR/$ff" |
145 | esac | 145 | esac |
146 | else | 146 | else |
147 | mkdir -p $D | 147 | mkdir -p $D |
148 | if cp -a $ff $D | 148 | if cp -a $ff $D |
149 | then | 149 | then |
150 | true | 150 | true |
151 | else | 151 | else |
152 | ERROR=1 | 152 | ERROR=1 |
153 | fi | 153 | fi |
154 | fi | 154 | fi |
155 | else | 155 | else |
156 | echo >&2 "$0: $i: No such file: $ff" | 156 | echo >&2 "$0: $i: No such file: $ff" |
157 | ERROR=1 | 157 | ERROR=1 |
158 | fi | 158 | fi |
159 | done | 159 | done |
160 | done | 160 | done |
161 | fi | 161 | fi |
162 | if [ -z "$ERROR" ] | 162 | if [ -z "$ERROR" ] |
163 | then | 163 | then |
164 | if [ -n "$RPM" ] | 164 | if [ -n "$RPM" ] |
165 | then | 165 | then |
166 | SPEC=/tmp/mkipks-rpm-$$.spec | 166 | SPEC=/tmp/mkipks-rpm-$$.spec |
167 | echo >$SPEC "Summary: $summary" | 167 | echo >$SPEC "Summary: $summary" |
168 | echo >>$SPEC "Name: $packagename" | 168 | echo >>$SPEC "Name: $packagename" |
169 | echo >>$SPEC "Group: $section" ########## | 169 | echo >>$SPEC "Group: $section" ########## |
170 | echo >>$SPEC "License: $license" | 170 | echo >>$SPEC "License: $license" |
171 | echo >>$SPEC "Version: ${version%-*}" | 171 | echo >>$SPEC "Version: ${version%-*}" |
172 | echo >>$SPEC "Release: ${version#*-}" | 172 | echo >>$SPEC "Release: ${version#*-}" |
173 | 173 | ||
174 | echo >>$SPEC "%description" | 174 | echo >>$SPEC "%description" |
175 | sed -n -e '/^Description:/,$ p' $i | tail +2 >>$SPEC | 175 | sed -n -e '/^Description:/,$ p' $i | tail +2 >>$SPEC |
176 | echo >>$SPEC "%files" | 176 | echo >>$SPEC "%files" |
177 | echo >>$SPEC "%defattr(-,root,root)" | 177 | echo >>$SPEC "%defattr(-,root,root)" |
178 | /bin/ls $RPMFILES >>$SPEC | 178 | /bin/ls $RPMFILES >>$SPEC |
179 | rpm -bb $SPEC --target $ARCH-unknown-linux | 179 | rpm -bb --target $ARCH-unknown-linux $SPEC |
180 | # rm $SPEC | 180 | # rm $SPEC |
181 | elif [ -z "$IMAGEDIR" ] | 181 | elif [ -z "$IMAGEDIR" ] |
182 | then | 182 | then |
183 | #size=$(du -h -s $DATADIR | sed -e 's/[ ].*//') | 183 | #size=$(du -h -s $DATADIR | sed -e 's/[ ].*//') |
184 | size=$(mkfs.jffs2 -r $DATADIR | wc -c) | 184 | size=$(mkfs.jffs2 -r $DATADIR | wc -c) |
185 | echo "Package: $packagename" >$CTRLDIR/control | 185 | echo "Package: $packagename" >$CTRLDIR/control |
186 | echo "Installed-Size: $size" >>$CTRLDIR/control | 186 | echo "Installed-Size: $size" >>$CTRLDIR/control |
187 | echo "Filename: ./$package.ipk" >>$CTRLDIR/control | 187 | echo "Filename: ./$package.ipk" >>$CTRLDIR/control |
188 | echo "Version: $version" >>$CTRLDIR/control | 188 | echo "Version: $version" >>$CTRLDIR/control |
189 | echo "Depends: $depends" >>$CTRLDIR/control | 189 | echo "Depends: $depends" >>$CTRLDIR/control |
190 | egrep -v "^(Files|Version|Depends):" >>$CTRLDIR/control $i | 190 | egrep -v "^(Files|Version|Depends):" >>$CTRLDIR/control $i |
191 | echo "$DEB_VERSION" >$TDIR/debian-binary | 191 | echo "$DEB_VERSION" >$TDIR/debian-binary |
192 | base=${i%.control} | 192 | base=${i%.control} |
193 | scripts="preinst postinst prerm postrm" | 193 | scripts="preinst postinst prerm postrm" |
194 | for pf in $scripts | 194 | for pf in $scripts |
195 | do | 195 | do |
196 | if [ -x ${base}.$pf ] | 196 | if [ -x ${base}.$pf ] |
197 | then | 197 | then |
198 | cp ${base}.$pf $CTRLDIR/$pf | 198 | cp ${base}.$pf $CTRLDIR/$pf |
199 | fi | 199 | fi |
200 | done | 200 | done |
201 | if [ "$UID" = 0 ] | 201 | if [ "$UID" = 0 ] |
202 | then | 202 | then |
203 | chown -R root.root $TDIR | 203 | chown -R root.root $TDIR |
204 | fi | 204 | fi |
205 | ( cd $CTRLDIR; tar cfz ../control.tar.gz ./*; ) | 205 | ( cd $CTRLDIR; tar cfz ../control.tar.gz ./*; ) |
206 | ( cd $DATADIR; tar cfz ../data.tar.gz ./*; ) | 206 | ( cd $DATADIR; tar cfz ../data.tar.gz ./*; ) |
207 | ( cd $TDIR; rm -rf control data; tar cf - ./debian-binary ./control.tar.gz ./data.tar.gz; ) | gzip >$RDIR/$package.ipk | 207 | ( cd $TDIR; rm -rf control data; tar cf - ./debian-binary ./control.tar.gz ./data.tar.gz; ) | gzip >$RDIR/$package.ipk |
208 | RESULT=$package.ipk | 208 | RESULT=$package.ipk |
209 | if [ -n "$VERB" ] | 209 | if [ -n "$VERB" ] |
210 | then | 210 | then |
211 | echo >&2 "Built $RESULT ($size)" | 211 | echo >&2 "Built $RESULT ($size)" |
212 | fi | 212 | fi |
213 | if [ -n "$LIST" ] | 213 | if [ -n "$LIST" ] |
214 | then | 214 | then |
215 | echo $RESULT | 215 | echo $RESULT |
216 | fi | 216 | fi |
217 | fi | 217 | fi |
218 | else | 218 | else |
219 | echo >&2 "Not building $package package" | 219 | echo >&2 "Not building $package package" |
220 | fi | 220 | fi |
221 | done | 221 | done |
diff --git a/noncore/games/minesweep/Makefile.in b/noncore/games/minesweep/Makefile.in index 67ea94c..6df2608 100644 --- a/noncore/games/minesweep/Makefile.in +++ b/noncore/games/minesweep/Makefile.in | |||
@@ -1,134 +1,136 @@ | |||
1 | ############################################################################# | 1 | ############################################################################# |
2 | 2 | ||
3 | ####### Compiler, tools and options | 3 | ####### Compiler, tools and options |
4 | 4 | ||
5 | CXX =$(SYSCONF_CXX) $(QT_CXX_MT) | 5 | CXX =$(SYSCONF_CXX) $(QT_CXX_MT) |
6 | CXXFLAGS=$(SYSCONF_CXXFLAGS_QT) $(SYSCONF_CXXFLAGS) | 6 | CXXFLAGS=$(SYSCONF_CXXFLAGS_QT) $(SYSCONF_CXXFLAGS) |
7 | CC =$(SYSCONF_CC) $(QT_C_MT) | 7 | CC =$(SYSCONF_CC) $(QT_C_MT) |
8 | CFLAGS =$(SYSCONF_CFLAGS) | 8 | CFLAGS =$(SYSCONF_CFLAGS) |
9 | INCPATH =-I$(OPIEDIR)/include | 9 | INCPATH =-I$(OPIEDIR)/include |
10 | LFLAGS =$(SYSCONF_LFLAGS_QT) $(SYSCONF_RPATH_QT) $(SYSCONF_LFLAGS) $(QT_LFLAGS_MT) | 10 | LFLAGS =$(SYSCONF_LFLAGS_QT) $(SYSCONF_RPATH_QT) $(SYSCONF_LFLAGS) $(QT_LFLAGS_MT) |
11 | LIBS =$(SUBLIBS) -lqpe $(SYSCONF_LIBS_QT) $(SYSCONF_LIBS) $(SYSCONF_LIBS_QTAPP) | 11 | LIBS =$(SUBLIBS) -lqpe $(SYSCONF_LIBS_QT) $(SYSCONF_LIBS) $(SYSCONF_LIBS_QTAPP) |
12 | MOC =$(SYSCONF_MOC) | 12 | MOC =$(SYSCONF_MOC) |
13 | UIC =$(SYSCONF_UIC) | 13 | UIC =$(SYSCONF_UIC) |
14 | 14 | ||
15 | ####### Target | 15 | ####### Target |
16 | 16 | ||
17 | DESTDIR = $(OPIEDIR)/bin/ | 17 | DESTDIR = $(OPIEDIR)/bin/ |
18 | VER_MAJ = 1 | 18 | VER_MAJ = 1 |
19 | VER_MIN = 0 | 19 | VER_MIN = 0 |
20 | VER_PATCH = 0 | 20 | VER_PATCH = 0 |
21 | TARGET= minesweep | 21 | TARGET= minesweep |
22 | TARGET1 = lib$(TARGET).so.$(VER_MAJ) | 22 | TARGET1 = lib$(TARGET).so.$(VER_MAJ) |
23 | 23 | ||
24 | ####### Files | 24 | ####### Files |
25 | 25 | ||
26 | HEADERS =minefield.h \ | 26 | HEADERS =minefield.h \ |
27 | minesweep.h | 27 | minesweep.h |
28 | SOURCES =main.cpp \ | 28 | SOURCES =main.cpp \ |
29 | minefield.cpp \ | 29 | minefield.cpp \ |
30 | minesweep.cpp | 30 | minesweep.cpp |
31 | OBJECTS =main.o \ | 31 | OBJECTS =main.o \ |
32 | minefield.o \ | 32 | minefield.o \ |
33 | minesweep.o | 33 | minesweep.o |
34 | INTERFACES = | 34 | INTERFACES = |
35 | UICDECLS = | 35 | UICDECLS = |
36 | UICIMPLS = | 36 | UICIMPLS = |
37 | SRCMOC =moc_minefield.cpp \ | 37 | SRCMOC =moc_minefield.cpp \ |
38 | moc_minesweep.cpp | 38 | moc_minesweep.cpp |
39 | OBJMOC =moc_minefield.o \ | 39 | OBJMOC =moc_minefield.o \ |
40 | moc_minesweep.o | 40 | moc_minesweep.o |
41 | 41 | ||
42 | 42 | ||
43 | ####### Implicit rules | 43 | ####### Implicit rules |
44 | 44 | ||
45 | .SUFFIXES: .cpp .cxx .cc .C .c | 45 | .SUFFIXES: .cpp .cxx .cc .C .c |
46 | 46 | ||
47 | .cpp.o: | 47 | .cpp.o: |
48 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< | 48 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< |
49 | 49 | ||
50 | .cxx.o: | 50 | .cxx.o: |
51 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< | 51 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< |
52 | 52 | ||
53 | .cc.o: | 53 | .cc.o: |
54 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< | 54 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< |
55 | 55 | ||
56 | .C.o: | 56 | .C.o: |
57 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< | 57 | $(CXX) -c $(CXXFLAGS) $(INCPATH) -o $@ $< |
58 | 58 | ||
59 | .c.o: | 59 | .c.o: |
60 | $(CC) -c $(CFLAGS) $(INCPATH) -o $@ $< | 60 | $(CC) -c $(CFLAGS) $(INCPATH) -o $@ $< |
61 | 61 | ||
62 | ####### Build rules | 62 | ####### Build rules |
63 | 63 | ||
64 | 64 | ||
65 | all: $(DESTDIR)$(TARGET) | 65 | all: $(DESTDIR)$(TARGET) |
66 | 66 | ||
67 | $(DESTDIR)$(TARGET): $(UICDECLS) $(OBJECTS) $(OBJMOC) $(SUBLIBS) | 67 | $(DESTDIR)$(TARGET): $(UICDECLS) $(OBJECTS) $(OBJMOC) $(SUBLIBS) |
68 | $(SYSCONF_LINK) $(LFLAGS) -o $(DESTDIR)$(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS) | 68 | $(SYSCONF_LINK) $(LFLAGS) -o $(DESTDIR)$(TARGET) $(OBJECTS) $(OBJMOC) $(LIBS) |
69 | 69 | ||
70 | moc: $(SRCMOC) | 70 | moc: $(SRCMOC) |
71 | 71 | ||
72 | tmake: | 72 | tmake: Makefile.in |
73 | tmake minesweep.pro | 73 | |
74 | Makefile.in: minesweep.pro | ||
75 | tmake minesweep.pro -o Makefile.in | ||
74 | 76 | ||
75 | clean: | 77 | clean: |
76 | -rm -f $(OBJECTS) $(OBJMOC) $(SRCMOC) $(UICIMPLS) $(UICDECLS) | 78 | -rm -f $(OBJECTS) $(OBJMOC) $(SRCMOC) $(UICIMPLS) $(UICDECLS) |
77 | -rm -f *~ core | 79 | -rm -f *~ core |
78 | -rm -f allmoc.cpp | 80 | -rm -f allmoc.cpp |
79 | 81 | ||
80 | ####### Extension Modules | 82 | ####### Extension Modules |
81 | 83 | ||
82 | listpromodules: | 84 | listpromodules: |
83 | @echo | 85 | @echo |
84 | 86 | ||
85 | listallmodules: | 87 | listallmodules: |
86 | @echo | 88 | @echo |
87 | 89 | ||
88 | listaddonpromodules: | 90 | listaddonpromodules: |
89 | @echo | 91 | @echo |
90 | 92 | ||
91 | listaddonentmodules: | 93 | listaddonentmodules: |
92 | @echo | 94 | @echo |
93 | 95 | ||
94 | 96 | ||
95 | REQUIRES= | 97 | REQUIRES= |
96 | 98 | ||
97 | ####### Sub-libraries | 99 | ####### Sub-libraries |
98 | 100 | ||
99 | 101 | ||
100 | ###### Combined headers | 102 | ###### Combined headers |
101 | 103 | ||
102 | 104 | ||
103 | 105 | ||
104 | ####### Compile | 106 | ####### Compile |
105 | 107 | ||
106 | main.o: main.cpp \ | 108 | main.o: main.cpp \ |
107 | minesweep.h \ | 109 | minesweep.h \ |
108 | $(OPIEDIR)/include/qpe/qpeapplication.h | 110 | /home/kergoth/roms/openzaurus/buildroot-oz/build/opie/include/qpe/qpeapplication.h |
109 | 111 | ||
110 | minefield.o: minefield.cpp \ | 112 | minefield.o: minefield.cpp \ |
111 | minefield.h \ | 113 | minefield.h \ |
112 | $(OPIEDIR)/include/qpe/config.h | 114 | /home/kergoth/roms/openzaurus/buildroot-oz/build/opie/include/qpe/config.h |
113 | 115 | ||
114 | minesweep.o: minesweep.cpp \ | 116 | minesweep.o: minesweep.cpp \ |
115 | minesweep.h \ | 117 | minesweep.h \ |
116 | minefield.h \ | 118 | minefield.h \ |
117 | $(OPIEDIR)/include/qpe/resource.h \ | 119 | /home/kergoth/roms/openzaurus/buildroot-oz/build/opie/include/qpe/resource.h \ |
118 | $(OPIEDIR)/include/qpe/config.h \ | 120 | /home/kergoth/roms/openzaurus/buildroot-oz/build/opie/include/qpe/config.h \ |
119 | $(OPIEDIR)/include/qpe/qpetoolbar.h \ | 121 | /home/kergoth/roms/openzaurus/buildroot-oz/build/opie/include/qpe/qpetoolbar.h \ |
120 | $(OPIEDIR)/include/qpe/qpemenubar.h | 122 | /home/kergoth/roms/openzaurus/buildroot-oz/build/opie/include/qpe/qpemenubar.h |
121 | 123 | ||
122 | moc_minefield.o: moc_minefield.cpp \ | 124 | moc_minefield.o: moc_minefield.cpp \ |
123 | minefield.h | 125 | minefield.h |
124 | 126 | ||
125 | moc_minesweep.o: moc_minesweep.cpp \ | 127 | moc_minesweep.o: moc_minesweep.cpp \ |
126 | minesweep.h | 128 | minesweep.h |
127 | 129 | ||
128 | moc_minefield.cpp: minefield.h | 130 | moc_minefield.cpp: minefield.h |
129 | $(MOC) minefield.h -o moc_minefield.cpp | 131 | $(MOC) minefield.h -o moc_minefield.cpp |
130 | 132 | ||
131 | moc_minesweep.cpp: minesweep.h | 133 | moc_minesweep.cpp: minesweep.h |
132 | $(MOC) minesweep.h -o moc_minesweep.cpp | 134 | $(MOC) minesweep.h -o moc_minesweep.cpp |
133 | 135 | ||
134 | 136 | ||