summaryrefslogtreecommitdiff
authorzecke <zecke>2002-10-29 19:08:40 (UTC)
committer zecke <zecke>2002-10-29 19:08:40 (UTC)
commit2957aae1073f4c41dd6783c41d1199be71cd9f4a (patch) (unidiff)
tree2aa5c4f61105aa151867e170601de58511479fd8
parenta575fd4c862693705018902b4482c5135a8cb6a2 (diff)
downloadopie-2957aae1073f4c41dd6783c41d1199be71cd9f4a.zip
opie-2957aae1073f4c41dd6783c41d1199be71cd9f4a.tar.gz
opie-2957aae1073f4c41dd6783c41d1199be71cd9f4a.tar.bz2
the reverse getting of filenames is actually enabled
There will be some code clean ups... but the interfaces should be fine now
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie/ofileselector/ofileselector.cpp15
-rw-r--r--libopie/ofileselector/olister.cpp10
-rw-r--r--libopie/ofileselector/olister.h18
-rw-r--r--libopie/ofileselector/olocallister.cpp29
-rw-r--r--libopie/ofileselector/olocallister.h5
5 files changed, 62 insertions, 15 deletions
diff --git a/libopie/ofileselector/ofileselector.cpp b/libopie/ofileselector/ofileselector.cpp
index 255e79e..9ce07dd 100644
--- a/libopie/ofileselector/ofileselector.cpp
+++ b/libopie/ofileselector/ofileselector.cpp
@@ -9,1093 +9,1084 @@
9#include <qlineedit.h> 9#include <qlineedit.h>
10#include <qlistview.h> 10#include <qlistview.h>
11#include <qmessagebox.h> 11#include <qmessagebox.h>
12#include <qpainter.h> 12#include <qpainter.h>
13#include <qpushbutton.h> 13#include <qpushbutton.h>
14#include <qwidgetstack.h> 14#include <qwidgetstack.h>
15#include <qpopupmenu.h> 15#include <qpopupmenu.h>
16#include <qdir.h> 16#include <qdir.h>
17#include <qfile.h> 17#include <qfile.h>
18#include <qfileinfo.h> 18#include <qfileinfo.h>
19#include <qtimer.h> 19#include <qtimer.h>
20 20
21#include <qpe/qpeapplication.h> 21#include <qpe/qpeapplication.h>
22#include <qpe/applnk.h> 22#include <qpe/applnk.h>
23#include <qpe/global.h> 23#include <qpe/global.h>
24#include <qpe/mimetype.h> 24#include <qpe/mimetype.h>
25#include <qpe/resource.h> 25#include <qpe/resource.h>
26#include <qpe/storage.h> 26#include <qpe/storage.h>
27 27
28#include <unistd.h> 28#include <unistd.h>
29#include <stdlib.h> 29#include <stdlib.h>
30#include <sys/stat.h> 30#include <sys/stat.h>
31 31
32#include "ofileview.h" 32#include "ofileview.h"
33#include "ofileselectormain.h" 33#include "ofileselectormain.h"
34#include "ofileselector.h" 34#include "ofileselector.h"
35#include "olocallister.h" 35#include "olocallister.h"
36#include "olister.h" 36#include "olister.h"
37#include "odefaultfactories.h" 37#include "odefaultfactories.h"
38 38
39QMap<QString,QPixmap> *OFileSelector::m_pixmaps = 0; 39QMap<QString,QPixmap> *OFileSelector::m_pixmaps = 0;
40 40
41namespace { 41namespace {
42 /* let's find the index for a specified string */ 42 /* let's find the index for a specified string */
43 int indexByString( const QComboBox *box, const QString &str ){ 43 int indexByString( const QComboBox *box, const QString &str ){
44 int index= 0; 44 int index= 0;
45 for(int i= 0; i < box->count(); i++ ){ 45 for(int i= 0; i < box->count(); i++ ){
46 /* found */ 46 /* found */
47 if( str == box->text(i ) ){ 47 if( str == box->text(i ) ){
48 index= i; 48 index= i;
49 break; 49 break;
50 } 50 }
51 } 51 }
52 return index; 52 return index;
53 } 53 }
54} 54}
55 55
56OFileSelector::OFileSelector( QWidget *wid, int mode, int selector, 56OFileSelector::OFileSelector( QWidget *wid, int mode, int selector,
57 const QString &dirName, 57 const QString &dirName,
58 const QString &fileName, 58 const QString &fileName,
59 const QMap<QString,QStringList>& mimeTypes) 59 const QMap<QString,QStringList>& mimeTypes)
60 : QWidget( wid, "OFileSelector") 60 : QWidget( wid, "OFileSelector")
61{ 61{
62 m_mimetypes = mimeTypes; 62 m_mimetypes = mimeTypes;
63 if (mode == Save ) 63 if (mode == Save )
64 m_name = fileName; 64 m_name = fileName;
65 65
66 initVars(); 66 initVars();
67 67
68 m_mode = mode; 68 m_mode = mode;
69 m_selector = selector; 69 m_selector = selector;
70 m_currentDir = dirName; 70 m_currentDir = dirName;
71 init(); 71 init();
72} 72}
73 73
74OFileSelector::OFileSelector(const QString &mimeFilter, QWidget *parent, 74OFileSelector::OFileSelector(const QString &mimeFilter, QWidget *parent,
75 const char *name, bool newVisible, 75 const char *name, bool newVisible,
76 bool closeVisible ) 76 bool closeVisible )
77 : QWidget( parent, name ) 77 : QWidget( parent, name )
78{ 78{
79 /* update the mimefilter */ 79 /* update the mimefilter */
80 if (!mimeFilter.isEmpty() ) { 80 if (!mimeFilter.isEmpty() ) {
81 QStringList list = QStringList::split(";", mimeFilter ); 81 QStringList list = QStringList::split(";", mimeFilter );
82 m_mimetypes.insert(mimeFilter, list ); 82 m_mimetypes.insert(mimeFilter, list );
83 } 83 }
84 initVars(); 84 initVars();
85 m_currentDir = QPEApplication::documentDir(); 85 m_currentDir = QPEApplication::documentDir();
86 m_mode = Fileselector; 86 m_mode = Fileselector;
87 m_selector = Normal; 87 m_selector = Normal;
88 m_shClose = closeVisible; 88 m_shClose = closeVisible;
89 m_shNew = newVisible; 89 m_shNew = newVisible;
90 m_shLne = false; 90 m_shLne = false;
91 m_shPerm = false; 91 m_shPerm = false;
92 m_shYesNo = false; 92 m_shYesNo = false;
93 init(); 93 init();
94 94
95 95
96} 96}
97 97
98OFileSelector::~OFileSelector() 98OFileSelector::~OFileSelector()
99{ 99{
100 100
101 101
102} 102}
103 103
104void OFileSelector::setNewVisible( bool visible ) 104void OFileSelector::setNewVisible( bool visible )
105{ 105{
106 m_shNew = visible; 106 m_shNew = visible;
107 if (m_new ) 107 if (m_new )
108 m_new->show(); 108 m_new->show();
109} 109}
110void OFileSelector::setCloseVisible( bool visible ) 110void OFileSelector::setCloseVisible( bool visible )
111{ 111{
112 m_shClose = visible; 112 m_shClose = visible;
113 113
114 if( m_close ) 114 if( m_close )
115 m_close->show(); 115 m_close->show();
116} 116}
117void OFileSelector::reread() 117void OFileSelector::reread()
118{ 118{
119 if( m_selector == Normal ) 119 if( m_selector == Normal )
120 initializeOldSelector(); 120 initializeOldSelector();
121 else 121 else
122 reparse(); 122 reparse();
123} 123}
124 124
125const DocLnk *OFileSelector::selected() 125const DocLnk *OFileSelector::selected()
126{ 126{
127 DocLnk *lnk = new DocLnk(selectedDocument() ); 127 DocLnk *lnk = new DocLnk(selectedDocument() );
128 return lnk; 128 return lnk;
129} 129}
130 130
131void OFileSelector::setYesCancelVisible( bool show ) 131void OFileSelector::setYesCancelVisible( bool show )
132{ 132{
133 initializeYes(); // FIXME if YesCancel is not shown we will initialize it to hide it :( 133 initializeYes(); // FIXME if YesCancel is not shown we will initialize it to hide it :(
134 m_shYesNo = show; 134 m_shYesNo = show;
135 135
136 if( m_shYesNo ) 136 if( m_shYesNo )
137 m_boxOk->show(); 137 m_boxOk->show();
138 else 138 else
139 m_boxOk->hide(); 139 m_boxOk->hide();
140 140
141} 141}
142void OFileSelector::setToolbarVisible( bool show ) 142void OFileSelector::setToolbarVisible( bool show )
143{ 143{
144 m_shTool = show; 144 m_shTool = show;
145 145
146 if(!m_shTool ){ 146 if(!m_shTool ){
147 m_location->hide(); 147 m_location->hide();
148 m_up->hide(); 148 m_up->hide();
149 m_homeButton->hide(); 149 m_homeButton->hide();
150 m_docButton->hide(); 150 m_docButton->hide();
151 }else{ 151 }else{
152 m_location->show(); 152 m_location->show();
153 m_up->show(); 153 m_up->show();
154 m_homeButton->show(); 154 m_homeButton->show();
155 m_docButton->show(); 155 m_docButton->show();
156 } 156 }
157} 157}
158void OFileSelector::setPermissionBarVisible( bool show ) 158void OFileSelector::setPermissionBarVisible( bool show )
159{ 159{
160 m_shPerm = show; 160 m_shPerm = show;
161 initializePerm(); 161 initializePerm();
162 162
163 if( m_shPerm ) 163 if( m_shPerm )
164 m_checkPerm->show(); 164 m_checkPerm->show();
165 else 165 else
166 m_checkPerm->hide(); 166 m_checkPerm->hide();
167} 167}
168void OFileSelector::setLineEditVisible( bool show ) 168void OFileSelector::setLineEditVisible( bool show )
169{ 169{
170 if( show ){ 170 if( show ){
171 initializeName(); 171 initializeName();
172 m_boxName->show(); 172 m_boxName->show();
173 }else{ 173 }else{
174 // check if we showed before this is the way to go 174 // check if we showed before this is the way to go
175 if( m_shLne && m_boxName != 0 ) 175 if( m_shLne && m_boxName != 0 )
176 m_boxName->hide(); 176 m_boxName->hide();
177 } 177 }
178 m_shLne = show; 178 m_shLne = show;
179} 179}
180 180
181void OFileSelector::setChooserVisible( bool show ) 181void OFileSelector::setChooserVisible( bool show )
182{ 182{
183 m_shChooser = show; 183 m_shChooser = show;
184 initializeChooser(); 184 initializeChooser();
185 185
186 if( m_shChooser ) 186 if( m_shChooser )
187 m_boxView->hide(); 187 m_boxView->hide();
188 else 188 else
189 m_boxView->show(); 189 m_boxView->show();
190 190
191} 191}
192 192
193QCheckBox* OFileSelector::permissionCheckbox() 193QCheckBox* OFileSelector::permissionCheckbox()
194{ 194{
195 if( m_selector == Normal ) 195 if( m_selector == Normal )
196 return 0l; 196 return 0l;
197 else 197 else
198 return m_checkPerm; 198 return m_checkPerm;
199} 199}
200bool OFileSelector::setPermission()const 200bool OFileSelector::setPermission()const
201{ 201{
202 return m_checkPerm == 0 ? false : m_checkPerm->isChecked(); 202 return m_checkPerm == 0 ? false : m_checkPerm->isChecked();
203} 203}
204void OFileSelector::setPermissionChecked( bool check ) 204void OFileSelector::setPermissionChecked( bool check )
205{ 205{
206 if( m_checkPerm ) 206 if( m_checkPerm )
207 m_checkPerm->setChecked( check ); 207 m_checkPerm->setChecked( check );
208} 208}
209 209
210void OFileSelector::setMode(int mode) // FIXME do direct raising 210void OFileSelector::setMode(int mode) // FIXME do direct raising
211{ 211{
212 m_mode = mode; 212 m_mode = mode;
213 if( m_selector == Normal ) 213 if( m_selector == Normal )
214 return; 214 return;
215} 215}
216void OFileSelector::setShowDirs(bool dir) 216void OFileSelector::setShowDirs(bool dir)
217{ 217{
218 m_dir = dir; 218 m_dir = dir;
219 if ( m_selector != Fileselector ) 219 if ( m_selector != Fileselector )
220 reparse(); 220 reparse();
221} 221}
222void OFileSelector::setCaseSensetive(bool caSe ) 222void OFileSelector::setCaseSensetive(bool caSe )
223{ 223{
224 m_case = caSe; 224 m_case = caSe;
225 225
226 if ( m_selector != Fileselector ) 226 if ( m_selector != Fileselector )
227 reparse(); 227 reparse();
228} 228}
229void OFileSelector::setShowFiles(bool show ) 229void OFileSelector::setShowFiles(bool show )
230{ 230{
231 m_files = show; 231 m_files = show;
232 reparse(); 232 reparse();
233} 233}
234/// 234///
235bool OFileSelector::cd(const QString &path ) 235bool OFileSelector::cd(const QString &path )
236{ 236{
237 m_currentDir = path; 237 m_currentDir = path;
238 reparse(); 238 reparse();
239 return true; 239 return true;
240} 240}
241void OFileSelector::setSelector(int mode ) 241void OFileSelector::setSelector(int mode )
242{ 242{
243 QString text; 243 QString text;
244 switch( mode ){ 244 switch( mode ){
245 case Normal: 245 case Normal:
246 text = tr("Documents"); 246 text = tr("Documents");
247 break; 247 break;
248 case Extended: 248 case Extended:
249 text = tr("List View"); 249 text = tr("List View");
250 break; 250 break;
251 case ExtendedAll: 251 case ExtendedAll:
252 text = tr("All List View"); 252 text = tr("All List View");
253 break; 253 break;
254 } 254 }
255 slotViewCheck( text ); 255 slotViewCheck( text );
256} 256}
257 257
258void OFileSelector::setPopupFactory(OPopupMenuFactory */*popup*/ ) 258void OFileSelector::setPopupFactory(OPopupMenuFactory */*popup*/ )
259{ 259{
260/* m_custom = popup; 260/* m_custom = popup;
261 m_showPopup = true; 261 m_showPopup = true;
262*/ 262*/
263} 263}
264 264
265//void OFileSelector::updateL
266
267QString OFileSelector::selectedName() const 265QString OFileSelector::selectedName() const
268{ 266{
269 QString name; 267 QString name;
270 if( m_selector == Normal ){ 268 if( m_selector == Normal ){
271 DocLnk lnk = m_select->selectedDocument(); 269 DocLnk lnk = m_select->selectedDocument();
272 name = lnk.file(); 270 name = lnk.file();
273 }else { 271 }else {
274 if ( m_shLne ) { 272 name = currentLister()->selectedName();
275 name = m_currentDir + "/" +m_edit->text();
276 }else{
277 name = m_currentDir + "/" + currentView()->selectedName();
278 }
279 } 273 }
280 return name; 274 return name;
281} 275}
282QStringList OFileSelector::selectedNames()const 276QStringList OFileSelector::selectedNames()const
283{ 277{
284 QStringList list; 278 QStringList list;
285 if( m_selector == Normal ){ 279 if( m_selector == Normal ){
286 list << selectedName(); 280 list << selectedName();
287 }else { 281 }else {
288 list << selectedName(); // FIXME implement multiple Selections 282 list << selectedName(); // FIXME implement multiple Selections
289 } 283 }
290 return list; 284 return list;
291} 285}
292/** If mode is set to the Dir selection this will return the selected path. 286/** If mode is set to the Dir selection this will return the selected path.
293 * 287 *
294 * 288 *
295 */ 289 */
296QString OFileSelector::selectedPath()const 290QString OFileSelector::selectedPath()const
297{ 291{
298 QString path; 292 QString path;
299 if( m_selector == Normal ){ 293 if( m_selector == Normal ){
300 path = QPEApplication::documentDir(); 294 path = QPEApplication::documentDir();
301 } /* normal case to do */ 295 } /* normal case to do */
302 return path; 296 return path;
303} 297}
304QStringList OFileSelector::selectedPaths() const 298QStringList OFileSelector::selectedPaths() const
305{ 299{
306 QStringList list; 300 QStringList list;
307 list << selectedPath(); 301 list << selectedPath();
308 return list; 302 return list;
309} 303}
310QString OFileSelector::directory()const 304QString OFileSelector::directory()const
311{ 305{
312 if( m_selector == Normal ) 306 if( m_selector == Normal )
313 return QPEApplication::documentDir(); 307 return QPEApplication::documentDir();
314 308
315 return QDir(m_currentDir).absPath(); 309 return QDir(m_currentDir).absPath();
316} 310}
317 311
318int OFileSelector::fileCount() 312int OFileSelector::fileCount()
319{ 313{
320 int count; 314 int count;
321 switch( m_selector ){ 315 switch( m_selector ){
322 case Normal: 316 case Normal:
323 count = m_select->fileCount(); 317 count = m_select->fileCount();
324 break; 318 break;
325 case Extended: 319 case Extended:
326 case ExtendedAll: 320 case ExtendedAll:
327 default: 321 default:
328 count = currentView()->fileCount(); 322 count = currentView()->fileCount();
329 break; 323 break;
330 } 324 }
331 return count; 325 return count;
332} 326}
333DocLnk OFileSelector::selectedDocument() const 327DocLnk OFileSelector::selectedDocument() const
334{ 328{
335 DocLnk lnk; 329 DocLnk lnk;
336 switch( m_selector ){ 330 switch( m_selector ){
337 case Normal:{ 331 case Normal:{
338 lnk = m_select->selectedDocument(); 332 lnk = m_select->selectedDocument();
339 break; 333 break;
340 } 334 }
341 case Extended: 335 case Extended:
342 case ExtendedAll: 336 case ExtendedAll:
343 default: 337 default:
344 lnk = DocLnk( selectedName() ); 338 lnk = DocLnk( selectedName() );
345 break; 339 break;
346 } 340 }
347 return lnk; 341 return lnk;
348} 342}
349QValueList<DocLnk> OFileSelector::selectedDocuments() const 343QValueList<DocLnk> OFileSelector::selectedDocuments() const
350{ 344{
351 QValueList<DocLnk> docs; 345 QValueList<DocLnk> docs;
352 docs.append( selectedDocument() ); 346 docs.append( selectedDocument() );
353 return docs; 347 return docs;
354} 348}
355 349
356 350
357// slots internal 351// slots internal
358 352
359void OFileSelector::slotOk() 353void OFileSelector::slotOk()
360{ 354{
361 emit ok(); 355 emit ok();
362} 356}
363void OFileSelector::slotCancel() 357void OFileSelector::slotCancel()
364{ 358{
365 emit cancel(); 359 emit cancel();
366} 360}
367/* switch the views */ 361/* switch the views */
368void OFileSelector::slotViewCheck(const QString &sel) 362void OFileSelector::slotViewCheck(const QString &sel)
369{ 363{
370 setView( sel ); 364 setView( sel );
371} 365}
372 366
373QString OFileSelector::currentMimeType() const{ 367QString OFileSelector::currentMimeType() const{
374 QString mime; 368 QString mime;
375 QString currentText; 369 QString currentText;
376 if (m_shChooser && m_mimeCheck ) 370 if (m_shChooser && m_mimeCheck )
377 currentText = m_mimeCheck->currentText(); 371 currentText = m_mimeCheck->currentText();
378 372
379 qWarning("CurrentText" + currentText ); 373 qWarning("CurrentText" + currentText );
380 if (tr("All") == currentText ) return QString::null; 374 if (tr("All") == currentText ) return QString::null;
381 else if (currentText.isEmpty() ) { 375 else if (currentText.isEmpty() ) {
382 ; 376 ;
383 }else { 377 }else {
384 QMap<QString, QStringList>::ConstIterator it; 378 QMap<QString, QStringList>::ConstIterator it;
385 it = m_mimetypes.find( currentText ); 379 it = m_mimetypes.find( currentText );
386 if ( it != m_mimetypes.end() ) { 380 if ( it != m_mimetypes.end() ) {
387 mime = it.data().join(";"); 381 mime = it.data().join(";");
388 }else{ 382 }else{
389 mime = currentText; 383 mime = currentText;
390 } 384 }
391 } 385 }
392 return mime; 386 return mime;
393} 387}
394void OFileSelector::slotMimeCheck(const QString &mime) 388void OFileSelector::slotMimeCheck(const QString &mime)
395{ 389{
396 if( m_selector == Normal ){ 390 if( m_selector == Normal ){
397 initializeOldSelector(); 391 initializeOldSelector();
398 392
399 updateMimes(); 393 updateMimes();
400 updateMimeCheck(); 394 updateMimeCheck();
401 m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); 395 m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) );
402 }else{ // others 396 }else{ // others
403 qWarning("Mime %s", mime.latin1() ); 397 qWarning("Mime %s", mime.latin1() );
404 if(m_shChooser ){ 398 if(m_shChooser ){
405 qWarning("Current Text %s", m_mimeCheck->currentText().latin1() ); 399 qWarning("Current Text %s", m_mimeCheck->currentText().latin1() );
406 //m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); 400 //m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) );
407 } 401 }
408 reparse(); 402 reparse();
409 } 403 }
410} 404}
411/* 405/*
412 * Ok if a non dir gets inserted into this combobox 406 * Ok if a non dir gets inserted into this combobox
413 * we need to change it 407 * we need to change it
414 * QFileInfo and dirPath will give us the right Dir 408 * QFileInfo and dirPath will give us the right Dir
415 */ 409 */
416void OFileSelector::slotLocationActivated(const QString &file) 410void OFileSelector::slotLocationActivated(const QString &file)
417{ 411{
418 qWarning("slotLocationActivated"); 412 qWarning("slotLocationActivated");
419 QString name = file.left( file.find("<-", 0, TRUE ) ); 413 QString name = file.left( file.find("<-", 0, TRUE ) );
420 QFileInfo info( name ); 414 QFileInfo info( name );
421 if ( info.isFile() ) 415 if ( info.isFile() )
422 cd(info.dirPath( TRUE ) ); //absolute 416 cd(info.dirPath( TRUE ) ); //absolute
423 else 417 else
424 cd(name ); 418 cd(name );
425 reparse();
426} 419}
427void OFileSelector::slotInsertLocationPath(const QString &currentPath, int count) 420void OFileSelector::slotInsertLocationPath(const QString &currentPath, int count)
428{ 421{
429 QStringList pathList; 422 QStringList pathList;
430 bool underDog = FALSE; 423 bool underDog = FALSE;
431 for(int i=0;i<count;i++) { 424 for(int i=0;i<count;i++) {
432 pathList << m_location->text(i); 425 pathList << m_location->text(i);
433 if( m_location->text(i) == currentPath) 426 if( m_location->text(i) == currentPath)
434 underDog = TRUE; 427 underDog = TRUE;
435 } 428 }
436 if( !underDog) { 429 if( !underDog) {
437 m_location->clear(); 430 m_location->clear();
438 if( currentPath.left(2)=="//") 431 if( currentPath.left(2)=="//")
439 pathList.append( currentPath.right(currentPath.length()-1) ); 432 pathList.append( currentPath.right(currentPath.length()-1) );
440 else 433 else
441 pathList.append( currentPath ); 434 pathList.append( currentPath );
442 m_location->insertStringList( pathList,-1); 435 m_location->insertStringList( pathList,-1);
443 } 436 }
444} 437}
445/* 438/*
446 * Do not crash anymore 439 * Do not crash anymore
447 * don't try to change dir to a file 440 * don't try to change dir to a file
448 */ 441 */
449void OFileSelector::locationComboChanged() 442void OFileSelector::locationComboChanged()
450{ 443{
451 QFileInfo info( m_location->lineEdit()->text() ); 444 QFileInfo info( m_location->lineEdit()->text() );
452 qWarning("info %s %s", info.dirPath(true).latin1(), m_location->lineEdit()->text().latin1() ); 445 qWarning("info %s %s", info.dirPath(true).latin1(), m_location->lineEdit()->text().latin1() );
453 if (info.isFile() ) 446 if (info.isFile() )
454 cd(info.dirPath(TRUE) ); //absolute path 447 cd(info.dirPath(TRUE) ); //absolute path
455 else 448 else
456 cd( m_location->lineEdit()->text() ); 449 cd( m_location->lineEdit()->text() );
457
458 reparse();
459} 450}
460void OFileSelector::init() 451void OFileSelector::init()
461{ 452{
462 initFactory(); 453 initFactory();
463 m_lay = new QVBoxLayout( this ); 454 m_lay = new QVBoxLayout( this );
464 m_lay->setSpacing(0 ); 455 m_lay->setSpacing(0 );
465 456
466 /* take care of the main view... */ 457 /* take care of the main view... */
467 initToolbar(); 458 initToolbar();
468 //if( m_shChooser ) // the Chooser for the view and Mimetypes 459 //if( m_shChooser ) // the Chooser for the view and Mimetypes
469 initializeChooser(); 460 initializeChooser();
470 461
471 /* initialize the file lister */ 462 /* initialize the file lister */
472 if( m_selector == Normal ){ 463 if( m_selector == Normal ){
473 QString mime; 464 QString mime;
474 if (!m_autoMime) { 465 if (!m_autoMime) {
475 if (!m_mimetypes.isEmpty() ) { 466 if (!m_mimetypes.isEmpty() ) {
476 QMap<QString, QStringList>::Iterator it; 467 QMap<QString, QStringList>::Iterator it;
477 it = m_mimetypes.begin(); // cause we're in the init 468 it = m_mimetypes.begin(); // cause we're in the init
478 mime = it.data().join(";"); 469 mime = it.data().join(";");
479 } 470 }
480 } 471 }
481 initializeOldSelector(); 472 initializeOldSelector();
482 }else{ 473 }else{
483 initializeView(); 474 initializeView();
484 } 475 }
485 476
486 if( m_shLne ) // the LineEdit with the current FileName 477 if( m_shLne ) // the LineEdit with the current FileName
487 initializeName(); 478 initializeName();
488 479
489 if( m_shPerm ) // the Permission QCheckBox 480 if( m_shPerm ) // the Permission QCheckBox
490 initializePerm(); 481 initializePerm();
491 482
492 if( m_shYesNo ) // the Yes No button row 483 if( m_shYesNo ) // the Yes No button row
493 initializeYes( ); 484 initializeYes( );
494 485
495 if (m_selector != Normal ) 486 if (m_selector != Normal )
496 reparse(); 487 reparse();
497} 488}
498void OFileSelector::updateMimes() 489void OFileSelector::updateMimes()
499{ 490{
500 if( m_autoMime ){ 491 if( m_autoMime ){
501 m_mimetypes.clear(); 492 m_mimetypes.clear();
502 m_mimetypes.insert( tr("All"), QString::null ); 493 m_mimetypes.insert( tr("All"), QString::null );
503 if( m_selector == Normal ){ 494 if( m_selector == Normal ){
504 DocLnkSet set; 495 DocLnkSet set;
505 Global::findDocuments(&set, QString::null ); 496 Global::findDocuments(&set, QString::null );
506 QListIterator<DocLnk> dit( set.children() ); 497 QListIterator<DocLnk> dit( set.children() );
507 for( ; dit.current(); ++dit ){ 498 for( ; dit.current(); ++dit ){
508 if( !m_mimetypes.contains( (*dit)->type() ) ) 499 if( !m_mimetypes.contains( (*dit)->type() ) )
509 m_mimetypes.insert( (*dit)->type(), (*dit)->type() ); 500 m_mimetypes.insert( (*dit)->type(), (*dit)->type() );
510 } 501 }
511 }// else done in reparse 502 }// else done in reparse
512 } 503 }
513} 504}
514void OFileSelector::initVars() 505void OFileSelector::initVars()
515{ 506{
516 if( m_mimetypes.isEmpty() ) 507 if( m_mimetypes.isEmpty() )
517 m_autoMime = true; 508 m_autoMime = true;
518 else 509 else
519 m_autoMime = false; 510 m_autoMime = false;
520 511
521 m_shClose = false; 512 m_shClose = false;
522 m_shNew = false; 513 m_shNew = false;
523 m_shTool = true; 514 m_shTool = true;
524 m_shPerm = false; 515 m_shPerm = false;
525 m_shLne = true; 516 m_shLne = true;
526 m_shChooser = true; 517 m_shChooser = true;
527 m_shYesNo = true; 518 m_shYesNo = true;
528 m_case = false; 519 m_case = false;
529 m_dir = true; 520 m_dir = true;
530 m_files = true; 521 m_files = true;
531 m_showPopup = false; 522 m_showPopup = false;
532 m_mainView = 0l; 523 m_mainView = 0l;
533 m_fileView = 0l; 524 m_fileView = 0l;
534 m_lister = 0l; 525 m_lister = 0l;
535 526
536 if(m_pixmaps == 0 ) // init the pixmaps 527 if(m_pixmaps == 0 ) // init the pixmaps
537 initPics(); 528 initPics();
538 529
539 // pointers 530 // pointers
540 m_location = 0; 531 m_location = 0;
541 m_mimeCheck = 0; 532 m_mimeCheck = 0;
542 m_viewCheck = 0; 533 m_viewCheck = 0;
543 m_homeButton = 0; 534 m_homeButton = 0;
544 m_docButton = 0; 535 m_docButton = 0;
545 m_hideButton = 0; 536 m_hideButton = 0;
546 m_ok = 0; 537 m_ok = 0;
547 m_cancel = 0; 538 m_cancel = 0;
548 m_reread = 0; 539 m_reread = 0;
549 m_up = 0; 540 m_up = 0;
550 m_View = 0; 541 m_View = 0;
551 m_checkPerm = 0; 542 m_checkPerm = 0;
552 m_pseudo = 0; 543 m_pseudo = 0;
553 m_pseudoLayout = 0; 544 m_pseudoLayout = 0;
554 m_select = 0; 545 m_select = 0;
555 m_lay = 0; 546 m_lay = 0;
556 m_Oselector = 0; 547 m_Oselector = 0;
557 m_boxToolbar = 0; 548 m_boxToolbar = 0;
558 m_boxOk = 0; 549 m_boxOk = 0;
559 m_boxName = 0; 550 m_boxName = 0;
560 m_boxView = 0; 551 m_boxView = 0;
561 m_edit = 0; 552 m_edit = 0;
562 m_fnLabel = 0; 553 m_fnLabel = 0;
563 m_new = 0; 554 m_new = 0;
564 m_close = 0; 555 m_close = 0;
565} 556}
566void OFileSelector::initializeName() 557void OFileSelector::initializeName()
567{ 558{
568 /** Name Layout Line 559 /** Name Layout Line
569 * This is the Layout line arranged in 560 * This is the Layout line arranged in
570 * horizontal way each components 561 * horizontal way each components
571 * are next to each other 562 * are next to each other
572 * but we will only do this if 563 * but we will only do this if
573 * we didn't initialize a while ago. 564 * we didn't initialize a while ago.
574 */ 565 */
575 if( m_boxName == 0 ){ 566 if( m_boxName == 0 ){
576 m_boxName = new QHBox( this ); // remove this this? or use a QHBox 567 m_boxName = new QHBox( this ); // remove this this? or use a QHBox
577 m_fnLabel = new QLabel( m_boxName ); 568 m_fnLabel = new QLabel( m_boxName );
578 m_fnLabel->setText( tr("Name:") ); 569 m_fnLabel->setText( tr("Name:") );
579 m_edit = new QLineEdit( m_boxName ); 570 m_edit = new QLineEdit( m_boxName );
580 m_edit->setText( m_name ); 571 m_edit->setText( m_name );
581 //m_boxName->addWidget( m_fnLabel ); 572 //m_boxName->addWidget( m_fnLabel );
582 m_boxName->setMargin( 5 ); 573 m_boxName->setMargin( 5 );
583 m_boxName->setSpacing( 8 ); 574 m_boxName->setSpacing( 8 );
584 //m_boxName->setStretchFactor(m_edit, 100 ); // 100 is stretch factor 575 //m_boxName->setStretchFactor(m_edit, 100 ); // 100 is stretch factor
585 576
586 m_lay->addWidget( m_boxName, 0 ); // add it to the topLevel layout 577 m_lay->addWidget( m_boxName, 0 ); // add it to the topLevel layout
587 }// else we already initialized 578 }// else we already initialized
588 // maybe show the components? 579 // maybe show the components?
589 // 580 //
590} 581}
591void OFileSelector::initializeYes() 582void OFileSelector::initializeYes()
592{ 583{
593 /** The Save Cancel bar 584 /** The Save Cancel bar
594 * 585 *
595 */ 586 */
596 if( m_boxOk == 0 ){ 587 if( m_boxOk == 0 ){
597 m_boxOk = new QHBox( this ); 588 m_boxOk = new QHBox( this );
598 m_ok = new QPushButton( tr("&Save"),m_boxOk , "save" ); 589 m_ok = new QPushButton( tr("&Save"),m_boxOk , "save" );
599 m_cancel = new QPushButton( tr("C&ancel"), m_boxOk, "cancel" ); 590 m_cancel = new QPushButton( tr("C&ancel"), m_boxOk, "cancel" );
600 591
601 //m_boxOk->addWidget( m_ok ); 592 //m_boxOk->addWidget( m_ok );
602 //m_boxOk->addWidget( m_cancel ); 593 //m_boxOk->addWidget( m_cancel );
603 m_boxOk->setMargin( 5 ); 594 m_boxOk->setMargin( 5 );
604 m_boxOk->setSpacing( 10 ); 595 m_boxOk->setSpacing( 10 );
605 m_lay->addWidget( m_boxOk, 0 ); 596 m_lay->addWidget( m_boxOk, 0 );
606 597
607 connect( m_ok, SIGNAL( clicked() ), 598 connect( m_ok, SIGNAL( clicked() ),
608 this, SLOT(slotOk() ) ); 599 this, SLOT(slotOk() ) );
609 connect( m_cancel, SIGNAL( clicked() ), 600 connect( m_cancel, SIGNAL( clicked() ),
610 this, SLOT( slotCancel() ) ); 601 this, SLOT( slotCancel() ) );
611 } 602 }
612} 603}
613/* 604/*
614 * OK m_mimeCheck is a QComboBox we now want to fill 605 * OK m_mimeCheck is a QComboBox we now want to fill
615 * out that combobox 606 * out that combobox
616 * if automime we need to update the mimetypes 607 * if automime we need to update the mimetypes
617 */ 608 */
618void OFileSelector::updateMimeCheck() { 609void OFileSelector::updateMimeCheck() {
619 m_mimeCheck->clear(); 610 m_mimeCheck->clear();
620 if (m_autoMime ) { 611 if (m_autoMime ) {
621 //m_mimeCheck->insertItem( tr("All") ); 612 //m_mimeCheck->insertItem( tr("All") );
622 updateMimes(); 613 updateMimes();
623 } 614 }
624 615
625 QMap<QString, QStringList>::Iterator it; 616 QMap<QString, QStringList>::Iterator it;
626 for (it = m_mimetypes.begin(); it != m_mimetypes.end(); ++it ) { 617 for (it = m_mimetypes.begin(); it != m_mimetypes.end(); ++it ) {
627 m_mimeCheck->insertItem( it.key() ); 618 m_mimeCheck->insertItem( it.key() );
628 } 619 }
629} 620}
630 621
631void OFileSelector::initializeChooser() 622void OFileSelector::initializeChooser()
632{ 623{
633 if( m_boxView == 0 ){ 624 if( m_boxView == 0 ){
634 m_boxView = new QHBox( this ); 625 m_boxView = new QHBox( this );
635 m_viewCheck = new QComboBox( m_boxView, "view check"); 626 m_viewCheck = new QComboBox( m_boxView, "view check");
636 m_mimeCheck = new QComboBox( m_boxView, "mime check"); 627 m_mimeCheck = new QComboBox( m_boxView, "mime check");
637 m_boxView->setSpacing( 8 ); 628 m_boxView->setSpacing( 8 );
638 m_lay->addWidget(m_boxView, 0 ); 629 m_lay->addWidget(m_boxView, 0 );
639 630
640 631
641 updateMimeCheck(); 632 updateMimeCheck();
642 fillList(); 633 fillList();
643 634
644 connect( m_viewCheck, SIGNAL( activated(const QString & ) ), 635 connect( m_viewCheck, SIGNAL( activated(const QString & ) ),
645 this, SLOT( slotViewCheck(const QString & ) ) ); 636 this, SLOT( slotViewCheck(const QString & ) ) );
646 connect( m_mimeCheck, SIGNAL( activated(const QString & ) ), 637 connect( m_mimeCheck, SIGNAL( activated(const QString & ) ),
647 this, SLOT( slotMimeCheck( const QString & ) ) ); 638 this, SLOT( slotMimeCheck( const QString & ) ) );
648 } 639 }
649} 640}
650/* generate the buttons for the toolbar */ 641/* generate the buttons for the toolbar */
651void OFileSelector::initToolbar() { 642void OFileSelector::initToolbar() {
652 m_mainView = new OFileSelectorMain( this ); 643 m_mainView = new OFileSelectorMain( this );
653 644
654 /* now generate the tool bar */ 645 /* now generate the tool bar */
655 qWarning( "toolbar" ); 646 qWarning( "toolbar" );
656 m_pseudo = new QWidget( m_mainView, "Pseudo Widget" ); 647 m_pseudo = new QWidget( m_mainView, "Pseudo Widget" );
657 m_pseudoLayout = new QVBoxLayout( m_pseudo ); 648 m_pseudoLayout = new QVBoxLayout( m_pseudo );
658 649
659 m_boxToolbar = new QHBox( m_pseudo ); 650 m_boxToolbar = new QHBox( m_pseudo );
660 m_boxToolbar->setSpacing( 0 ); 651 m_boxToolbar->setSpacing( 0 );
661 652
662 // tool bar members now 653 // tool bar members now
663 m_location = new QComboBox( m_boxToolbar ); 654 m_location = new QComboBox( m_boxToolbar );
664 m_location->setEditable( TRUE ); 655 m_location->setEditable( TRUE );
665 m_location->setDuplicatesEnabled( FALSE ); 656 m_location->setDuplicatesEnabled( FALSE );
666 connect( m_location, SIGNAL(activated(const QString& ) ), 657 connect( m_location, SIGNAL(activated(const QString& ) ),
667 this, SLOT(slotLocationActivated(const QString& )) ); 658 this, SLOT(slotLocationActivated(const QString& )) );
668 connect( m_location->lineEdit(), SIGNAL(returnPressed() ) , 659 connect( m_location->lineEdit(), SIGNAL(returnPressed() ) ,
669 this, SLOT(locationComboChanged() ) ); 660 this, SLOT(locationComboChanged() ) );
670 661
671 // UP Button 662 // UP Button
672 m_up = new QPushButton( Resource::loadIconSet("up"), QString::null, 663 m_up = new QPushButton( Resource::loadIconSet("up"), QString::null,
673 m_boxToolbar, "cdUpButton" ); 664 m_boxToolbar, "cdUpButton" );
674 m_up->setFixedSize( QSize(20, 20 ) ); 665 m_up->setFixedSize( QSize(20, 20 ) );
675 connect( m_up, SIGNAL( clicked() ), this, SLOT(cdUP() ) ); 666 connect( m_up, SIGNAL( clicked() ), this, SLOT(cdUP() ) );
676 m_up->setFlat( TRUE ); 667 m_up->setFlat( TRUE );
677 668
678 // Home Button 669 // Home Button
679 m_homeButton = new QPushButton(Resource::loadIconSet("home"), 670 m_homeButton = new QPushButton(Resource::loadIconSet("home"),
680 QString::null, m_boxToolbar ); 671 QString::null, m_boxToolbar );
681 m_homeButton->setFixedSize( QSize(20, 20 ) ); 672 m_homeButton->setFixedSize( QSize(20, 20 ) );
682 connect(m_homeButton, SIGNAL(clicked() ), this, SLOT(slotHome() ) ); 673 connect(m_homeButton, SIGNAL(clicked() ), this, SLOT(slotHome() ) );
683 m_homeButton->setFlat( TRUE ); 674 m_homeButton->setFlat( TRUE );
684 675
685 // Documents Button 676 // Documents Button
686 m_docButton = new QPushButton( Resource::loadIconSet("DocsIcon"), 677 m_docButton = new QPushButton( Resource::loadIconSet("DocsIcon"),
687 QString::null, m_boxToolbar, 678 QString::null, m_boxToolbar,
688 "docsButton" ); 679 "docsButton" );
689 m_docButton->setFixedSize( QSize(20, 20 ) ); 680 m_docButton->setFixedSize( QSize(20, 20 ) );
690 m_docButton->setFlat( true ); 681 m_docButton->setFlat( true );
691 connect( m_docButton, SIGNAL(clicked() ), 682 connect( m_docButton, SIGNAL(clicked() ),
692 this, SLOT(slotDoc() ) ); 683 this, SLOT(slotDoc() ) );
693 684
694 // close button 685 // close button
695 m_close = new QPushButton( Resource::loadIconSet( "close"), "", 686 m_close = new QPushButton( Resource::loadIconSet( "close"), "",
696 m_boxToolbar ); 687 m_boxToolbar );
697 connect( m_close, SIGNAL(clicked() ), this, SIGNAL(closeMe() ) ); 688 connect( m_close, SIGNAL(clicked() ), this, SIGNAL(closeMe() ) );
698 m_close->setFixedSize( 20, 20 ); 689 m_close->setFixedSize( 20, 20 );
699 690
700 m_boxToolbar->setFixedHeight( 20 ); 691 m_boxToolbar->setFixedHeight( 20 );
701 m_pseudoLayout->addWidget(m_boxToolbar ); 692 m_pseudoLayout->addWidget(m_boxToolbar );
702 693
703 /* init the locations */ 694 /* init the locations */
704 initLocations(); 695 initLocations();
705 696
706 if( !m_shTool ){ 697 if( !m_shTool ){
707 m_location->hide( ); 698 m_location->hide( );
708 m_up->hide( ); 699 m_up->hide( );
709 m_homeButton->hide( ); 700 m_homeButton->hide( );
710 m_docButton->hide( ); 701 m_docButton->hide( );
711 } 702 }
712 if(!m_shClose ) 703 if(!m_shClose )
713 m_close->hide(); 704 m_close->hide();
714 705
715 m_mainView->setToolbar( m_pseudo ); 706 m_mainView->setToolbar( m_pseudo );
716 m_lay->addWidget( m_mainView, 100 ); 707 m_lay->addWidget( m_mainView, 100 );
717} 708}
718/* put default locations into the bar */ 709/* put default locations into the bar */
719void OFileSelector::initLocations () { 710void OFileSelector::initLocations () {
720 711
721 // let;s fill the Location ComboBox 712 // let;s fill the Location ComboBox
722 StorageInfo storage; 713 StorageInfo storage;
723 const QList<FileSystem> &fs = storage.fileSystems(); 714 const QList<FileSystem> &fs = storage.fileSystems();
724 QListIterator<FileSystem> it ( fs ); 715 QListIterator<FileSystem> it ( fs );
725 for( ; it.current(); ++it ){ 716 for( ; it.current(); ++it ){
726 const QString disk = (*it)->name(); 717 const QString disk = (*it)->name();
727 const QString path = (*it)->path(); 718 const QString path = (*it)->path();
728 m_location->insertItem(path+ "<-"+disk ); 719 m_location->insertItem(path+ "<-"+disk );
729 } 720 }
730 int count = m_location->count(); 721 int count = m_location->count();
731 m_location->insertItem( m_currentDir ); 722 m_location->insertItem( m_currentDir );
732 m_location->setCurrentItem( count ); 723 m_location->setCurrentItem( count );
733 724
734} 725}
735void OFileSelector::initializePerm() 726void OFileSelector::initializePerm()
736{ 727{
737 if( m_checkPerm == 0 ){ 728 if( m_checkPerm == 0 ){
738 m_checkPerm = new QCheckBox(tr("Set Permission"), this, "perm"); 729 m_checkPerm = new QCheckBox(tr("Set Permission"), this, "perm");
739 m_checkPerm->setChecked( false ); 730 m_checkPerm->setChecked( false );
740 m_lay->addWidget( m_checkPerm ); 731 m_lay->addWidget( m_checkPerm );
741 } 732 }
742} 733}
743void OFileSelector::initPics() 734void OFileSelector::initPics()
744{ 735{
745 m_pixmaps = new QMap<QString,QPixmap>; 736 m_pixmaps = new QMap<QString,QPixmap>;
746 QPixmap pm = Resource::loadPixmap( "folder" ); 737 QPixmap pm = Resource::loadPixmap( "folder" );
747 QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); 738 QPixmap lnk = Resource::loadPixmap( "opie/symlink" );
748 739
749 QPainter painter( &pm ); 740 QPainter painter( &pm );
750 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); 741 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk );
751 pm.setMask( pm.createHeuristicMask( FALSE ) ); 742 pm.setMask( pm.createHeuristicMask( FALSE ) );
752 m_pixmaps->insert("dirsymlink", pm ); 743 m_pixmaps->insert("dirsymlink", pm );
753 744
754 QPixmap pm2 = Resource::loadPixmap( "lockedfolder" ); 745 QPixmap pm2 = Resource::loadPixmap( "lockedfolder" );
755 QPainter pen(&pm2 ); 746 QPainter pen(&pm2 );
756 pen.drawPixmap(pm2.width()-lnk.width(), pm2.height()-lnk.height(), lnk ); 747 pen.drawPixmap(pm2.width()-lnk.width(), pm2.height()-lnk.height(), lnk );
757 pm2.setMask( pm2.createHeuristicMask( FALSE ) ); 748 pm2.setMask( pm2.createHeuristicMask( FALSE ) );
758 m_pixmaps->insert("symlinkedlocked", pm2 ); 749 m_pixmaps->insert("symlinkedlocked", pm2 );
759} 750}
760// if a mime complies with the m_mimeCheck->currentItem 751// if a mime complies with the m_mimeCheck->currentItem
761bool OFileSelector::compliesMime( const QString &path, const QString &mime ) 752bool OFileSelector::compliesMime( const QString &path, const QString &mime )
762{ 753{
763 if( mime == "All" ) 754 if( mime == "All" )
764 return true; 755 return true;
765 MimeType type( path ); 756 MimeType type( path );
766 if( type.id() == mime ) 757 if( type.id() == mime )
767 return true; 758 return true;
768 return false; 759 return false;
769} 760}
770/* check if the mimetype in mime 761/* check if the mimetype in mime
771 * complies with the one which is current 762 * complies with the one which is current
772 */ 763 */
773/* 764/*
774 * We've the mimetype of the file 765 * We've the mimetype of the file
775 * We need to get the stringlist of the current mimetype 766 * We need to get the stringlist of the current mimetype
776 * 767 *
777 * mime = image/jpeg 768 * mime = image/jpeg
778 * QStringList = 'image/*' 769 * QStringList = 'image/*'
779 * or QStringList = image/jpeg;image/png;application/x-ogg 770 * or QStringList = image/jpeg;image/png;application/x-ogg
780 * or QStringList = application/x-ogg;image/*; 771 * or QStringList = application/x-ogg;image/*;
781 * with all these mime filters it should get acceptes 772 * with all these mime filters it should get acceptes
782 * to do so we need to look if mime is contained inside 773 * to do so we need to look if mime is contained inside
783 * the stringlist 774 * the stringlist
784 * if it's contained return true 775 * if it's contained return true
785 * if not ( I'm no RegExp expert at all ) we'll look if a '/*' 776 * if not ( I'm no RegExp expert at all ) we'll look if a '/*'
786 * is contained in the mimefilter and then we will 777 * is contained in the mimefilter and then we will
787 * look if both are equal until the '/' 778 * look if both are equal until the '/'
788 */ 779 */
789bool OFileSelector::compliesMime( const QString& mime ) { 780bool OFileSelector::compliesMime( const QString& mime ) {
790 qWarning("mimetype is %s", mime.latin1() ); 781 qWarning("mimetype is %s", mime.latin1() );
791 QString currentText; 782 QString currentText;
792 if (m_shChooser ) 783 if (m_shChooser )
793 currentText = m_mimeCheck->currentText(); 784 currentText = m_mimeCheck->currentText();
794 785
795 qWarning("current text is %s", currentText.latin1() ); 786 qWarning("current text is %s", currentText.latin1() );
796 QMap<QString, QStringList>::Iterator it; 787 QMap<QString, QStringList>::Iterator it;
797 QStringList list; 788 QStringList list;
798 if ( currentText == tr("All") ) return true; 789 if ( currentText == tr("All") ) return true;
799 else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { 790 else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) {
800 it = m_mimetypes.begin(); 791 it = m_mimetypes.begin();
801 list = it.data(); 792 list = it.data();
802 }else if ( currentText.isEmpty() ) return true; 793 }else if ( currentText.isEmpty() ) return true;
803 else{ 794 else{
804 it = m_mimetypes.find(currentText ); 795 it = m_mimetypes.find(currentText );
805 if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; 796 if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText;
806 else qWarning("found"), list = it.data(); 797 else qWarning("found"), list = it.data();
807 } 798 }
808 799
809 800
810 if ( list.contains(mime) ) return true; 801 if ( list.contains(mime) ) return true;
811 qWarning("list doesn't contain it "); 802 qWarning("list doesn't contain it ");
812 QStringList::Iterator it2; 803 QStringList::Iterator it2;
813 int pos; 804 int pos;
814 for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { 805 for ( it2 = list.begin(); it2 != list.end(); ++it2 ) {
815 pos = (*it2).findRev("/*"); 806 pos = (*it2).findRev("/*");
816 if ( pos >= 0 ) { 807 if ( pos >= 0 ) {
817 if ( mime.contains( (*it2).left(pos) ) ) return true; 808 if ( mime.contains( (*it2).left(pos) ) ) return true;
818 } 809 }
819 } 810 }
820 return false; 811 return false;
821} 812}
822void OFileSelector::slotFileSelected( const QString &string ) 813void OFileSelector::slotFileSelected( const QString &string )
823{ 814{
824 if( m_shLne ) 815 if( m_shLne )
825 m_edit->setText( string ); 816 m_edit->setText( string );
826 emit fileSelected( string ); 817 emit fileSelected( string );
827} 818}
828void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) 819void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk )
829{ 820{
830 slotFileSelected( lnk.name() ); 821 slotFileSelected( lnk.name() );
831 // emit fileSelected( lnk ); 822 // emit fileSelected( lnk );
832} 823}
833 824
834 825
835void OFileSelector::slotDelete() 826void OFileSelector::slotDelete()
836{ 827{
837 /* 828 /*
838 OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); 829 OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem();
839 QStringList list = QStringList::split("->", sel->text(1) ); 830 QStringList list = QStringList::split("->", sel->text(1) );
840 if( sel->isDir() ){ 831 if( sel->isDir() ){
841 QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry 832 QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry
842 switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], 833 switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0],
843 tr("Yes"),tr("No"),0,1,1) ) { 834 tr("Yes"),tr("No"),0,1,1) ) {
844 case 0: 835 case 0:
845 ::system(str.utf8().data() ); 836 ::system(str.utf8().data() );
846 break; 837 break;
847 } 838 }
848 } else { 839 } else {
849 QFile::remove( list[0] ); 840 QFile::remove( list[0] );
850 } 841 }
851 m_View->takeItem( sel ); 842 m_View->takeItem( sel );
852 delete sel; 843 delete sel;
853 */ 844 */
854} 845}
855void OFileSelector::cdUP() 846void OFileSelector::cdUP()
856{ 847{
848 // FIXME won't work on non filesystem based systems
849 // better call the Olister
857 QDir dir( m_currentDir ); 850 QDir dir( m_currentDir );
858 dir.cdUp(); 851 dir.cdUp();
859 if(dir.exists() ){ 852 if(dir.exists() ){
860 m_currentDir = dir.absPath(); 853 m_currentDir = dir.absPath();
861 reparse(); 854 reparse();
862 int count = m_location->count(); 855 int count = m_location->count();
863 slotInsertLocationPath( m_currentDir, count); 856 slotInsertLocationPath( m_currentDir, count);
864 m_location->setCurrentItem( indexByString( m_location, m_currentDir)); 857 m_location->setCurrentItem( indexByString( m_location, m_currentDir));
865 //this wont work in all instances
866 // FIXME
867 } 858 }
868} 859}
869void OFileSelector::slotHome() 860void OFileSelector::slotHome()
870{ 861{
871 cd(QDir::homeDirPath() ); 862 cd(QDir::homeDirPath() );
872} 863}
873void OFileSelector::slotDoc() 864void OFileSelector::slotDoc()
874{ 865{
875 cd(QPEApplication::documentDir() ); 866 cd(QPEApplication::documentDir() );
876} 867}
877void OFileSelector::slotNavigate( ) 868void OFileSelector::slotNavigate( )
878{ 869{
879 870
880} 871}
881// fill the View with life 872// fill the View with life
882void OFileSelector::reparse() 873void OFileSelector::reparse()
883{ 874{
884 if( m_selector == Normal ) 875 if( m_selector == Normal )
885 return; 876 return;
886 877
887 currentView()->clear(); 878 currentView()->clear();
888 879
889 if( m_shChooser) 880 if( m_shChooser)
890 qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); 881 qWarning("reparse %s", m_mimeCheck->currentText().latin1() );
891 882
892 QString currentMimeType; 883 QString currentMimeType;
893 884
894 // let's update the mimetype 885 // let's update the mimetype
895 if( m_autoMime ){ 886 if( m_autoMime ){
896 m_mimetypes.clear(); 887 m_mimetypes.clear();
897 // ok we can change mimetype so we need to be able to give a selection 888 // ok we can change mimetype so we need to be able to give a selection
898 if( m_shChooser ) { 889 if( m_shChooser ) {
899 currentMimeType = m_mimeCheck->currentText(); 890 currentMimeType = m_mimeCheck->currentText();
900 m_mimeCheck->clear(); 891 m_mimeCheck->clear();
901 892
902 // let's find possible mimetypes 893 // let's find possible mimetypes
903 m_mimetypes = currentLister()->mimeTypes( m_currentDir ); 894 m_mimetypes = currentLister()->mimeTypes( m_currentDir );
904 895
905 // add them to the chooser 896 // add them to the chooser
906 updateMimeCheck(); 897 updateMimeCheck();
907 m_mimeCheck->setCurrentItem( indexByString( m_mimeCheck, currentMimeType ) ); 898 m_mimeCheck->setCurrentItem( indexByString( m_mimeCheck, currentMimeType ) );
908 currentMimeType = m_mimeCheck->currentText(); 899 currentMimeType = m_mimeCheck->currentText();
909 } 900 }
910 }else { // no autoMime 901 }else { // no autoMime
911 // let the mimetype be set from out side the m_mimeCheck FEATURE 902 // let the mimetype be set from out side the m_mimeCheck FEATURE
912 903
913 if( m_shChooser ) 904 if( m_shChooser )
914 currentMimeType = m_mimeCheck->currentText(); 905 currentMimeType = m_mimeCheck->currentText();
915 906
916 } 907 }
917 // now we got our mimetypes we can add the files 908 // now we got our mimetypes we can add the files
918 909
919 currentLister()->reparse( m_currentDir ); 910 currentLister()->reparse( m_currentDir );
920 /* we're done with adding let's sort */ 911 /* we're done with adding let's sort */
921 currentView()->sort(); 912 currentView()->sort();
922 913
923 914
924 if( m_shTool ){ 915 if( m_shTool ){
925 m_location->insertItem( m_currentDir ); 916 m_location->insertItem( m_currentDir );
926 917
927 } 918 }
928 // reenable painting and updates 919 // reenable painting and updates
929} 920}
930/* switch lister to @param lister */ 921/* switch lister to @param lister */
931void OFileSelector::setLister(const QString& lister) { 922void OFileSelector::setLister(const QString& lister) {
932 QStringList listerList = factory()->lister(); 923 QStringList listerList = factory()->lister();
933 924
934 if (listerList.contains(lister) ) { 925 if (listerList.contains(lister) ) {
935 delete (OLister*) m_lister; 926 delete (OLister*) m_lister;
936 m_lister = factory()->lister( lister, this ); 927 m_lister = factory()->lister( lister, this );
937 }else if (!m_lister ) { 928 }else if (!m_lister ) {
938 /* 929 /*
939 * if we do not have a lister 930 * if we do not have a lister
940 * we need to take the default one 931 * we need to take the default one
941 */ 932 */
942 m_lister = new OLocalLister(this); 933 m_lister = new OLocalLister(this);
943 } 934 }
944 m_listerName = lister; 935 m_listerName = lister;
945} 936}
946void OFileSelector::setView( const QString& lis ) { 937void OFileSelector::setView( const QString& lis ) {
947 qWarning("setView "); 938 qWarning("setView ");
948 fillList(); 939 fillList();
949 if ( lis == tr("Documents") ) { 940 if ( lis == tr("Documents") ) {
950 m_selector = Normal; 941 m_selector = Normal;
951 delete m_lister; 942 delete m_lister;
952 delete m_fileView; 943 delete m_fileView;
953 m_lister = 0l; 944 m_lister = 0l;
954 m_fileView = 0l; 945 m_fileView = 0l;
955 initializeOldSelector(); 946 initializeOldSelector();
956 }else { 947 }else {
957 qWarning("lis %s", lis.latin1() ); 948 qWarning("lis %s", lis.latin1() );
958 QString list; 949 QString list;
959 950
960 delete m_lister; 951 delete m_lister;
961 delete m_fileView; 952 delete m_fileView;
962 delete m_select; 953 delete m_select;
963 m_lister =0l; 954 m_lister =0l;
964 m_fileView = 0l; 955 m_fileView = 0l;
965 m_select = 0l; 956 m_select = 0l;
966 if ( lis.startsWith("All") ) { 957 if ( lis.startsWith("All") ) {
967 m_selector = ExtendedAll; 958 m_selector = ExtendedAll;
968 list = lis.mid(4 ).stripWhiteSpace(); 959 list = lis.mid(4 ).stripWhiteSpace();
969 } else{ 960 } else{
970 list = lis; 961 list = lis;
971 m_selector = Extended; 962 m_selector = Extended;
972 } 963 }
973 setLister(m_listerName); 964 setLister(m_listerName);
974 m_fileView = factory()->view( list, this, m_mainView ); 965 m_fileView = factory()->view( list, this, m_mainView );
975 m_mainView->setWidget( m_fileView->widget() ); 966 m_mainView->setWidget( m_fileView->widget() );
976 reparse(); 967 reparse();
977 } 968 }
978} 969}
979/* 970/*
980 * the factory 971 * the factory
981 */ 972 */
982void OFileSelector::initFactory() { 973void OFileSelector::initFactory() {
983 m_fileFactory = new OFileFactory(); 974 m_fileFactory = new OFileFactory();
984 m_fileFactory->addLister(tr("Files"), newLocalLister ); 975 m_fileFactory->addLister(tr("Files"), newLocalLister );
985 m_fileFactory->addView(tr("List View"), newFileListView ); 976 m_fileFactory->addView(tr("List View"), newFileListView );
986 /* the factory is just a dummy */ 977 /* the factory is just a dummy */
987 m_fileFactory->addView(tr("Documents"), newFileListView ); 978 m_fileFactory->addView(tr("Documents"), newFileListView );
988} 979}
989void OFileSelector::fillList() { 980void OFileSelector::fillList() {
990 qWarning("fill list"); 981 qWarning("fill list");
991 if (!m_viewCheck ) 982 if (!m_viewCheck )
992 return; 983 return;
993 984
994 m_viewCheck->clear(); 985 m_viewCheck->clear();
995 QStringList list = factory()->views(); 986 QStringList list = factory()->views();
996 qWarning("views: " + list.join(";") ); 987 qWarning("views: " + list.join(";") );
997 for (QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { 988 for (QStringList::Iterator it = list.begin(); it != list.end(); ++it ) {
998 qWarning( (*it) ); 989 qWarning( (*it) );
999 if ( (*it) == tr("Documents") ) { 990 if ( (*it) == tr("Documents") ) {
1000 m_viewCheck->insertItem( (*it) ); 991 m_viewCheck->insertItem( (*it) );
1001 }else{ 992 }else{
1002 m_viewCheck->insertItem( (*it) ); 993 m_viewCheck->insertItem( (*it) );
1003 m_viewCheck->insertItem( tr("All ") + (*it) ); 994 m_viewCheck->insertItem( tr("All ") + (*it) );
1004 } 995 }
1005 } 996 }
1006} 997}
1007OFileFactory* OFileSelector::factory() { 998OFileFactory* OFileSelector::factory() {
1008 return m_fileFactory; 999 return m_fileFactory;
1009} 1000}
1010 1001
1011 1002
1012OFileView* OFileSelector::currentView() { 1003OFileView* OFileSelector::currentView() {
1013 return m_fileView; 1004 return m_fileView;
1014} 1005}
1015OFileView* OFileSelector::currentView() const{ 1006OFileView* OFileSelector::currentView() const{
1016 return m_fileView; 1007 return m_fileView;
1017} 1008}
1018int OFileSelector::filter() { 1009int OFileSelector::filter() {
1019 int filter; 1010 int filter;
1020 if ( m_selector == ExtendedAll ) 1011 if ( m_selector == ExtendedAll )
1021 filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; 1012 filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All;
1022 else 1013 else
1023 filter = QDir::Files | QDir::Dirs | QDir::All ; 1014 filter = QDir::Files | QDir::Dirs | QDir::All ;
1024 1015
1025 return filter; 1016 return filter;
1026} 1017}
1027int OFileSelector::sorting() { 1018int OFileSelector::sorting() {
1028 int sort; 1019 int sort;
1029 1020
1030 if (m_case ) 1021 if (m_case )
1031 sort = ( QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed ); 1022 sort = ( QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed );
1032 else 1023 else
1033 sort = ( QDir::Name | QDir::DirsFirst | QDir::Reversed ); 1024 sort = ( QDir::Name | QDir::DirsFirst | QDir::Reversed );
1034 1025
1035 return sort; 1026 return sort;
1036} 1027}
1037void OFileSelector::internFileSelected( const QString& s) { 1028void OFileSelector::internFileSelected( const QString& s) {
1038 emit fileSelected( s ); 1029 emit fileSelected( s );
1039 DocLnk lnk( s ); 1030 DocLnk lnk( s );
1040 internFileSelected( lnk ); 1031 internFileSelected( lnk );
1041} 1032}
1042void OFileSelector::internFileSelected( const DocLnk& d ) { 1033void OFileSelector::internFileSelected( const DocLnk& d ) {
1043 emit fileSelected( d ); 1034 emit fileSelected( d );
1044} 1035}
1045void OFileSelector::internContextMenu() { 1036void OFileSelector::internContextMenu() {
1046 emit contextMenu(); 1037 emit contextMenu();
1047} 1038}
1048void OFileSelector::internChangedDir( const QString& s) { 1039void OFileSelector::internChangedDir( const QString& s) {
1049 emit dirSelected( s ); 1040 emit dirSelected( s );
1050 cd(s ); 1041 cd(s );
1051} 1042}
1052void OFileSelector::internChangedDir( const QDir& s) { 1043void OFileSelector::internChangedDir( const QDir& s) {
1053 emit dirSelected( s ); 1044 emit dirSelected( s );
1054} 1045}
1055QPixmap OFileSelector::pixmap( const QString& s ) { 1046QPixmap OFileSelector::pixmap( const QString& s ) {
1056 1047
1057 return (*m_pixmaps)[s]; 1048 return (*m_pixmaps)[s];
1058} 1049}
1059OLister* OFileSelector::currentLister()const { 1050OLister* OFileSelector::currentLister()const {
1060 return m_lister; 1051 return m_lister;
1061} 1052}
1062void OFileSelector::initializeOldSelector() { 1053void OFileSelector::initializeOldSelector() {
1063 qWarning("initializeOldSelector"); 1054 qWarning("initializeOldSelector");
1064 1055
1065 delete m_select; 1056 delete m_select;
1066 1057
1067 // we need to initialize but keep the selected mimetype 1058 // we need to initialize but keep the selected mimetype
1068 /* we default not to show close and new buttons */ 1059 /* we default not to show close and new buttons */
1069 QString mime = currentMimeType(); 1060 QString mime = currentMimeType();
1070 qWarning("MimeType " + mime ); 1061 qWarning("MimeType " + mime );
1071 m_select = new FileSelector( mime , 1062 m_select = new FileSelector( mime ,
1072 m_mainView, "fileselector", 1063 m_mainView, "fileselector",
1073 FALSE, FALSE); 1064 FALSE, FALSE);
1074 m_select->setCategorySelectVisible( FALSE ); 1065 m_select->setCategorySelectVisible( FALSE );
1075 m_select->setTypeComboVisible( FALSE ); 1066 m_select->setTypeComboVisible( FALSE );
1076 1067
1077 connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), 1068 connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ),
1078 this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); 1069 this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) );
1079 connect(m_select, SIGNAL(closeMe() ), 1070 connect(m_select, SIGNAL(closeMe() ),
1080 this, SIGNAL(closeMe() ) ); 1071 this, SIGNAL(closeMe() ) );
1081 //connect to close me and other signals as well 1072 //connect to close me and other signals as well
1082 m_mainView->setWidget( m_select ); 1073 m_mainView->setWidget( m_select );
1083} 1074}
1084/* 1075/*
1085 * initialize the listview 1076 * initialize the listview
1086 * we will call fillList 1077 * we will call fillList
1087 * setLister 1078 * setLister
1088 * with QString::null to get the default 1079 * with QString::null to get the default
1089 * setView with either Files or All Files 1080 * setView with either Files or All Files
1090 * depending on Extended 1081 * depending on Extended
1091 */ 1082 */
1092void OFileSelector::initializeView() { 1083void OFileSelector::initializeView() {
1093 setLister(QString::null); 1084 setLister(QString::null);
1094 fillList(); 1085 fillList();
1095 if (m_selector == Extended ) { 1086 if (m_selector == Extended ) {
1096 setView( tr("List View") ); 1087 setView( tr("List View") );
1097 }else{ 1088 }else{
1098 setView( tr("All List View") ); 1089 setView( tr("All List View") );
1099 } 1090 }
1100} 1091}
1101 1092
diff --git a/libopie/ofileselector/olister.cpp b/libopie/ofileselector/olister.cpp
index ea09940..aaaf6a2 100644
--- a/libopie/ofileselector/olister.cpp
+++ b/libopie/ofileselector/olister.cpp
@@ -1,171 +1,181 @@
1#include <qcombobox.h> 1#include <qcombobox.h>
2#include <qlineedit.h>
2 3
3#include "olister.h" 4#include "olister.h"
4#include "ofileview.h" 5#include "ofileview.h"
5#include "opixmapprovider.h" 6#include "opixmapprovider.h"
6#include "ofileselector.h" 7#include "ofileselector.h"
7 8
8 9
9OLister::OLister( OFileSelector* view) 10OLister::OLister( OFileSelector* view)
10 : m_view( view ), m_acc( 0l ) 11 : m_view( view ), m_acc( 0l )
11{ 12{
12 m_prov = new OPixmapProvider( view ); 13 m_prov = new OPixmapProvider( view );
13} 14}
14OLister::~OLister() { 15OLister::~OLister() {
15 delete m_prov; 16 delete m_prov;
16} 17}
17void OLister::setPixmapProvider( OPixmapProvider* prov ) { 18void OLister::setPixmapProvider( OPixmapProvider* prov ) {
18 delete m_prov; 19 delete m_prov;
19 m_prov = prov; 20 m_prov = prov;
20} 21}
21bool OLister::showFiles()const { 22bool OLister::showFiles()const {
22 return m_view->showFiles(); 23 return m_view->showFiles();
23} 24}
24bool OLister::showDirs()const { 25bool OLister::showDirs()const {
25 return m_view->showDirs(); 26 return m_view->showDirs();
26} 27}
27void OLister::addFile( const QString& mine, 28void OLister::addFile( const QString& mine,
28 QFileInfo* info, 29 QFileInfo* info,
29 const QString& extra, 30 const QString& extra,
30 bool isSymlink ) { 31 bool isSymlink ) {
31 int t = isSymlink ? OPixmapProvider::File | OPixmapProvider::Symlink : 32 int t = isSymlink ? OPixmapProvider::File | OPixmapProvider::Symlink :
32 OPixmapProvider::File; 33 OPixmapProvider::File;
33 QPixmap pix = provider()->pixmap(t, mine, 34 QPixmap pix = provider()->pixmap(t, mine,
34 info); 35 info);
35 view()->currentView()->addFile( pix, 36 view()->currentView()->addFile( pix,
36 mine, 37 mine,
37 info, 38 info,
38 extra, 39 extra,
39 isSymlink ); 40 isSymlink );
40} 41}
41void OLister::addFile( const QString& mine, 42void OLister::addFile( const QString& mine,
42 const QString& path, 43 const QString& path,
43 const QString& file, 44 const QString& file,
44 const QString& extra, 45 const QString& extra,
45 bool isSymlink ) { 46 bool isSymlink ) {
46 int t = isSymlink ? OPixmapProvider::File | OPixmapProvider::Symlink : 47 int t = isSymlink ? OPixmapProvider::File | OPixmapProvider::Symlink :
47 OPixmapProvider::File; 48 OPixmapProvider::File;
48 49
49 QPixmap pix = provider()->pixmap(t, mine, path, file ); 50 QPixmap pix = provider()->pixmap(t, mine, path, file );
50 view()->currentView()->addFile( pix, 51 view()->currentView()->addFile( pix,
51 mine, 52 mine,
52 path, 53 path,
53 file, 54 file,
54 extra, 55 extra,
55 isSymlink ); 56 isSymlink );
56} 57}
57void OLister::addDir( const QString& mine, 58void OLister::addDir( const QString& mine,
58 QFileInfo* info, 59 QFileInfo* info,
59 const QString& extra, 60 const QString& extra,
60 bool isSymlink ) { 61 bool isSymlink ) {
61 int t = isSymlink ? OPixmapProvider::Dir | OPixmapProvider::Symlink : 62 int t = isSymlink ? OPixmapProvider::Dir | OPixmapProvider::Symlink :
62 OPixmapProvider::Dir; 63 OPixmapProvider::Dir;
63 QPixmap pix = provider()->pixmap(t, mine, info ); 64 QPixmap pix = provider()->pixmap(t, mine, info );
64 view()->currentView()->addDir( pix, 65 view()->currentView()->addDir( pix,
65 mine, 66 mine,
66 info, 67 info,
67 extra, 68 extra,
68 isSymlink ); 69 isSymlink );
69} 70}
70void OLister::addDir( const QString& mine, 71void OLister::addDir( const QString& mine,
71 const QString& path, 72 const QString& path,
72 const QString& dir, 73 const QString& dir,
73 const QString& extra, 74 const QString& extra,
74 bool isSymlink ) { 75 bool isSymlink ) {
75 76
76 int t = isSymlink ? OPixmapProvider::Dir | OPixmapProvider::Symlink : 77 int t = isSymlink ? OPixmapProvider::Dir | OPixmapProvider::Symlink :
77 OPixmapProvider::Dir; 78 OPixmapProvider::Dir;
78 QPixmap pix = provider()->pixmap(t, mine, path, dir ); 79 QPixmap pix = provider()->pixmap(t, mine, path, dir );
79 80
80 view()->currentView()->addDir( pix, 81 view()->currentView()->addDir( pix,
81 mine, 82 mine,
82 path, 83 path,
83 dir, 84 dir,
84 extra, 85 extra,
85 isSymlink ); 86 isSymlink );
86} 87}
87void OLister::addSymlink( const QString& mine, 88void OLister::addSymlink( const QString& mine,
88 QFileInfo* info, 89 QFileInfo* info,
89 const QString& extra, 90 const QString& extra,
90 bool isSymlink ) { 91 bool isSymlink ) {
91 QPixmap pix = provider()->pixmap( OPixmapProvider::Symlink, mine, info ); 92 QPixmap pix = provider()->pixmap( OPixmapProvider::Symlink, mine, info );
92 view()->currentView()->addSymlink( pix, 93 view()->currentView()->addSymlink( pix,
93 mine, 94 mine,
94 info, 95 info,
95 extra, 96 extra,
96 isSymlink ); 97 isSymlink );
97} 98}
98void OLister::addSymlink( const QString& mine, 99void OLister::addSymlink( const QString& mine,
99 const QString& path, 100 const QString& path,
100 const QString& name, 101 const QString& name,
101 const QString& extra, 102 const QString& extra,
102 bool isSymlink ) { 103 bool isSymlink ) {
103 QPixmap pix = provider()->pixmap( OPixmapProvider::Symlink, mine, 104 QPixmap pix = provider()->pixmap( OPixmapProvider::Symlink, mine,
104 path, name ); 105 path, name );
105 view()->currentView()->addSymlink( pix, 106 view()->currentView()->addSymlink( pix,
106 mine, 107 mine,
107 path, 108 path,
108 name, 109 name,
109 extra, 110 extra,
110 isSymlink ); 111 isSymlink );
111} 112}
112OFileSelector* OLister::view() { 113OFileSelector* OLister::view() {
113 return m_view; 114 return m_view;
114} 115}
116OFileSelector* OLister::view()const {
117 return m_view;
118}
115OPixmapProvider* OLister::provider() { 119OPixmapProvider* OLister::provider() {
116 return m_prov; 120 return m_prov;
117} 121}
118bool OLister::compliesMime( const QString& mime ) { 122bool OLister::compliesMime( const QString& mime ) {
119 return view()->compliesMime( mime ); 123 return view()->compliesMime( mime );
120} 124}
121void OLister::internFileSelected( const QString& dir ) { 125void OLister::internFileSelected( const QString& dir ) {
122 view()->internFileSelected( dir ); 126 view()->internFileSelected( dir );
123} 127}
124void OLister::internChangedDir( const QString& dir ) { 128void OLister::internChangedDir( const QString& dir ) {
125 view()->internChangedDir( dir ); 129 view()->internChangedDir( dir );
126} 130}
127OListerCmbAccess* OLister::comboBox() { 131OListerCmbAccess* OLister::comboBox() {
128 if (!m_acc ) 132 if (!m_acc )
129 m_acc = new OListerCmbAccess( view()->m_location ); 133 m_acc = new OListerCmbAccess( view()->m_location );
130 134
131 return m_acc; 135 return m_acc;
132} 136}
133 137
134 138
135OListerCmbAccess::OListerCmbAccess(QComboBox* cmb ) 139OListerCmbAccess::OListerCmbAccess(QComboBox* cmb )
136 : m_cmb( cmb ) 140 : m_cmb( cmb )
137{} 141{}
138OListerCmbAccess::~OListerCmbAccess() { 142OListerCmbAccess::~OListerCmbAccess() {
139} 143}
140void OListerCmbAccess::clear() { 144void OListerCmbAccess::clear() {
141 if ( m_cmb ) 145 if ( m_cmb )
142 m_cmb->clear(); 146 m_cmb->clear();
143} 147}
144void OListerCmbAccess::setCurrentItem( const QString& add, bool FORCE_ADD) { 148void OListerCmbAccess::setCurrentItem( const QString& add, bool FORCE_ADD) {
145 if ( !m_cmb ) return; 149 if ( !m_cmb ) return;
146 150
147 151
148 int c = m_cmb->count(); 152 int c = m_cmb->count();
149 for ( int i = 0; i < m_cmb->count(); i++ ) { 153 for ( int i = 0; i < m_cmb->count(); i++ ) {
150 if ( m_cmb->text(i) == add ) { 154 if ( m_cmb->text(i) == add ) {
151 m_cmb->setCurrentItem( i ); 155 m_cmb->setCurrentItem( i );
152 return; 156 return;
153 } 157 }
154 } 158 }
155 if (!FORCE_ADD ) return; 159 if (!FORCE_ADD ) return;
156 160
157 161
158 m_cmb->insertItem(add ); 162 m_cmb->insertItem(add );
159 m_cmb->setCurrentItem( c ); 163 m_cmb->setCurrentItem( c );
160} 164}
161void OListerCmbAccess::insert( const QString& str ) { 165void OListerCmbAccess::insert( const QString& str ) {
162 if ( m_cmb ) 166 if ( m_cmb )
163 m_cmb->insertItem( str ); 167 m_cmb->insertItem( str );
164} 168}
165QString OListerCmbAccess::currentText()const { 169QString OListerCmbAccess::currentText()const {
166 QString str; 170 QString str;
167 if (m_cmb ) 171 if (m_cmb )
168 str = m_cmb->currentText(); 172 str = m_cmb->currentText();
169 173
170 return str; 174 return str;
171} 175}
176QString OLister::lineEdit()const {
177 if ( view()->m_shLne )
178 return view()->m_edit->text();
179
180 return QString::null;
181}
diff --git a/libopie/ofileselector/olister.h b/libopie/ofileselector/olister.h
index cd84316..4adb9f8 100644
--- a/libopie/ofileselector/olister.h
+++ b/libopie/ofileselector/olister.h
@@ -1,128 +1,144 @@
1#ifndef OPIE_FILE_LISTER_H 1#ifndef OPIE_FILE_LISTER_H
2#define OPIE_FILE_LISTER_H 2#define OPIE_FILE_LISTER_H
3 3
4#include <qfileinfo.h> 4#include <qfileinfo.h>
5#include <qmap.h> 5#include <qmap.h>
6#include <qstring.h> 6#include <qstring.h>
7#include <qstringlist.h> 7#include <qstringlist.h>
8 8
9class QComboBox; 9class QComboBox;
10class OPixmapProvider; 10class OPixmapProvider;
11class OFileSelector; 11class OFileSelector;
12 12
13class OListerCmbAccess; 13class OListerCmbAccess;
14/** 14/**
15 * lister is something like KIO but very 15 * lister is something like KIO but very
16 * very basic and currently only for 16 * very basic and currently only for
17 * populating our views. 17 * populating our views.
18 * This is a base class which needs to be implemented. 18 * This is a base class which needs to be implemented.
19 * @see OLocalLister for a filesystem based implementation 19 * @see OLocalLister for a filesystem based implementation
20 */ 20 */
21 21
22class OLister { 22class OLister {
23public: 23public:
24 OLister( OFileSelector* ); 24 OLister( OFileSelector* );
25 virtual ~OLister(); 25 virtual ~OLister();
26 virtual void reparse(const QString& path) = 0; 26
27 /**
28 * if path == QString::null reread current dir
29 */
30 virtual void reparse(const QString& path = QString::null ) = 0;
27 31
28 /** 32 /**
29 * return a list of available mimetypes 33 * return a list of available mimetypes
30 */ 34 */
31 virtual QMap<QString, QStringList> mimeTypes( const QString& dir ) = 0; 35 virtual QMap<QString, QStringList> mimeTypes( const QString& dir ) = 0;
32 void setPixmapProvider( OPixmapProvider* ); 36 void setPixmapProvider( OPixmapProvider* );
33 37
34 38
35 /* some way a slot */ 39 /* some way a slot */
36 virtual void fileSelected( const QString& dir, const QString& file, const QString& extra ) = 0; 40 virtual void fileSelected( const QString& dir, const QString& file, const QString& extra ) = 0;
37 virtual void changedDir( const QString& dir, const QString& file, const QString& extra ) = 0; 41 virtual void changedDir( const QString& dir, const QString& file, const QString& extra ) = 0;
42 virtual QString selectedName()const = 0;
43 virtual QStringList selectedNames()const = 0;
38protected: 44protected:
39 /** 45 /**
40 * I hate too big classes 46 * I hate too big classes
41 * this is a way to group 47 * this is a way to group
42 * access to a ComboBox 48 * access to a ComboBox
43 * which might exist or 49 * which might exist or
44 * not in a secure way 50 * not in a secure way
45 */ 51 */
46 OListerCmbAccess* comboBox(); 52 OListerCmbAccess* comboBox();
47 53
48 bool showFiles()const; 54 bool showFiles()const;
49 bool showDirs()const; 55 bool showDirs()const;
50 bool compliesMime( const QString& mime ); 56 bool compliesMime( const QString& mime );
51 void addFile( const QString& mine, 57 void addFile( const QString& mine,
52 QFileInfo*, 58 QFileInfo*,
53 const QString& extra = QString::null, 59 const QString& extra = QString::null,
54 bool isSymlink = FALSE ); 60 bool isSymlink = FALSE );
55 61
56 void addFile( const QString& mine, 62 void addFile( const QString& mine,
57 const QString& path, 63 const QString& path,
58 const QString& file, 64 const QString& file,
59 const QString& extra = QString::null, 65 const QString& extra = QString::null,
60 bool isSymlink = FALSE ); 66 bool isSymlink = FALSE );
61 void addDir( const QString& mine, 67 void addDir( const QString& mine,
62 QFileInfo*, 68 QFileInfo*,
63 const QString& extra = QString::null, 69 const QString& extra = QString::null,
64 bool isSymlink = FALSE ); 70 bool isSymlink = FALSE );
65 void addDir( const QString& mine, 71 void addDir( const QString& mine,
66 const QString& path, 72 const QString& path,
67 const QString& dir, 73 const QString& dir,
68 const QString& extra = QString::null, 74 const QString& extra = QString::null,
69 bool isSymlink = FALSE ); 75 bool isSymlink = FALSE );
70 void addSymlink( const QString& mine, 76 void addSymlink( const QString& mine,
71 QFileInfo* info, 77 QFileInfo* info,
72 const QString& extra = QString::null, 78 const QString& extra = QString::null,
73 bool isSymlink = FALSE); 79 bool isSymlink = FALSE);
74 void addSymlink( const QString& mine, 80 void addSymlink( const QString& mine,
75 const QString& path, 81 const QString& path,
76 const QString& name, 82 const QString& name,
77 const QString& extra = QString::null, 83 const QString& extra = QString::null,
78 bool isSymlink = FALSE ); 84 bool isSymlink = FALSE );
79 OFileSelector* view(); 85 OFileSelector* view();
86 OFileSelector* view()const;
80 OPixmapProvider* provider(); 87 OPixmapProvider* provider();
81 void internFileSelected( const QString& file ); 88 void internFileSelected( const QString& file );
82 void internChangedDir( const QString& dir ); 89 void internChangedDir( const QString& dir );
90
91 /**
92 * try to take
93 * the text from the mainwindows
94 * lineedit
95 * if it's not available QString::null
96 * will be returned
97 */
98 QString lineEdit()const;
83private: 99private:
84 OFileSelector* m_view; 100 OFileSelector* m_view;
85 OPixmapProvider* m_prov; 101 OPixmapProvider* m_prov;
86 OListerCmbAccess* m_acc; 102 OListerCmbAccess* m_acc;
87 103
88 class Private; 104 class Private;
89 Private *d; 105 Private *d;
90}; 106};
91 107
92class OListerCmbAccess { 108class OListerCmbAccess {
93 friend class OLister; 109 friend class OLister;
94public: 110public:
95 OListerCmbAccess( QComboBox* = 0l); 111 OListerCmbAccess( QComboBox* = 0l);
96 ~OListerCmbAccess(); 112 ~OListerCmbAccess();
97 113
98 /** 114 /**
99 * clears the combobox 115 * clears the combobox
100 */ 116 */
101 void clear(); 117 void clear();
102 118
103 /** 119 /**
104 * set's @param add to be the current Item 120 * set's @param add to be the current Item
105 * if the item is not present it'll be removed 121 * if the item is not present it'll be removed
106 */ 122 */
107 void setCurrentItem( const QString& add, bool FORECE_ADD = TRUE ); 123 void setCurrentItem( const QString& add, bool FORECE_ADD = TRUE );
108 124
109 /** 125 /**
110 * inserts the the String at 126 * inserts the the String at
111 * a non predictable position... The position is determined 127 * a non predictable position... The position is determined
112 * by the QComboBox code 128 * by the QComboBox code
113 */ 129 */
114 void insert( const QString& ); 130 void insert( const QString& );
115 131
116 /** 132 /**
117 * 133 *
118 */ 134 */
119 QString currentText()const; 135 QString currentText()const;
120 136
121private: 137private:
122 class Private; 138 class Private;
123 Private* d; 139 Private* d;
124 QComboBox* m_cmb; 140 QComboBox* m_cmb;
125 141
126}; 142};
127 143
128#endif 144#endif
diff --git a/libopie/ofileselector/olocallister.cpp b/libopie/ofileselector/olocallister.cpp
index 5d7884d..4d36d64 100644
--- a/libopie/ofileselector/olocallister.cpp
+++ b/libopie/ofileselector/olocallister.cpp
@@ -1,125 +1,150 @@
1#include <qdir.h> 1#include <qdir.h>
2#include <qfileinfo.h> 2#include <qfileinfo.h>
3#include <qmap.h> 3#include <qmap.h>
4 4
5#include <qpe/mimetype.h> 5#include <qpe/mimetype.h>
6 6
7#include "ofileselector.h" 7#include "ofileselector.h"
8#include "ofileview.h"
8#include "olocallister.h" 9#include "olocallister.h"
9 10
10OLocalLister::OLocalLister( OFileSelector* file ) 11OLocalLister::OLocalLister( OFileSelector* file )
11 : OLister( file ) 12 : OLister( file )
12{ 13{
14 m_dir = QDir::homeDirPath();
13} 15}
14OLocalLister::~OLocalLister() { 16OLocalLister::~OLocalLister() {
15} 17}
16 18
17QMap<QString, QStringList> OLocalLister::mimeTypes( const QString& curDir ) { 19QMap<QString, QStringList> OLocalLister::mimeTypes( const QString& curDir ) {
18 QMap<QString, QStringList> mimes; 20 QMap<QString, QStringList> mimes;
19 21
20 // let's find possible mimetypes 22 // let's find possible mimetypes
21 QDir dir( curDir ); 23 QDir dir( curDir );
22 dir.setFilter( QDir::Files | QDir::Readable ); 24 dir.setFilter( QDir::Files | QDir::Readable );
23 dir.setSorting( QDir::Size ); 25 dir.setSorting( QDir::Size );
24 26
25 const QFileInfoList *list = dir.entryInfoList(); 27 const QFileInfoList *list = dir.entryInfoList();
26 QFileInfoListIterator it( *list ); 28 QFileInfoListIterator it( *list );
27 QFileInfo *fi; 29 QFileInfo *fi;
28 30
29 while( (fi=it.current() ) ) { 31 while( (fi=it.current() ) ) {
30 /* skip .desktop */ 32 /* skip .desktop */
31 if( fi->extension() == QString::fromLatin1("desktop") ){ 33 if( fi->extension() == QString::fromLatin1("desktop") ){
32 ++it; 34 ++it;
33 continue; 35 continue;
34 } 36 }
35 MimeType type( fi->absFilePath() ); 37 MimeType type( fi->absFilePath() );
36 38
37 if( !mimes.contains( type.id() ) ){ 39 if( !mimes.contains( type.id() ) ){
38 mimes.insert( type.id(), type.id() ); 40 mimes.insert( type.id(), type.id() );
39 } 41 }
40 42
41 ++it; 43 ++it;
42 } 44 }
43 45
44 return mimes; 46 return mimes;
45} 47}
46/** 48/**
47 * FIXME mimecheck 49 * FIXME mimecheck
48 * use mime check for that 50 * use mime check for that
49 * filter dirs 51 * filter dirs
50 * filter filters 52 * filter filters
51 * filter files 53 * filter files
52 * filter mimetypes 54 * filter mimetypes
53 */ 55 */
54void OLocalLister::reparse( const QString& path ) { 56void OLocalLister::reparse( const QString& pa ) {
57 if (!pa.isEmpty() )
58 m_dir = pa;
59
55 QString currentMimeType; 60 QString currentMimeType;
56 QDir dir( path ); 61 QDir dir( m_dir );
57 62
58 dir.setSorting( view()->sorting() ); 63 dir.setSorting( view()->sorting() );
59 dir.setFilter( view()->filter() ); 64 dir.setFilter( view()->filter() );
60 65
61 66
62 const QFileInfoList *list = dir.entryInfoList(); 67 const QFileInfoList *list = dir.entryInfoList();
63 QFileInfoListIterator it( *list ); 68 QFileInfoListIterator it( *list );
64 QFileInfo *fi; 69 QFileInfo *fi;
65 70
66 while( (fi=it.current() ) ){ 71 while( (fi=it.current() ) ){
67 72
68 if( fi->fileName() == QString::fromLatin1("..") || 73 if( fi->fileName() == QString::fromLatin1("..") ||
69 fi->fileName() == QString::fromLatin1(".") ){ 74 fi->fileName() == QString::fromLatin1(".") ){
70 ++it; 75 ++it;
71 continue; 76 continue;
72 } 77 }
73 if( fi->isSymLink() ){ 78 if( fi->isSymLink() ){
74 QString file = fi->dirPath( true ) + "/" + fi->readLink(); 79 QString file = fi->dirPath( true ) + "/" + fi->readLink();
75 /* 80 /*
76 * 5 tries to prevent dos attack 81 * 5 tries to prevent dos attack
77 */ 82 */
78 for( int i = 0; i<=4; i++) { 83 for( int i = 0; i<=4; i++) {
79 QFileInfo info( file ); 84 QFileInfo info( file );
80 if( !info.exists() ){ 85 if( !info.exists() ){
81 addSymlink( currentMimeType, fi, QString::null, TRUE ); 86 addSymlink( currentMimeType, fi, QString::null, TRUE );
82 break; 87 break;
83 }else if( info.isDir() ){ 88 }else if( info.isDir() ){
84 if (!showDirs() ) 89 if (!showDirs() )
85 break; 90 break;
86 91
87 addDir( currentMimeType, fi, QString::null, 92 addDir( currentMimeType, fi, QString::null,
88 TRUE ); 93 TRUE );
89 break; 94 break;
90 }else if( info.isFile() ){ 95 }else if( info.isFile() ){
91 /* if not show files skip it */ 96 /* if not show files skip it */
92 if (!showFiles() ) 97 if (!showFiles() )
93 break; 98 break;
94 99
95 /* check if we comply to the mimetype */ 100 /* check if we comply to the mimetype */
96 MimeType type( info.absFilePath() ); 101 MimeType type( info.absFilePath() );
97 if (compliesMime( type.id() ) ) 102 if (compliesMime( type.id() ) )
98 addFile( currentMimeType, fi, QString::null, TRUE ); 103 addFile( currentMimeType, fi, QString::null, TRUE );
99 104
100 break; 105 break;
101 }else if( info.isSymLink() ){ 106 }else if( info.isSymLink() ){
102 file = info.dirPath(true ) + "/" + info.readLink() ; 107 file = info.dirPath(true ) + "/" + info.readLink() ;
103 break; 108 break;
104 }else if( i == 4){ 109 }else if( i == 4){
105 addSymlink( currentMimeType, fi ); 110 addSymlink( currentMimeType, fi );
106 } 111 }
107 } 112 }
108 113
109 }else if( fi->isDir() ){ 114 }else if( fi->isDir() ){
110 if (showDirs() ) 115 if (showDirs() )
111 addDir( currentMimeType, fi ); 116 addDir( currentMimeType, fi );
112 }else if( fi->isFile() ){ 117 }else if( fi->isFile() ){
113 if ( showFiles() ) 118 if ( showFiles() )
114 addFile( currentMimeType, fi ); 119 addFile( currentMimeType, fi );
115 } 120 }
116 ++it; 121 ++it;
117 } // of while loop 122 } // of while loop
118} 123}
119/* more accepting it code */ 124/* more accepting it code */
120void OLocalLister::fileSelected( const QString& dir, const QString& file, const QString& ) { 125void OLocalLister::fileSelected( const QString& dir, const QString& file, const QString& ) {
121 internFileSelected( dir + "/" + file ); 126 internFileSelected( dir + "/" + file );
122} 127}
123void OLocalLister::changedDir( const QString& dir, const QString& file, const QString& ) { 128void OLocalLister::changedDir( const QString& dir, const QString& file, const QString& ) {
124 internChangedDir( dir + "/" + file ); 129 internChangedDir( dir + "/" + file );
125} 130}
131/*
132 * assemble the the Url now
133 */
134QString OLocalLister::selectedName()const {
135 QString str = m_dir;
136 QString name = lineEdit();
137
138 if ( name.isEmpty() )
139 name = view()->currentView()->selectedName();
140
141 str += "/" + name;
142
143 return str;
144}
145QStringList OLocalLister::selectedNames()const {
146 QStringList list;
147 list << selectedName();
148
149 return list;
150}
diff --git a/libopie/ofileselector/olocallister.h b/libopie/ofileselector/olocallister.h
index 01e6f3c..0cdf51f 100644
--- a/libopie/ofileselector/olocallister.h
+++ b/libopie/ofileselector/olocallister.h
@@ -1,16 +1,21 @@
1#ifndef OPIE_LOCAL_LISTER 1#ifndef OPIE_LOCAL_LISTER
2#define OPIE_LOCAL_LISTER 2#define OPIE_LOCAL_LISTER
3 3
4#include "olister.h" 4#include "olister.h"
5 5
6class OLocalLister : public OLister { 6class OLocalLister : public OLister {
7public: 7public:
8 OLocalLister( OFileSelector* ); 8 OLocalLister( OFileSelector* );
9 ~OLocalLister(); 9 ~OLocalLister();
10 void reparse( const QString& path ); 10 void reparse( const QString& path );
11 QMap<QString, QStringList> mimeTypes(const QString& dir ); 11 QMap<QString, QStringList> mimeTypes(const QString& dir );
12 void fileSelected( const QString& dir, const QString& file, const QString& ); 12 void fileSelected( const QString& dir, const QString& file, const QString& );
13 void changedDir( const QString& dir, const QString& file,const QString& ); 13 void changedDir( const QString& dir, const QString& file,const QString& );
14 QString selectedName()const;
15 QStringList selectedNames()const;
16
17private:
18 QString m_dir;
14}; 19};
15 20
16#endif 21#endif