summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/advancedfm/advancedfm.cpp22
1 files changed, 16 insertions, 6 deletions
diff --git a/noncore/apps/advancedfm/advancedfm.cpp b/noncore/apps/advancedfm/advancedfm.cpp
index ee3f736..a9ba3c2 100644
--- a/noncore/apps/advancedfm/advancedfm.cpp
+++ b/noncore/apps/advancedfm/advancedfm.cpp
@@ -289,79 +289,84 @@ void AdvancedFm::populateLocalView()
289 const QFileInfoList *list = currentDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); 289 const QFileInfoList *list = currentDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/);
290 QFileInfoListIterator it(*list); 290 QFileInfoListIterator it(*list);
291 QFileInfo *fi; 291 QFileInfo *fi;
292 while ( (fi=it.current()) ) { 292 while ( (fi=it.current()) ) {
293 if (fi->isSymLink() ) { 293 if (fi->isSymLink() ) {
294 QString symLink=fi->readLink(); 294 QString symLink=fi->readLink();
295// qDebug("Symlink detected "+symLink); 295// qDebug("Symlink detected "+symLink);
296 QFileInfo sym( symLink); 296 QFileInfo sym( symLink);
297 fileS.sprintf( "%10li", sym.size() ); 297 fileS.sprintf( "%10li", sym.size() );
298 fileL.sprintf( "%s -> %s", sym.fileName().data(),sym.absFilePath().data() ); 298 fileL.sprintf( "%s -> %s", sym.fileName().data(),sym.absFilePath().data() );
299 fileDate = sym.lastModified().toString(); 299 fileDate = sym.lastModified().toString();
300 } else { 300 } else {
301 fileS.sprintf( "%10li", fi->size() ); 301 fileS.sprintf( "%10li", fi->size() );
302 fileL.sprintf( "%s",fi->fileName().data() ); 302 fileL.sprintf( "%s",fi->fileName().data() );
303 fileDate= fi->lastModified().toString(); 303 fileDate= fi->lastModified().toString();
304 if( QDir(QDir::cleanDirPath( currentDir.canonicalPath()+"/"+fileL)).exists() ) { 304 if( QDir(QDir::cleanDirPath( currentDir.canonicalPath()+"/"+fileL)).exists() ) {
305 fileL+="/"; 305 fileL+="/";
306 isDir=TRUE; 306 isDir=TRUE;
307// qDebug( fileL); 307// qDebug( fileL);
308 } 308 }
309 } 309 }
310 QFileInfo fileInfo( currentDir.canonicalPath()+"/"+fileL); 310 QFileInfo fileInfo( currentDir.canonicalPath()+"/"+fileL);
311 if(fileL !="./" && fi->exists()) { 311 if(fileL !="./" && fi->exists()) {
312 item= new QListViewItem( Local_View, fileL, fileS , fileDate); 312 item= new QListViewItem( Local_View, fileL, fileS , fileDate);
313 313
314 if(isDir || fileL.find("/",0,TRUE) != -1) { 314 if(isDir || fileL.find("/",0,TRUE) != -1) {
315 315
316 if( !QDir( fi->filePath() ).isReadable()) //is directory 316 if( !QDir( fi->filePath() ).isReadable()) //is directory
317 pm = Resource::loadPixmap( "lockedfolder" ); 317 pm = Resource::loadPixmap( "lockedfolder" );
318 else 318 else
319 pm= Resource::loadPixmap( "folder" ); 319 pm= Resource::loadPixmap( "folder" );
320// item->setPixmap( 0,pm ); 320// item->setPixmap( 0,pm );
321 } else if( fileInfo.isExecutable() || fs == "vfat" && fi->filePath().contains("/bin") ) { //is exec 321 } else if( (fileInfo.permission( QFileInfo::ExeUser)
322 pm = Resource::loadPixmap( "exec"); 322 | fileInfo.permission( QFileInfo::ExeGroup)
323// item->setPixmap( 0,pm); 323 | fileInfo.permission( QFileInfo::ExeOther)) & fs.find("vfat",0,TRUE) == -1) {
324 pm = Resource::loadPixmap( "exec");
325// else { //is exec
326// pm = Resource::loadPixmap( "exec");
327// }
328// // item->setPixmap( 0,pm);
324 } else if( !fi->isReadable() ) { 329 } else if( !fi->isReadable() ) {
325 pm = Resource::loadPixmap( "locked" ); 330 pm = Resource::loadPixmap( "locked" );
326// item->setPixmap( 0,pm); 331// item->setPixmap( 0,pm);
327 } else { //everything else goes by mimetype 332 } else { //everything else goes by mimetype
328 MimeType mt(fi->filePath()); 333 MimeType mt(fi->filePath());
329 pm=mt.pixmap(); //sets the correct pixmap for mimetype 334 pm=mt.pixmap(); //sets the correct pixmap for mimetype
330 if(pm.isNull()) 335 if(pm.isNull())
331 pm = Resource::loadPixmap( "UnknownDocument-14" ); 336 pm = Resource::loadPixmap( "UnknownDocument-14" );
332// item->setPixmap( 0,pm); 337// item->setPixmap( 0,pm);
333 } 338 }
334 item->setPixmap( 0,pm); 339 item->setPixmap( 0,pm);
335 if( fi->isSymLink() &&fileL.find("->",0,TRUE) != -1) { 340 if( fi->isSymLink() && fileL.find("->",0,TRUE) != -1) {
336 // overlay link image 341 // overlay link image
337 pm= Resource::loadPixmap( "folder" ); 342 pm= Resource::loadPixmap( "folder" );
338 QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); 343 QPixmap lnk = Resource::loadPixmap( "opie/symlink" );
339 QPainter painter( &pm ); 344 QPainter painter( &pm );
340 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); 345 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk );
341 pm.setMask( pm.createHeuristicMask( FALSE ) ); 346 pm.setMask( pm.createHeuristicMask( FALSE ) );
342 item->setPixmap( 0, pm); 347 item->setPixmap( 0, pm);
343 } 348 }
344 } 349 }
345 isDir=FALSE; 350 isDir=FALSE;
346 ++it; 351 ++it;
347 } 352 }
348 353
349 if(currentDir.canonicalPath().find("dev",0,TRUE) != -1) { 354 if(currentDir.canonicalPath().find("dev",0,TRUE) != -1) {
350 struct stat buf; 355 struct stat buf;
351// struct stat st; 356// struct stat st;
352 dev_t devT; 357 dev_t devT;
353// mode_t mode; 358// mode_t mode;
354 DIR *dir; 359 DIR *dir;
355// int fd = 0; 360// int fd = 0;
356 struct dirent *mydirent; 361 struct dirent *mydirent;
357// int i = 1; 362// int i = 1;
358 if((dir = opendir( currentDir.canonicalPath().latin1())) != NULL) 363 if((dir = opendir( currentDir.canonicalPath().latin1())) != NULL)
359 while ((mydirent = readdir(dir)) != NULL) { 364 while ((mydirent = readdir(dir)) != NULL) {
360 lstat( mydirent->d_name, &buf); 365 lstat( mydirent->d_name, &buf);
361 qDebug(mydirent->d_name); 366 qDebug(mydirent->d_name);
362// mode = buf.st_mode; 367// mode = buf.st_mode;
363 fileL.sprintf("%s", mydirent->d_name); 368 fileL.sprintf("%s", mydirent->d_name);
364// fileS.sprintf("%d, %d", ); //this isn't correct 369// fileS.sprintf("%d, %d", ); //this isn't correct
365 devT = buf.st_dev; 370 devT = buf.st_dev;
366 fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); 371 fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF);
367// fileS.sprintf("%d,%d", devT, devT); 372// fileS.sprintf("%d,%d", devT, devT);
@@ -395,76 +400,81 @@ void AdvancedFm::populateRemoteView()
395 QPixmap pm; 400 QPixmap pm;
396 Remote_View->clear(); 401 Remote_View->clear();
397 currentRemoteDir.setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); 402 currentRemoteDir.setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst);
398 currentRemoteDir.setMatchAllDirs(TRUE); 403 currentRemoteDir.setMatchAllDirs(TRUE);
399 currentRemoteDir.setNameFilter(filterStr); 404 currentRemoteDir.setNameFilter(filterStr);
400 QString fileL, fileS, fileDate; 405 QString fileL, fileS, fileDate;
401 406
402 QString fs= getFileSystemType((const QString &) currentRemoteDir.canonicalPath()); 407 QString fs= getFileSystemType((const QString &) currentRemoteDir.canonicalPath());
403 setCaption("AdvancedFm :: "+fs); 408 setCaption("AdvancedFm :: "+fs);
404 bool isDir=FALSE; 409 bool isDir=FALSE;
405 const QFileInfoList *list = currentRemoteDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); 410 const QFileInfoList *list = currentRemoteDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/);
406 QFileInfoListIterator it(*list); 411 QFileInfoListIterator it(*list);
407 QFileInfo *fi; 412 QFileInfo *fi;
408 while ( (fi=it.current()) ) { 413 while ( (fi=it.current()) ) {
409 if (fi->isSymLink() ){ 414 if (fi->isSymLink() ){
410 QString symLink=fi->readLink(); 415 QString symLink=fi->readLink();
411// qDebug("Symlink detected "+symLink); 416// qDebug("Symlink detected "+symLink);
412 QFileInfo sym( symLink); 417 QFileInfo sym( symLink);
413 fileS.sprintf( "%10li", sym.size() ); 418 fileS.sprintf( "%10li", sym.size() );
414 fileL.sprintf( "%s -> %s", sym.fileName().data(),sym.absFilePath().data() ); 419 fileL.sprintf( "%s -> %s", sym.fileName().data(),sym.absFilePath().data() );
415 fileDate = sym.lastModified().toString(); 420 fileDate = sym.lastModified().toString();
416 } else { 421 } else {
417// qDebug("Not a dir: "+currentDir.canonicalPath()+fileL); 422// qDebug("Not a dir: "+currentDir.canonicalPath()+fileL);
418 fileS.sprintf( "%10li", fi->size() ); 423 fileS.sprintf( "%10li", fi->size() );
419 fileL.sprintf( "%s",fi->fileName().data() ); 424 fileL.sprintf( "%s",fi->fileName().data() );
420 fileDate= fi->lastModified().toString(); 425 fileDate= fi->lastModified().toString();
421 if( QDir(QDir::cleanDirPath( currentRemoteDir.canonicalPath()+"/"+fileL)).exists() ) { 426 if( QDir(QDir::cleanDirPath( currentRemoteDir.canonicalPath()+"/"+fileL)).exists() ) {
422 fileL+="/"; 427 fileL+="/";
423 isDir=TRUE; 428 isDir=TRUE;
424// qDebug( fileL); 429// qDebug( fileL);
425 } 430 }
426 } 431 }
432 QFileInfo fileInfo( currentDir.canonicalPath()+"/"+fileL);
427 if(fileL !="./" && fi->exists()) { 433 if(fileL !="./" && fi->exists()) {
428 item= new QListViewItem( Remote_View, fileL, fileS, fileDate); 434 item= new QListViewItem( Remote_View, fileL, fileS, fileDate);
429 QPixmap pm; 435 QPixmap pm;
430 436
431 if(isDir || fileL.find("/",0,TRUE) != -1) { 437 if(isDir || fileL.find("/",0,TRUE) != -1) {
432 if( !QDir( fi->filePath() ).isReadable()) 438 if( !QDir( fi->filePath() ).isReadable())
433 pm = Resource::loadPixmap( "lockedfolder" ); 439 pm = Resource::loadPixmap( "lockedfolder" );
434 else 440 else
435 pm= Resource::loadPixmap( "folder" ); 441 pm= Resource::loadPixmap( "folder" );
436// item->setPixmap( 0,pm ); 442// item->setPixmap( 0,pm );
437 } else if( fi->isExecutable() || fs == "vfat" && fi->filePath().contains("/bin") ) { 443 } else if( (fileInfo.permission( QFileInfo::ExeUser)
438 pm = Resource::loadPixmap( "exec"); 444 | fileInfo.permission( QFileInfo::ExeGroup)
445 | fileInfo.permission( QFileInfo::ExeOther)) & fs.find("vfat",0,TRUE) == -1) {
446 pm = Resource::loadPixmap( "exec");
447///// } else if(fileInfo.isExecutable()){ //is exec <<<< BROKEN!!
448 pm = Resource::loadPixmap( "exec");
439// item->setPixmap( 0,pm); 449// item->setPixmap( 0,pm);
440 } else if( !fi->isReadable() ) { 450 } else if( !fi->isReadable() ) {
441 pm = Resource::loadPixmap( "locked" ); 451 pm = Resource::loadPixmap( "locked" );
442// item->setPixmap( 0,pm); 452// item->setPixmap( 0,pm);
443 } else { 453 } else {
444 MimeType mt(fi->filePath()); 454 MimeType mt(fi->filePath());
445 pm=mt.pixmap(); //sets the correct pixmap for mimetype 455 pm=mt.pixmap(); //sets the correct pixmap for mimetype
446 if(pm.isNull()) 456 if(pm.isNull())
447 pm = Resource::loadPixmap( "UnknownDocument-14" ); 457 pm = Resource::loadPixmap( "UnknownDocument-14" );
448// item->setPixmap( 0,pm); 458// item->setPixmap( 0,pm);
449 } 459 }
450 if( fi->isSymLink() && fileL.find("->",0,TRUE) != -1) { 460 if( fi->isSymLink() && fileL.find("->",0,TRUE) != -1) {
451 // overlay link image 461 // overlay link image
452 pm= Resource::loadPixmap( "folder" ); 462 pm= Resource::loadPixmap( "folder" );
453 QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); 463 QPixmap lnk = Resource::loadPixmap( "opie/symlink" );
454 QPainter painter( &pm ); 464 QPainter painter( &pm );
455 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); 465 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk );
456 pm.setMask( pm.createHeuristicMask( FALSE ) ); 466 pm.setMask( pm.createHeuristicMask( FALSE ) );
457// item->setPixmap( 0, pm); 467// item->setPixmap( 0, pm);
458 } 468 }
459 item->setPixmap( 0, pm); 469 item->setPixmap( 0, pm);
460 } 470 }
461 isDir=FALSE; 471 isDir=FALSE;
462 ++it; 472 ++it;
463 } 473 }
464 474
465 if(currentRemoteDir.canonicalPath().find("dev",0,TRUE) != -1) { 475 if(currentRemoteDir.canonicalPath().find("dev",0,TRUE) != -1) {
466 struct stat buf; 476 struct stat buf;
467// struct stat st; 477// struct stat st;
468// mode_t mode; 478// mode_t mode;
469 DIR *dir; 479 DIR *dir;
470// int fd = 0; 480// int fd = 0;