summaryrefslogtreecommitdiff
path: root/library/applnk.cpp
Unidiff
Diffstat (limited to 'library/applnk.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--library/applnk.cpp24
1 files changed, 22 insertions, 2 deletions
diff --git a/library/applnk.cpp b/library/applnk.cpp
index 44f3f58..a56da5d 100644
--- a/library/applnk.cpp
+++ b/library/applnk.cpp
@@ -1,1349 +1,1369 @@
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 20
21#define QTOPIA_INTERNAL_MIMEEXT 21#define QTOPIA_INTERNAL_MIMEEXT
22#define QTOPIA_INTERNAL_PRELOADACCESS 22#define QTOPIA_INTERNAL_PRELOADACCESS
23#define QTOPIA_INTERNAL_APPLNKASSIGN 23#define QTOPIA_INTERNAL_APPLNKASSIGN
24 24
25#include "applnk.h" 25#include "applnk.h"
26 26
27#include <qpe/qpeapplication.h> 27#include <qpe/qpeapplication.h>
28#include <qpe/categories.h> 28#include <qpe/categories.h>
29#include <qpe/categoryselect.h> 29#include <qpe/categoryselect.h>
30#ifdef QWS 30#ifdef QWS
31#include <qpe/qcopenvelope_qws.h> 31#include <qpe/qcopenvelope_qws.h>
32#endif 32#endif
33#include <qpe/global.h> 33#include <qpe/global.h>
34#include <qpe/mimetype.h> 34#include <qpe/mimetype.h>
35#include <qpe/config.h> 35#include <qpe/config.h>
36#include <qpe/storage.h> 36#include <qpe/storage.h>
37#include <qpe/resource.h> 37#include <qpe/resource.h>
38 38
39#include <qdict.h> 39#include <qdict.h>
40#include <qdir.h> 40#include <qdir.h>
41#include <qregexp.h> 41#include <qregexp.h>
42 42
43#ifdef Q_WS_QWS 43#ifdef Q_WS_QWS
44#include <qgfx_qws.h> 44#include <qgfx_qws.h>
45#endif 45#endif
46 46
47#include <stdlib.h> 47#include <stdlib.h>
48 48
49int AppLnk::lastId = 5000; 49int AppLnk::lastId = 5000;
50 50
51static int smallSize = 14; 51static int smallSize = 14;
52static int bigSize = 32; 52static int bigSize = 32;
53 53
54static QString safeFileName(const QString& n) 54static QString safeFileName(const QString& n)
55{ 55{
56 QString safename=n; 56 QString safename=n;
57 safename.replace(QRegExp("[^0-9A-Za-z.]"),"_"); 57 safename.replace(QRegExp("[^0-9A-Za-z.]"),"_");
58 safename.replace(QRegExp("^[^A-Za-z]*"),""); 58 safename.replace(QRegExp("^[^A-Za-z]*"),"");
59 if ( safename.isEmpty() ) 59 if ( safename.isEmpty() )
60 safename = "_"; 60 safename = "_";
61 return safename; 61 return safename;
62} 62}
63 63
64static bool prepareDirectories(const QString& lf) 64static bool prepareDirectories(const QString& lf)
65{ 65{
66 if ( !QFile::exists(lf) ) { 66 if ( !QFile::exists(lf) ) {
67 // May need to create directories 67 // May need to create directories
68 QFileInfo fi(lf); 68 QFileInfo fi(lf);
69 if ( system(("mkdir -p "+fi.dirPath(TRUE))) ) 69 if ( system(("mkdir -p "+fi.dirPath(TRUE))) )
70 return FALSE; 70 return FALSE;
71 } 71 }
72 return TRUE; 72 return TRUE;
73} 73}
74 74
75class AppLnkPrivate 75class AppLnkPrivate
76{ 76{
77public: 77public:
78 /* the size of the Pixmap */ 78 /* the size of the Pixmap */
79 enum Size {Normal = 0, Big }; 79 enum Size {Normal = 0, Big };
80 AppLnkPrivate() { 80 AppLnkPrivate() {
81 /* we want one normal and one big item */ 81 /* we want one normal and one big item */
82 82
83 QPixmap pix; 83 QPixmap pix;
84 mPixmaps.insert(0, pix ); 84 mPixmaps.insert(0, pix );
85 mPixmaps.insert(1, pix); 85 mPixmaps.insert(1, pix);
86 } 86 }
87 87
88 QStringList mCatList; // always correct 88 QStringList mCatList; // always correct
89 QArray<int> mCat; // cached value; correct if not empty 89 QArray<int> mCat; // cached value; correct if not empty
90 QMap<int, QPixmap> mPixmaps; 90 QMap<int, QPixmap> mPixmaps;
91 91
92 void updateCatListFromArray() 92 void updateCatListFromArray()
93 { 93 {
94 Categories cat( 0 ); 94 Categories cat( 0 );
95 cat.load( categoryFileName() ); 95 cat.load( categoryFileName() );
96 mCatList = cat.labels("Document View",mCat); 96 mCatList = cat.labels("Document View",mCat);
97 } 97 }
98 98
99 void setCatArrayDirty() 99 void setCatArrayDirty()
100 { 100 {
101 mCat.resize(0); 101 mCat.resize(0);
102 } 102 }
103 103
104 void ensureCatArray() 104 void ensureCatArray()
105 { 105 {
106 if ( mCat.count() > 0 || mCatList.count()==0 ) 106 if ( mCat.count() > 0 || mCatList.count()==0 )
107 return; 107 return;
108 108
109 Categories cat( 0 ); 109 Categories cat( 0 );
110 cat.load( categoryFileName() ); 110 cat.load( categoryFileName() );
111 mCat.resize( mCatList.count() ); 111 mCat.resize( mCatList.count() );
112 int i; 112 int i;
113 QStringList::ConstIterator it; 113 QStringList::ConstIterator it;
114 for ( i = 0, it = mCatList.begin(); it != mCatList.end(); 114 for ( i = 0, it = mCatList.begin(); it != mCatList.end();
115 ++it, i++ ) { 115 ++it, i++ ) {
116 116
117 bool number; 117 bool number;
118 int id = (*it).toInt( &number ); 118 int id = (*it).toInt( &number );
119 if ( !number ) { 119 if ( !number ) {
120 id = cat.id( "Document View", *it ); 120 id = cat.id( "Document View", *it );
121 if ( id == 0 ) 121 if ( id == 0 )
122 id = cat.addCategory( "Document View", *it ); 122 id = cat.addCategory( "Document View", *it );
123 } 123 }
124 mCat[i] = id; 124 mCat[i] = id;
125 } 125 }
126 } 126 }
127}; 127};
128 128
129/*! 129/*!
130 \class AppLnk applnk.h 130 \class AppLnk applnk.h
131 \brief The AppLnk class represents an application available on the system. 131 \brief The AppLnk class represents an application available on the system.
132 132
133 Every Qtopia application \e app has a corresponding \e app.desktop 133 Every Qtopia application \e app has a corresponding \e app.desktop
134 file. When one of these files is read its data is stored as an 134 file. When one of these files is read its data is stored as an
135 AppLnk object. 135 AppLnk object.
136 136
137 The AppLnk class introduces some Qtopia-specific concepts, and 137 The AppLnk class introduces some Qtopia-specific concepts, and
138 provides a variety of functions, as described in the following 138 provides a variety of functions, as described in the following
139 sections. 139 sections.
140 \tableofcontents 140 \tableofcontents
141 141
142 \target Types 142 \target Types
143 \section1 Types 143 \section1 Types
144 144
145 Every AppLnk object has a \e type. For applications, games and 145 Every AppLnk object has a \e type. For applications, games and
146 settings the type is \c Application; for documents the 146 settings the type is \c Application; for documents the
147 type is the document's MIME type. 147 type is the document's MIME type.
148 148
149 \target files-and-links 149 \target files-and-links
150 \section1 Files and Links 150 \section1 Files and Links
151 151
152 When you create an AppLnk (or more likely, a \link doclnk.html 152 When you create an AppLnk (or more likely, a \link doclnk.html
153 DocLnk\endlink), you don't deal directly with filenames in the 153 DocLnk\endlink), you don't deal directly with filenames in the
154 filesystem. Instead you do this: 154 filesystem. Instead you do this:
155 \code 155 \code
156 DocLnk d; 156 DocLnk d;
157 d.setType("text/plain"); 157 d.setType("text/plain");
158 d.setName("My Nicely Named Document / Whatever"); // Yes, "/" is legal. 158 d.setName("My Nicely Named Document / Whatever"); // Yes, "/" is legal.
159 \endcode 159 \endcode
160 At this point, the file() and linkFile() are unknown. Normally 160 At this point, the file() and linkFile() are unknown. Normally
161 this is uninteresting, and the names become automatically known, 161 this is uninteresting, and the names become automatically known,
162 and more importantly, becomes reserved, when you ask what they are: 162 and more importantly, becomes reserved, when you ask what they are:
163 163
164 \code 164 \code
165 QString fn = d.file(); 165 QString fn = d.file();
166 \endcode 166 \endcode
167 This invents a filename, and creates the file on disk (an empty 167 This invents a filename, and creates the file on disk (an empty
168 reservation file) to prevent the name being used by another 168 reservation file) to prevent the name being used by another
169 application. 169 application.
170 170
171 In some circumstances, you don't want to create the file if it 171 In some circumstances, you don't want to create the file if it
172 doesn't already exist (e.g. in the Document tab, some of the \link 172 doesn't already exist (e.g. in the Document tab, some of the \link
173 doclnk.html DocLnk\endlink objects represented by icons are 173 doclnk.html DocLnk\endlink objects represented by icons are
174 DocLnk's created just for that view - they don't have 174 DocLnk's created just for that view - they don't have
175 corresponding \c .desktop files. To avoid littering empty 175 corresponding \c .desktop files. To avoid littering empty
176 reservation files around, we check in a few places to see whether 176 reservation files around, we check in a few places to see whether
177 the file really needs to exist). 177 the file really needs to exist).
178 178
179 \section1 Functionality 179 \section1 Functionality
180 180
181 AppLnk objects are created by calling the constructor with the 181 AppLnk objects are created by calling the constructor with the
182 name of a \e .desktop file. The object can be checked for validity 182 name of a \e .desktop file. The object can be checked for validity
183 using isValid(). 183 using isValid().
184 184
185 The following functions are used to set or retrieve information 185 The following functions are used to set or retrieve information
186 about the application: 186 about the application:
187 \table 187 \table
188 \header \i Get Function \i Set Function \i Short Description 188 \header \i Get Function \i Set Function \i Short Description
189 \row \i \l name() \i \l setName() \i application's name 189 \row \i \l name() \i \l setName() \i application's name
190 \row \i \l pixmap() \i \e none \i application's icon 190 \row \i \l pixmap() \i \e none \i application's icon
191 \row \i \l bigPixmap() \i \e none \i application's large icon 191 \row \i \l bigPixmap() \i \e none \i application's large icon
192 \row \i \e none \i setIcon() \i sets the icon's filename 192 \row \i \e none \i setIcon() \i sets the icon's filename
193 \row \i \l type() \i \l setType() \i see \link #Types Types\endlink above 193 \row \i \l type() \i \l setType() \i see \link #Types Types\endlink above
194 \row \i \l rotation() \i \e none \i 0, 90, 180 or 270 degrees 194 \row \i \l rotation() \i \e none \i 0, 90, 180 or 270 degrees
195 \row \i \l comment() \i \l setComment() \i text for the Details dialog 195 \row \i \l comment() \i \l setComment() \i text for the Details dialog
196 \row \i \l exec() \i \l setExec() \i executable's filename 196 \row \i \l exec() \i \l setExec() \i executable's filename
197 \row \i \l file() \i \e none \i document's filename 197 \row \i \l file() \i \e none \i document's filename
198 \row \i \l linkFile() \i \l setLinkFile()\i \e .desktop filename 198 \row \i \l linkFile() \i \l setLinkFile()\i \e .desktop filename
199 \row \i \l mimeTypes() \i \e none \i the mime types the application can view or edit 199 \row \i \l mimeTypes() \i \e none \i the mime types the application can view or edit
200 \row \i \l categories() \i \l setCategories()\i \e{see the function descriptions} 200 \row \i \l categories() \i \l setCategories()\i \e{see the function descriptions}
201 \row \i \l fileKnown() \i \e none \i see \link 201 \row \i \l fileKnown() \i \e none \i see \link
202#files-and-links Files and Links\endlink above 202#files-and-links Files and Links\endlink above
203 \row \i \l linkFileKnown() \i \e none \i see \link 203 \row \i \l linkFileKnown() \i \e none \i see \link
204#files-and-links Files and Links\endlink above 204#files-and-links Files and Links\endlink above
205 \row \i \l property() \i \l setProperty()\i any AppLnk property 205 \row \i \l property() \i \l setProperty()\i any AppLnk property
206 can be retrieved or set (if writeable) using these 206 can be retrieved or set (if writeable) using these
207 \endtable 207 \endtable
208 208
209 To save an AppLnk to disk use writeLink(). To execute the 209 To save an AppLnk to disk use writeLink(). To execute the
210 application that the AppLnk object refers to, use execute(). 210 application that the AppLnk object refers to, use execute().
211 211
212 AppLnk's can be deleted from disk using removeLinkFile(). To 212 AppLnk's can be deleted from disk using removeLinkFile(). To
213 remove both the link and the application's executable use 213 remove both the link and the application's executable use
214 removeFiles(). 214 removeFiles().
215 215
216 Icon sizes can be globally changed (but only for AppLnk objects 216 Icon sizes can be globally changed (but only for AppLnk objects
217 created after the calls) with setSmallIconSize() and 217 created after the calls) with setSmallIconSize() and
218 setBigIconSize(). 218 setBigIconSize().
219 219
220 \ingroup qtopiaemb 220 \ingroup qtopiaemb
221*/ 221*/
222 222
223/*! 223/*!
224 Sets the size used for small icons to \a small pixels. 224 Sets the size used for small icons to \a small pixels.
225 Only affects AppLnk objects created after the call. 225 Only affects AppLnk objects created after the call.
226 226
227 \sa smallIconSize() setIcon() 227 \sa smallIconSize() setIcon()
228*/ 228*/
229void AppLnk::setSmallIconSize(int small) 229void AppLnk::setSmallIconSize(int small)
230{ 230{
231 smallSize = small; 231 smallSize = small;
232} 232}
233 233
234/*! 234/*!
235 Returns the size used for small icons. 235 Returns the size used for small icons.
236 236
237 \sa setSmallIconSize() setIcon() 237 \sa setSmallIconSize() setIcon()
238*/ 238*/
239int AppLnk::smallIconSize() 239int AppLnk::smallIconSize()
240{ 240{
241 return smallSize; 241 return smallSize;
242} 242}
243 243
244 244
245/*! 245/*!
246 Sets the size used for large icons to \a big pixels. 246 Sets the size used for large icons to \a big pixels.
247 Only affects AppLnk objects created after the call. 247 Only affects AppLnk objects created after the call.
248 248
249 \sa bigIconSize() setIcon() 249 \sa bigIconSize() setIcon()
250*/ 250*/
251void AppLnk::setBigIconSize(int big) 251void AppLnk::setBigIconSize(int big)
252{ 252{
253 bigSize = big; 253 bigSize = big;
254} 254}
255 255
256/*! 256/*!
257 Returns the size used for large icons. 257 Returns the size used for large icons.
258 258
259 \sa setBigIconSize() setIcon() 259 \sa setBigIconSize() setIcon()
260*/ 260*/
261int AppLnk::bigIconSize() 261int AppLnk::bigIconSize()
262{ 262{
263 return bigSize; 263 return bigSize;
264} 264}
265 265
266 266
267/*! 267/*!
268 \fn QString AppLnk::name() const 268 \fn QString AppLnk::name() const
269 269
270 Returns the Name property. This is the user-visible name for the 270 Returns the Name property. This is the user-visible name for the
271 document or application, not the filename. 271 document or application, not the filename.
272 272
273 See \link #files-and-links Files and Links\endlink. 273 See \link #files-and-links Files and Links\endlink.
274 274
275 \sa setName() 275 \sa setName()
276*/ 276*/
277/*! 277/*!
278 \fn QString AppLnk::exec() const 278 \fn QString AppLnk::exec() const
279 279
280 Returns the Exec property. This is the name of the executable 280 Returns the Exec property. This is the name of the executable
281 program associated with the AppLnk. 281 program associated with the AppLnk.
282 282
283 \sa setExec() 283 \sa setExec()
284*/ 284*/
285/*! 285/*!
286 \fn QString AppLnk::rotation() const 286 \fn QString AppLnk::rotation() const
287 287
288 Returns the Rotation property. The value is 0, 90, 180 or 270 288 Returns the Rotation property. The value is 0, 90, 180 or 270
289 degrees. 289 degrees.
290*/ 290*/
291/*! 291/*!
292 \fn QString AppLnk::comment() const 292 \fn QString AppLnk::comment() const
293 293
294 Returns the Comment property. 294 Returns the Comment property.
295 295
296 \sa setComment() 296 \sa setComment()
297*/ 297*/
298/*! 298/*!
299 \fn QStringList AppLnk::mimeTypes() const 299 \fn QStringList AppLnk::mimeTypes() const
300 300
301 Returns the MimeTypes property. This is the list of MIME types 301 Returns the MimeTypes property. This is the list of MIME types
302 that the application can view or edit. 302 that the application can view or edit.
303*/ 303*/
304/*! 304/*!
305 \fn const QArray<int>& AppLnk::categories() const 305 \fn const QArray<int>& AppLnk::categories() const
306 306
307 Returns the Categories property. 307 Returns the Categories property.
308 308
309 See the CategoryWidget for more details. 309 See the CategoryWidget for more details.
310 310
311 \sa setCategories() 311 \sa setCategories()
312*/ 312*/
313 313
314const QArray<int>& AppLnk::categories() const 314const QArray<int>& AppLnk::categories() const
315{ 315{
316 d->ensureCatArray(); 316 d->ensureCatArray();
317 return d->mCat; 317 return d->mCat;
318} 318}
319 319
320/*! 320/*!
321 \fn int AppLnk::id() const 321 \fn int AppLnk::id() const
322 322
323 Returns the id of the AppLnk. If the AppLnk is not in an AppLnkSet, 323 Returns the id of the AppLnk. If the AppLnk is not in an AppLnkSet,
324 this value is 0, otherwise it is a value that is unique for the 324 this value is 0, otherwise it is a value that is unique for the
325 duration of the current process. 325 duration of the current process.
326 326
327 \sa AppLnkSet::find() 327 \sa AppLnkSet::find()
328*/ 328*/
329 329
330/*! 330/*!
331 \fn bool AppLnk::isValid() const 331 \fn bool AppLnk::isValid() const
332 332
333 Returns TRUE if this AppLnk is valid; otherwise returns FALSE. 333 Returns TRUE if this AppLnk is valid; otherwise returns FALSE.
334*/ 334*/
335 335
336/*! 336/*!
337 Creates an invalid AppLnk. 337 Creates an invalid AppLnk.
338 338
339 \sa isValid() 339 \sa isValid()
340*/ 340*/
341AppLnk::AppLnk() 341AppLnk::AppLnk()
342{ 342{
343 mId = 0; 343 mId = 0;
344 d = new AppLnkPrivate(); 344 d = new AppLnkPrivate();
345} 345}
346 346
347/*! 347/*!
348 Loads \a file (e.g. \e app.desktop) as an AppLnk. 348 Loads \a file (e.g. \e app.desktop) as an AppLnk.
349 349
350 \sa writeLink() 350 \sa writeLink()
351*/ 351*/
352AppLnk::AppLnk( const QString &file ) 352AppLnk::AppLnk( const QString &file )
353{ 353{
354 QStringList sl; 354 QStringList sl;
355 d = new AppLnkPrivate(); 355 d = new AppLnkPrivate();
356 if ( !file.isNull() ) { 356 if ( !file.isNull() ) {
357 Config config( file, Config::File ); 357 Config config( file, Config::File );
358 358
359 if ( config.isValid() ) { 359 if ( config.isValid() ) {
360 config.setGroup( "Desktop Entry" ); 360 config.setGroup( "Desktop Entry" );
361 361
362 mName = config.readEntry( "Name", file ); 362 mName = config.readEntry( "Name", file );
363 mExec = config.readEntry( "Exec" ); 363 mExec = config.readEntry( "Exec" );
364 mType = config.readEntry( "Type", QString::null ); 364 mType = config.readEntry( "Type", QString::null );
365 mIconFile = config.readEntry( "Icon", QString::null ); 365 mIconFile = config.readEntry( "Icon", QString::null );
366 mRotation = config.readEntry( "Rotation", "" ); 366 mRotation = config.readEntry( "Rotation", "" );
367 mComment = config.readEntry( "Comment", QString::null ); 367 mComment = config.readEntry( "Comment", QString::null );
368 // MIME types are case-insensitive. 368 // MIME types are case-insensitive.
369 mMimeTypes = config.readListEntry( "MimeType", ';' ); 369 mMimeTypes = config.readListEntry( "MimeType", ';' );
370 for (QStringList::Iterator it=mMimeTypes.begin(); it!=mMimeTypes.end(); ++it) 370 for (QStringList::Iterator it=mMimeTypes.begin(); it!=mMimeTypes.end(); ++it)
371 *it = (*it).lower(); 371 *it = (*it).lower();
372 mMimeTypeIcons = config.readListEntry( "MimeTypeIcons", ';' ); 372 mMimeTypeIcons = config.readListEntry( "MimeTypeIcons", ';' );
373 mLinkFile = file; 373 mLinkFile = file;
374 mFile = config.readEntry("File", QString::null); 374 mFile = config.readEntry("File", QString::null);
375 if ( mFile[0] != '/' ) { 375 if ( !mExec. isEmpty ( )) {
376 mFile = QString::null;
377 }
378 else if ( mFile[0] != '/' ) {
376 int slash = file.findRev('/'); 379 int slash = file.findRev('/');
377 if ( slash >= 0 ) { 380 if ( slash >= 0 ) {
378 mFile = file.left(slash) + '/' + mFile; 381 mFile = file.left(slash) + '/' + mFile;
379 } 382 }
380 } 383 }
381 d->mCatList = config.readListEntry("Categories", ';'); 384 d->mCatList = config.readListEntry("Categories", ';');
382 if ( d->mCatList[0].toInt() < -1 ) { 385 if ( d->mCatList[0].toInt() < -1 ) {
383 // numeric cats in file! convert to text 386 // numeric cats in file! convert to text
384 Categories cat( 0 ); 387 Categories cat( 0 );
385 cat.load( categoryFileName() ); 388 cat.load( categoryFileName() );
386 d->mCat.resize( d->mCatList.count() ); 389 d->mCat.resize( d->mCatList.count() );
387 int i; 390 int i;
388 QStringList::ConstIterator it; 391 QStringList::ConstIterator it;
389 for ( i = 0, it = d->mCatList.begin(); it != d->mCatList.end(); 392 for ( i = 0, it = d->mCatList.begin(); it != d->mCatList.end();
390 ++it, i++ ) { 393 ++it, i++ ) {
391 bool number; 394 bool number;
392 int id = (*it).toInt( &number ); 395 int id = (*it).toInt( &number );
393 if ( !number ) { 396 if ( !number ) {
394 // convert from text 397 // convert from text
395 id = cat.id( "Document View", *it ); 398 id = cat.id( "Document View", *it );
396 if ( id == 0 ) 399 if ( id == 0 )
397 id = cat.addCategory( "Document View", *it ); 400 id = cat.addCategory( "Document View", *it );
398 } 401 }
399 d->mCat[i] = id; 402 d->mCat[i] = id;
400 } 403 }
401 d->updateCatListFromArray(); 404 d->updateCatListFromArray();
402 } 405 }
403 } 406 }
404 } 407 }
405 mId = 0; 408 mId = 0;
406} 409}
407 410
408AppLnk& AppLnk::operator=(const AppLnk &copy) 411AppLnk& AppLnk::operator=(const AppLnk &copy)
409{ 412{
410 if ( mId ) 413 if ( mId )
411 qWarning("Deleting AppLnk that is in an AppLnkSet"); 414 qWarning("Deleting AppLnk that is in an AppLnkSet");
412 if ( d ) 415 if ( d )
413 delete d; 416 delete d;
414 417
415 418
416 mName = copy.mName; 419 mName = copy.mName;
417 420
418 /* remove for Qtopia 3.0 -zecke */ 421 /* remove for Qtopia 3.0 -zecke */
419 mPixmap = copy.mPixmap; 422 mPixmap = copy.mPixmap;
420 mBigPixmap = copy.mBigPixmap; 423 mBigPixmap = copy.mBigPixmap;
421 424
422 mExec = copy.mExec; 425 mExec = copy.mExec;
423 mType = copy.mType; 426 mType = copy.mType;
424 mRotation = copy.mRotation; 427 mRotation = copy.mRotation;
425 mComment = copy.mComment; 428 mComment = copy.mComment;
426 mFile = copy.mFile; 429 mFile = copy.mFile;
427 mLinkFile = copy.mLinkFile; 430 mLinkFile = copy.mLinkFile;
428 mIconFile = copy.mIconFile; 431 mIconFile = copy.mIconFile;
429 mMimeTypes = copy.mMimeTypes; 432 mMimeTypes = copy.mMimeTypes;
430 mMimeTypeIcons = copy.mMimeTypeIcons; 433 mMimeTypeIcons = copy.mMimeTypeIcons;
431 mId = 0; 434 mId = 0;
432 d = new AppLnkPrivate(); 435 d = new AppLnkPrivate();
433 d->mCat = copy.d->mCat; 436 d->mCat = copy.d->mCat;
434 d->mCatList = copy.d->mCatList; 437 d->mCatList = copy.d->mCatList;
435 d->mPixmaps = copy.d->mPixmaps; 438 d->mPixmaps = copy.d->mPixmaps;
436 439
437 return *this; 440 return *this;
438} 441}
439/*! 442/*!
440 protected internally to share code 443 protected internally to share code
441 should I document that at all? 444 should I document that at all?
442 I don't know the TT style for that 445 I don't know the TT style for that
443*/ 446*/
444const QPixmap& AppLnk::pixmap( int pos, int size ) const { 447const QPixmap& AppLnk::pixmap( int pos, int size ) const {
445 if ( d->mPixmaps[pos].isNull() ) { 448 if ( d->mPixmaps[pos].isNull() ) {
446 AppLnk* that = (AppLnk*)this; 449 AppLnk* that = (AppLnk*)this;
447 if ( mIconFile.isEmpty() ) { 450 if ( mIconFile.isEmpty() ) {
448 MimeType mt(type()); 451 MimeType mt(type());
449 that->d->mPixmaps[pos] = mt.pixmap(); 452 that->d->mPixmaps[pos] = mt.pixmap();
450 if ( that->d->mPixmaps[pos].isNull() ) 453 if ( that->d->mPixmaps[pos].isNull() )
451 that->d->mPixmaps[pos].convertFromImage( 454 that->d->mPixmaps[pos].convertFromImage(
452 Resource::loadImage("UnknownDocument") 455 Resource::loadImage("UnknownDocument")
453 .smoothScale( size, size ) ); 456 .smoothScale( size, size ) );
454 return that->d->mPixmaps[pos]; 457 return that->d->mPixmaps[pos];
455 } 458 }
456 QImage unscaledIcon = Resource::loadImage( that->mIconFile ); 459 QImage unscaledIcon = Resource::loadImage( that->mIconFile );
457 if ( unscaledIcon.isNull() ) { 460 if ( unscaledIcon.isNull() ) {
458 qDebug( "Cannot find icon: %s", that->mIconFile.latin1() ); 461 qDebug( "Cannot find icon: %s", that->mIconFile.latin1() );
459 that->d->mPixmaps[pos].convertFromImage( 462 that->d->mPixmaps[pos].convertFromImage(
460 Resource::loadImage("UnknownDocument") 463 Resource::loadImage("UnknownDocument")
461 .smoothScale( size, size ) ); 464 .smoothScale( size, size ) );
462 } else { 465 } else {
463 that->d->mPixmaps[0].convertFromImage( unscaledIcon.smoothScale( smallSize, smallSize ) ); 466 that->d->mPixmaps[0].convertFromImage( unscaledIcon.smoothScale( smallSize, smallSize ) );
464 that->d->mPixmaps[1].convertFromImage( unscaledIcon.smoothScale( bigSize, bigSize ) ); 467 that->d->mPixmaps[1].convertFromImage( unscaledIcon.smoothScale( bigSize, bigSize ) );
465 } 468 }
466 return that->d->mPixmaps[pos]; 469 return that->d->mPixmaps[pos];
467 } 470 }
468 return d->mPixmaps[pos]; 471 return d->mPixmaps[pos];
469} 472}
470 473
471/*! 474/*!
472 Returns a small pixmap associated with the application. 475 Returns a small pixmap associated with the application.
473 476
474 \sa bigPixmap() setIcon() 477 \sa bigPixmap() setIcon()
475*/ 478*/
476const QPixmap& AppLnk::pixmap() const 479const QPixmap& AppLnk::pixmap() const
477{ 480{
478 if ( d->mPixmaps[0].isNull() ) { 481 if ( d->mPixmaps[0].isNull() ) {
479 return pixmap(AppLnkPrivate::Normal, smallSize ); 482 return pixmap(AppLnkPrivate::Normal, smallSize );
480 } 483 }
481 return d->mPixmaps[0]; 484 return d->mPixmaps[0];
482} 485}
483 486
484/*! 487/*!
485 Returns a large pixmap associated with the application. 488 Returns a large pixmap associated with the application.
486 489
487 \sa pixmap() setIcon() 490 \sa pixmap() setIcon()
488*/ 491*/
489const QPixmap& AppLnk::bigPixmap() const 492const QPixmap& AppLnk::bigPixmap() const
490{ 493{
491 if ( d->mPixmaps[1].isNull() ) { 494 if ( d->mPixmaps[1].isNull() ) {
492 return pixmap( AppLnkPrivate::Big, bigSize ); 495 return pixmap( AppLnkPrivate::Big, bigSize );
493 } 496 }
494 return d->mPixmaps[1]; 497 return d->mPixmaps[1];
495} 498}
496 499
497/*! 500/*!
498 Returns the type of the AppLnk. For applications, games and 501 Returns the type of the AppLnk. For applications, games and
499 settings the type is \c Application; for documents the type is the 502 settings the type is \c Application; for documents the type is the
500 document's MIME type. 503 document's MIME type.
501*/ 504*/
502QString AppLnk::type() const 505QString AppLnk::type() const
503{ 506{
504 if ( mType.isNull() ) { 507 if ( mType.isNull() ) {
505 AppLnk* that = (AppLnk*)this; 508 AppLnk* that = (AppLnk*)this;
506 QString f = file(); 509 QString f = file();
507 if ( !f.isNull() ) { 510 if ( !f.isNull() ) {
508 MimeType mt(f); 511 MimeType mt(f);
509 that->mType = mt.id(); 512 that->mType = mt.id();
510 return that->mType; 513 return that->mType;
511 } 514 }
512 } 515 }
513 return mType; 516 return mType;
514} 517}
515 518
516/*! 519/*!
517 Returns the file associated with the AppLnk. 520 Returns the file associated with the AppLnk.
518 521
519 \sa exec() name() 522 \sa exec() name()
520*/ 523*/
521QString AppLnk::file() const 524QString AppLnk::file() const
522{ 525{
523 if ( mFile.isNull() ) { 526 if ( mExec.isEmpty ( ) && mFile.isNull() ) {
524 AppLnk* that = (AppLnk*)this; 527 AppLnk* that = (AppLnk*)this;
525 QString ext = MimeType(mType).extension(); 528 QString ext = MimeType(mType).extension();
526 if ( !ext.isEmpty() ) 529 if ( !ext.isEmpty() )
527 ext = "." + ext; 530 ext = "." + ext;
528 if ( !mLinkFile.isEmpty() ) { 531 if ( !mLinkFile.isEmpty() ) {
529 that->mFile = 532 that->mFile =
530 mLinkFile.right(8)==".desktop" // 8 = strlen(".desktop") 533 mLinkFile.right(8)==".desktop" // 8 = strlen(".desktop")
531 ? mLinkFile.left(mLinkFile.length()-8) : mLinkFile; 534 ? mLinkFile.left(mLinkFile.length()-8) : mLinkFile;
535 qDebug("mFile now == %s", mFile.latin1());
532 } else if ( mType.contains('/') ) { 536 } else if ( mType.contains('/') ) {
533 that->mFile = 537 that->mFile =
534 QString(getenv("HOME"))+"/Documents/"+mType+"/"+safeFileName(that->mName); 538 QString(getenv("HOME"))+"/Documents/"+mType+"/"+safeFileName(that->mName);
535 /* 539 /*
536 * A file with the same name or a .desktop file already exists 540 * A file with the same name or a .desktop file already exists
537 */ 541 */
538 if ( QFile::exists(that->mFile+ext) || QFile::exists(that->mFile+".desktop") ) { 542 if ( QFile::exists(that->mFile+ext) || QFile::exists(that->mFile+".desktop") ) {
539 int n=1; 543 int n=1;
540 QString nn; 544 QString nn;
541 while (QFile::exists((nn=(that->mFile+"_"+QString::number(n)))+ext) 545 while (QFile::exists((nn=(that->mFile+"_"+QString::number(n)))+ext)
542 || QFile::exists(nn+".desktop")) 546 || QFile::exists(nn+".desktop"))
543 n++; 547 n++;
544 that->mFile = nn; 548 that->mFile = nn;
545 } 549 }
546 that->mLinkFile = that->mFile+".desktop"; 550 that->mLinkFile = that->mFile+".desktop";
547 that->mFile += ext; 551 that->mFile += ext;
548 } 552 }
549 prepareDirectories(that->mFile); 553 prepareDirectories(that->mFile);
550 if ( !that->mFile.isEmpty() ) { 554 if ( !that->mFile.isEmpty() ) {
551 QFile f(that->mFile); 555 QFile f(that->mFile);
552 if ( !f.open(IO_WriteOnly) ) 556 if ( !f.open(IO_WriteOnly) )
553 that->mFile = QString::null; 557 that->mFile = QString::null;
554 return that->mFile; 558 return that->mFile;
555 } 559 }
556 } 560 }
557 return mFile; 561 return mFile;
558} 562}
559 563
560/*! 564/*!
561 Returns the desktop file corresponding to this AppLnk. 565 Returns the desktop file corresponding to this AppLnk.
562 566
563 \sa file() exec() name() 567 \sa file() exec() name()
564*/ 568*/
565QString AppLnk::linkFile() const 569QString AppLnk::linkFile() const
566{ 570{
567 if ( mLinkFile.isNull() ) { 571 if ( mLinkFile.isNull() ) {
568 AppLnk* that = (AppLnk*)this; 572 AppLnk* that = (AppLnk*)this;
569 if ( type().contains('/') ) { 573 if ( type().contains('/') ) {
570 StorageInfo storage; 574 StorageInfo storage;
571 const FileSystem *fs = storage.fileSystemOf( that->mFile ); 575 const FileSystem *fs = storage.fileSystemOf( that->mFile );
572 /* tmpfs + and ramfs are available too but not removable 576 /* tmpfs + and ramfs are available too but not removable
573 * either we fix storage or add this 577 * either we fix storage or add this
574 */ 578 */
575 if ( fs && ( fs->isRemovable() || fs->disk() == "/dev/mtdblock6" || fs->disk() == "tmpfs") ) { 579 if ( fs && ( fs->isRemovable() || fs->disk() == "/dev/mtdblock6" || fs->disk() == "tmpfs") ) {
576 that->mLinkFile = fs->path(); 580 that->mLinkFile = fs->path();
577 } else 581 } else
578 that->mLinkFile = getenv( "HOME" ); 582 that->mLinkFile = getenv( "HOME" );
579 that->mLinkFile += "/Documents/"+type()+"/"+safeFileName(that->mName); 583 that->mLinkFile += "/Documents/"+type()+"/"+safeFileName(that->mName);
580 584
581 /* the desktop file exists make sure we don't point to the same file */ 585 /* the desktop file exists make sure we don't point to the same file */
582 if ( QFile::exists(that->mLinkFile+".desktop") ) { 586 if ( QFile::exists(that->mLinkFile+".desktop") ) {
583 AppLnk lnk( that->mLinkFile + ".desktop" ); 587 AppLnk lnk( that->mLinkFile + ".desktop" );
584 588
585 /* the linked is different */ 589 /* the linked is different */
586 if(that->file() != lnk.file() ) { 590 if(that->file() != lnk.file() ) {
587 int n = 1; 591 int n = 1;
588 QString nn; 592 QString nn;
589 while (QFile::exists((nn=that->mLinkFile+"_"+QString::number(n))+".desktop")) { 593 while (QFile::exists((nn=that->mLinkFile+"_"+QString::number(n))+".desktop")) {
590 n++; 594 n++;
591 /* just to be sure */ 595 /* just to be sure */
592 AppLnk lnk(nn ); 596 AppLnk lnk(nn );
593 if (lnk.file() == that->file() ) 597 if (lnk.file() == that->file() )
594 break; 598 break;
595 } 599 }
596 that->mLinkFile = nn; 600 that->mLinkFile = nn;
597 } 601 }
598 } 602 }
599 that->mLinkFile += ".desktop"; 603 that->mLinkFile += ".desktop";
600 storeLink(); 604 storeLink();
601 } 605 }
602 return that->mLinkFile; 606 return that->mLinkFile;
603 } 607 }
604 return mLinkFile; 608 return mLinkFile;
605} 609}
606 610
607/*! 611/*!
608 Copies \a copy. 612 Copies \a copy.
609*/ 613*/
610AppLnk::AppLnk( const AppLnk &copy ) 614AppLnk::AppLnk( const AppLnk &copy )
611{ 615{
612 mName = copy.mName; 616 mName = copy.mName;
613 mPixmap = copy.mPixmap; 617 mPixmap = copy.mPixmap;
614 mBigPixmap = copy.mBigPixmap; 618 mBigPixmap = copy.mBigPixmap;
615 mExec = copy.mExec; 619 mExec = copy.mExec;
616 mType = copy.mType; 620 mType = copy.mType;
617 mRotation = copy.mRotation; 621 mRotation = copy.mRotation;
618 mComment = copy.mComment; 622 mComment = copy.mComment;
619 mFile = copy.mFile; 623 mFile = copy.mFile;
620 mLinkFile = copy.mLinkFile; 624 mLinkFile = copy.mLinkFile;
621 mIconFile = copy.mIconFile; 625 mIconFile = copy.mIconFile;
622 mMimeTypes = copy.mMimeTypes; 626 mMimeTypes = copy.mMimeTypes;
623 mMimeTypeIcons = copy.mMimeTypeIcons; 627 mMimeTypeIcons = copy.mMimeTypeIcons;
624 mId = 0; 628 mId = 0;
625 d = new AppLnkPrivate(); 629 d = new AppLnkPrivate();
626 d->mCat = copy.d->mCat; 630 d->mCat = copy.d->mCat;
627 d->mCatList = copy.d->mCatList; 631 d->mCatList = copy.d->mCatList;
628 d->mPixmaps = copy.d->mPixmaps; 632 d->mPixmaps = copy.d->mPixmaps;
629} 633}
630 634
631/*! 635/*!
632 Destroys the AppLnk. Note that if the AppLnk is currently a member 636 Destroys the AppLnk. Note that if the AppLnk is currently a member
633 of an AppLnkSet, this will produce a run-time warning. 637 of an AppLnkSet, this will produce a run-time warning.
634 638
635 \sa AppLnkSet::add() AppLnkSet::remove() 639 \sa AppLnkSet::add() AppLnkSet::remove()
636*/ 640*/
637AppLnk::~AppLnk() 641AppLnk::~AppLnk()
638{ 642{
639 if ( mId ) 643 if ( mId )
640 qWarning("Deleting AppLnk that is in an AppLnkSet"); 644 qWarning("Deleting AppLnk that is in an AppLnkSet");
641 if ( d ) 645 if ( d )
642 delete d; 646 delete d;
643} 647}
644 648
645/*! 649/*!
646 \overload 650 \overload
647 Executes the application associated with this AppLnk. 651 Executes the application associated with this AppLnk.
648 652
649 \sa exec() 653 \sa exec()
650*/ 654*/
651void AppLnk::execute() const 655void AppLnk::execute() const
652{ 656{
653 execute(QStringList()); 657 execute(QStringList());
654} 658}
655 659
656/*! 660/*!
657 Executes the application associated with this AppLnk, with 661 Executes the application associated with this AppLnk, with
658 \a args as arguments. 662 \a args as arguments.
659 663
660 \sa exec() 664 \sa exec()
661*/ 665*/
662void AppLnk::execute(const QStringList& args) const 666void AppLnk::execute(const QStringList& args) const
663{ 667{
664#ifdef Q_WS_QWS 668#ifdef Q_WS_QWS
665 if ( !mRotation.isEmpty() ) { 669 if ( !mRotation.isEmpty() ) {
666 // ######## this will only work in the server 670 // ######## this will only work in the server
667 int rot = QPEApplication::defaultRotation(); 671 int rot = QPEApplication::defaultRotation();
668 rot = (rot+mRotation.toInt())%360; 672 rot = (rot+mRotation.toInt())%360;
669 QCString old = getenv("QWS_DISPLAY"); 673 QCString old = getenv("QWS_DISPLAY");
670 setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(rot), 1); 674 setenv("QWS_DISPLAY", QString("Transformed:Rot%1:0").arg(rot), 1);
671 invoke(args); 675 invoke(args);
672 setenv("QWS_DISPLAY", old.data(), 1); 676 setenv("QWS_DISPLAY", old.data(), 1);
673 } else 677 } else
674#endif 678#endif
675 invoke(args); 679 invoke(args);
676} 680}
677 681
678/*! 682/*!
679 Invokes the application associated with this AppLnk, with 683 Invokes the application associated with this AppLnk, with
680 \a args as arguments. Rotation is not taken into account by 684 \a args as arguments. Rotation is not taken into account by
681 this function, so you should not call it directly. 685 this function, so you should not call it directly.
682 686
683 \sa execute() 687 \sa execute()
684*/ 688*/
685void AppLnk::invoke(const QStringList& args) const 689void AppLnk::invoke(const QStringList& args) const
686{ 690{
687 Global::execute( exec(), args[0] ); 691 Global::execute( exec(), args[0] );
688} 692}
689 693
690/*! 694/*!
691 Sets the Exec property to \a exec. 695 Sets the Exec property to \a exec.
692 696
693 \sa exec() name() 697 \sa exec() name()
694*/ 698*/
695void AppLnk::setExec( const QString& exec ) 699void AppLnk::setExec( const QString& exec )
696{ 700{
697 mExec = exec; 701 mExec = exec;
698} 702}
699 703
704#if 0 // this was inlined for better BC
705/*!
706 Sets the Rotation property to \a rot.
707
708 \sa rotation()
709*/
710void AppLnk::setRotation ( const QString &rot )
711{
712 mRotation = rot;
713}
714#endif
715
700/*! 716/*!
701 Sets the Name property to \a docname. 717 Sets the Name property to \a docname.
702 718
703 \sa name() 719 \sa name()
704*/ 720*/
705void AppLnk::setName( const QString& docname ) 721void AppLnk::setName( const QString& docname )
706{ 722{
707 mName = docname; 723 mName = docname;
708} 724}
709 725
710/*! 726/*!
711 Sets the File property to \a filename. 727 Sets the File property to \a filename.
712 728
713 \sa file() name() 729 \sa file() name()
714*/ 730*/
715void AppLnk::setFile( const QString& filename ) 731void AppLnk::setFile( const QString& filename )
716{ 732{
717 mFile = filename; 733 mFile = filename;
718} 734}
719 735
720/*! 736/*!
721 Sets the LinkFile property to \a filename. 737 Sets the LinkFile property to \a filename.
722 738
723 \sa linkFile() 739 \sa linkFile()
724*/ 740*/
725void AppLnk::setLinkFile( const QString& filename ) 741void AppLnk::setLinkFile( const QString& filename )
726{ 742{
727 mLinkFile = filename; 743 mLinkFile = filename;
728} 744}
729 745
730/*! 746/*!
731 Sets the Comment property to \a comment. 747 Sets the Comment property to \a comment.
732 748
733 This text is displayed in the 'Details Dialog', for example if the 749 This text is displayed in the 'Details Dialog', for example if the
734 user uses the 'press-and-hold' gesture. 750 user uses the 'press-and-hold' gesture.
735 751
736 \sa comment() 752 \sa comment()
737*/ 753*/
738void AppLnk::setComment( const QString& comment ) 754void AppLnk::setComment( const QString& comment )
739{ 755{
740 mComment = comment; 756 mComment = comment;
741} 757}
742 758
743/*! 759/*!
744 Sets the Type property to \a type. 760 Sets the Type property to \a type.
745 761
746 For applications, games and settings the type should be \c 762 For applications, games and settings the type should be \c
747 Application; for documents the type should be the document's MIME 763 Application; for documents the type should be the document's MIME
748 type. 764 type.
749 765
750 \sa type() 766 \sa type()
751*/ 767*/
752void AppLnk::setType( const QString& type ) 768void AppLnk::setType( const QString& type )
753{ 769{
754 mType = type; 770 mType = type;
755} 771}
756 772
757/*! 773/*!
758 \fn QString AppLnk::icon() const 774 \fn QString AppLnk::icon() const
759 775
760 Returns the Icon property. 776 Returns the Icon property.
761 777
762 \sa setIcon() 778 \sa setIcon()
763*/ 779*/
764 780
765/*! 781/*!
766 Sets the Icon property to \a iconname. This is the filename from 782 Sets the Icon property to \a iconname. This is the filename from
767 which the pixmap() and bigPixmap() are obtained. 783 which the pixmap() and bigPixmap() are obtained.
768 784
769 \sa icon() setSmallIconSize() setBigIconSize() 785 \sa icon() setSmallIconSize() setBigIconSize()
770*/ 786*/
771void AppLnk::setIcon( const QString& iconname ) 787void AppLnk::setIcon( const QString& iconname )
772{ 788{
773 mIconFile = iconname; 789 mIconFile = iconname;
774 QImage unscaledIcon = Resource::loadImage( mIconFile ); 790 QImage unscaledIcon = Resource::loadImage( mIconFile );
775 d->mPixmaps[0].convertFromImage( unscaledIcon.smoothScale( smallSize, smallSize ) ); 791 d->mPixmaps[0].convertFromImage( unscaledIcon.smoothScale( smallSize, smallSize ) );
776 d->mPixmaps[1].convertFromImage( unscaledIcon.smoothScale( bigSize, bigSize ) ); 792 d->mPixmaps[1].convertFromImage( unscaledIcon.smoothScale( bigSize, bigSize ) );
777} 793}
778 794
779/*! 795/*!
780 Sets the Categories property to \a c. 796 Sets the Categories property to \a c.
781 797
782 See the CategoryWidget for more details. 798 See the CategoryWidget for more details.
783 799
784 \sa categories() 800 \sa categories()
785*/ 801*/
786void AppLnk::setCategories( const QArray<int>& c ) 802void AppLnk::setCategories( const QArray<int>& c )
787{ 803{
788 d->mCat = c; 804 d->mCat = c;
789 d->updateCatListFromArray(); 805 d->updateCatListFromArray();
790} 806}
791 807
792/*! 808/*!
793 \fn QStringList AppLnk::mimeTypeIcons() const 809 \fn QStringList AppLnk::mimeTypeIcons() const
794 810
795 Returns the MimeTypeIcons property of the AppLnk. 811 Returns the MimeTypeIcons property of the AppLnk.
796*/ 812*/
797 813
798/*! 814/*!
799 Attempts to ensure that the link file for this AppLnk exists, 815 Attempts to ensure that the link file for this AppLnk exists,
800 including creating any required directories. Returns TRUE if 816 including creating any required directories. Returns TRUE if
801 successful; otherwise returns FALSE. 817 successful; otherwise returns FALSE.
802 818
803 You should not need to use this function. 819 You should not need to use this function.
804*/ 820*/
805bool AppLnk::ensureLinkExists() const 821bool AppLnk::ensureLinkExists() const
806{ 822{
807 QString lf = linkFile(); 823 QString lf = linkFile();
808 return prepareDirectories(lf); 824 return prepareDirectories(lf);
809} 825}
810 826
811/*! 827/*!
812 Commits the AppLnk to disk. Returns TRUE if the operation succeeded; 828 Commits the AppLnk to disk. Returns TRUE if the operation succeeded;
813 otherwise returns FALSE. 829 otherwise returns FALSE.
814 830
815 In addition, the "linkChanged(QString)" message is sent to the 831 In addition, the "linkChanged(QString)" message is sent to the
816 "QPE/System" \link qcop.html QCop\endlink channel. 832 "QPE/System" \link qcop.html QCop\endlink channel.
817*/ 833*/
818bool AppLnk::writeLink() const 834bool AppLnk::writeLink() const
819{ 835{
820 // Only re-writes settable parts 836 // Only re-writes settable parts
821 QString lf = linkFile(); 837 QString lf = linkFile();
822 if ( !ensureLinkExists() ) 838 if ( !ensureLinkExists() )
823 return FALSE; 839 return FALSE;
824 storeLink(); 840 storeLink();
825 return TRUE; 841 return TRUE;
826} 842}
827 843
828/*! 844/*!
829 \internal 845 \internal
830*/ 846*/
831void AppLnk::storeLink() const 847void AppLnk::storeLink() const
832{ 848{
833 Config config( mLinkFile, Config::File ); 849 Config config( mLinkFile, Config::File );
834 config.setGroup("Desktop Entry"); 850 config.setGroup("Desktop Entry");
835 config.writeEntry("Name",mName); 851 config.writeEntry("Name",mName);
836 if ( !mIconFile.isNull() ) config.writeEntry("Icon",mIconFile); 852 if ( !mIconFile.isNull() ) config.writeEntry("Icon",mIconFile);
837 config.writeEntry("Type",type()); 853 config.writeEntry("Type",type());
854 if(!rotation().isEmpty())
855 config.writeEntry("Rotation",rotation());
856 else
857 config.removeEntry("Rotation");
838 if ( !mComment.isNull() ) config.writeEntry("Comment",mComment); 858 if ( !mComment.isNull() ) config.writeEntry("Comment",mComment);
839 QString f = file(); 859 QString f = file();
840 int i = 0; 860 int i = 0;
841 while ( i < (int)f.length() && i < (int)mLinkFile.length() && f[i] == mLinkFile[i] ) 861 while ( i < (int)f.length() && i < (int)mLinkFile.length() && f[i] == mLinkFile[i] )
842 i++; 862 i++;
843 while ( i && f[i] != '/' ) 863 while ( i && f[i] != '/' )
844 i--; 864 i--;
845 // simple case where in the same directory 865 // simple case where in the same directory
846 if ( mLinkFile.find( '/', i + 1 ) < 0 ) 866 if ( mLinkFile.find( '/', i + 1 ) < 0 )
847 f = f.mid(i+1); 867 f = f.mid(i+1);
848 // ### could do relative ie ../../otherDocs/file.doc 868 // ### could do relative ie ../../otherDocs/file.doc
849 config.writeEntry("File",f); 869 config.writeEntry("File",f);
850 config.writeEntry( "Categories", d->mCatList, ';' ); 870 config.writeEntry( "Categories", d->mCatList, ';' );
851 871
852#ifndef QT_NO_COP 872#ifndef QT_NO_COP
853 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 873 QCopEnvelope e("QPE/System", "linkChanged(QString)");
854 e << mLinkFile; 874 e << mLinkFile;
855#endif 875#endif
856} 876}
857 877
858/*! 878/*!
859 Sets the property named \a key to \a value. 879 Sets the property named \a key to \a value.
860 880
861 \sa property() 881 \sa property()
862*/ 882*/
863void AppLnk::setProperty(const QString& key, const QString& value) 883void AppLnk::setProperty(const QString& key, const QString& value)
864{ 884{
865 if ( ensureLinkExists() ) { 885 if ( ensureLinkExists() ) {
866 Config cfg(linkFile(), Config::File); 886 Config cfg(linkFile(), Config::File);
867 cfg.writeEntry(key,value); 887 cfg.writeEntry(key,value);
868 } 888 }
869} 889}
870 890
871/*! 891/*!
872 Returns the property named \a key. 892 Returns the property named \a key.
873 893
874 \sa setProperty() 894 \sa setProperty()
875*/ 895*/
876QString AppLnk::property(const QString& key) const 896QString AppLnk::property(const QString& key) const
877{ 897{
878 QString lf = linkFile(); 898 QString lf = linkFile();
879 if ( !QFile::exists(lf) ) 899 if ( !QFile::exists(lf) )
880 return QString::null; 900 return QString::null;
881 Config cfg(lf, Config::File); 901 Config cfg(lf, Config::File);
882 return cfg.readEntry(key); 902 return cfg.readEntry(key);
883} 903}
884 904
885bool AppLnk::isPreloaded() const { 905bool AppLnk::isPreloaded() const {
886 // Preload information is stored in the Launcher config in v1.5. 906 // Preload information is stored in the Launcher config in v1.5.
887 Config cfg("Launcher"); 907 Config cfg("Launcher");
888 cfg.setGroup("Preload"); 908 cfg.setGroup("Preload");
889 QStringList apps = cfg.readListEntry("Apps",','); 909 QStringList apps = cfg.readListEntry("Apps",',');
890 if (apps.contains(exec())) 910 if (apps.contains(exec()))
891 return true; 911 return true;
892 return false; 912 return false;
893} 913}
894 914
895void AppLnk::setPreloaded(bool yesNo) { 915void AppLnk::setPreloaded(bool yesNo) {
896 // Preload information is stored in the Launcher config in v1.5. 916 // Preload information is stored in the Launcher config in v1.5.
897 Config cfg("Launcher"); 917 Config cfg("Launcher");
898 cfg.setGroup("Preload"); 918 cfg.setGroup("Preload");
899 QStringList apps = cfg.readListEntry("Apps", ','); 919 QStringList apps = cfg.readListEntry("Apps", ',');
900 if (apps.contains(exec()) && !yesNo) 920 if (apps.contains(exec()) && !yesNo)
901 apps.remove(exec()); 921 apps.remove(exec());
902 else if (yesNo && !apps.contains(exec())) 922 else if (yesNo && !apps.contains(exec()))
903 apps.append(exec()); 923 apps.append(exec());
904 cfg.writeEntry("Apps", apps, ','); 924 cfg.writeEntry("Apps", apps, ',');
905} 925}
906 926
907 927
908/*! 928/*!
909 Deletes both the linkFile() and the file() associated with this AppLnk. 929 Deletes both the linkFile() and the file() associated with this AppLnk.
910 930
911 \sa removeLinkFile() 931 \sa removeLinkFile()
912*/ 932*/
913void AppLnk::removeFiles() 933void AppLnk::removeFiles()
914{ 934{
915 bool valid = isValid(); 935 bool valid = isValid();
916 if ( !valid || !linkFileKnown() || QFile::remove(linkFile()) ) { 936 if ( !valid || !linkFileKnown() || QFile::remove(linkFile()) ) {
917 if ( QFile::remove(file()) ) { 937 if ( QFile::remove(file()) ) {
918#ifndef QT_NO_COP 938#ifndef QT_NO_COP
919 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 939 QCopEnvelope e("QPE/System", "linkChanged(QString)");
920 if ( linkFileKnown() ) 940 if ( linkFileKnown() )
921 e << linkFile(); 941 e << linkFile();
922 else 942 else
923 e << file(); 943 e << file();
924#endif 944#endif
925 } else if ( valid ) { 945 } else if ( valid ) {
926 // restore link 946 // restore link
927 writeLink(); 947 writeLink();
928 } 948 }
929 } 949 }
930} 950}
931 951
932/*! 952/*!
933 Deletes the linkFile(), leaving any file() untouched. 953 Deletes the linkFile(), leaving any file() untouched.
934 954
935 \sa removeFiles() 955 \sa removeFiles()
936*/ 956*/
937void AppLnk::removeLinkFile() 957void AppLnk::removeLinkFile()
938{ 958{
939 if ( isValid() && linkFileKnown() && QFile::remove(linkFile()) ) { 959 if ( isValid() && linkFileKnown() && QFile::remove(linkFile()) ) {
940#ifndef QT_NO_COP 960#ifndef QT_NO_COP
941 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 961 QCopEnvelope e("QPE/System", "linkChanged(QString)");
942 e << linkFile(); 962 e << linkFile();
943#endif 963#endif
944 } 964 }
945} 965}
946 966
947class AppLnkSetPrivate { 967class AppLnkSetPrivate {
948public: 968public:
949 AppLnkSetPrivate() 969 AppLnkSetPrivate()
950 { 970 {
951 typPix.setAutoDelete(TRUE); 971 typPix.setAutoDelete(TRUE);
952 typPixBig.setAutoDelete(TRUE); 972 typPixBig.setAutoDelete(TRUE);
953 typName.setAutoDelete(TRUE); 973 typName.setAutoDelete(TRUE);
954 } 974 }
955 975
956 QDict<QPixmap> typPix; 976 QDict<QPixmap> typPix;
957 QDict<QPixmap> typPixBig; 977 QDict<QPixmap> typPixBig;
958 QDict<QString> typName; 978 QDict<QString> typName;
959}; 979};
960 980
961/*! 981/*!
962 \class AppLnkSet applnk.h 982 \class AppLnkSet applnk.h
963 \brief The AppLnkSet class is a set of AppLnk objects. 983 \brief The AppLnkSet class is a set of AppLnk objects.
964*/ 984*/
965 985
966/*! 986/*!
967 \fn QStringList AppLnkSet::types() const 987 \fn QStringList AppLnkSet::types() const
968 988
969 Returns the list of \link applnk.html#Types types\endlink in the set. 989 Returns the list of \link applnk.html#Types types\endlink in the set.
970 990
971 For applications, games and settings the type is \c Application; 991 For applications, games and settings the type is \c Application;
972 for documents the type is the document's MIME type. 992 for documents the type is the document's MIME type.
973 993
974 \sa AppLnk::type(), typeName(), typePixmap(), typeBigPixmap() 994 \sa AppLnk::type(), typeName(), typePixmap(), typeBigPixmap()
975*/ 995*/
976 996
977/*! 997/*!
978 \fn const QList<AppLnk>& AppLnkSet::children() const 998 \fn const QList<AppLnk>& AppLnkSet::children() const
979 999
980 Returns the members of the set. 1000 Returns the members of the set.
981*/ 1001*/
982 1002
983/*! 1003/*!
984 Constructs an empty AppLnkSet. 1004 Constructs an empty AppLnkSet.
985*/ 1005*/
986AppLnkSet::AppLnkSet() : 1006AppLnkSet::AppLnkSet() :
987 d(new AppLnkSetPrivate) 1007 d(new AppLnkSetPrivate)
988{ 1008{
989} 1009}
990 1010
991/*! 1011/*!
992 Constructs an AppLnkSet that contains AppLnk objects representing 1012 Constructs an AppLnkSet that contains AppLnk objects representing
993 all the files in the given \a directory (and any subdirectories 1013 all the files in the given \a directory (and any subdirectories
994 recursively). 1014 recursively).
995 1015
996 \omit 1016 \omit
997 The directories may contain ".directory" files which override 1017 The directories may contain ".directory" files which override
998 any AppLnk::type() values for AppLnk objects found in the directory. 1018 any AppLnk::type() values for AppLnk objects found in the directory.
999 This allows simple localization of application types. 1019 This allows simple localization of application types.
1000 \endomit 1020 \endomit
1001*/ 1021*/
1002AppLnkSet::AppLnkSet( const QString &directory ) : 1022AppLnkSet::AppLnkSet( const QString &directory ) :
1003 d(new AppLnkSetPrivate) 1023 d(new AppLnkSetPrivate)
1004{ 1024{
1005 QDir dir( directory ); 1025 QDir dir( directory );
1006 mFile = directory; 1026 mFile = directory;
1007 findChildren(directory,QString::null,QString::null); 1027 findChildren(directory,QString::null,QString::null);
1008} 1028}
1009 1029
1010/*! 1030/*!
1011 Detaches all AppLnk objects from the set. The set become empty and 1031 Detaches all AppLnk objects from the set. The set become empty and
1012 the caller becomes responsible for deleting the AppLnk objects. 1032 the caller becomes responsible for deleting the AppLnk objects.
1013*/ 1033*/
1014void AppLnkSet::detachChildren() 1034void AppLnkSet::detachChildren()
1015{ 1035{
1016 QListIterator<AppLnk> it( mApps ); 1036 QListIterator<AppLnk> it( mApps );
1017 for ( ; it.current(); ) { 1037 for ( ; it.current(); ) {
1018 AppLnk* a = *it; 1038 AppLnk* a = *it;
1019 ++it; 1039 ++it;
1020 a->mId = 0; 1040 a->mId = 0;
1021 } 1041 }
1022 mApps.clear(); 1042 mApps.clear();
1023} 1043}
1024 1044
1025/*! 1045/*!
1026 Destroys the set, deleting all the AppLnk objects it contains. 1046 Destroys the set, deleting all the AppLnk objects it contains.
1027 1047
1028 \sa detachChildren() 1048 \sa detachChildren()
1029*/ 1049*/
1030AppLnkSet::~AppLnkSet() 1050AppLnkSet::~AppLnkSet()
1031{ 1051{
1032 QListIterator<AppLnk> it( mApps ); 1052 QListIterator<AppLnk> it( mApps );
1033 for ( ; it.current(); ) { 1053 for ( ; it.current(); ) {
1034 AppLnk* a = *it; 1054 AppLnk* a = *it;
1035 ++it; 1055 ++it;
1036 a->mId = 0; 1056 a->mId = 0;
1037 delete a; 1057 delete a;
1038 } 1058 }
1039 delete d; 1059 delete d;
1040} 1060}
1041 1061
1042void AppLnkSet::findChildren(const QString &dr, const QString& typ, const QString& typName, int depth) 1062void AppLnkSet::findChildren(const QString &dr, const QString& typ, const QString& typName, int depth)
1043{ 1063{
1044 depth++; 1064 depth++;
1045 if ( depth > 10 ) 1065 if ( depth > 10 )
1046 return; 1066 return;
1047 1067
1048 QDir dir( dr ); 1068 QDir dir( dr );
1049 QString typNameLocal = typName; 1069 QString typNameLocal = typName;
1050 1070
1051 if ( dir.exists( ".directory" ) ) { 1071 if ( dir.exists( ".directory" ) ) {
1052 Config config( dr + "/.directory", Config::File ); 1072 Config config( dr + "/.directory", Config::File );
1053 config.setGroup( "Desktop Entry" ); 1073 config.setGroup( "Desktop Entry" );
1054 typNameLocal = config.readEntry( "Name", typNameLocal ); 1074 typNameLocal = config.readEntry( "Name", typNameLocal );
1055 if ( !typ.isEmpty() ) { 1075 if ( !typ.isEmpty() ) {
1056 QString iconFile = config.readEntry( "Icon", "AppsIcon" ); 1076 QString iconFile = config.readEntry( "Icon", "AppsIcon" );
1057 QImage unscaledIcon = Resource::loadImage( iconFile ); 1077 QImage unscaledIcon = Resource::loadImage( iconFile );
1058 QPixmap pm, bpm; 1078 QPixmap pm, bpm;
1059 pm.convertFromImage( unscaledIcon.smoothScale( smallSize, smallSize ) ); 1079 pm.convertFromImage( unscaledIcon.smoothScale( smallSize, smallSize ) );
1060 bpm.convertFromImage( unscaledIcon.smoothScale( bigSize, bigSize ) ); 1080 bpm.convertFromImage( unscaledIcon.smoothScale( bigSize, bigSize ) );
1061 d->typPix.insert(typ, new QPixmap(pm)); 1081 d->typPix.insert(typ, new QPixmap(pm));
1062 d->typPixBig.insert(typ, new QPixmap(bpm)); 1082 d->typPixBig.insert(typ, new QPixmap(bpm));
1063 d->typName.insert(typ, new QString(typNameLocal)); 1083 d->typName.insert(typ, new QString(typNameLocal));
1064 } 1084 }
1065 } 1085 }
1066 1086
1067 const QFileInfoList *list = dir.entryInfoList(); 1087 const QFileInfoList *list = dir.entryInfoList();
1068 if ( list ) { 1088 if ( list ) {
1069 QFileInfo* fi; 1089 QFileInfo* fi;
1070 bool cadded=FALSE; 1090 bool cadded=FALSE;
1071 for ( QFileInfoListIterator it(*list); (fi=*it); ++it ) { 1091 for ( QFileInfoListIterator it(*list); (fi=*it); ++it ) {
1072 QString bn = fi->fileName(); 1092 QString bn = fi->fileName();
1073 if ( bn[0] != '.' && bn != "CVS" ) { 1093 if ( bn[0] != '.' && bn != "CVS" ) {
1074 if ( fi->isDir() ) { 1094 if ( fi->isDir() ) {
1075 QString c = typ.isNull() ? bn : typ+"/"+bn; 1095 QString c = typ.isNull() ? bn : typ+"/"+bn;
1076 QString d = typNameLocal.isNull() ? bn : typNameLocal+"/"+bn; 1096 QString d = typNameLocal.isNull() ? bn : typNameLocal+"/"+bn;
1077 findChildren(fi->filePath(), c, d, depth ); 1097 findChildren(fi->filePath(), c, d, depth );
1078 } else { 1098 } else {
1079 if ( fi->extension(FALSE) == "desktop" ) { 1099 if ( fi->extension(FALSE) == "desktop" ) {
1080 AppLnk* app = new AppLnk( fi->filePath() ); 1100 AppLnk* app = new AppLnk( fi->filePath() );
1081#ifdef QT_NO_QWS_MULTIPROCESS 1101#ifdef QT_NO_QWS_MULTIPROCESS
1082 if ( !Global::isBuiltinCommand( app->exec() ) ) 1102 if ( !Global::isBuiltinCommand( app->exec() ) )
1083 delete app; 1103 delete app;
1084 else 1104 else
1085#endif 1105#endif
1086 { 1106 {
1087 if ( !typ.isEmpty() ) { 1107 if ( !typ.isEmpty() ) {
1088 if ( !cadded ) { 1108 if ( !cadded ) {
1089 typs.append(typ); 1109 typs.append(typ);
1090 cadded = TRUE; 1110 cadded = TRUE;
1091 } 1111 }
1092 app->setType(typ); 1112 app->setType(typ);
1093 } 1113 }
1094 add(app); 1114 add(app);
1095 } 1115 }
1096 } 1116 }
1097 } 1117 }
1098 } 1118 }
1099 } 1119 }
1100 } 1120 }
1101} 1121}
1102 1122
1103/*! 1123/*!
1104 Adds AppLnk \a f to the set. The set takes responsibility for 1124 Adds AppLnk \a f to the set. The set takes responsibility for
1105 deleting \a f. 1125 deleting \a f.
1106 1126
1107 \sa remove() 1127 \sa remove()
1108*/ 1128*/
1109void AppLnkSet::add( AppLnk *f ) 1129void AppLnkSet::add( AppLnk *f )
1110{ 1130{
1111 if ( f->mId == 0 ) { 1131 if ( f->mId == 0 ) {
1112 AppLnk::lastId++; 1132 AppLnk::lastId++;
1113 f->mId = AppLnk::lastId; 1133 f->mId = AppLnk::lastId;
1114 mApps.append( f ); 1134 mApps.append( f );
1115 } else { 1135 } else {
1116 qWarning("Attempt to add an AppLnk twice"); 1136 qWarning("Attempt to add an AppLnk twice");
1117 } 1137 }
1118} 1138}
1119 1139
1120/*! 1140/*!
1121 Removes AppLnk \a f to the set. The caller becomes responsible for 1141 Removes AppLnk \a f to the set. The caller becomes responsible for
1122 deleting \a f. Returns TRUE if \a f was in the set; otherwise 1142 deleting \a f. Returns TRUE if \a f was in the set; otherwise
1123 returns FALSE. 1143 returns FALSE.
1124 1144
1125 \sa add() 1145 \sa add()
1126*/ 1146*/
1127bool AppLnkSet::remove( AppLnk *f ) 1147bool AppLnkSet::remove( AppLnk *f )
1128{ 1148{
1129 if ( mApps.remove( f ) ) { 1149 if ( mApps.remove( f ) ) {
1130 f->mId = 0; 1150 f->mId = 0;
1131 return TRUE; 1151 return TRUE;
1132 } 1152 }
1133 return FALSE; 1153 return FALSE;
1134} 1154}
1135 1155
1136 1156
1137/*! 1157/*!
1138 Returns the localized name for type \a t. 1158 Returns the localized name for type \a t.
1139 1159
1140 For applications, games and settings the type is \c Application; 1160 For applications, games and settings the type is \c Application;
1141 for documents the type is the document's MIME type. 1161 for documents the type is the document's MIME type.
1142*/ 1162*/
1143QString AppLnkSet::typeName( const QString& t ) const 1163QString AppLnkSet::typeName( const QString& t ) const
1144{ 1164{
1145 QString *st = d->typName.find(t); 1165 QString *st = d->typName.find(t);
1146 return st ? *st : QString::null; 1166 return st ? *st : QString::null;
1147} 1167}
1148 1168
1149/*! 1169/*!
1150 Returns the small pixmap associated with type \a t. 1170 Returns the small pixmap associated with type \a t.
1151 1171
1152 For applications, games and settings the type is \c Application; 1172 For applications, games and settings the type is \c Application;
1153 for documents the type is the document's MIME type. 1173 for documents the type is the document's MIME type.
1154*/ 1174*/
1155QPixmap AppLnkSet::typePixmap( const QString& t ) const 1175QPixmap AppLnkSet::typePixmap( const QString& t ) const
1156{ 1176{
1157 QPixmap *pm = d->typPix.find(t); 1177 QPixmap *pm = d->typPix.find(t);
1158 return pm ? *pm : QPixmap(); 1178 return pm ? *pm : QPixmap();
1159} 1179}
1160 1180
1161/*! 1181/*!
1162 Returns the large pixmap associated with type \a t. 1182 Returns the large pixmap associated with type \a t.
1163 1183
1164 For applications, games and settings the type is \c Application; 1184 For applications, games and settings the type is \c Application;
1165 for documents the type is the document's MIME type. 1185 for documents the type is the document's MIME type.
1166*/ 1186*/
1167QPixmap AppLnkSet::typeBigPixmap( const QString& t ) const 1187QPixmap AppLnkSet::typeBigPixmap( const QString& t ) const
1168{ 1188{
1169 QPixmap *pm = d->typPixBig.find(t); 1189 QPixmap *pm = d->typPixBig.find(t);
1170 return pm ? *pm : QPixmap(); 1190 return pm ? *pm : QPixmap();
1171} 1191}
1172 1192
1173/*! 1193/*!
1174 Returns the AppLnk with the given \a id. 1194 Returns the AppLnk with the given \a id.
1175*/ 1195*/
1176const AppLnk *AppLnkSet::find( int id ) const 1196const AppLnk *AppLnkSet::find( int id ) const
1177{ 1197{
1178 QListIterator<AppLnk> it( children() ); 1198 QListIterator<AppLnk> it( children() );
1179 1199
1180 for ( ; it.current(); ++it ) { 1200 for ( ; it.current(); ++it ) {
1181 const AppLnk *app = it.current(); 1201 const AppLnk *app = it.current();
1182 if ( app->id() == id ) 1202 if ( app->id() == id )
1183 return app; 1203 return app;
1184 } 1204 }
1185 1205
1186 return 0; 1206 return 0;
1187} 1207}
1188 1208
1189/*! 1209/*!
1190 Returns the AppLnk with the given \a exec attribute. 1210 Returns the AppLnk with the given \a exec attribute.
1191*/ 1211*/
1192const AppLnk *AppLnkSet::findExec( const QString& exec ) const 1212const AppLnk *AppLnkSet::findExec( const QString& exec ) const
1193{ 1213{
1194 QListIterator<AppLnk> it( children() ); 1214 QListIterator<AppLnk> it( children() );
1195 1215
1196 for ( ; it.current(); ++it ) { 1216 for ( ; it.current(); ++it ) {
1197 const AppLnk *app = it.current(); 1217 const AppLnk *app = it.current();
1198 if ( app->exec() == exec ) 1218 if ( app->exec() == exec )
1199 return app; 1219 return app;
1200 } 1220 }
1201 1221
1202 return 0; 1222 return 0;
1203} 1223}
1204 1224
1205/*! 1225/*!
1206 \class DocLnkSet applnk.h 1226 \class DocLnkSet applnk.h
1207 \brief The DocLnkSet class is a set of DocLnk objects. 1227 \brief The DocLnkSet class is a set of DocLnk objects.
1208*/ 1228*/
1209 1229
1210/*! 1230/*!
1211 \fn const QList<DocLnk>& DocLnkSet::children() const 1231 \fn const QList<DocLnk>& DocLnkSet::children() const
1212 1232
1213 Returns the members of the set. 1233 Returns the members of the set.
1214*/ 1234*/
1215 1235
1216/*! 1236/*!
1217 Constructs an empty DocLnkSet. 1237 Constructs an empty DocLnkSet.
1218 1238
1219 \sa appendFrom() 1239 \sa appendFrom()
1220*/ 1240*/
1221DocLnkSet::DocLnkSet() 1241DocLnkSet::DocLnkSet()
1222{ 1242{
1223} 1243}
1224 1244
1225/*! 1245/*!
1226 Constructs a DocLnkSet that contains DocLnk objects representing all 1246 Constructs a DocLnkSet that contains DocLnk objects representing all
1227 the files in the \a directory (and any subdirectories, recursively). 1247 the files in the \a directory (and any subdirectories, recursively).
1228 1248
1229 If \a mimefilter is not null, 1249 If \a mimefilter is not null,
1230 only documents with a MIME type matching \a mimefilter are selected. 1250 only documents with a MIME type matching \a mimefilter are selected.
1231 The value may contain multiple wild-card patterns separated by ";", 1251 The value may contain multiple wild-card patterns separated by ";",
1232 such as \c{*o/mpeg;audio/x-wav}. 1252 such as \c{*o/mpeg;audio/x-wav}.
1233 1253
1234 See also \link applnk.html#files-and-links Files and Links\endlink. 1254 See also \link applnk.html#files-and-links Files and Links\endlink.
1235 1255
1236*/ 1256*/
1237DocLnkSet::DocLnkSet( const QString &directory, const QString& mimefilter ) : 1257DocLnkSet::DocLnkSet( const QString &directory, const QString& mimefilter ) :
1238 AppLnkSet() 1258 AppLnkSet()
1239{ 1259{
1240 QDir dir( directory ); 1260 QDir dir( directory );
1241 mFile = dir.dirName(); 1261 mFile = dir.dirName();
1242 QDict<void> reference; 1262 QDict<void> reference;
1243 1263
1244 QStringList subFilter = QStringList::split(";", mimefilter); 1264 QStringList subFilter = QStringList::split(";", mimefilter);
1245 QValueList<QRegExp> mimeFilters; 1265 QValueList<QRegExp> mimeFilters;
1246 for( QStringList::Iterator it = subFilter.begin(); it != subFilter.end(); ++ it ) 1266 for( QStringList::Iterator it = subFilter.begin(); it != subFilter.end(); ++ it )
1247 mimeFilters.append( QRegExp(*it, FALSE, TRUE) ); 1267 mimeFilters.append( QRegExp(*it, FALSE, TRUE) );
1248 1268
1249 findChildren(directory, mimeFilters, reference); 1269 findChildren(directory, mimeFilters, reference);
1250 1270
1251 const QList<DocLnk> &list = children(); 1271 const QList<DocLnk> &list = children();
1252 for ( QListIterator<DocLnk> it( list ); it.current(); ++it ) { 1272 for ( QListIterator<DocLnk> it( list ); it.current(); ++it ) {
1253 reference.remove( (*it)->file() ); 1273 reference.remove( (*it)->file() );
1254 } 1274 }
1255 1275
1256 for ( QDictIterator<void> dit(reference); dit.current(); ++dit ) { 1276 for ( QDictIterator<void> dit(reference); dit.current(); ++dit ) {
1257 if ( dit.current() == (void*)2 ) { 1277 if ( dit.current() == (void*)2 ) {
1258 // Unreferenced, make an unwritten link 1278 // Unreferenced, make an unwritten link
1259 DocLnk* dl = new DocLnk; 1279 DocLnk* dl = new DocLnk;
1260 QFileInfo fi( dit.currentKey() ); 1280 QFileInfo fi( dit.currentKey() );
1261 dl->setFile(fi.filePath()); 1281 dl->setFile(fi.filePath());
1262 dl->setName(fi.baseName()); 1282 dl->setName(fi.baseName());
1263 // #### default to current path? 1283 // #### default to current path?
1264 // dl->setCategories( ... ); 1284 // dl->setCategories( ... );
1265 bool match = mimefilter.isNull(); 1285 bool match = mimefilter.isNull();
1266 if ( !match ) 1286 if ( !match )
1267 for( QValueList<QRegExp>::Iterator it = mimeFilters.begin(); it != mimeFilters.end() && !match; ++ it ) 1287 for( QValueList<QRegExp>::Iterator it = mimeFilters.begin(); it != mimeFilters.end() && !match; ++ it )
1268 if ( (*it).match(dl->type()) >= 0 ) 1288 if ( (*it).match(dl->type()) >= 0 )
1269 match = TRUE; 1289 match = TRUE;
1270 if ( match /* && dl->type() != "application/octet-stream" */ 1290 if ( match /* && dl->type() != "application/octet-stream" */
1271 && !!dl->exec() ) 1291 && !!dl->exec() )
1272 add(dl); 1292 add(dl);
1273 else 1293 else
1274 delete dl; 1294 delete dl;
1275 } 1295 }
1276 } 1296 }
1277} 1297}
1278 1298
1279// other becomes empty 1299// other becomes empty
1280/*! 1300/*!
1281 Transfers all DocLnk objects from \a other to this set. \a other becomes 1301 Transfers all DocLnk objects from \a other to this set. \a other becomes
1282 empty. 1302 empty.
1283*/ 1303*/
1284void DocLnkSet::appendFrom( DocLnkSet& other ) 1304void DocLnkSet::appendFrom( DocLnkSet& other )
1285{ 1305{
1286 if ( &other == this ) 1306 if ( &other == this )
1287 return; 1307 return;
1288 QListIterator<AppLnk> it( other.mApps ); 1308 QListIterator<AppLnk> it( other.mApps );
1289 for ( ; it.current(); ) { 1309 for ( ; it.current(); ) {
1290 mApps.append(*it); 1310 mApps.append(*it);
1291 ++it; 1311 ++it;
1292 } 1312 }
1293 other.mApps.clear(); 1313 other.mApps.clear();
1294} 1314}
1295 1315
1296void DocLnkSet::findChildren(const QString &dr, const QValueList<QRegExp> &mimeFilters, QDict<void> &reference, int depth) 1316void DocLnkSet::findChildren(const QString &dr, const QValueList<QRegExp> &mimeFilters, QDict<void> &reference, int depth)
1297{ 1317{
1298 depth++; 1318 depth++;
1299 if ( depth > 10 ) 1319 if ( depth > 10 )
1300 return; 1320 return;
1301 1321
1302 QDir dir( dr ); 1322 QDir dir( dr );
1303 1323
1304 /* Opie got a different approach 1324 /* Opie got a different approach
1305 * I guess it's geek vs. consumer 1325 * I guess it's geek vs. consumer
1306 * in this case to be discussed 1326 * in this case to be discussed
1307 */ 1327 */
1308 if ( dir.exists( ".Qtopia-ignore" ) ) 1328 if ( dir.exists( ".Qtopia-ignore" ) )
1309 return; 1329 return;
1310 1330
1311 const QFileInfoList *list = dir.entryInfoList(); 1331 const QFileInfoList *list = dir.entryInfoList();
1312 if ( list ) { 1332 if ( list ) {
1313 QFileInfo* fi; 1333 QFileInfo* fi;
1314 for ( QFileInfoListIterator it(*list); (fi=*it); ++it ) { 1334 for ( QFileInfoListIterator it(*list); (fi=*it); ++it ) {
1315 QString bn = fi->fileName(); 1335 QString bn = fi->fileName();
1316 if ( bn[0] != '.' ) { 1336 if ( bn[0] != '.' ) {
1317 if ( fi->isDir() ) { 1337 if ( fi->isDir() ) {
1318 if ( bn != "CVS" && bn != "Qtopia" && bn != "QtPalmtop" ) 1338 if ( bn != "CVS" && bn != "Qtopia" && bn != "QtPalmtop" )
1319 findChildren(fi->filePath(), mimeFilters, reference, depth); 1339 findChildren(fi->filePath(), mimeFilters, reference, depth);
1320 } else { 1340 } else {
1321 if ( fi->extension(FALSE) == "desktop" ) { 1341 if ( fi->extension(FALSE) == "desktop" ) {
1322 DocLnk* dl = new DocLnk( fi->filePath() ); 1342 DocLnk* dl = new DocLnk( fi->filePath() );
1323 QFileInfo fi2(dl->file()); 1343 QFileInfo fi2(dl->file());
1324 bool match = FALSE; 1344 bool match = FALSE;
1325 if ( !fi2.exists() ) { 1345 if ( !fi2.exists() ) {
1326 dir.remove( dl->file() ); 1346 dir.remove( dl->file() );
1327 } 1347 }
1328 if ( mimeFilters.count() == 0 ) { 1348 if ( mimeFilters.count() == 0 ) {
1329 add( dl ); 1349 add( dl );
1330 match = TRUE; 1350 match = TRUE;
1331 } else { 1351 } else {
1332 for( QValueList<QRegExp>::ConstIterator it = mimeFilters.begin(); it != mimeFilters.end(); ++ it ) { 1352 for( QValueList<QRegExp>::ConstIterator it = mimeFilters.begin(); it != mimeFilters.end(); ++ it ) {
1333 if ( (*it).match(dl->type()) >= 0 ) { 1353 if ( (*it).match(dl->type()) >= 0 ) {
1334 add(dl); 1354 add(dl);
1335 match = TRUE; 1355 match = TRUE;
1336 } 1356 }
1337 } 1357 }
1338 } 1358 }
1339 if ( !match ) 1359 if ( !match )
1340 delete dl; 1360 delete dl;
1341 } else { 1361 } else {
1342 if ( !reference.find(fi->fileName()) ) 1362 if ( !reference.find(fi->fileName()) )
1343 reference.insert(fi->filePath(), (void*)2); 1363 reference.insert(fi->filePath(), (void*)2);
1344 } 1364 }
1345 } 1365 }
1346 } 1366 }
1347 } 1367 }
1348 } 1368 }
1349} 1369}