author | erik <erik> | 2007-01-10 17:27:56 (UTC) |
---|---|---|
committer | erik <erik> | 2007-01-10 17:27:56 (UTC) |
commit | d8e580a239ab84fbe063b2f3779d417598d5ca0a (patch) (unidiff) | |
tree | a8b215c071088f167f011e51027b0a30ef3a5622 | |
parent | e7d3e1d0f3c75979c01ea6373ed3c80d0c986000 (diff) | |
download | opie-d8e580a239ab84fbe063b2f3779d417598d5ca0a.zip opie-d8e580a239ab84fbe063b2f3779d417598d5ca0a.tar.gz opie-d8e580a239ab84fbe063b2f3779d417598d5ca0a.tar.bz2 |
BUG: The case statement was using err to figure out what to say about
why sendfile didn't work. Since err is only the return value of sendfile
this meant that it never reported the right thing because it can only be
-1 at this point. What the author probably wanted to do was look at errno
since that is what the man page says will have the real error info.
FIX: Switch the case statement to use errno.
-rw-r--r-- | noncore/apps/advancedfm/advancedfmMenu.cpp | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/noncore/apps/advancedfm/advancedfmMenu.cpp b/noncore/apps/advancedfm/advancedfmMenu.cpp index 9181810..3986b1f 100644 --- a/noncore/apps/advancedfm/advancedfmMenu.cpp +++ b/noncore/apps/advancedfm/advancedfmMenu.cpp | |||
@@ -329,513 +329,513 @@ void AdvancedFm::copy() { | |||
329 | case 0: | 329 | case 0: |
330 | break; | 330 | break; |
331 | case 1: | 331 | case 1: |
332 | return; | 332 | return; |
333 | break; | 333 | break; |
334 | default: | 334 | default: |
335 | return; | 335 | return; |
336 | break; | 336 | break; |
337 | }; | 337 | }; |
338 | } | 338 | } |
339 | f.remove(); | 339 | f.remove(); |
340 | } | 340 | } |
341 | 341 | ||
342 | if( !copyFile( curFile, destFile) ) { | 342 | if( !copyFile( curFile, destFile) ) { |
343 | QMessageBox::message("AdvancedFm", | 343 | QMessageBox::message("AdvancedFm", |
344 | tr( "<P>Could not copy %1 to %2</P>").arg(curFile).arg(destFile)); | 344 | tr( "<P>Could not copy %1 to %2</P>").arg(curFile).arg(destFile)); |
345 | return; | 345 | return; |
346 | } | 346 | } |
347 | } | 347 | } |
348 | rePopulate(); | 348 | rePopulate(); |
349 | } | 349 | } |
350 | } | 350 | } |
351 | 351 | ||
352 | void AdvancedFm::copyAsTimer() { | 352 | void AdvancedFm::copyAsTimer() { |
353 | QTimer::singleShot(125,this,SLOT(copyAs())); | 353 | QTimer::singleShot(125,this,SLOT(copyAs())); |
354 | } | 354 | } |
355 | 355 | ||
356 | void AdvancedFm::copyAs() { | 356 | void AdvancedFm::copyAs() { |
357 | 357 | ||
358 | QStringList curFileList = getPath(); | 358 | QStringList curFileList = getPath(); |
359 | QString curFile, item; | 359 | QString curFile, item; |
360 | InputDialog *fileDlg; | 360 | InputDialog *fileDlg; |
361 | 361 | ||
362 | QDir *thisDir = CurrentDir(); | 362 | QDir *thisDir = CurrentDir(); |
363 | QDir *thatDir = OtherDir(); | 363 | QDir *thatDir = OtherDir(); |
364 | 364 | ||
365 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 365 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
366 | QString destFile; | 366 | QString destFile; |
367 | item=(*it); | 367 | item=(*it); |
368 | curFile = thisDir->canonicalPath()+"/"+(*it); | 368 | curFile = thisDir->canonicalPath()+"/"+(*it); |
369 | fileDlg = new InputDialog( this, tr("Copy %1 As").arg(curFile), TRUE, 0); | 369 | fileDlg = new InputDialog( this, tr("Copy %1 As").arg(curFile), TRUE, 0); |
370 | 370 | ||
371 | fileDlg->setInputText((const QString &) destFile ); | 371 | fileDlg->setInputText((const QString &) destFile ); |
372 | fileDlg->exec(); | 372 | fileDlg->exec(); |
373 | 373 | ||
374 | if( fileDlg->result() == 1 ) { | 374 | if( fileDlg->result() == 1 ) { |
375 | QString filename = fileDlg->LineEdit1->text(); | 375 | QString filename = fileDlg->LineEdit1->text(); |
376 | destFile = thatDir->canonicalPath()+"/"+filename; | 376 | destFile = thatDir->canonicalPath()+"/"+filename; |
377 | 377 | ||
378 | QFile f( destFile); | 378 | QFile f( destFile); |
379 | if( f.exists()) { | 379 | if( f.exists()) { |
380 | switch (QMessageBox::warning(this,tr("File Exists!"), | 380 | switch (QMessageBox::warning(this,tr("File Exists!"), |
381 | tr("<P> %1 already exists. Ok to overwrite?</p>").arg(item), | 381 | tr("<P> %1 already exists. Ok to overwrite?</p>").arg(item), |
382 | tr("Yes"),tr("No"),0,0,1) ) { | 382 | tr("Yes"),tr("No"),0,0,1) ) { |
383 | case 0: | 383 | case 0: |
384 | f.remove(); | 384 | f.remove(); |
385 | break; | 385 | break; |
386 | case 1: | 386 | case 1: |
387 | return; | 387 | return; |
388 | break; | 388 | break; |
389 | default: | 389 | default: |
390 | return; | 390 | return; |
391 | break; | 391 | break; |
392 | }; | 392 | }; |
393 | } | 393 | } |
394 | if( !copyFile( curFile, destFile) ) { | 394 | if( !copyFile( curFile, destFile) ) { |
395 | QMessageBox::message("AdvancedFm",tr("<p>Could not copy %1 to %2</P>").arg(curFile).arg(destFile)); | 395 | QMessageBox::message("AdvancedFm",tr("<p>Could not copy %1 to %2</P>").arg(curFile).arg(destFile)); |
396 | return; | 396 | return; |
397 | } | 397 | } |
398 | } | 398 | } |
399 | delete fileDlg; | 399 | delete fileDlg; |
400 | 400 | ||
401 | } | 401 | } |
402 | rePopulate(); | 402 | rePopulate(); |
403 | // setOtherTabCurrent(); | 403 | // setOtherTabCurrent(); |
404 | qApp->processEvents(); | 404 | qApp->processEvents(); |
405 | 405 | ||
406 | } | 406 | } |
407 | 407 | ||
408 | void AdvancedFm::copySameDirTimer() { | 408 | void AdvancedFm::copySameDirTimer() { |
409 | QTimer::singleShot(125,this,SLOT(copySameDir())); | 409 | QTimer::singleShot(125,this,SLOT(copySameDir())); |
410 | } | 410 | } |
411 | 411 | ||
412 | void AdvancedFm::copySameDir() { | 412 | void AdvancedFm::copySameDir() { |
413 | qApp->processEvents(); | 413 | qApp->processEvents(); |
414 | QStringList curFileList = getPath(); | 414 | QStringList curFileList = getPath(); |
415 | QString curFile, item, destFile; | 415 | QString curFile, item, destFile; |
416 | InputDialog *fileDlg; | 416 | InputDialog *fileDlg; |
417 | 417 | ||
418 | QDir *thisDir = CurrentDir(); | 418 | QDir *thisDir = CurrentDir(); |
419 | 419 | ||
420 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 420 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
421 | item=(*it); | 421 | item=(*it); |
422 | curFile = thisDir->canonicalPath()+"/"+ item; | 422 | curFile = thisDir->canonicalPath()+"/"+ item; |
423 | 423 | ||
424 | fileDlg = new InputDialog(this,tr("Copy ")+curFile+tr(" As"),TRUE, 0); | 424 | fileDlg = new InputDialog(this,tr("Copy ")+curFile+tr(" As"),TRUE, 0); |
425 | fileDlg->setInputText((const QString &) destFile ); | 425 | fileDlg->setInputText((const QString &) destFile ); |
426 | fileDlg->exec(); | 426 | fileDlg->exec(); |
427 | 427 | ||
428 | if( fileDlg->result() == 1 ) { | 428 | if( fileDlg->result() == 1 ) { |
429 | 429 | ||
430 | QString filename = fileDlg->LineEdit1->text(); | 430 | QString filename = fileDlg->LineEdit1->text(); |
431 | destFile = thisDir->canonicalPath()+"/"+filename; | 431 | destFile = thisDir->canonicalPath()+"/"+filename; |
432 | 432 | ||
433 | QFile f(destFile); | 433 | QFile f(destFile); |
434 | if( f.exists()) { | 434 | if( f.exists()) { |
435 | switch (QMessageBox::warning(this,tr("Delete"), | 435 | switch (QMessageBox::warning(this,tr("Delete"), |
436 | tr("<p> %1 already exists. Do you really want to delete it?</P>").arg(destFile), | 436 | tr("<p> %1 already exists. Do you really want to delete it?</P>").arg(destFile), |
437 | tr("Yes"),tr("No"),0,0,1) ) { | 437 | tr("Yes"),tr("No"),0,0,1) ) { |
438 | case 0: | 438 | case 0: |
439 | f.remove(); | 439 | f.remove(); |
440 | break; | 440 | break; |
441 | case 1: | 441 | case 1: |
442 | return; | 442 | return; |
443 | break; | 443 | break; |
444 | default: | 444 | default: |
445 | return; | 445 | return; |
446 | break; | 446 | break; |
447 | }; | 447 | }; |
448 | } | 448 | } |
449 | if(!copyFile( curFile,destFile) ) { | 449 | if(!copyFile( curFile,destFile) ) { |
450 | QMessageBox::message("AdvancedFm",tr("<P>Could not copy %1 to %2</P>").arg(curFile).arg(destFile)); | 450 | QMessageBox::message("AdvancedFm",tr("<P>Could not copy %1 to %2</P>").arg(curFile).arg(destFile)); |
451 | return; | 451 | return; |
452 | } | 452 | } |
453 | 453 | ||
454 | // odebug << "copy "+curFile+" as "+destFile << oendl; | 454 | // odebug << "copy "+curFile+" as "+destFile << oendl; |
455 | } | 455 | } |
456 | delete fileDlg; | 456 | delete fileDlg; |
457 | } | 457 | } |
458 | rePopulate(); | 458 | rePopulate(); |
459 | } | 459 | } |
460 | 460 | ||
461 | void AdvancedFm::moveTimer() { | 461 | void AdvancedFm::moveTimer() { |
462 | QTimer::singleShot(125,this,SLOT(move())); | 462 | QTimer::singleShot(125,this,SLOT(move())); |
463 | } | 463 | } |
464 | 464 | ||
465 | void AdvancedFm::move() { | 465 | void AdvancedFm::move() { |
466 | 466 | ||
467 | QStringList curFileList = getPath(); | 467 | QStringList curFileList = getPath(); |
468 | if( curFileList.count() > 0) { | 468 | if( curFileList.count() > 0) { |
469 | QString curFile, destFile, item; | 469 | QString curFile, destFile, item; |
470 | 470 | ||
471 | QDir *thisDir = CurrentDir(); | 471 | QDir *thisDir = CurrentDir(); |
472 | QDir *thatDir = OtherDir(); | 472 | QDir *thatDir = OtherDir(); |
473 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 473 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
474 | item=(*it); | 474 | item=(*it); |
475 | QString destFile = thatDir->canonicalPath(); | 475 | QString destFile = thatDir->canonicalPath(); |
476 | 476 | ||
477 | if(destFile.right(1).find("/",0,TRUE) == -1) | 477 | if(destFile.right(1).find("/",0,TRUE) == -1) |
478 | destFile+="/"; | 478 | destFile+="/"; |
479 | destFile += item; | 479 | destFile += item; |
480 | // odebug << "Destination file is "+destFile << oendl; | 480 | // odebug << "Destination file is "+destFile << oendl; |
481 | 481 | ||
482 | curFile = thisDir->canonicalPath(); | 482 | curFile = thisDir->canonicalPath(); |
483 | if(curFile.right(1).find("/",0,TRUE) == -1) | 483 | if(curFile.right(1).find("/",0,TRUE) == -1) |
484 | curFile +="/"; | 484 | curFile +="/"; |
485 | curFile+= item; | 485 | curFile+= item; |
486 | // odebug << "CurrentFile file is " + curFile << oendl; | 486 | // odebug << "CurrentFile file is " + curFile << oendl; |
487 | 487 | ||
488 | if(QFileInfo(curFile).isDir()) { | 488 | if(QFileInfo(curFile).isDir()) { |
489 | moveDirectory( curFile, destFile ); | 489 | moveDirectory( curFile, destFile ); |
490 | rePopulate(); | 490 | rePopulate(); |
491 | return; | 491 | return; |
492 | } | 492 | } |
493 | QFile f( destFile); | 493 | QFile f( destFile); |
494 | if( f.exists()) { | 494 | if( f.exists()) { |
495 | switch ( QMessageBox::warning(this,tr("File Exists!"), | 495 | switch ( QMessageBox::warning(this,tr("File Exists!"), |
496 | tr("<p>%1 already exists. Ok to overwrite?</P>").arg(destFile), | 496 | tr("<p>%1 already exists. Ok to overwrite?</P>").arg(destFile), |
497 | tr("Yes"),tr("No"),0,0,1)) { | 497 | tr("Yes"),tr("No"),0,0,1)) { |
498 | case 0: | 498 | case 0: |
499 | break; | 499 | break; |
500 | case 1: | 500 | case 1: |
501 | return; | 501 | return; |
502 | break; | 502 | break; |
503 | default: | 503 | default: |
504 | return; | 504 | return; |
505 | break; | 505 | break; |
506 | }; | 506 | }; |
507 | } | 507 | } |
508 | if( !copyFile( curFile, destFile) ) { | 508 | if( !copyFile( curFile, destFile) ) { |
509 | QMessageBox::message(tr("Note"),tr("<p>Could not move %1</p>").arg(curFile)); | 509 | QMessageBox::message(tr("Note"),tr("<p>Could not move %1</p>").arg(curFile)); |
510 | return; | 510 | return; |
511 | } else | 511 | } else |
512 | QFile::remove(curFile); | 512 | QFile::remove(curFile); |
513 | } | 513 | } |
514 | } | 514 | } |
515 | rePopulate(); | 515 | rePopulate(); |
516 | //setOtherTabCurrent(); | 516 | //setOtherTabCurrent(); |
517 | } | 517 | } |
518 | 518 | ||
519 | bool AdvancedFm::moveDirectory( const QString & src, const QString & dest ) { | 519 | bool AdvancedFm::moveDirectory( const QString & src, const QString & dest ) { |
520 | int err = 0; | 520 | int err = 0; |
521 | if( copyDirectory( src, dest ) ) { | 521 | if( copyDirectory( src, dest ) ) { |
522 | QString cmd = "rm -rf " + src; | 522 | QString cmd = "rm -rf " + src; |
523 | err = system((const char*)cmd); | 523 | err = system((const char*)cmd); |
524 | } else | 524 | } else |
525 | err = -1; | 525 | err = -1; |
526 | 526 | ||
527 | if(err!=0) { | 527 | if(err!=0) { |
528 | QMessageBox::message(tr("Note"),tr("<p>Could not move %1</p>").arg( src)); | 528 | QMessageBox::message(tr("Note"),tr("<p>Could not move %1</p>").arg( src)); |
529 | return false; | 529 | return false; |
530 | } | 530 | } |
531 | return true; | 531 | return true; |
532 | } | 532 | } |
533 | 533 | ||
534 | bool AdvancedFm::copyDirectory( const QString & src, const QString & dest ) { | 534 | bool AdvancedFm::copyDirectory( const QString & src, const QString & dest ) { |
535 | 535 | ||
536 | QString cmd = "/bin/cp -fpR " + src + " " + dest; | 536 | QString cmd = "/bin/cp -fpR " + src + " " + dest; |
537 | owarn << cmd << oendl; | 537 | owarn << cmd << oendl; |
538 | int err = system( (const char *) cmd ); | 538 | int err = system( (const char *) cmd ); |
539 | if ( err != 0 ) { | 539 | if ( err != 0 ) { |
540 | QMessageBox::message("AdvancedFm", tr( "<p>Could not copy %1 to %2</p>").arg( src ).arg( dest ) ); | 540 | QMessageBox::message("AdvancedFm", tr( "<p>Could not copy %1 to %2</p>").arg( src ).arg( dest ) ); |
541 | return false; | 541 | return false; |
542 | } | 542 | } |
543 | 543 | ||
544 | return true; | 544 | return true; |
545 | } | 545 | } |
546 | 546 | ||
547 | 547 | ||
548 | bool AdvancedFm::copyFile( const QString & src, const QString & dest ) { | 548 | bool AdvancedFm::copyFile( const QString & src, const QString & dest ) { |
549 | if(QFileInfo(src).isDir()) { | 549 | if(QFileInfo(src).isDir()) { |
550 | if( copyDirectory( src, dest )) { | 550 | if( copyDirectory( src, dest )) { |
551 | // setOtherTabCurrent(); | 551 | // setOtherTabCurrent(); |
552 | rePopulate(); | 552 | rePopulate(); |
553 | return true; | 553 | return true; |
554 | } | 554 | } |
555 | else | 555 | else |
556 | return false; | 556 | return false; |
557 | } | 557 | } |
558 | 558 | ||
559 | 559 | ||
560 | bool success = true; | 560 | bool success = true; |
561 | struct stat status; | 561 | struct stat status; |
562 | QFile srcFile(src); | 562 | QFile srcFile(src); |
563 | QFile destFile(dest); | 563 | QFile destFile(dest); |
564 | int err=0; | 564 | int err=0; |
565 | int read_fd=0; | 565 | int read_fd=0; |
566 | int write_fd=0; | 566 | int write_fd=0; |
567 | struct stat stat_buf; | 567 | struct stat stat_buf; |
568 | off_t offset = 0; | 568 | off_t offset = 0; |
569 | if(!srcFile.open( IO_ReadOnly|IO_Raw)) { | 569 | if(!srcFile.open( IO_ReadOnly|IO_Raw)) { |
570 | // owarn << "open failed" << oendl; | 570 | // owarn << "open failed" << oendl; |
571 | return success = false; | 571 | return success = false; |
572 | } | 572 | } |
573 | read_fd = srcFile.handle(); | 573 | read_fd = srcFile.handle(); |
574 | if(read_fd != -1) { | 574 | if(read_fd != -1) { |
575 | fstat (read_fd, &stat_buf); | 575 | fstat (read_fd, &stat_buf); |
576 | if( !destFile.open( IO_WriteOnly|IO_Raw ) ) { | 576 | if( !destFile.open( IO_WriteOnly|IO_Raw ) ) { |
577 | // owarn << "destfile open failed" << oendl; | 577 | // owarn << "destfile open failed" << oendl; |
578 | return success = false; | 578 | return success = false; |
579 | } | 579 | } |
580 | write_fd = destFile.handle(); | 580 | write_fd = destFile.handle(); |
581 | if(write_fd != -1) { | 581 | if(write_fd != -1) { |
582 | err = sendfile(write_fd, read_fd, &offset, stat_buf.st_size); | 582 | err = sendfile(write_fd, read_fd, &offset, stat_buf.st_size); |
583 | if( err == -1) { | 583 | if( err == -1) { |
584 | QString msg; | 584 | QString msg; |
585 | switch(err) { | 585 | switch(errno) { |
586 | case EBADF : msg = "The input file was not opened for reading or the output file was not opened for writing. "; | 586 | case EBADF : msg = "The input file was not opened for reading or the output file was not opened for writing. "; |
587 | case EINVAL: msg = "Descriptor is not valid or locked. "; | 587 | case EINVAL: msg = "Descriptor is not valid or locked. "; |
588 | case ENOMEM: msg = "Insufficient memory to read from in_fd."; | 588 | case ENOMEM: msg = "Insufficient memory to read from in_fd."; |
589 | case EIO: msg = "Unspecified error while reading from in_fd."; | 589 | case EIO: msg = "Unspecified error while reading from in_fd."; |
590 | }; | 590 | }; |
591 | success = false; | 591 | success = false; |
592 | // owarn << msg << oendl; | 592 | // owarn << msg << oendl; |
593 | } | 593 | } |
594 | } else { | 594 | } else { |
595 | success = false; | 595 | success = false; |
596 | } | 596 | } |
597 | } else { | 597 | } else { |
598 | success = false; | 598 | success = false; |
599 | } | 599 | } |
600 | srcFile.close(); | 600 | srcFile.close(); |
601 | destFile.close(); | 601 | destFile.close(); |
602 | // Set file permissions | 602 | // Set file permissions |
603 | if( stat( QFile::encodeName(src), &status ) == 0 ) { | 603 | if( stat( QFile::encodeName(src), &status ) == 0 ) { |
604 | chmod( QFile::encodeName(dest), status.st_mode ); | 604 | chmod( QFile::encodeName(dest), status.st_mode ); |
605 | } | 605 | } |
606 | 606 | ||
607 | return success; | 607 | return success; |
608 | } | 608 | } |
609 | 609 | ||
610 | void AdvancedFm::runCommand() { | 610 | void AdvancedFm::runCommand() { |
611 | if( !CurrentView()->currentItem()) return; | 611 | if( !CurrentView()->currentItem()) return; |
612 | QDir *thisDir = CurrentDir(); | 612 | QDir *thisDir = CurrentDir(); |
613 | 613 | ||
614 | QString curFile; | 614 | QString curFile; |
615 | curFile = thisDir->canonicalPath() +"/"+ CurrentView()->currentItem()->text(0); | 615 | curFile = thisDir->canonicalPath() +"/"+ CurrentView()->currentItem()->text(0); |
616 | 616 | ||
617 | InputDialog *fileDlg; | 617 | InputDialog *fileDlg; |
618 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); | 618 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); |
619 | fileDlg->setInputText(curFile); | 619 | fileDlg->setInputText(curFile); |
620 | fileDlg->exec(); | 620 | fileDlg->exec(); |
621 | //QString command; | 621 | //QString command; |
622 | 622 | ||
623 | if( fileDlg->result() == 1 ) { | 623 | if( fileDlg->result() == 1 ) { |
624 | // odebug << fileDlg->LineEdit1->text() << oendl; | 624 | // odebug << fileDlg->LineEdit1->text() << oendl; |
625 | QStringList command; | 625 | QStringList command; |
626 | 626 | ||
627 | command << "/bin/sh"; | 627 | command << "/bin/sh"; |
628 | command << "-c"; | 628 | command << "-c"; |
629 | command << fileDlg->LineEdit1->text(); | 629 | command << fileDlg->LineEdit1->text(); |
630 | Output *outDlg; | 630 | Output *outDlg; |
631 | outDlg = new Output( command, this, tr("AdvancedFm Output"), true); | 631 | outDlg = new Output( command, this, tr("AdvancedFm Output"), true); |
632 | QPEApplication::execDialog( outDlg ); | 632 | QPEApplication::execDialog( outDlg ); |
633 | qApp->processEvents(); | 633 | qApp->processEvents(); |
634 | 634 | ||
635 | } | 635 | } |
636 | } | 636 | } |
637 | 637 | ||
638 | void AdvancedFm::runCommandStd() { | 638 | void AdvancedFm::runCommandStd() { |
639 | if( !CurrentView()->currentItem()) return; | 639 | if( !CurrentView()->currentItem()) return; |
640 | QString curFile; | 640 | QString curFile; |
641 | QDir *thisDir = CurrentDir(); | 641 | QDir *thisDir = CurrentDir(); |
642 | QListView *thisView = CurrentView(); | 642 | QListView *thisView = CurrentView(); |
643 | if( thisView->currentItem()) | 643 | if( thisView->currentItem()) |
644 | curFile = thisDir->canonicalPath() +"/"+ thisView->currentItem()->text(0); | 644 | curFile = thisDir->canonicalPath() +"/"+ thisView->currentItem()->text(0); |
645 | 645 | ||
646 | InputDialog *fileDlg; | 646 | InputDialog *fileDlg; |
647 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); | 647 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); |
648 | fileDlg->setInputText(curFile); | 648 | fileDlg->setInputText(curFile); |
649 | fileDlg->exec(); | 649 | fileDlg->exec(); |
650 | 650 | ||
651 | if( fileDlg->result() == 1 ) { | 651 | if( fileDlg->result() == 1 ) { |
652 | qApp->processEvents(); | 652 | qApp->processEvents(); |
653 | startProcess( (const QString)fileDlg->LineEdit1->text().latin1()); | 653 | startProcess( (const QString)fileDlg->LineEdit1->text().latin1()); |
654 | } | 654 | } |
655 | } | 655 | } |
656 | 656 | ||
657 | void AdvancedFm::fileStatus() { | 657 | void AdvancedFm::fileStatus() { |
658 | if( !CurrentView()->currentItem()) return; | 658 | if( !CurrentView()->currentItem()) return; |
659 | 659 | ||
660 | QString curFile; | 660 | QString curFile; |
661 | curFile = CurrentView()->currentItem()->text(0); | 661 | curFile = CurrentView()->currentItem()->text(0); |
662 | 662 | ||
663 | QFileInfo curFileInfo(curFile); | 663 | QFileInfo curFileInfo(curFile); |
664 | 664 | ||
665 | FileInfoDialog *infoDlg = new FileInfoDialog(this); | 665 | FileInfoDialog *infoDlg = new FileInfoDialog(this); |
666 | infoDlg->setCaption(tr("Info for %1").arg(curFile)); | 666 | infoDlg->setCaption(tr("Info for %1").arg(curFile)); |
667 | 667 | ||
668 | uint size = curFileInfo.size(); | 668 | uint size = curFileInfo.size(); |
669 | QString sizestr; | 669 | QString sizestr; |
670 | if( size > 1048576 ) | 670 | if( size > 1048576 ) |
671 | sizestr = tr("%1MB (%2 bytes)").arg(QString().sprintf("%.0f", size / 1048576.0)).arg(size); | 671 | sizestr = tr("%1MB (%2 bytes)").arg(QString().sprintf("%.0f", size / 1048576.0)).arg(size); |
672 | else if( size > 1024 ) | 672 | else if( size > 1024 ) |
673 | sizestr = tr("%1kB (%2 bytes)").arg(QString().sprintf("%.0f", size / 1024.0)).arg(size); | 673 | sizestr = tr("%1kB (%2 bytes)").arg(QString().sprintf("%.0f", size / 1024.0)).arg(size); |
674 | else | 674 | else |
675 | sizestr = tr("%1 bytes").arg(size); | 675 | sizestr = tr("%1 bytes").arg(size); |
676 | 676 | ||
677 | infoDlg->sizeLabel->setText(sizestr); | 677 | infoDlg->sizeLabel->setText(sizestr); |
678 | 678 | ||
679 | if(curFileInfo.isSymLink()) | 679 | if(curFileInfo.isSymLink()) |
680 | infoDlg->typeLabel->setText(tr("symbolic link")); | 680 | infoDlg->typeLabel->setText(tr("symbolic link")); |
681 | else if(curFileInfo.isFile()) { | 681 | else if(curFileInfo.isFile()) { |
682 | if(curFileInfo.isExecutable()) | 682 | if(curFileInfo.isExecutable()) |
683 | infoDlg->typeLabel->setText(tr("executable file")); | 683 | infoDlg->typeLabel->setText(tr("executable file")); |
684 | else | 684 | else |
685 | infoDlg->typeLabel->setText(tr("file")); | 685 | infoDlg->typeLabel->setText(tr("file")); |
686 | } | 686 | } |
687 | else if(curFileInfo.isDir()) | 687 | else if(curFileInfo.isDir()) |
688 | infoDlg->typeLabel->setText(tr("directory")); | 688 | infoDlg->typeLabel->setText(tr("directory")); |
689 | else | 689 | else |
690 | infoDlg->typeLabel->setText(tr("unknown")); | 690 | infoDlg->typeLabel->setText(tr("unknown")); |
691 | 691 | ||
692 | infoDlg->ownerLabel->setText( QString("%1 (%2)").arg(curFileInfo.owner()).arg(curFileInfo.ownerId()) ); | 692 | infoDlg->ownerLabel->setText( QString("%1 (%2)").arg(curFileInfo.owner()).arg(curFileInfo.ownerId()) ); |
693 | infoDlg->groupLabel->setText( QString("%1 (%2)").arg(curFileInfo.group()).arg(curFileInfo.groupId()) ); | 693 | infoDlg->groupLabel->setText( QString("%1 (%2)").arg(curFileInfo.group()).arg(curFileInfo.groupId()) ); |
694 | 694 | ||
695 | infoDlg->lastReadLabel->setText( curFileInfo.lastRead().toString() ); | 695 | infoDlg->lastReadLabel->setText( curFileInfo.lastRead().toString() ); |
696 | infoDlg->lastModifiedLabel->setText( curFileInfo.lastModified().toString() ); | 696 | infoDlg->lastModifiedLabel->setText( curFileInfo.lastModified().toString() ); |
697 | 697 | ||
698 | QString perms; | 698 | QString perms; |
699 | // User | 699 | // User |
700 | if(curFileInfo.permission(QFileInfo::ReadUser)) | 700 | if(curFileInfo.permission(QFileInfo::ReadUser)) |
701 | perms += "r"; | 701 | perms += "r"; |
702 | else | 702 | else |
703 | perms += "-"; | 703 | perms += "-"; |
704 | if(curFileInfo.permission(QFileInfo::WriteUser)) | 704 | if(curFileInfo.permission(QFileInfo::WriteUser)) |
705 | perms += "w"; | 705 | perms += "w"; |
706 | else | 706 | else |
707 | perms += "-"; | 707 | perms += "-"; |
708 | if(curFileInfo.permission(QFileInfo::ExeUser)) | 708 | if(curFileInfo.permission(QFileInfo::ExeUser)) |
709 | perms += "x"; | 709 | perms += "x"; |
710 | else | 710 | else |
711 | perms += "-"; | 711 | perms += "-"; |
712 | // Group | 712 | // Group |
713 | if(curFileInfo.permission(QFileInfo::ReadGroup)) | 713 | if(curFileInfo.permission(QFileInfo::ReadGroup)) |
714 | perms += "r"; | 714 | perms += "r"; |
715 | else | 715 | else |
716 | perms += "-"; | 716 | perms += "-"; |
717 | if(curFileInfo.permission(QFileInfo::WriteGroup)) | 717 | if(curFileInfo.permission(QFileInfo::WriteGroup)) |
718 | perms += "w"; | 718 | perms += "w"; |
719 | else | 719 | else |
720 | perms += "-"; | 720 | perms += "-"; |
721 | if(curFileInfo.permission(QFileInfo::ExeGroup)) | 721 | if(curFileInfo.permission(QFileInfo::ExeGroup)) |
722 | perms += "x"; | 722 | perms += "x"; |
723 | else | 723 | else |
724 | perms += "-"; | 724 | perms += "-"; |
725 | // Other | 725 | // Other |
726 | if(curFileInfo.permission(QFileInfo::ReadOther)) | 726 | if(curFileInfo.permission(QFileInfo::ReadOther)) |
727 | perms += "r"; | 727 | perms += "r"; |
728 | else | 728 | else |
729 | perms += "-"; | 729 | perms += "-"; |
730 | if(curFileInfo.permission(QFileInfo::WriteOther)) | 730 | if(curFileInfo.permission(QFileInfo::WriteOther)) |
731 | perms += "w"; | 731 | perms += "w"; |
732 | else | 732 | else |
733 | perms += "-"; | 733 | perms += "-"; |
734 | if(curFileInfo.permission(QFileInfo::ExeOther)) | 734 | if(curFileInfo.permission(QFileInfo::ExeOther)) |
735 | perms += "x"; | 735 | perms += "x"; |
736 | else | 736 | else |
737 | perms += "-"; | 737 | perms += "-"; |
738 | infoDlg->permsLabel->setText( perms ); | 738 | infoDlg->permsLabel->setText( perms ); |
739 | 739 | ||
740 | QPEApplication::execDialog( infoDlg ); | 740 | QPEApplication::execDialog( infoDlg ); |
741 | 741 | ||
742 | qApp->processEvents(); | 742 | qApp->processEvents(); |
743 | } | 743 | } |
744 | 744 | ||
745 | 745 | ||
746 | void AdvancedFm::mkDir() { | 746 | void AdvancedFm::mkDir() { |
747 | makeDir(); | 747 | makeDir(); |
748 | } | 748 | } |
749 | 749 | ||
750 | void AdvancedFm::rn() { | 750 | void AdvancedFm::rn() { |
751 | renameIt(); | 751 | renameIt(); |
752 | } | 752 | } |
753 | 753 | ||
754 | void AdvancedFm::del() { | 754 | void AdvancedFm::del() { |
755 | doDelete(); | 755 | doDelete(); |
756 | } | 756 | } |
757 | 757 | ||
758 | void AdvancedFm::mkSym() { | 758 | void AdvancedFm::mkSym() { |
759 | QString cmd; | 759 | QString cmd; |
760 | QStringList curFileList = getPath(); | 760 | QStringList curFileList = getPath(); |
761 | if( curFileList.count() > 0) { | 761 | if( curFileList.count() > 0) { |
762 | QDir *thisDir = CurrentDir(); | 762 | QDir *thisDir = CurrentDir(); |
763 | QDir * thatDir = OtherDir(); | 763 | QDir * thatDir = OtherDir(); |
764 | 764 | ||
765 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 765 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
766 | 766 | ||
767 | QString destName = thatDir->canonicalPath()+"/"+(*it); | 767 | QString destName = thatDir->canonicalPath()+"/"+(*it); |
768 | if(destName.right(1) == "/") { | 768 | if(destName.right(1) == "/") { |
769 | destName = destName.left( destName.length() -1); | 769 | destName = destName.left( destName.length() -1); |
770 | } | 770 | } |
771 | 771 | ||
772 | QString curFile = thisDir->canonicalPath()+"/"+(*it); | 772 | QString curFile = thisDir->canonicalPath()+"/"+(*it); |
773 | 773 | ||
774 | if( curFile.right(1) == "/") { | 774 | if( curFile.right(1) == "/") { |
775 | curFile = curFile.left( curFile.length() -1); | 775 | curFile = curFile.left( curFile.length() -1); |
776 | } | 776 | } |
777 | 777 | ||
778 | cmd = "ln -s "+curFile+" "+destName; | 778 | cmd = "ln -s "+curFile+" "+destName; |
779 | // odebug << cmd << oendl; | 779 | // odebug << cmd << oendl; |
780 | startProcess( (const QString)cmd ); | 780 | startProcess( (const QString)cmd ); |
781 | } | 781 | } |
782 | rePopulate(); | 782 | rePopulate(); |
783 | setOtherTabCurrent(); | 783 | setOtherTabCurrent(); |
784 | } | 784 | } |
785 | } | 785 | } |
786 | 786 | ||
787 | void AdvancedFm::doBeam() { | 787 | void AdvancedFm::doBeam() { |
788 | Ir ir; | 788 | Ir ir; |
789 | if(!ir.supported()) { | 789 | if(!ir.supported()) { |
790 | } else { | 790 | } else { |
791 | QStringList curFileList = getPath(); | 791 | QStringList curFileList = getPath(); |
792 | if( curFileList.count() > 0) { | 792 | if( curFileList.count() > 0) { |
793 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 793 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
794 | QString curFile = (*it); | 794 | QString curFile = (*it); |
795 | QString curFilePath = CurrentDir()->canonicalPath()+"/"+curFile; | 795 | QString curFilePath = CurrentDir()->canonicalPath()+"/"+curFile; |
796 | if( curFilePath.right(1) == "/") { | 796 | if( curFilePath.right(1) == "/") { |
797 | curFilePath = curFilePath.left( curFilePath.length() -1); | 797 | curFilePath = curFilePath.left( curFilePath.length() -1); |
798 | } | 798 | } |
799 | Ir *file = new Ir(this, "IR"); | 799 | Ir *file = new Ir(this, "IR"); |
800 | connect(file, SIGNAL(done(Ir*)), this, SLOT( fileBeamFinished(Ir*))); | 800 | connect(file, SIGNAL(done(Ir*)), this, SLOT( fileBeamFinished(Ir*))); |
801 | file->send( curFilePath, curFile ); | 801 | file->send( curFilePath, curFile ); |
802 | } | 802 | } |
803 | } | 803 | } |
804 | } | 804 | } |
805 | } | 805 | } |
806 | 806 | ||
807 | void AdvancedFm::fileBeamFinished( Ir *) { | 807 | void AdvancedFm::fileBeamFinished( Ir *) { |
808 | QMessageBox::message( tr("Advancedfm Beam out"), tr("Ir sent.") ,tr("Ok") ); | 808 | QMessageBox::message( tr("Advancedfm Beam out"), tr("Ir sent.") ,tr("Ok") ); |
809 | } | 809 | } |
810 | 810 | ||
811 | void AdvancedFm::selectAll() { | 811 | void AdvancedFm::selectAll() { |
812 | QListView *thisView = CurrentView(); | 812 | QListView *thisView = CurrentView(); |
813 | thisView->selectAll(true); | 813 | thisView->selectAll(true); |
814 | thisView->setSelected( thisView->firstChild(),false); | 814 | thisView->setSelected( thisView->firstChild(),false); |
815 | } | 815 | } |
816 | 816 | ||
817 | void AdvancedFm::startProcess(const QString & cmd) { | 817 | void AdvancedFm::startProcess(const QString & cmd) { |
818 | QStringList command; | 818 | QStringList command; |
819 | OProcess *process; | 819 | OProcess *process; |
820 | process = new OProcess(); | 820 | process = new OProcess(); |
821 | connect(process,SIGNAL(processExited(Opie::Core::OProcess*)),this,SLOT(processEnded(Opie::Core::OProcess*))); | 821 | connect(process,SIGNAL(processExited(Opie::Core::OProcess*)),this,SLOT(processEnded(Opie::Core::OProcess*))); |
822 | connect(process,SIGNAL(receivedStderr(Opie::Core::OProcess*,char*,int)),this,SLOT(oprocessStderr(Opie::Core::OProcess*,char*,int))); | 822 | connect(process,SIGNAL(receivedStderr(Opie::Core::OProcess*,char*,int)),this,SLOT(oprocessStderr(Opie::Core::OProcess*,char*,int))); |
823 | 823 | ||
824 | command << "/bin/sh"; | 824 | command << "/bin/sh"; |
825 | command << "-c"; | 825 | command << "-c"; |
826 | command << cmd.latin1(); | 826 | command << cmd.latin1(); |
827 | *process << command; | 827 | *process << command; |
828 | if(!process->start(OProcess::NotifyOnExit, OProcess::All) ) | 828 | if(!process->start(OProcess::NotifyOnExit, OProcess::All) ) |
829 | odebug << "could not start process" << oendl; | 829 | odebug << "could not start process" << oendl; |
830 | } | 830 | } |
831 | 831 | ||
832 | void AdvancedFm::processEnded(OProcess *) { | 832 | void AdvancedFm::processEnded(OProcess *) { |
833 | rePopulate(); | 833 | rePopulate(); |
834 | } | 834 | } |
835 | 835 | ||
836 | void AdvancedFm::oprocessStderr(OProcess*, char *buffer, int ) { | 836 | void AdvancedFm::oprocessStderr(OProcess*, char *buffer, int ) { |
837 | // owarn << "received stderrt " << buflen << " bytes" << oendl; | 837 | // owarn << "received stderrt " << buflen << " bytes" << oendl; |
838 | 838 | ||
839 | QString lineStr = buffer; | 839 | QString lineStr = buffer; |
840 | QMessageBox::warning( this, tr("Error"), lineStr ,tr("Ok") ); | 840 | QMessageBox::warning( this, tr("Error"), lineStr ,tr("Ok") ); |
841 | } | 841 | } |