author | llornkcor <llornkcor> | 2003-02-24 03:49:20 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2003-02-24 03:49:20 (UTC) |
commit | 04470810d71cc8aa3ddde193559312fd3ecc7a11 (patch) (unidiff) | |
tree | f9d291fed1aa1627927863fc0381d6d15f6b6f7e | |
parent | e144592570ddacf26d27f3e2759dbe7f2370d0a0 (diff) | |
download | opie-04470810d71cc8aa3ddde193559312fd3ecc7a11.zip opie-04470810d71cc8aa3ddde193559312fd3ecc7a11.tar.gz opie-04470810d71cc8aa3ddde193559312fd3ecc7a11.tar.bz2 |
fix for hidden dirs
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.cpp | 34 | ||||
-rw-r--r-- | noncore/apps/advancedfm/advancedfmMenu.cpp | 18 |
2 files changed, 26 insertions, 26 deletions
diff --git a/noncore/apps/advancedfm/advancedfm.cpp b/noncore/apps/advancedfm/advancedfm.cpp index fc6c3bf..d56e746 100644 --- a/noncore/apps/advancedfm/advancedfm.cpp +++ b/noncore/apps/advancedfm/advancedfm.cpp | |||
@@ -225,258 +225,255 @@ void AdvancedFm::populateView() | |||
225 | lstat( mydirent->d_name, &buf); | 225 | lstat( mydirent->d_name, &buf); |
226 | // qDebug(mydirent->d_name); | 226 | // qDebug(mydirent->d_name); |
227 | fileL.sprintf("%s", mydirent->d_name); | 227 | fileL.sprintf("%s", mydirent->d_name); |
228 | devT = buf.st_dev; | 228 | devT = buf.st_dev; |
229 | fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); | 229 | fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); |
230 | fileDate.sprintf("%s", ctime( &buf.st_mtime)); | 230 | fileDate.sprintf("%s", ctime( &buf.st_mtime)); |
231 | if( fileL.find(".") == -1 ) | 231 | if( fileL.find(".") == -1 ) |
232 | { | 232 | { |
233 | item= new QListViewItem( thisView, fileL, fileS, fileDate); | 233 | item= new QListViewItem( thisView, fileL, fileS, fileDate); |
234 | pm = Resource::loadPixmap( "UnknownDocument-14" ); | 234 | pm = Resource::loadPixmap( "UnknownDocument-14" ); |
235 | item->setPixmap( 0,pm); | 235 | item->setPixmap( 0,pm); |
236 | } | 236 | } |
237 | } | 237 | } |
238 | 238 | ||
239 | closedir(dir); | 239 | closedir(dir); |
240 | } | 240 | } |
241 | 241 | ||
242 | thisView->setSorting( 3,FALSE); | 242 | thisView->setSorting( 3,FALSE); |
243 | fillCombo( (const QString &) path ); | 243 | fillCombo( (const QString &) path ); |
244 | } | 244 | } |
245 | 245 | ||
246 | 246 | ||
247 | void AdvancedFm::ListClicked(QListViewItem *selectedItem) | 247 | void AdvancedFm::ListClicked(QListViewItem *selectedItem) |
248 | { | 248 | { |
249 | if(selectedItem) | 249 | if(selectedItem) |
250 | { | 250 | { |
251 | QString strItem=selectedItem->text(0); | 251 | QString strItem=selectedItem->text(0); |
252 | QString strSize=selectedItem->text(1); | 252 | QString strSize=selectedItem->text(1); |
253 | strSize=strSize.stripWhiteSpace(); | 253 | strSize=strSize.stripWhiteSpace(); |
254 | bool isDirectory = false; | 254 | bool isDirectory = false; |
255 | QString strItem2; | 255 | QString strItem2; |
256 | 256 | ||
257 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 )//if symlink | 257 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 )//if symlink |
258 | { | 258 | { |
259 | strItem2 = dealWithSymName((const QString&)strItem); | 259 | strItem2 = dealWithSymName((const QString&)strItem); |
260 | if(QDir(strItem2).exists() ) | 260 | if(QDir(strItem2).exists() ) |
261 | strItem = strItem2; | 261 | strItem = strItem2; |
262 | } | 262 | } |
263 | 263 | ||
264 | if( strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) | 264 | if( strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) |
265 | { | 265 | { |
266 | 266 | ||
267 | if(QDir(strItem).exists()) | 267 | if(QDir(strItem).exists()) |
268 | isDirectory = true; | 268 | isDirectory = true; |
269 | } | 269 | } |
270 | 270 | ||
271 | if( isDirectory ) | 271 | if( isDirectory ) |
272 | { | 272 | { |
273 | CurrentDir()->cd( strItem, TRUE); | 273 | CurrentDir()->cd( strItem, TRUE); |
274 | populateView(); | 274 | populateView(); |
275 | CurrentView()->ensureItemVisible( CurrentView()->firstChild()); | 275 | CurrentView()->ensureItemVisible( CurrentView()->firstChild()); |
276 | } | 276 | } |
277 | chdir( strItem.latin1()); | 277 | chdir( strItem.latin1()); |
278 | } | 278 | } |
279 | } | 279 | } |
280 | 280 | ||
281 | void AdvancedFm::ListPressed( int mouse, QListViewItem *, const QPoint& , int ) { | 281 | void AdvancedFm::ListPressed( int mouse, QListViewItem *, const QPoint& , int ) { |
282 | switch (mouse) { | 282 | switch (mouse) { |
283 | case 1: | 283 | case 1: |
284 | { | 284 | { |
285 | if(renameBox != 0 ) | 285 | if(renameBox != 0 ) |
286 | { | 286 | { |
287 | cancelRename(); | 287 | cancelRename(); |
288 | } | 288 | } |
289 | |||
290 | } | 289 | } |
291 | break; | 290 | break; |
292 | case 2: | 291 | case 2: |
293 | menuTimer.start( 500, TRUE ); | 292 | menuTimer.start( 500, TRUE ); |
294 | break; | 293 | break; |
295 | }; | 294 | }; |
296 | } | 295 | } |
297 | 296 | ||
298 | void AdvancedFm::switchToLocalTab() | 297 | void AdvancedFm::switchToLocalTab() |
299 | { | 298 | { |
300 | TabWidget->setCurrentTab(0); | 299 | TabWidget->setCurrentTab(0); |
301 | Local_View->setFocus(); | 300 | Local_View->setFocus(); |
302 | } | 301 | } |
303 | 302 | ||
304 | void AdvancedFm::switchToRemoteTab() | 303 | void AdvancedFm::switchToRemoteTab() |
305 | { | 304 | { |
306 | TabWidget->setCurrentTab(1); | 305 | TabWidget->setCurrentTab(1); |
307 | Remote_View->setFocus(); | 306 | Remote_View->setFocus(); |
308 | } | 307 | } |
309 | 308 | ||
310 | void AdvancedFm::readConfig() | 309 | void AdvancedFm::readConfig() |
311 | { | 310 | { |
312 | Config cfg("AdvancedFm"); | 311 | Config cfg("AdvancedFm"); |
313 | } | 312 | } |
314 | 313 | ||
315 | void AdvancedFm::writeConfig() | 314 | void AdvancedFm::writeConfig() |
316 | { | 315 | { |
317 | Config cfg("AdvancedFm"); | 316 | Config cfg("AdvancedFm"); |
318 | } | 317 | } |
319 | 318 | ||
320 | void AdvancedFm::currentPathComboChanged() | 319 | void AdvancedFm::currentPathComboChanged() |
321 | { | 320 | { |
322 | if(QDir( currentPathCombo->lineEdit()->text()).exists()) | 321 | if(QDir( currentPathCombo->lineEdit()->text()).exists()) |
323 | { | 322 | { |
324 | CurrentDir()->setPath( currentPathCombo->lineEdit()->text() ); | 323 | CurrentDir()->setPath( currentPathCombo->lineEdit()->text() ); |
325 | populateView(); | 324 | populateView(); |
326 | } | 325 | } |
327 | else | 326 | else |
328 | { | 327 | { |
329 | QMessageBox::message(tr("Note"),tr("That directory does not exist")); | 328 | QMessageBox::message(tr("Note"),tr("That directory does not exist")); |
330 | } | 329 | } |
331 | } | 330 | } |
332 | 331 | ||
333 | void AdvancedFm::fillCombo(const QString ¤tPath) | 332 | void AdvancedFm::fillCombo(const QString ¤tPath) |
334 | { | 333 | { |
335 | // qDebug("%d",TabWidget->getCurrentTab()); | 334 | // qDebug("%d",TabWidget->getCurrentTab()); |
336 | if ( whichTab == 1) | 335 | if ( whichTab == 1) |
337 | { | 336 | { |
338 | currentPathCombo->lineEdit()->setText( currentPath); | 337 | currentPathCombo->lineEdit()->setText( currentPath); |
339 | if( localDirPathStringList.grep( currentPath,TRUE).isEmpty() ) | 338 | if( localDirPathStringList.grep( currentPath,TRUE).isEmpty() ) |
340 | { | 339 | { |
341 | currentPathCombo->clear(); | 340 | currentPathCombo->clear(); |
342 | localDirPathStringList.prepend( currentPath ); | 341 | localDirPathStringList.prepend( currentPath ); |
343 | currentPathCombo->insertStringList( localDirPathStringList,-1); | 342 | currentPathCombo->insertStringList( localDirPathStringList,-1); |
344 | } | 343 | } |
345 | } | 344 | } |
346 | else | 345 | else |
347 | { | 346 | { |
348 | currentPathCombo->lineEdit()->setText( currentPath); | 347 | currentPathCombo->lineEdit()->setText( currentPath); |
349 | if( remoteDirPathStringList.grep( currentPath,TRUE).isEmpty() ) | 348 | if( remoteDirPathStringList.grep( currentPath,TRUE).isEmpty() ) |
350 | { | 349 | { |
351 | currentPathCombo->clear(); | 350 | currentPathCombo->clear(); |
352 | remoteDirPathStringList.prepend( currentPath ); | 351 | remoteDirPathStringList.prepend( currentPath ); |
353 | currentPathCombo->insertStringList( remoteDirPathStringList,-1); | 352 | currentPathCombo->insertStringList( remoteDirPathStringList,-1); |
354 | } | 353 | } |
355 | } | 354 | } |
356 | } | 355 | } |
357 | 356 | ||
358 | void AdvancedFm::currentPathComboActivated(const QString & currentPath) | 357 | void AdvancedFm::currentPathComboActivated(const QString & currentPath) |
359 | { | 358 | { |
360 | chdir( currentPath.latin1() ); | 359 | chdir( currentPath.latin1() ); |
361 | CurrentDir()->cd( currentPath, TRUE); | 360 | CurrentDir()->cd( currentPath, TRUE); |
362 | populateView(); | 361 | populateView(); |
363 | update(); | 362 | update(); |
364 | } | 363 | } |
365 | 364 | ||
366 | QStringList AdvancedFm::getPath() | 365 | QStringList AdvancedFm::getPath() |
367 | { | 366 | { |
368 | QStringList strList; | 367 | QStringList strList; |
369 | QListView *thisView=CurrentView(); | 368 | QListView *thisView=CurrentView(); |
370 | QList<QListViewItem> * getSelectedItems( QListView * thisView ); | 369 | QList<QListViewItem> * getSelectedItems( QListView * thisView ); |
371 | QListViewItemIterator it( thisView ); | 370 | QListViewItemIterator it( thisView ); |
372 | for ( ; it.current(); ++it ) | 371 | for ( ; it.current(); ++it ) |
373 | { | 372 | { |
374 | if ( it.current()->isSelected() ) | 373 | if ( it.current()->isSelected() ) |
375 | { | 374 | { |
376 | strList << it.current()->text(0); | 375 | strList << it.current()->text(0); |
377 | // qDebug(it.current()->text(0)); | 376 | // qDebug(it.current()->text(0)); |
378 | } | 377 | } |
379 | } | 378 | } |
380 | return strList; | 379 | return strList; |
381 | } | 380 | } |
382 | 381 | ||
383 | void AdvancedFm::homeButtonPushed() | 382 | void AdvancedFm::homeButtonPushed() |
384 | { | 383 | { |
385 | QString current = QDir::homeDirPath(); | 384 | QString current = QDir::homeDirPath(); |
386 | chdir( current.latin1() ); | 385 | chdir( current.latin1() ); |
387 | CurrentDir()->cd( current, TRUE); | 386 | CurrentDir()->cd( current, TRUE); |
388 | populateView(); | 387 | populateView(); |
389 | update(); | 388 | update(); |
390 | } | 389 | } |
391 | 390 | ||
392 | void AdvancedFm::docButtonPushed() | 391 | void AdvancedFm::docButtonPushed() |
393 | { | 392 | { |
394 | QString current = QPEApplication::documentDir(); | 393 | QString current = QPEApplication::documentDir(); |
395 | chdir( current.latin1() ); | 394 | chdir( current.latin1() ); |
396 | 395 | CurrentDir()->cd( current, TRUE); | |
397 | CurrentDir()->cd( current, TRUE); | 396 | populateView(); |
398 | populateView(); | ||
399 | update(); | 397 | update(); |
400 | } | 398 | } |
401 | 399 | ||
402 | void AdvancedFm::SDButtonPushed() | 400 | void AdvancedFm::SDButtonPushed() |
403 | { | 401 | { |
404 | QString current = "/mnt/card";// this can change so fix | 402 | QString current = "/mnt/card";// this can change so fix |
405 | chdir( current.latin1() ); | 403 | chdir( current.latin1() ); |
406 | CurrentDir()->cd( current, TRUE); | 404 | CurrentDir()->cd( current, TRUE); |
407 | populateView(); | 405 | populateView(); |
408 | update(); | 406 | update(); |
409 | } | 407 | } |
410 | 408 | ||
411 | void AdvancedFm::CFButtonPushed() | 409 | void AdvancedFm::CFButtonPushed() |
412 | { | 410 | { |
413 | QString current; | 411 | QString current; |
414 | if(zaurusDevice) | 412 | if(zaurusDevice) |
415 | current= "/mnt/cf"; //zaurus | 413 | current= "/mnt/cf"; //zaurus |
416 | else | 414 | else |
417 | current = "/mnt/hda"; //ipaq | 415 | current = "/mnt/hda"; //ipaq |
418 | |||
419 | chdir( current.latin1() ); | 416 | chdir( current.latin1() ); |
420 | CurrentDir()->cd( current, TRUE); | 417 | CurrentDir()->cd( current, TRUE); |
421 | populateView(); | 418 | populateView(); |
422 | update(); | 419 | update(); |
423 | } | 420 | } |
424 | 421 | ||
425 | 422 | ||
426 | void AdvancedFm::doAbout() | 423 | void AdvancedFm::doAbout() |
427 | { | 424 | { |
428 | QMessageBox::message("AdvancedFm",tr("Advanced FileManager\n" | 425 | QMessageBox::message("AdvancedFm",tr("Advanced FileManager\n" |
429 | "is copyright 2002-2003 by\n" | 426 | "is copyright 2002-2003 by\n" |
430 | "L.J.Potter<llornkcor@handhelds.org>\n" | 427 | "L.J.Potter<llornkcor@handhelds.org>\n" |
431 | "and is licensed by the GPL")); | 428 | "and is licensed by the GPL")); |
432 | } | 429 | } |
433 | 430 | ||
434 | void AdvancedFm::keyPressEvent( QKeyEvent *e) | 431 | void AdvancedFm::keyPressEvent( QKeyEvent *e) |
435 | { | 432 | { |
436 | // e->accept(); | 433 | // e->accept(); |
437 | if( CurrentView()->hasFocus() ) | 434 | if( CurrentView()->hasFocus() ) |
438 | { | 435 | { |
439 | switch ( e->key() ) { | 436 | switch ( e->key() ) { |
440 | case Key_Delete: | 437 | case Key_Delete: |
441 | del(); | 438 | del(); |
442 | break; | 439 | break; |
443 | case Key_A: | 440 | case Key_A: |
444 | copyAs(); | 441 | copyAs(); |
445 | break; | 442 | break; |
446 | case Key_C: | 443 | case Key_C: |
447 | copy(); | 444 | copy(); |
448 | break; | 445 | break; |
449 | case Key_E: | 446 | case Key_E: |
450 | runThis(); | 447 | runThis(); |
451 | break; | 448 | break; |
452 | case Key_G: | 449 | case Key_G: |
453 | { | 450 | { |
454 | currentPathCombo->lineEdit()->setFocus(); | 451 | currentPathCombo->lineEdit()->setFocus(); |
455 | } | 452 | } |
456 | break; | 453 | break; |
457 | 454 | ||
458 | case Key_H: | 455 | case Key_H: |
459 | showHidden(); | 456 | showHidden(); |
460 | break; | 457 | break; |
461 | case Key_I: | 458 | case Key_I: |
462 | fileStatus(); | 459 | fileStatus(); |
463 | break; | 460 | break; |
464 | case Key_M: | 461 | case Key_M: |
465 | move(); | 462 | move(); |
466 | break; | 463 | break; |
467 | case Key_N: | 464 | case Key_N: |
468 | mkDir(); | 465 | mkDir(); |
469 | break; | 466 | break; |
470 | case Key_P: | 467 | case Key_P: |
471 | filePerms(); | 468 | filePerms(); |
472 | break; | 469 | break; |
473 | case Key_R: | 470 | case Key_R: |
474 | rn(); | 471 | rn(); |
475 | break; | 472 | break; |
476 | case Key_U: | 473 | case Key_U: |
477 | upDir(); | 474 | upDir(); |
478 | break; | 475 | break; |
479 | case Key_1: | 476 | case Key_1: |
480 | switchToLocalTab(); | 477 | switchToLocalTab(); |
481 | break; | 478 | break; |
482 | case Key_2: | 479 | case Key_2: |
@@ -726,129 +723,130 @@ void AdvancedFm::dirMenuSelected(int item) | |||
726 | qDebug("menu item %d", item); | 723 | qDebug("menu item %d", item); |
727 | switch(item) | 724 | switch(item) |
728 | { | 725 | { |
729 | 726 | ||
730 | case -21: | 727 | case -21: |
731 | case 0: | 728 | case 0: |
732 | addCustomDir(); | 729 | addCustomDir(); |
733 | break; | 730 | break; |
734 | case -22: | 731 | case -22: |
735 | case 1: | 732 | case 1: |
736 | removeCustomDir(); | 733 | removeCustomDir(); |
737 | break; | 734 | break; |
738 | default: | 735 | default: |
739 | { | 736 | { |
740 | // gotoCustomDir( menuButton->text(item)); | 737 | // gotoCustomDir( menuButton->text(item)); |
741 | // gotoCustomDir( customDirMenu->text(item)); | 738 | // gotoCustomDir( customDirMenu->text(item)); |
742 | } | 739 | } |
743 | break; | 740 | break; |
744 | 741 | ||
745 | }; | 742 | }; |
746 | } | 743 | } |
747 | 744 | ||
748 | void AdvancedFm::addCustomDir() | 745 | void AdvancedFm::addCustomDir() |
749 | { | 746 | { |
750 | Config cfg("AdvancedFm"); | 747 | Config cfg("AdvancedFm"); |
751 | cfg.setGroup("Menu"); | 748 | cfg.setGroup("Menu"); |
752 | QString dir; | 749 | QString dir; |
753 | QStringList list = cfg.readListEntry( (const QString &)"CustomDir", (const QChar)','); | 750 | QStringList list = cfg.readListEntry( (const QString &)"CustomDir", (const QChar)','); |
754 | 751 | ||
755 | dir = CurrentDir()->canonicalPath(); | 752 | dir = CurrentDir()->canonicalPath(); |
756 | 753 | ||
757 | bool addIt=true; | 754 | bool addIt=true; |
758 | for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) | 755 | for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) |
759 | { | 756 | { |
760 | if( dir == (*it)) | 757 | if( dir == (*it)) |
761 | { | 758 | { |
762 | addIt=false; | 759 | addIt=false; |
763 | } | 760 | } |
764 | } | 761 | } |
765 | if(addIt) | 762 | if(addIt) |
766 | { | 763 | { |
767 | menuButton->insertItem(dir); | 764 | menuButton->insertItem(dir); |
768 | // customDirMenu->insertItem(dir); | 765 | // customDirMenu->insertItem(dir); |
769 | list << dir; | 766 | list << dir; |
770 | } | 767 | } |
771 | 768 | ||
772 | cfg.writeEntry("CustomDir", list, ','); | 769 | cfg.writeEntry("CustomDir", list, ','); |
773 | cfg.write(); | 770 | cfg.write(); |
774 | } | 771 | } |
775 | 772 | ||
776 | void AdvancedFm::removeCustomDir() | 773 | void AdvancedFm::removeCustomDir() |
777 | { | 774 | { |
778 | // qDebug("remove custom dir"); | 775 | // qDebug("remove custom dir"); |
779 | Config cfg("AdvancedFm"); | 776 | Config cfg("AdvancedFm"); |
780 | cfg.setGroup("Menu"); | 777 | cfg.setGroup("Menu"); |
781 | QString dir; | 778 | QString dir; |
782 | QStringList list = cfg.readListEntry( (const QString &)"CustomDir", (const QChar)','); | 779 | QStringList list = cfg.readListEntry( (const QString &)"CustomDir", (const QChar)','); |
783 | QStringList list2; | 780 | QStringList list2; |
784 | dir = CurrentDir()->canonicalPath(); | 781 | dir = CurrentDir()->canonicalPath(); |
785 | int ramble=2; | 782 | int ramble=2; |
786 | // int ramble=-24; | 783 | // int ramble=-24; |
787 | //first remove list | 784 | //first remove list |
788 | if(list.grep(dir,true).isEmpty()) | 785 | if(list.grep(dir,true).isEmpty()) |
789 | { | 786 | { |
790 | QMessageBox::message("AdvancedFm",tr("Cannot remove current directory\nfrom bookmarks.\nIt is not bookmarked!!")); | 787 | QMessageBox::message("AdvancedFm", |
788 | tr("Cannot remove current directory\nfrom bookmarks.\nIt is not bookmarked!!")); | ||
791 | } | 789 | } |
792 | else | 790 | else |
793 | { | 791 | { |
794 | for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) | 792 | for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) |
795 | { | 793 | { |
796 | if((*it) != dir)//current item is not our current dir, so add it to temp list | 794 | if((*it) != dir)//current item is not our current dir, so add it to temp list |
797 | { | 795 | { |
798 | list2 <<(*it); | 796 | list2 <<(*it); |
799 | } | 797 | } |
800 | else | 798 | else |
801 | { | 799 | { |
802 | // customDirMenu->removeItem( ramble); | 800 | // customDirMenu->removeItem( ramble); |
803 | menuButton->remove( ramble); | 801 | menuButton->remove( ramble); |
804 | 802 | ||
805 | } | 803 | } |
806 | ramble++; | 804 | ramble++; |
807 | // ramble--; | 805 | // ramble--; |
808 | } | 806 | } |
809 | 807 | ||
810 | cfg.writeEntry("CustomDir", list2, ','); | 808 | cfg.writeEntry("CustomDir", list2, ','); |
811 | cfg.write(); | 809 | cfg.write(); |
812 | } | 810 | } |
813 | // customDirsToMenu(); | 811 | // customDirsToMenu(); |
814 | 812 | ||
815 | } | 813 | } |
816 | 814 | ||
817 | void AdvancedFm::gotoCustomDir(const QString &dir) | 815 | void AdvancedFm::gotoCustomDir(const QString &dir) |
818 | { | 816 | { |
819 | // qDebug("gotoCustomDir(const QString &dir) " +dir ); | 817 | // qDebug("gotoCustomDir(const QString &dir) " +dir ); |
820 | QString curDir = dir; | 818 | QString curDir = dir; |
821 | QDir *thisDir = CurrentDir(); | 819 | QDir *thisDir = CurrentDir(); |
822 | // if( curDir.isEmpty()) { | 820 | // if( curDir.isEmpty()) { |
823 | // } | 821 | // } |
824 | if( curDir == s_addBookmark) | 822 | if( curDir == s_addBookmark) |
825 | { | 823 | { |
826 | addCustomDir(); | 824 | addCustomDir(); |
827 | } | 825 | } |
828 | if( curDir == s_removeBookmark) | 826 | if( curDir == s_removeBookmark) |
829 | { | 827 | { |
830 | removeCustomDir( ); | 828 | removeCustomDir( ); |
831 | } | 829 | } |
832 | else | 830 | else |
833 | { | 831 | { |
834 | if(QDir( curDir).exists() ) | 832 | if(QDir( curDir).exists() ) |
835 | { | 833 | { |
836 | thisDir->setPath( curDir ); | 834 | thisDir->setPath( curDir ); |
837 | chdir( curDir.latin1() ); | 835 | chdir( curDir.latin1() ); |
838 | thisDir->cd( curDir, TRUE); | 836 | thisDir->cd( curDir, TRUE); |
839 | populateView(); | 837 | populateView(); |
840 | } | 838 | } |
841 | } | 839 | } |
842 | } | 840 | } |
843 | 841 | ||
844 | QDir *AdvancedFm::CurrentDir() | 842 | QDir *AdvancedFm::CurrentDir() |
845 | { | 843 | { |
846 | if ( whichTab == 1) | 844 | if ( whichTab == 1) |
847 | { | 845 | { |
848 | return ¤tDir; | 846 | return ¤tDir; |
849 | } | 847 | } |
850 | else | 848 | else |
851 | { | 849 | { |
852 | return ¤tRemoteDir; | 850 | return ¤tRemoteDir; |
853 | } | 851 | } |
854 | } | 852 | } |
diff --git a/noncore/apps/advancedfm/advancedfmMenu.cpp b/noncore/apps/advancedfm/advancedfmMenu.cpp index c553017..062a013 100644 --- a/noncore/apps/advancedfm/advancedfmMenu.cpp +++ b/noncore/apps/advancedfm/advancedfmMenu.cpp | |||
@@ -1,152 +1,154 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | AdvancedFm.cpp | 2 | AdvancedFm.cpp |
3 | ------------------- | 3 | ------------------- |
4 | ** Created: Sat Mar 9 23:33:09 2002 | 4 | ** Created: Sat Mar 9 23:33:09 2002 |
5 | copyright : (C) 2002 by ljp | 5 | copyright : (C) 2002 by ljp |
6 | email : ljp@llornkcor.com | 6 | email : ljp@llornkcor.com |
7 | * This program is free software; you can redistribute it and/or modify * | 7 | * This program is free software; you can redistribute it and/or modify * |
8 | * it under the terms of the GNU General Public License as published by * | 8 | * it under the terms of the GNU General Public License as published by * |
9 | * the Free Software Foundation; either version 2 of the License, or * | 9 | * the Free Software Foundation; either version 2 of the License, or * |
10 | * (at your option) any later version. * | 10 | * (at your option) any later version. * |
11 | ***************************************************************************/ | 11 | ***************************************************************************/ |
12 | #include "advancedfm.h" | 12 | #include "advancedfm.h" |
13 | #include "output.h" | 13 | #include "output.h" |
14 | #include "filePermissions.h" | 14 | #include "filePermissions.h" |
15 | 15 | ||
16 | #include <opie/otabwidget.h> | 16 | #include <opie/otabwidget.h> |
17 | #include <opie/oprocess.h> | 17 | #include <opie/oprocess.h> |
18 | 18 | ||
19 | #include <qpe/lnkproperties.h> | 19 | #include <qpe/lnkproperties.h> |
20 | #include <qpe/qpeapplication.h> | 20 | #include <qpe/qpeapplication.h> |
21 | #include <qpe/qpemenubar.h> | 21 | #include <qpe/qpemenubar.h> |
22 | #include <qpe/qpetoolbar.h> | 22 | #include <qpe/qpetoolbar.h> |
23 | #include <qpe/resource.h> | 23 | #include <qpe/resource.h> |
24 | #include <qpe/qcopenvelope_qws.h> | 24 | #include <qpe/qcopenvelope_qws.h> |
25 | #include <qpe/applnk.h> | 25 | #include <qpe/applnk.h> |
26 | #include <qpe/ir.h> | 26 | #include <qpe/ir.h> |
27 | 27 | ||
28 | #include <qmessagebox.h> | 28 | #include <qmessagebox.h> |
29 | #include <qmultilineedit.h> | 29 | #include <qmultilineedit.h> |
30 | 30 | ||
31 | #include <qstring.h> | 31 | #include <qstring.h> |
32 | 32 | ||
33 | #include <qlayout.h> | 33 | #include <qlayout.h> |
34 | #include <qpixmap.h> | 34 | #include <qpixmap.h> |
35 | #include <qcombobox.h> | 35 | #include <qcombobox.h> |
36 | #include <qpopupmenu.h> | 36 | #include <qpopupmenu.h> |
37 | #include <qtabwidget.h> | 37 | #include <qtabwidget.h> |
38 | #include <qtoolbutton.h> | 38 | #include <qtoolbutton.h> |
39 | #include <qtabwidget.h> | 39 | #include <qtabwidget.h> |
40 | #include <qlineedit.h> | 40 | #include <qlineedit.h> |
41 | #include <qlistview.h> | 41 | #include <qlistview.h> |
42 | 42 | ||
43 | #include <stdlib.h> | 43 | #include <stdlib.h> |
44 | #include <unistd.h> | 44 | #include <unistd.h> |
45 | #include <sys/stat.h> | 45 | #include <sys/stat.h> |
46 | #include <dirent.h> | 46 | #include <dirent.h> |
47 | 47 | ||
48 | 48 | ||
49 | void AdvancedFm::doDirChange() | 49 | void AdvancedFm::doDirChange() |
50 | { | 50 | { |
51 | ListClicked( CurrentView()->currentItem()); | 51 | ListClicked( CurrentView()->currentItem()); |
52 | } | 52 | } |
53 | 53 | ||
54 | void AdvancedFm::showMenuHidden() | 54 | void AdvancedFm::showMenuHidden() |
55 | { | 55 | { |
56 | if (b) | 56 | if (b) |
57 | { | 57 | { |
58 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 58 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
59 | currentRemoteDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 59 | OtherDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
60 | fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); | 60 | fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); |
61 | // b=FALSE; | 61 | // b=FALSE; |
62 | 62 | ||
63 | } | 63 | } |
64 | else | 64 | else |
65 | { | 65 | { |
66 | currentDir.setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 66 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
67 | currentRemoteDir.setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 67 | OtherDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
68 | fileMenu->setItemChecked( fileMenu->idAt(0),FALSE); | 68 | fileMenu->setItemChecked( fileMenu->idAt(0),FALSE); |
69 | // b=TRUE; | 69 | // b=TRUE; |
70 | } | 70 | } |
71 | populateView(); | 71 | populateView(); |
72 | // populateRemoteView(); | 72 | // populateRemoteView(); |
73 | // if(b) qDebug("<<<<<<<<<<<<<<<<<<<<<<<<<<<< true"); | 73 | // if(b) qDebug("<<<<<<<<<<<<<<<<<<<<<<<<<<<< true"); |
74 | if(b) b = false; else b = true; | 74 | if(b) b = false; else b = true; |
75 | } | 75 | } |
76 | 76 | ||
77 | void AdvancedFm::showHidden() | 77 | void AdvancedFm::showHidden() |
78 | { | 78 | { |
79 | if (b) | 79 | if (b) |
80 | { | 80 | { |
81 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 81 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
82 | OtherDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | ||
82 | // fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); | 83 | // fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); |
83 | // b=FALSE; | 84 | // b=FALSE; |
84 | 85 | ||
85 | } | 86 | } |
86 | else | 87 | else |
87 | { | 88 | { |
88 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 89 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
90 | s OtherDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | ||
89 | // fileMenu->setItemChecked( fileMenu->idAt(0),FALSE); | 91 | // fileMenu->setItemChecked( fileMenu->idAt(0),FALSE); |
90 | // b=TRUE; | 92 | // b=TRUE; |
91 | } | 93 | } |
92 | populateView(); | 94 | populateView(); |
93 | } | 95 | } |
94 | 96 | ||
95 | QString AdvancedFm::dealWithSymName(const QString &fileName) | 97 | QString AdvancedFm::dealWithSymName(const QString &fileName) |
96 | { | 98 | { |
97 | QString strItem = fileName; | 99 | QString strItem = fileName; |
98 | return strItem.right( (strItem.length() - strItem.find("->",0,TRUE)) - 4); | 100 | return strItem.right( (strItem.length() - strItem.find("->",0,TRUE)) - 4); |
99 | } | 101 | } |
100 | 102 | ||
101 | void AdvancedFm::runThis() | 103 | void AdvancedFm::runThis() |
102 | { | 104 | { |
103 | QString fs; | 105 | QString fs; |
104 | QDir *thisDir = CurrentDir(); | 106 | QDir *thisDir = CurrentDir(); |
105 | 107 | ||
106 | QString curFile = CurrentView()->currentItem()->text(0); | 108 | QString curFile = CurrentView()->currentItem()->text(0); |
107 | QString path = thisDir->canonicalPath(); | 109 | QString path = thisDir->canonicalPath(); |
108 | 110 | ||
109 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink | 111 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink |
110 | 112 | ||
111 | curFile = dealWithSymName((const QString&)curFile); | 113 | curFile = dealWithSymName((const QString&)curFile); |
112 | 114 | ||
113 | if(curFile != "../") | 115 | if(curFile != "../") |
114 | { | 116 | { |
115 | 117 | ||
116 | fs = getFileSystemType((const QString &) path); | 118 | fs = getFileSystemType((const QString &) path); |
117 | QFileInfo fileInfo( path + "/" + curFile); | 119 | QFileInfo fileInfo( path + "/" + curFile); |
118 | qDebug( fileInfo.owner()); | 120 | qDebug( fileInfo.owner()); |
119 | 121 | ||
120 | if( (fileInfo.permission( QFileInfo::ExeUser) | 122 | if( (fileInfo.permission( QFileInfo::ExeUser) |
121 | | fileInfo.permission( QFileInfo::ExeGroup) | 123 | | fileInfo.permission( QFileInfo::ExeGroup) |
122 | | fileInfo.permission( QFileInfo::ExeOther)) // & fs.find("vfat",0,TRUE) == -1) { | 124 | | fileInfo.permission( QFileInfo::ExeOther)) // & fs.find("vfat",0,TRUE) == -1) { |
123 | | fs == "vfat" && fileInfo.filePath().contains("/bin") ) { | 125 | | fs == "vfat" && fileInfo.filePath().contains("/bin") ) { |
124 | QCopEnvelope e("QPE/System", "execute(QString)" ); | 126 | QCopEnvelope e("QPE/System", "execute(QString)" ); |
125 | e << curFile; | 127 | e << curFile; |
126 | } | 128 | } |
127 | else | 129 | else |
128 | { | 130 | { |
129 | curFile = path + "/" + curFile; | 131 | curFile = path + "/" + curFile; |
130 | DocLnk nf(curFile); | 132 | DocLnk nf(curFile); |
131 | QString execStr = nf.exec(); | 133 | QString execStr = nf.exec(); |
132 | qDebug( execStr); | 134 | qDebug( execStr); |
133 | if( execStr.isEmpty() ) | 135 | if( execStr.isEmpty() ) |
134 | { | 136 | { |
135 | } | 137 | } |
136 | else | 138 | else |
137 | { | 139 | { |
138 | nf.execute(); | 140 | nf.execute(); |
139 | } | 141 | } |
140 | } | 142 | } |
141 | } | 143 | } |
142 | } | 144 | } |
143 | 145 | ||
144 | void AdvancedFm::runText() | 146 | void AdvancedFm::runText() |
145 | { | 147 | { |
146 | QString curFile = CurrentView()->currentItem()->text(0); | 148 | QString curFile = CurrentView()->currentItem()->text(0); |
147 | if(curFile != "../") | 149 | if(curFile != "../") |
148 | { | 150 | { |
149 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink | 151 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink |
150 | curFile = dealWithSymName((const QString&)curFile); | 152 | curFile = dealWithSymName((const QString&)curFile); |
151 | curFile = CurrentDir()->canonicalPath()+"/"+curFile; | 153 | curFile = CurrentDir()->canonicalPath()+"/"+curFile; |
152 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); | 154 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); |