-rw-r--r-- | noncore/apps/advancedfm/advancedfm.cpp | 22 |
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; |