summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/advancedfm/advancedfmMenu.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/noncore/apps/advancedfm/advancedfmMenu.cpp b/noncore/apps/advancedfm/advancedfmMenu.cpp
index d34f330..4628170 100644
--- a/noncore/apps/advancedfm/advancedfmMenu.cpp
+++ b/noncore/apps/advancedfm/advancedfmMenu.cpp
@@ -516,98 +516,98 @@ bool AdvancedFm::copyFile( const QString & src, const QString & dest ) {
516 else 516 else
517 return false; 517 return false;
518 } 518 }
519 519
520 520
521 bool success = true; 521 bool success = true;
522 struct stat status; 522 struct stat status;
523 QFile srcFile(src); 523 QFile srcFile(src);
524 QFile destFile(dest); 524 QFile destFile(dest);
525 int err=0; 525 int err=0;
526 int read_fd=0; 526 int read_fd=0;
527 int write_fd=0; 527 int write_fd=0;
528 struct stat stat_buf; 528 struct stat stat_buf;
529 off_t offset = 0; 529 off_t offset = 0;
530 if(!srcFile.open( IO_ReadOnly|IO_Raw)) { 530 if(!srcFile.open( IO_ReadOnly|IO_Raw)) {
531// owarn << "open failed" << oendl; 531// owarn << "open failed" << oendl;
532 return success = false; 532 return success = false;
533 } 533 }
534 read_fd = srcFile.handle(); 534 read_fd = srcFile.handle();
535 if(read_fd != -1) { 535 if(read_fd != -1) {
536 fstat (read_fd, &stat_buf); 536 fstat (read_fd, &stat_buf);
537 if( !destFile.open( IO_WriteOnly|IO_Raw ) ) { 537 if( !destFile.open( IO_WriteOnly|IO_Raw ) ) {
538// owarn << "destfile open failed" << oendl; 538// owarn << "destfile open failed" << oendl;
539 return success = false; 539 return success = false;
540 } 540 }
541 write_fd = destFile.handle(); 541 write_fd = destFile.handle();
542 if(write_fd != -1) { 542 if(write_fd != -1) {
543 err = sendfile(write_fd, read_fd, &offset, stat_buf.st_size); 543 err = sendfile(write_fd, read_fd, &offset, stat_buf.st_size);
544 if( err == -1) { 544 if( err == -1) {
545 QString msg; 545 QString msg;
546 switch(err) { 546 switch(err) {
547 case EBADF : msg = "The input file was not opened for reading or the output file was not opened for writing. "; 547 case EBADF : msg = "The input file was not opened for reading or the output file was not opened for writing. ";
548 case EINVAL: msg = "Descriptor is not valid or locked. "; 548 case EINVAL: msg = "Descriptor is not valid or locked. ";
549 case ENOMEM: msg = "Insufficient memory to read from in_fd."; 549 case ENOMEM: msg = "Insufficient memory to read from in_fd.";
550 case EIO: msg = "Unspecified error while reading from in_fd."; 550 case EIO: msg = "Unspecified error while reading from in_fd.";
551 }; 551 };
552 success = false; 552 success = false;
553// owarn << msg << oendl; 553// owarn << msg << oendl;
554 } 554 }
555 } else { 555 } else {
556 success = false; 556 success = false;
557 } 557 }
558 } else { 558 } else {
559 success = false; 559 success = false;
560 } 560 }
561 srcFile.close(); 561 srcFile.close();
562 destFile.close(); 562 destFile.close();
563 // Set file permissions 563 // Set file permissions
564 if( stat( (const char *) src, &status ) == 0 ) { 564 if( stat( QFile::encodeName(src), &status ) == 0 ) {
565 chmod( (const char *) dest, status.st_mode ); 565 chmod( QFile::encodeName(dest), status.st_mode );
566 } 566 }
567 567
568 return success; 568 return success;
569} 569}
570 570
571void AdvancedFm::runCommand() { 571void AdvancedFm::runCommand() {
572 if( !CurrentView()->currentItem()) return; 572 if( !CurrentView()->currentItem()) return;
573 QDir *thisDir = CurrentDir(); 573 QDir *thisDir = CurrentDir();
574 574
575 QString curFile; 575 QString curFile;
576 curFile = thisDir->canonicalPath() +"/"+ CurrentView()->currentItem()->text(0); 576 curFile = thisDir->canonicalPath() +"/"+ CurrentView()->currentItem()->text(0);
577 577
578 InputDialog *fileDlg; 578 InputDialog *fileDlg;
579 fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); 579 fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0);
580 fileDlg->setInputText(curFile); 580 fileDlg->setInputText(curFile);
581 fileDlg->exec(); 581 fileDlg->exec();
582 //QString command; 582 //QString command;
583 583
584 if( fileDlg->result() == 1 ) { 584 if( fileDlg->result() == 1 ) {
585// odebug << fileDlg->LineEdit1->text() << oendl; 585// odebug << fileDlg->LineEdit1->text() << oendl;
586 QStringList command; 586 QStringList command;
587 587
588 command << "/bin/sh"; 588 command << "/bin/sh";
589 command << "-c"; 589 command << "-c";
590 command << fileDlg->LineEdit1->text(); 590 command << fileDlg->LineEdit1->text();
591 Output *outDlg; 591 Output *outDlg;
592 outDlg = new Output( command, this, tr("AdvancedFm Output"), true); 592 outDlg = new Output( command, this, tr("AdvancedFm Output"), true);
593 QPEApplication::execDialog( outDlg ); 593 QPEApplication::execDialog( outDlg );
594 qApp->processEvents(); 594 qApp->processEvents();
595 595
596 } 596 }
597} 597}
598 598
599void AdvancedFm::runCommandStd() { 599void AdvancedFm::runCommandStd() {
600 if( !CurrentView()->currentItem()) return; 600 if( !CurrentView()->currentItem()) return;
601 QString curFile; 601 QString curFile;
602 QDir *thisDir = CurrentDir(); 602 QDir *thisDir = CurrentDir();
603 QListView *thisView = CurrentView(); 603 QListView *thisView = CurrentView();
604 if( thisView->currentItem()) 604 if( thisView->currentItem())
605 curFile = thisDir->canonicalPath() +"/"+ thisView->currentItem()->text(0); 605 curFile = thisDir->canonicalPath() +"/"+ thisView->currentItem()->text(0);
606 606
607 InputDialog *fileDlg; 607 InputDialog *fileDlg;
608 fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); 608 fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0);
609 fileDlg->setInputText(curFile); 609 fileDlg->setInputText(curFile);
610 fileDlg->exec(); 610 fileDlg->exec();
611 611
612 if( fileDlg->result() == 1 ) { 612 if( fileDlg->result() == 1 ) {
613 qApp->processEvents(); 613 qApp->processEvents();