summaryrefslogtreecommitdiff
authoralwin <alwin>2004-02-24 02:47:03 (UTC)
committer alwin <alwin>2004-02-24 02:47:03 (UTC)
commitf196130d43642f2397ddadeed72e3ea062cda281 (patch) (unidiff)
tree1916d2e66a8ea4fb149397b71888057c62156091
parent4baf741237a4c4575b3efe0bff6c4e143902b7ec (diff)
downloadopie-f196130d43642f2397ddadeed72e3ea062cda281.zip
opie-f196130d43642f2397ddadeed72e3ea062cda281.tar.gz
opie-f196130d43642f2397ddadeed72e3ea062cda281.tar.bz2
- check now for the storage media flag "check =" in DocumentListPrivate::appendDocpath
- fixed a possible segmentation fault in DocumentListPrivate::nextFile
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/documentlist.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/core/launcher/documentlist.cpp b/core/launcher/documentlist.cpp
index 39dc7c9..63f853e 100644
--- a/core/launcher/documentlist.cpp
+++ b/core/launcher/documentlist.cpp
@@ -1,690 +1,697 @@
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#include "documentlist.h" 20#include "documentlist.h"
21#include "serverinterface.h" 21#include "serverinterface.h"
22#include "mediadlg.h" 22#include "mediadlg.h"
23 23
24#include <opie2/oglobal.h> 24#include <opie2/oglobal.h>
25 25
26#include <qtopia/config.h> 26#include <qtopia/config.h>
27#include <qtopia/mimetype.h> 27#include <qtopia/mimetype.h>
28#include <qtopia/resource.h> 28#include <qtopia/resource.h>
29#include <qtopia/private/categories.h> 29#include <qtopia/private/categories.h>
30#include <qtopia/qpeapplication.h> 30#include <qtopia/qpeapplication.h>
31#include <qtopia/applnk.h> 31#include <qtopia/applnk.h>
32#include <qtopia/storage.h> 32#include <qtopia/storage.h>
33#ifdef Q_WS_QWS 33#ifdef Q_WS_QWS
34#include <qtopia/qcopenvelope_qws.h> 34#include <qtopia/qcopenvelope_qws.h>
35#endif 35#endif
36 36
37#include <qtimer.h> 37#include <qtimer.h>
38#include <qfileinfo.h> 38#include <qfileinfo.h>
39#include <qtextstream.h> 39#include <qtextstream.h>
40#include <qfile.h> 40#include <qfile.h>
41#include <qdir.h> 41#include <qdir.h>
42#include <qpainter.h> 42#include <qpainter.h>
43#include <qimage.h> 43#include <qimage.h>
44#include <qcopchannel_qws.h> 44#include <qcopchannel_qws.h>
45#include <qlistview.h> 45#include <qlistview.h>
46#include <qlist.h> 46#include <qlist.h>
47#include <qpixmap.h> 47#include <qpixmap.h>
48 48
49 49
50AppLnkSet *DocumentList::appLnkSet = 0; 50AppLnkSet *DocumentList::appLnkSet = 0;
51 51
52static const int MAX_SEARCH_DEPTH = 10; 52static const int MAX_SEARCH_DEPTH = 10;
53 53
54 54
55class DocumentListPrivate : public QObject { 55class DocumentListPrivate : public QObject {
56 Q_OBJECT 56 Q_OBJECT
57public: 57public:
58 DocumentListPrivate( ServerInterface *gui ); 58 DocumentListPrivate( ServerInterface *gui );
59 ~DocumentListPrivate(); 59 ~DocumentListPrivate();
60 60
61 void initialize(); 61 void initialize();
62 62
63 const QString nextFile(); 63 const QString nextFile();
64 const DocLnk *iterate(); 64 const DocLnk *iterate();
65 bool store( DocLnk* dl ); 65 bool store( DocLnk* dl );
66 void estimatedPercentScanned(); 66 void estimatedPercentScanned();
67 void appendDocpath(FileSystem*); 67 void appendDocpath(FileSystem*);
68 68
69 69
70 DocLnkSet dls; 70 DocLnkSet dls;
71 QDict<void> reference; 71 QDict<void> reference;
72 QDictIterator<void> *dit; 72 QDictIterator<void> *dit;
73 enum { Find, RemoveKnownFiles, MakeUnknownFiles, Done } state; 73 enum { Find, RemoveKnownFiles, MakeUnknownFiles, Done } state;
74 74
75 QStringList docPaths; 75 QStringList docPaths;
76 unsigned int docPathsSearched; 76 unsigned int docPathsSearched;
77 77
78 int searchDepth; 78 int searchDepth;
79 QDir *listDirs[MAX_SEARCH_DEPTH]; 79 QDir *listDirs[MAX_SEARCH_DEPTH];
80 const QFileInfoList *lists[MAX_SEARCH_DEPTH]; 80 const QFileInfoList *lists[MAX_SEARCH_DEPTH];
81 unsigned int listPositions[MAX_SEARCH_DEPTH]; 81 unsigned int listPositions[MAX_SEARCH_DEPTH];
82 82
83 StorageInfo *storage; 83 StorageInfo *storage;
84 84
85 int tid; 85 int tid;
86 86
87 ServerInterface *serverGui; 87 ServerInterface *serverGui;
88 88
89 bool needToSendAllDocLinks; 89 bool needToSendAllDocLinks;
90 bool sendAppLnks; 90 bool sendAppLnks;
91 bool sendDocLnks; 91 bool sendDocLnks;
92 bool scanDocs; 92 bool scanDocs;
93}; 93};
94 94
95 95
96/* 96/*
97 * scandocs will be read from Config 97 * scandocs will be read from Config
98 */ 98 */
99DocumentList::DocumentList( ServerInterface *serverGui, bool /*scanDocs*/, 99DocumentList::DocumentList( ServerInterface *serverGui, bool /*scanDocs*/,
100 QObject *parent, const char *name ) 100 QObject *parent, const char *name )
101 : QObject( parent, name ) 101 : QObject( parent, name )
102{ 102{
103 appLnkSet = new AppLnkSet( MimeType::appsFolderName() ); 103 appLnkSet = new AppLnkSet( MimeType::appsFolderName() );
104 d = new DocumentListPrivate( serverGui ); 104 d = new DocumentListPrivate( serverGui );
105 d->needToSendAllDocLinks = false; 105 d->needToSendAllDocLinks = false;
106 106
107 Config cfg( "Launcher" ); 107 Config cfg( "Launcher" );
108 cfg.setGroup( "DocTab" ); 108 cfg.setGroup( "DocTab" );
109 d->scanDocs = cfg.readBoolEntry( "Enable", true ); 109 d->scanDocs = cfg.readBoolEntry( "Enable", true );
110 qDebug( "DocumentList::DocumentList() : scanDocs = %d", d->scanDocs ); 110 qDebug( "DocumentList::DocumentList() : scanDocs = %d", d->scanDocs );
111 111
112 QTimer::singleShot( 10, this, SLOT( startInitialScan() ) ); 112 QTimer::singleShot( 10, this, SLOT( startInitialScan() ) );
113} 113}
114 114
115void DocumentList::startInitialScan() 115void DocumentList::startInitialScan()
116{ 116{
117 reloadAppLnks(); 117 reloadAppLnks();
118 reloadDocLnks(); 118 reloadDocLnks();
119} 119}
120 120
121DocumentList::~DocumentList() 121DocumentList::~DocumentList()
122{ 122{
123 delete appLnkSet; 123 delete appLnkSet;
124 delete d; 124 delete d;
125} 125}
126 126
127 127
128void DocumentList::add( const DocLnk& doc ) 128void DocumentList::add( const DocLnk& doc )
129{ 129{
130 if ( d->serverGui && QFile::exists( doc.file() ) ) 130 if ( d->serverGui && QFile::exists( doc.file() ) )
131 d->serverGui->documentAdded( doc ); 131 d->serverGui->documentAdded( doc );
132} 132}
133 133
134 134
135void DocumentList::start() 135void DocumentList::start()
136{ 136{
137 resume(); 137 resume();
138} 138}
139 139
140 140
141void DocumentList::pause() 141void DocumentList::pause()
142{ 142{
143 //qDebug("pause %i", d->tid); 143 //qDebug("pause %i", d->tid);
144 killTimer( d->tid ); 144 killTimer( d->tid );
145 d->tid = 0; 145 d->tid = 0;
146} 146}
147 147
148 148
149void DocumentList::resume() 149void DocumentList::resume()
150{ 150{
151 if ( d->tid == 0 ) { 151 if ( d->tid == 0 ) {
152 d->tid = startTimer( 20 ); 152 d->tid = startTimer( 20 );
153 //qDebug("resumed %i", d->tid); 153 //qDebug("resumed %i", d->tid);
154 } 154 }
155} 155}
156 156
157/* 157/*
158void DocumentList::resend() 158void DocumentList::resend()
159{ 159{
160 // Re-emits all the added items to the list (firstly letting everyone know to 160 // Re-emits all the added items to the list (firstly letting everyone know to
161 // clear what they have as it is being sent again) 161 // clear what they have as it is being sent again)
162 pause(); 162 pause();
163 emit allRemoved(); 163 emit allRemoved();
164 QTimer::singleShot( 5, this, SLOT( resendWorker() ) ); 164 QTimer::singleShot( 5, this, SLOT( resendWorker() ) );
165} 165}
166 166
167 167
168void DocumentList::resendWorker() 168void DocumentList::resendWorker()
169{ 169{
170 const QList<DocLnk> &list = d->dls.children(); 170 const QList<DocLnk> &list = d->dls.children();
171 for ( QListIterator<DocLnk> it( list ); it.current(); ++it ) 171 for ( QListIterator<DocLnk> it( list ); it.current(); ++it )
172 add( *(*it) ); 172 add( *(*it) );
173 resume(); 173 resume();
174} 174}
175*/ 175*/
176 176
177void DocumentList::rescan() 177void DocumentList::rescan()
178{ 178{
179 //qDebug("rescan"); 179 //qDebug("rescan");
180 pause(); 180 pause();
181 d->initialize(); 181 d->initialize();
182 resume(); 182 resume();
183} 183}
184 184
185 185
186void DocumentList::timerEvent( QTimerEvent *te ) 186void DocumentList::timerEvent( QTimerEvent *te )
187{ 187{
188 if ( te->timerId() == d->tid ) { 188 if ( te->timerId() == d->tid ) {
189 // Do 3 at a time 189 // Do 3 at a time
190 for (int i = 0; i < 3; i++ ) { 190 for (int i = 0; i < 3; i++ ) {
191 const DocLnk *lnk = d->iterate(); 191 const DocLnk *lnk = d->iterate();
192 if ( lnk ) { 192 if ( lnk ) {
193 add( *lnk ); 193 add( *lnk );
194 } else { 194 } else {
195 // stop when done 195 // stop when done
196 pause(); 196 pause();
197 if ( d->serverGui ) 197 if ( d->serverGui )
198 d->serverGui->documentScanningProgress( 100 ); 198 d->serverGui->documentScanningProgress( 100 );
199 if ( d->needToSendAllDocLinks ) 199 if ( d->needToSendAllDocLinks )
200 sendAllDocLinks(); 200 sendAllDocLinks();
201 break; 201 break;
202 } 202 }
203 } 203 }
204 } 204 }
205} 205}
206 206
207 207
208void DocumentList::reloadAppLnks() 208void DocumentList::reloadAppLnks()
209{ 209{
210 if ( d->sendAppLnks && d->serverGui ) { 210 if ( d->sendAppLnks && d->serverGui ) {
211 d->serverGui->applicationScanningProgress( 0 ); 211 d->serverGui->applicationScanningProgress( 0 );
212 d->serverGui->allApplicationsRemoved(); 212 d->serverGui->allApplicationsRemoved();
213 } 213 }
214 214
215 delete appLnkSet; 215 delete appLnkSet;
216 appLnkSet = new AppLnkSet( MimeType::appsFolderName() ); 216 appLnkSet = new AppLnkSet( MimeType::appsFolderName() );
217 217
218 if ( d->sendAppLnks && d->serverGui ) { 218 if ( d->sendAppLnks && d->serverGui ) {
219 static QStringList prevTypeList; 219 static QStringList prevTypeList;
220 QStringList types = appLnkSet->types(); 220 QStringList types = appLnkSet->types();
221 for ( QStringList::Iterator ittypes=types.begin(); ittypes!=types.end(); ++ittypes) { 221 for ( QStringList::Iterator ittypes=types.begin(); ittypes!=types.end(); ++ittypes) {
222 if ( !(*ittypes).isEmpty() ) { 222 if ( !(*ittypes).isEmpty() ) {
223 if ( !prevTypeList.contains(*ittypes) ) { 223 if ( !prevTypeList.contains(*ittypes) ) {
224 QString name = appLnkSet->typeName(*ittypes); 224 QString name = appLnkSet->typeName(*ittypes);
225 QPixmap pm = appLnkSet->typePixmap(*ittypes); 225 QPixmap pm = appLnkSet->typePixmap(*ittypes);
226 QPixmap bgPm = appLnkSet->typeBigPixmap(*ittypes); 226 QPixmap bgPm = appLnkSet->typeBigPixmap(*ittypes);
227 227
228 if (pm.isNull()) { 228 if (pm.isNull()) {
229 QImage img( Resource::loadImage( "UnknownDocument" ) ); 229 QImage img( Resource::loadImage( "UnknownDocument" ) );
230 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); 230 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() );
231 bgPm = img.smoothScale( AppLnk::bigIconSize(), AppLnk::bigIconSize() ); 231 bgPm = img.smoothScale( AppLnk::bigIconSize(), AppLnk::bigIconSize() );
232 } 232 }
233 233
234 //qDebug("adding type %s", (*ittypes).latin1()); 234 //qDebug("adding type %s", (*ittypes).latin1());
235 235
236 // ### our current launcher expects docs tab to be last 236 // ### our current launcher expects docs tab to be last
237 d->serverGui->typeAdded( *ittypes, name.isNull() ? (*ittypes) : name, pm, bgPm ); 237 d->serverGui->typeAdded( *ittypes, name.isNull() ? (*ittypes) : name, pm, bgPm );
238 } 238 }
239 prevTypeList.remove(*ittypes); 239 prevTypeList.remove(*ittypes);
240 } 240 }
241 } 241 }
242 for ( QStringList::Iterator ittypes=prevTypeList.begin(); ittypes!=prevTypeList.end(); ++ittypes) { 242 for ( QStringList::Iterator ittypes=prevTypeList.begin(); ittypes!=prevTypeList.end(); ++ittypes) {
243 //qDebug("removing type %s", (*ittypes).latin1()); 243 //qDebug("removing type %s", (*ittypes).latin1());
244 d->serverGui->typeRemoved(*ittypes); 244 d->serverGui->typeRemoved(*ittypes);
245 } 245 }
246 prevTypeList = types; 246 prevTypeList = types;
247 } 247 }
248 248
249 QListIterator<AppLnk> itapp( appLnkSet->children() ); 249 QListIterator<AppLnk> itapp( appLnkSet->children() );
250 AppLnk* l; 250 AppLnk* l;
251 while ( (l=itapp.current()) ) { 251 while ( (l=itapp.current()) ) {
252 ++itapp; 252 ++itapp;
253 if ( d->sendAppLnks && d->serverGui ) 253 if ( d->sendAppLnks && d->serverGui )
254 d->serverGui->applicationAdded( l->type(), *l ); 254 d->serverGui->applicationAdded( l->type(), *l );
255 } 255 }
256 256
257 if ( d->sendAppLnks && d->serverGui ) 257 if ( d->sendAppLnks && d->serverGui )
258 d->serverGui->applicationScanningProgress( 100 ); 258 d->serverGui->applicationScanningProgress( 100 );
259} 259}
260 260
261void DocumentList::reloadDocLnks() 261void DocumentList::reloadDocLnks()
262{ 262{
263 if ( !d->scanDocs ) 263 if ( !d->scanDocs )
264 return; 264 return;
265 265
266 if ( d->sendDocLnks && d->serverGui ) { 266 if ( d->sendDocLnks && d->serverGui ) {
267 d->serverGui->documentScanningProgress( 0 ); 267 d->serverGui->documentScanningProgress( 0 );
268 d->serverGui->allDocumentsRemoved(); 268 d->serverGui->allDocumentsRemoved();
269 } 269 }
270 270
271 rescan(); 271 rescan();
272} 272}
273 273
274void DocumentList::linkChanged( QString arg ) 274void DocumentList::linkChanged( QString arg )
275{ 275{
276 //qDebug( "linkchanged( %s )", arg.latin1() ); 276 //qDebug( "linkchanged( %s )", arg.latin1() );
277 277
278 if ( arg.isNull() || OGlobal::isAppLnkFileName( arg ) ) { 278 if ( arg.isNull() || OGlobal::isAppLnkFileName( arg ) ) {
279 reloadAppLnks(); 279 reloadAppLnks();
280 } else { 280 } else {
281 281
282 const QList<DocLnk> &list = d->dls.children(); 282 const QList<DocLnk> &list = d->dls.children();
283 QListIterator<DocLnk> it( list ); 283 QListIterator<DocLnk> it( list );
284 while ( it.current() ) { 284 while ( it.current() ) {
285 DocLnk *doc = it.current(); 285 DocLnk *doc = it.current();
286 ++it; 286 ++it;
287 if ( ( doc->linkFileKnown() && doc->linkFile() == arg ) 287 if ( ( doc->linkFileKnown() && doc->linkFile() == arg )
288 || ( doc->fileKnown() && doc->file() == arg ) ) { 288 || ( doc->fileKnown() && doc->file() == arg ) ) {
289 //qDebug( "found old link" ); 289 //qDebug( "found old link" );
290 DocLnk* dl = new DocLnk( arg ); 290 DocLnk* dl = new DocLnk( arg );
291 // add new one if it exists and matches the mimetype 291 // add new one if it exists and matches the mimetype
292 if ( d->store( dl ) ) { 292 if ( d->store( dl ) ) {
293 // Existing link has been changed, send old link ref and a ref 293 // Existing link has been changed, send old link ref and a ref
294 // to the new link 294 // to the new link
295 //qDebug( "change case" ); 295 //qDebug( "change case" );
296 if ( d->serverGui ) 296 if ( d->serverGui )
297 d->serverGui->documentChanged( *doc, *dl ); 297 d->serverGui->documentChanged( *doc, *dl );
298 298
299 } else { 299 } else {
300 // Link has been removed or doesn't match the mimetypes any more 300 // Link has been removed or doesn't match the mimetypes any more
301 // so we aren't interested in it, so take it away from the list 301 // so we aren't interested in it, so take it away from the list
302 //qDebug( "removal case" ); 302 //qDebug( "removal case" );
303 if ( d->serverGui ) 303 if ( d->serverGui )
304 d->serverGui->documentRemoved( *doc ); 304 d->serverGui->documentRemoved( *doc );
305 305
306 } 306 }
307 d->dls.remove( doc ); // remove old link from docLnkSet 307 d->dls.remove( doc ); // remove old link from docLnkSet
308 delete doc; 308 delete doc;
309 return; 309 return;
310 } 310 }
311 } 311 }
312 // Didn't find existing link, must be new 312 // Didn't find existing link, must be new
313 DocLnk* dl = new DocLnk( arg ); 313 DocLnk* dl = new DocLnk( arg );
314 if ( d->store( dl ) ) { 314 if ( d->store( dl ) ) {
315 // Add if it's a link we are interested in 315 // Add if it's a link we are interested in
316 //qDebug( "add case" ); 316 //qDebug( "add case" );
317 add( *dl ); 317 add( *dl );
318 } 318 }
319 319
320 } 320 }
321} 321}
322 322
323void DocumentList::restoreDone() 323void DocumentList::restoreDone()
324{ 324{
325 reloadAppLnks(); 325 reloadAppLnks();
326 reloadDocLnks(); 326 reloadDocLnks();
327} 327}
328 328
329void DocumentList::storageChanged() 329void DocumentList::storageChanged()
330{ 330{
331 // ### can implement better 331 // ### can implement better
332 reloadAppLnks(); 332 reloadAppLnks();
333 reloadDocLnks(); 333 reloadDocLnks();
334 // ### Optimization opportunity 334 // ### Optimization opportunity
335 // Could be a bit more intelligent and somehow work out which 335 // Could be a bit more intelligent and somehow work out which
336 // mtab entry has changed and then only scan that and add and remove 336 // mtab entry has changed and then only scan that and add and remove
337 // links appropriately. 337 // links appropriately.
338// rescan(); 338// rescan();
339} 339}
340 340
341void DocumentList::sendAllDocLinks() 341void DocumentList::sendAllDocLinks()
342{ 342{
343 if ( d->tid != 0 ) { 343 if ( d->tid != 0 ) {
344 // We are in the middle of scanning, set a flag so 344 // We are in the middle of scanning, set a flag so
345 // we do this when we finish our scanning 345 // we do this when we finish our scanning
346 d->needToSendAllDocLinks = true; 346 d->needToSendAllDocLinks = true;
347 return; 347 return;
348 } 348 }
349 349
350 QString contents; 350 QString contents;
351 Categories cats; 351 Categories cats;
352 for ( QListIterator<DocLnk> it( d->dls.children() ); it.current(); ++it ) { 352 for ( QListIterator<DocLnk> it( d->dls.children() ); it.current(); ++it ) {
353 DocLnk *doc = it.current(); 353 DocLnk *doc = it.current();
354 QFileInfo fi( doc->file() ); 354 QFileInfo fi( doc->file() );
355 if ( !fi.exists() ) 355 if ( !fi.exists() )
356 continue; 356 continue;
357 357
358 bool fake = !doc->linkFileKnown(); 358 bool fake = !doc->linkFileKnown();
359 if ( !fake ) { 359 if ( !fake ) {
360 QFile f( doc->linkFile() ); 360 QFile f( doc->linkFile() );
361 if ( f.open( IO_ReadOnly ) ) { 361 if ( f.open( IO_ReadOnly ) ) {
362 QTextStream ts( &f ); 362 QTextStream ts( &f );
363 ts.setEncoding( QTextStream::UnicodeUTF8 ); 363 ts.setEncoding( QTextStream::UnicodeUTF8 );
364 contents += ts.read(); 364 contents += ts.read();
365 f.close(); 365 f.close();
366 } else 366 } else
367 fake = TRUE; 367 fake = TRUE;
368 } 368 }
369 if (fake) { 369 if (fake) {
370 contents += "[Desktop Entry]\n"; // No tr 370 contents += "[Desktop Entry]\n"; // No tr
371 contents += "Categories = " + // No tr 371 contents += "Categories = " + // No tr
372 cats.labels("Document View",doc->categories()).join(";") + "\n"; // No tr 372 cats.labels("Document View",doc->categories()).join(";") + "\n"; // No tr
373 contents += "Name = "+doc->name()+"\n"; // No tr 373 contents += "Name = "+doc->name()+"\n"; // No tr
374 contents += "Type = "+doc->type()+"\n"; // No tr 374 contents += "Type = "+doc->type()+"\n"; // No tr
375 } 375 }
376 contents += "File = "+doc->file()+"\n"; // No tr // (resolves path) 376 contents += "File = "+doc->file()+"\n"; // No tr // (resolves path)
377 contents += QString("Size = %1\n").arg( fi.size() ); // No tr 377 contents += QString("Size = %1\n").arg( fi.size() ); // No tr
378 } 378 }
379 379
380 //qDebug( "sending length %d", contents.length() ); 380 //qDebug( "sending length %d", contents.length() );
381#ifndef QT_NO_COP 381#ifndef QT_NO_COP
382 QCopEnvelope e( "QPE/Desktop", "docLinks(QString)" ); 382 QCopEnvelope e( "QPE/Desktop", "docLinks(QString)" );
383 e << contents; 383 e << contents;
384#endif 384#endif
385 //qDebug( "================ \n\n%s\n\n===============", contents.latin1() ); 385 //qDebug( "================ \n\n%s\n\n===============", contents.latin1() );
386 386
387 d->needToSendAllDocLinks = false; 387 d->needToSendAllDocLinks = false;
388} 388}
389 389
390 390
391 391
392 392
393 393
394 394
395 395
396 396
397 397
398 398
399 399
400 400
401 401
402 402
403 403
404 404
405 405
406 406
407 407
408 408
409 409
410 410
411 411
412 412
413DocumentListPrivate::DocumentListPrivate( ServerInterface *gui ) 413DocumentListPrivate::DocumentListPrivate( ServerInterface *gui )
414{ 414{
415 storage = new StorageInfo( this ); 415 storage = new StorageInfo( this );
416 serverGui = gui; 416 serverGui = gui;
417 if ( serverGui ) { 417 if ( serverGui ) {
418 sendAppLnks = serverGui->requiresApplications(); 418 sendAppLnks = serverGui->requiresApplications();
419 sendDocLnks = serverGui->requiresDocuments(); 419 sendDocLnks = serverGui->requiresDocuments();
420 } else { 420 } else {
421 sendAppLnks = false; 421 sendAppLnks = false;
422 sendDocLnks = false; 422 sendDocLnks = false;
423 } 423 }
424 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ ) { 424 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ ) {
425 listDirs[i] = 0; 425 listDirs[i] = 0;
426 lists[i] = 0; 426 lists[i] = 0;
427 listPositions[i] = 0; 427 listPositions[i] = 0;
428 } 428 }
429 initialize(); 429 initialize();
430 tid = 0; 430 tid = 0;
431} 431}
432 432
433void DocumentListPrivate::appendDocpath(FileSystem*fs) 433void DocumentListPrivate::appendDocpath(FileSystem*fs)
434{ 434{
435 QDir defPath(fs->path()+"/Documents"); 435 QDir defPath(fs->path()+"/Documents");
436 QFileInfo f(fs->path()+"/.opiestorage.cf"); 436 QFileInfo f(fs->path()+"/.opiestorage.cf");
437 if (!f.exists()) { 437 if (!f.exists()) {
438 Mediadlg dlg(fs); 438 Mediadlg dlg(fs);
439 if (QDialog::Accepted != QPEApplication::execDialog( &dlg )) { 439 if (QDialog::Accepted != QPEApplication::execDialog( &dlg )) {
440 return; 440 return;
441 } 441 }
442 } 442 }
443 Config conf(f.filePath(), Config::File ); 443 Config conf(f.filePath(), Config::File );
444 conf.setGroup("main");
445 if (!conf.readBoolEntry("check",false)) {
446 return;
447 }
444 conf.setGroup("subdirs"); 448 conf.setGroup("subdirs");
445 bool read_all = conf.readBoolEntry("wholemedia",true); 449 bool read_all = conf.readBoolEntry("wholemedia",true);
446 if (read_all) { 450 if (read_all) {
447 docPaths+=fs->path(); 451 docPaths+=fs->path();
448 return; 452 return;
449 } 453 }
450 QStringList subDirs = conf.readListEntry("subdirs",':'); 454 QStringList subDirs = conf.readListEntry("subdirs",':');
451 if (subDirs.isEmpty()) { 455 if (subDirs.isEmpty()) {
452 if (defPath.exists()) { 456 if (defPath.exists()) {
453 docPaths+=defPath.path(); 457 docPaths+=defPath.path();
454 } 458 }
455 return; 459 return;
456 } 460 }
457 for (unsigned c = 0; c < subDirs.count();++c) { 461 for (unsigned c = 0; c < subDirs.count();++c) {
458 QDir docDir(QString(fs->path()+"/"+subDirs[c])); 462 QDir docDir(QString(fs->path()+"/"+subDirs[c]));
459 if (docDir.exists()) { 463 if (docDir.exists()) {
460 docPaths+=docDir.path(); 464 docPaths+=docDir.path();
461 } 465 }
462 } 466 }
463} 467}
464 468
465void DocumentListPrivate::initialize() 469void DocumentListPrivate::initialize()
466{ 470{
467 // Reset 471 // Reset
468 dls.clear(); 472 dls.clear();
469 docPaths.clear(); 473 docPaths.clear();
470 reference.clear(); 474 reference.clear();
471 475
472 QDir docDir( QPEApplication::documentDir() ); 476 QDir docDir( QPEApplication::documentDir() );
473 if ( docDir.exists() ) 477 if ( docDir.exists() )
474 docPaths += QPEApplication::documentDir(); 478 docPaths += QPEApplication::documentDir();
475 int i = 1; 479 int i = 1;
476 const QList<FileSystem> &fs = storage->fileSystems(); 480 const QList<FileSystem> &fs = storage->fileSystems();
477 QListIterator<FileSystem> it( fs ); 481 QListIterator<FileSystem> it( fs );
478 for ( ; it.current(); ++it ) { 482 for ( ; it.current(); ++it ) {
479 if ( (*it)->isRemovable() ) { 483 if ( (*it)->isRemovable() ) {
480 appendDocpath((*it)); 484 appendDocpath((*it));
481 ++i; 485 ++i;
482 } 486 }
483 } 487 }
484 488
485 for ( int i = 0; i < MAX_SEARCH_DEPTH; ++i ) { 489 for ( int i = 0; i < MAX_SEARCH_DEPTH; ++i ) {
486 if ( listDirs[i] ) { 490 if ( listDirs[i] ) {
487 delete listDirs[i]; 491 delete listDirs[i];
488 listDirs[i] = 0; 492 listDirs[i] = 0;
489 } 493 }
490 lists[i] = 0; 494 lists[i] = 0;
491 listPositions[i] = 0; 495 listPositions[i] = 0;
492 } 496 }
493 497
494 docPathsSearched = 0; 498 docPathsSearched = 0;
495 searchDepth = -1; 499 searchDepth = -1;
496 state = Find; 500 state = Find;
497 dit = 0; 501 dit = 0;
498} 502}
499 503
500 504
501DocumentListPrivate::~DocumentListPrivate() 505DocumentListPrivate::~DocumentListPrivate()
502{ 506{
503 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ ) 507 for ( int i = 0; i < MAX_SEARCH_DEPTH; i++ )
504 if ( listDirs[i] ) 508 if ( listDirs[i] )
505 delete listDirs[i]; 509 delete listDirs[i];
506 delete dit; 510 delete dit;
507} 511}
508 512
509 513
510void DocumentListPrivate::estimatedPercentScanned() 514void DocumentListPrivate::estimatedPercentScanned()
511{ 515{
512 double overallProgress = 0.0; 516 double overallProgress = 0.0;
513 double levelWeight = 75.0; 517 double levelWeight = 75.0;
514 518
515 int topCount = docPaths.count(); 519 int topCount = docPaths.count();
516 if ( topCount > 1 ) { 520 if ( topCount > 1 ) {
517 levelWeight = levelWeight / topCount; 521 levelWeight = levelWeight / topCount;
518 overallProgress += (docPathsSearched - 1) * levelWeight; 522 overallProgress += (docPathsSearched - 1) * levelWeight;
519 } 523 }
520 524
521 for ( int d = 0; d <= searchDepth; d++ ) { 525 for ( int d = 0; d <= searchDepth; d++ ) {
522 if ( listDirs[d] ) { 526 if ( listDirs[d] ) {
523 int items = lists[d]->count(); 527 int items = lists[d]->count();
524 if ( items > 1 ) { 528 if ( items > 1 ) {
525 levelWeight = levelWeight / items; 529 levelWeight = levelWeight / items;
526 // Take in to account "." and ".." 530 // Take in to account "." and ".."
527 overallProgress += (listPositions[d] - 3) * levelWeight; 531 overallProgress += (listPositions[d] - 3) * levelWeight;
528 } 532 }
529 } else { 533 } else {
530 break; 534 break;
531 } 535 }
532 } 536 }
533 537
534 // qDebug( "overallProgress: %f", overallProgress ); 538 // qDebug( "overallProgress: %f", overallProgress );
535 539
536 if ( serverGui ) 540 if ( serverGui )
537 serverGui->documentScanningProgress( (int)overallProgress ); 541 serverGui->documentScanningProgress( (int)overallProgress );
538} 542}
539 543
540 544
541const QString DocumentListPrivate::nextFile() 545const QString DocumentListPrivate::nextFile()
542{ 546{
543 while ( TRUE ) { 547 while ( TRUE ) {
544 while ( searchDepth < 0 ) { 548 while ( searchDepth < 0 ) {
545 // go to next base path 549 // go to next base path
546 if ( docPathsSearched >= docPaths.count() ) { 550 if ( docPathsSearched >= docPaths.count() ) {
547 // end of base paths 551 // end of base paths
548 return QString::null; 552 return QString::null;
549 } else { 553 } else {
550 QDir dir( docPaths[docPathsSearched] ); 554 QDir dir( docPaths[docPathsSearched] );
551 // qDebug("now using base path: %s", docPaths[docPathsSearched].latin1() ); 555 // qDebug("now using base path: %s", docPaths[docPathsSearched].latin1() );
552 docPathsSearched++; 556 docPathsSearched++;
553 if ( !dir.exists( ".Qtopia-ignore" ) ) { 557 if ( !dir.exists( ".Qtopia-ignore" ) ) {
554 listDirs[0] = new QDir( dir ); 558 listDirs[0] = new QDir( dir );
555 lists[0] = listDirs[0]->entryInfoList(); 559 lists[0] = listDirs[0]->entryInfoList();
556 listPositions[0] = 0; 560 listPositions[0] = 0;
557 searchDepth = 0; 561 searchDepth = 0;
558 } 562 }
559 } 563 }
560 } 564 }
561 565
562 const QFileInfoList *fil = lists[searchDepth]; 566 const QFileInfoList *fil = lists[searchDepth];
567 if (!fil) {
568 return QString::null;
569 }
563 QFileInfoList *fl = (QFileInfoList *)fil; 570 QFileInfoList *fl = (QFileInfoList *)fil;
564 unsigned int pos = listPositions[searchDepth]; 571 unsigned int pos = listPositions[searchDepth];
565 572
566 if ( pos >= fl->count() ) { 573 if ( pos >= fl->count() ) {
567 // go up a depth 574 // go up a depth
568 delete listDirs[searchDepth]; 575 delete listDirs[searchDepth];
569 listDirs[searchDepth] = 0; 576 listDirs[searchDepth] = 0;
570 lists[searchDepth] = 0; 577 lists[searchDepth] = 0;
571 listPositions[searchDepth] = 0; 578 listPositions[searchDepth] = 0;
572 searchDepth--; 579 searchDepth--;
573 } else { 580 } else {
574 const QFileInfo *fi = fl->at(pos); 581 const QFileInfo *fi = fl->at(pos);
575 listPositions[searchDepth]++; 582 listPositions[searchDepth]++;
576 QString bn = fi->fileName(); 583 QString bn = fi->fileName();
577 if ( bn[0] != '.' ) { 584 if ( bn[0] != '.' ) {
578 if ( fi->isDir() ) { 585 if ( fi->isDir() ) {
579 if ( bn != "CVS" && bn != "Qtopia" && bn != "QtPalmtop" ) { 586 if ( bn != "CVS" && bn != "Qtopia" && bn != "QtPalmtop" ) {
580 // go down a depth 587 // go down a depth
581 QDir dir( fi->filePath() ); 588 QDir dir( fi->filePath() );
582 // qDebug("now going in to path: %s", bn.latin1() ); 589 // qDebug("now going in to path: %s", bn.latin1() );
583 if ( !dir.exists( ".Qtopia-ignore" ) ) { 590 if ( !dir.exists( ".Qtopia-ignore" ) ) {
584 if ( searchDepth < MAX_SEARCH_DEPTH - 1) { 591 if ( searchDepth < MAX_SEARCH_DEPTH - 1) {
585 searchDepth++; 592 searchDepth++;
586 listDirs[searchDepth] = new QDir( dir ); 593 listDirs[searchDepth] = new QDir( dir );
587 lists[searchDepth] = listDirs[searchDepth]->entryInfoList(); 594 lists[searchDepth] = listDirs[searchDepth]->entryInfoList();
588 listPositions[searchDepth] = 0; 595 listPositions[searchDepth] = 0;
589 } 596 }
590 } 597 }
591 } 598 }
592 } else { 599 } else {
593 estimatedPercentScanned(); 600 estimatedPercentScanned();
594 return fl->at(pos)->filePath(); 601 return fl->at(pos)->filePath();
595 } 602 }
596 } 603 }
597 } 604 }
598 } 605 }
599 606
600 return QString::null; 607 return QString::null;
601} 608}
602 609
603 610
604bool DocumentListPrivate::store( DocLnk* dl ) 611bool DocumentListPrivate::store( DocLnk* dl )
605{ 612{
606 // if ( dl->fileKnown() && !dl->file().isEmpty() ) { 613 // if ( dl->fileKnown() && !dl->file().isEmpty() ) {
607 if ( dl && dl->fileKnown() ) { 614 if ( dl && dl->fileKnown() ) {
608 dls.add( dl ); // store 615 dls.add( dl ); // store
609 return TRUE; 616 return TRUE;
610 } 617 }
611 618
612 // don't store - delete 619 // don't store - delete
613 delete dl; 620 delete dl;
614 return FALSE; 621 return FALSE;
615} 622}
616 623
617 624
618 #define MAGIC_NUMBER((void*)2) 625 #define MAGIC_NUMBER((void*)2)
619 626
620const DocLnk *DocumentListPrivate::iterate() 627const DocLnk *DocumentListPrivate::iterate()
621{ 628{
622 if ( state == Find ) { 629 if ( state == Find ) {
623 //qDebug("state Find"); 630 //qDebug("state Find");
624 QString file = nextFile(); 631 QString file = nextFile();
625 while ( !file.isNull() ) { 632 while ( !file.isNull() ) {
626 if ( file.right(8) == ".desktop" ) { // No tr 633 if ( file.right(8) == ".desktop" ) { // No tr
627 DocLnk* dl = new DocLnk( file ); 634 DocLnk* dl = new DocLnk( file );
628 if ( store(dl) ) 635 if ( store(dl) )
629 return dl; 636 return dl;
630 } else { 637 } else {
631 reference.insert( file, MAGIC_NUMBER ); 638 reference.insert( file, MAGIC_NUMBER );
632 } 639 }
633 file = nextFile(); 640 file = nextFile();
634 } 641 }
635 state = RemoveKnownFiles; 642 state = RemoveKnownFiles;
636 643
637 if ( serverGui ) 644 if ( serverGui )
638 serverGui->documentScanningProgress( 75 ); 645 serverGui->documentScanningProgress( 75 );
639 } 646 }
640 647
641 static int iterationI; 648 static int iterationI;
642 static int iterationCount; 649 static int iterationCount;
643 650
644 if ( state == RemoveKnownFiles ) { 651 if ( state == RemoveKnownFiles ) {
645 //qDebug("state RemoveKnownFiles"); 652 //qDebug("state RemoveKnownFiles");
646 const QList<DocLnk> &list = dls.children(); 653 const QList<DocLnk> &list = dls.children();
647 for ( QListIterator<DocLnk> it( list ); it.current(); ++it ) { 654 for ( QListIterator<DocLnk> it( list ); it.current(); ++it ) {
648 reference.remove( (*it)->file() ); 655 reference.remove( (*it)->file() );
649 // ### does this need to be deleted? 656 // ### does this need to be deleted?
650 } 657 }
651 dit = new QDictIterator<void>(reference); 658 dit = new QDictIterator<void>(reference);
652 state = MakeUnknownFiles; 659 state = MakeUnknownFiles;
653 660
654 iterationI = 0; 661 iterationI = 0;
655 iterationCount = dit->count(); 662 iterationCount = dit->count();
656 } 663 }
657 664
658 if ( state == MakeUnknownFiles ) { 665 if ( state == MakeUnknownFiles ) {
659 //qDebug("state MakeUnknownFiles"); 666 //qDebug("state MakeUnknownFiles");
660 for (void* c; (c=dit->current()); ++(*dit) ) { 667 for (void* c; (c=dit->current()); ++(*dit) ) {
661 if ( c == MAGIC_NUMBER ) { 668 if ( c == MAGIC_NUMBER ) {
662 DocLnk* dl = new DocLnk; 669 DocLnk* dl = new DocLnk;
663 QFileInfo fi( dit->currentKey() ); 670 QFileInfo fi( dit->currentKey() );
664 dl->setFile( fi.filePath() ); 671 dl->setFile( fi.filePath() );
665 dl->setName( fi.baseName() ); 672 dl->setName( fi.baseName() );
666 if ( store(dl) ) { 673 if ( store(dl) ) {
667 ++*dit; 674 ++*dit;
668 iterationI++; 675 iterationI++;
669 if ( serverGui ) 676 if ( serverGui )
670 serverGui->documentScanningProgress( 75 + (25*iterationI)/iterationCount ); 677 serverGui->documentScanningProgress( 75 + (25*iterationI)/iterationCount );
671 return dl; 678 return dl;
672 } 679 }
673 } 680 }
674 iterationI++; 681 iterationI++;
675 } 682 }
676 683
677 delete dit; 684 delete dit;
678 dit = 0; 685 dit = 0;
679 state = Done; 686 state = Done;
680 } 687 }
681 688
682 //qDebug("state Done"); 689 //qDebug("state Done");
683 return NULL; 690 return NULL;
684} 691}
685 692
686 693
687#include "documentlist.moc" 694#include "documentlist.moc"
688 695
689 696
690 697