summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2003-02-16 20:54:08 (UTC)
committer llornkcor <llornkcor>2003-02-16 20:54:08 (UTC)
commit64178d4839f12540b8a3d19cf79c9c2b1d33707e (patch) (unidiff)
treec8e1b65c379e286b9f8f6750b0c69eaf5c00235c
parentb24a37c7e412cdf49f5d93c8ab51786b6cda24fb (diff)
downloadopie-64178d4839f12540b8a3d19cf79c9c2b1d33707e.zip
opie-64178d4839f12540b8a3d19cf79c9c2b1d33707e.tar.gz
opie-64178d4839f12540b8a3d19cf79c9c2b1d33707e.tar.bz2
fix for bug 616- hitting ok when no file is selected hangs
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/apps/textedit/textedit.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/core/apps/textedit/textedit.cpp b/core/apps/textedit/textedit.cpp
index 4cf1b07..e931f01 100644
--- a/core/apps/textedit/textedit.cpp
+++ b/core/apps/textedit/textedit.cpp
@@ -384,513 +384,513 @@ TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
384 384
385 nAdvanced = new QAction( tr("Prompt on Exit"), 385 nAdvanced = new QAction( tr("Prompt on Exit"),
386 QString::null, 0, this, 0 ); 386 QString::null, 0, this, 0 );
387 connect( nAdvanced, SIGNAL( toggled(bool) ), 387 connect( nAdvanced, SIGNAL( toggled(bool) ),
388 this, SLOT( doPrompt(bool) ) ); 388 this, SLOT( doPrompt(bool) ) );
389 nAdvanced->setToggleAction(true); 389 nAdvanced->setToggleAction(true);
390 nAdvanced->addTo( advancedMenu ); 390 nAdvanced->addTo( advancedMenu );
391 391
392 desktopAction = new QAction( tr("Always open linked file"), 392 desktopAction = new QAction( tr("Always open linked file"),
393 QString::null, 0, this, 0 ); 393 QString::null, 0, this, 0 );
394 connect( desktopAction, SIGNAL( toggled(bool) ), 394 connect( desktopAction, SIGNAL( toggled(bool) ),
395 this, SLOT( doDesktop(bool) ) ); 395 this, SLOT( doDesktop(bool) ) );
396 desktopAction->setToggleAction(true); 396 desktopAction->setToggleAction(true);
397 desktopAction->addTo( advancedMenu); 397 desktopAction->addTo( advancedMenu);
398 398
399 filePermAction = new QAction( tr("File Permissions"), 399 filePermAction = new QAction( tr("File Permissions"),
400 QString::null, 0, this, 0 ); 400 QString::null, 0, this, 0 );
401 connect( filePermAction, SIGNAL( toggled(bool) ), 401 connect( filePermAction, SIGNAL( toggled(bool) ),
402 this, SLOT( doFilePerms(bool) ) ); 402 this, SLOT( doFilePerms(bool) ) );
403 filePermAction->setToggleAction(true); 403 filePermAction->setToggleAction(true);
404 filePermAction->addTo( advancedMenu); 404 filePermAction->addTo( advancedMenu);
405 405
406 searchBarAction = new QAction( tr("Search Bar Open"), 406 searchBarAction = new QAction( tr("Search Bar Open"),
407 QString::null, 0, this, 0 ); 407 QString::null, 0, this, 0 );
408 connect( searchBarAction, SIGNAL( toggled(bool) ), 408 connect( searchBarAction, SIGNAL( toggled(bool) ),
409 this, SLOT( setSearchBar(bool) ) ); 409 this, SLOT( setSearchBar(bool) ) );
410 searchBarAction->setToggleAction(true); 410 searchBarAction->setToggleAction(true);
411 searchBarAction->addTo( advancedMenu); 411 searchBarAction->addTo( advancedMenu);
412 412
413 413
414 font->insertSeparator(); 414 font->insertSeparator();
415 415
416 font->insertItem(tr("About"), this, SLOT( doAbout()) ); 416 font->insertItem(tr("About"), this, SLOT( doAbout()) );
417 417
418 mb->insertItem( tr( "File" ), file ); 418 mb->insertItem( tr( "File" ), file );
419 mb->insertItem( tr( "Edit" ), edit ); 419 mb->insertItem( tr( "Edit" ), edit );
420 mb->insertItem( tr( "View" ), font ); 420 mb->insertItem( tr( "View" ), font );
421 421
422 searchBar = new QPEToolBar(this); 422 searchBar = new QPEToolBar(this);
423 addToolBar( searchBar, "Search", QMainWindow::Top, true ); 423 addToolBar( searchBar, "Search", QMainWindow::Top, true );
424 424
425 searchBar->setHorizontalStretchable( true ); 425 searchBar->setHorizontalStretchable( true );
426 426
427 searchEdit = new QLineEdit( searchBar, "searchEdit" ); 427 searchEdit = new QLineEdit( searchBar, "searchEdit" );
428 searchBar->setStretchableWidget( searchEdit ); 428 searchBar->setStretchableWidget( searchEdit );
429 connect( searchEdit, SIGNAL( textChanged( const QString & ) ), 429 connect( searchEdit, SIGNAL( textChanged( const QString & ) ),
430 this, SLOT( search() ) ); 430 this, SLOT( search() ) );
431 431
432 a = new QAction( tr( "Find Next" ), Resource::loadPixmap( "next" ), 432 a = new QAction( tr( "Find Next" ), Resource::loadPixmap( "next" ),
433 QString::null, 0, this, 0 ); 433 QString::null, 0, this, 0 );
434 connect( a, SIGNAL( activated() ), this, SLOT( findNext() ) ); 434 connect( a, SIGNAL( activated() ), this, SLOT( findNext() ) );
435 a->addTo( searchBar ); 435 a->addTo( searchBar );
436 a->addTo( edit ); 436 a->addTo( edit );
437 437
438 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), 438 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ),
439 QString::null, 0, this, 0 ); 439 QString::null, 0, this, 0 );
440 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) ); 440 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) );
441 a->addTo( searchBar ); 441 a->addTo( searchBar );
442 442
443 edit->insertSeparator(); 443 edit->insertSeparator();
444 a = new QAction( tr( "Delete" ), Resource::loadPixmap( "close" ), 444 a = new QAction( tr( "Delete" ), Resource::loadPixmap( "close" ),
445 QString::null, 0, this, 0 ); 445 QString::null, 0, this, 0 );
446 connect( a, SIGNAL( activated() ), this, SLOT( editDelete() ) ); 446 connect( a, SIGNAL( activated() ), this, SLOT( editDelete() ) );
447 a->addTo( edit ); 447 a->addTo( edit );
448 448
449 searchBar->hide(); 449 searchBar->hide();
450 450
451 editor = new QpeEditor( this ); 451 editor = new QpeEditor( this );
452 setCentralWidget( editor ); 452 setCentralWidget( editor );
453 editor->setFrameStyle( QFrame::Panel | QFrame::Sunken ); 453 editor->setFrameStyle( QFrame::Panel | QFrame::Sunken );
454 connect( editor, SIGNAL( textChanged() ), 454 connect( editor, SIGNAL( textChanged() ),
455 this, SLOT( editorChanged() ) ); 455 this, SLOT( editorChanged() ) );
456 456
457 QPEApplication::setStylusOperation( editor, QPEApplication::RightOnHold); 457 QPEApplication::setStylusOperation( editor, QPEApplication::RightOnHold);
458 458
459 Config cfg("TextEdit"); 459 Config cfg("TextEdit");
460 cfg. setGroup ( "Font" ); 460 cfg. setGroup ( "Font" );
461 461
462 QFont defaultFont = editor-> font ( ); 462 QFont defaultFont = editor-> font ( );
463 463
464 QString family = cfg. readEntry ( "Family", defaultFont. family ( )); 464 QString family = cfg. readEntry ( "Family", defaultFont. family ( ));
465 int size = cfg. readNumEntry ( "Size", defaultFont. pointSize ( )); 465 int size = cfg. readNumEntry ( "Size", defaultFont. pointSize ( ));
466 int weight = cfg. readNumEntry ( "Weight", defaultFont. weight ( )); 466 int weight = cfg. readNumEntry ( "Weight", defaultFont. weight ( ));
467 bool italic = cfg. readBoolEntry ( "Italic", defaultFont. italic ( )); 467 bool italic = cfg. readBoolEntry ( "Italic", defaultFont. italic ( ));
468 468
469 defaultFont = QFont ( family, size, weight, italic ); 469 defaultFont = QFont ( family, size, weight, italic );
470 editor-> setFont ( defaultFont ); 470 editor-> setFont ( defaultFont );
471 471
472// updateCaption(); 472// updateCaption();
473 473
474 cfg.setGroup ( "View" ); 474 cfg.setGroup ( "View" );
475 475
476 promptExit = cfg.readBoolEntry ( "PromptExit", false ); 476 promptExit = cfg.readBoolEntry ( "PromptExit", false );
477 openDesktop = cfg.readBoolEntry ( "OpenDesktop", true ); 477 openDesktop = cfg.readBoolEntry ( "OpenDesktop", true );
478 filePerms = cfg.readBoolEntry ( "FilePermissions", false ); 478 filePerms = cfg.readBoolEntry ( "FilePermissions", false );
479 useSearchBar = cfg.readBoolEntry ( "SearchBar", false ); 479 useSearchBar = cfg.readBoolEntry ( "SearchBar", false );
480 startWithNew = cfg.readBoolEntry ( "startNew", true); 480 startWithNew = cfg.readBoolEntry ( "startNew", true);
481 481
482 if(useSearchBar) searchBarAction->setOn(true); 482 if(useSearchBar) searchBarAction->setOn(true);
483 if(promptExit ) nAdvanced->setOn( true ); 483 if(promptExit ) nAdvanced->setOn( true );
484 if(openDesktop) desktopAction->setOn( true ); 484 if(openDesktop) desktopAction->setOn( true );
485 if(filePerms) filePermAction->setOn( true ); 485 if(filePerms) filePermAction->setOn( true );
486 if(startWithNew) nStart->setOn( true ); 486 if(startWithNew) nStart->setOn( true );
487 487
488 bool wrap = cfg. readBoolEntry ( "Wrap", true ); 488 bool wrap = cfg. readBoolEntry ( "Wrap", true );
489 wa-> setOn ( wrap ); 489 wa-> setOn ( wrap );
490 setWordWrap ( wrap ); 490 setWordWrap ( wrap );
491 491
492 if( qApp->argc() > 1) { 492 if( qApp->argc() > 1) {
493 currentFileName=qApp->argv()[1]; 493 currentFileName=qApp->argv()[1];
494 494
495 QFileInfo fi(currentFileName); 495 QFileInfo fi(currentFileName);
496 496
497 if(fi.baseName().left(1) == "") { 497 if(fi.baseName().left(1) == "") {
498 openDotFile(currentFileName); 498 openDotFile(currentFileName);
499 } else { 499 } else {
500 openFile(currentFileName); 500 openFile(currentFileName);
501 } 501 }
502 } else { 502 } else {
503 edited1=false; 503 edited1=false;
504 openDotFile(""); 504 openDotFile("");
505 } 505 }
506 506
507 viewSelection = cfg.readNumEntry( "FileView", 0 ); 507 viewSelection = cfg.readNumEntry( "FileView", 0 );
508} 508}
509 509
510TextEdit::~TextEdit() { 510TextEdit::~TextEdit() {
511 qWarning("textedit d'tor"); 511 qWarning("textedit d'tor");
512 delete editor; 512 delete editor;
513} 513}
514 514
515void TextEdit::closeEvent(QCloseEvent *) { 515void TextEdit::closeEvent(QCloseEvent *) {
516 if( edited1 && promptExit) 516 if( edited1 && promptExit)
517 saveAs(); 517 saveAs();
518 qApp->quit(); 518 qApp->quit();
519} 519}
520 520
521void TextEdit::cleanUp() { 521void TextEdit::cleanUp() {
522 522
523 Config cfg ( "TextEdit" ); 523 Config cfg ( "TextEdit" );
524 cfg. setGroup ( "Font" ); 524 cfg. setGroup ( "Font" );
525 QFont f = editor->font(); 525 QFont f = editor->font();
526 cfg.writeEntry ( "Family", f. family ( )); 526 cfg.writeEntry ( "Family", f. family ( ));
527 cfg.writeEntry ( "Size", f. pointSize ( )); 527 cfg.writeEntry ( "Size", f. pointSize ( ));
528 cfg.writeEntry ( "Weight", f. weight ( )); 528 cfg.writeEntry ( "Weight", f. weight ( ));
529 cfg.writeEntry ( "Italic", f. italic ( )); 529 cfg.writeEntry ( "Italic", f. italic ( ));
530 530
531 cfg.setGroup ( "View" ); 531 cfg.setGroup ( "View" );
532 cfg.writeEntry ( "Wrap", editor->wordWrap() == QMultiLineEdit::WidgetWidth ); 532 cfg.writeEntry ( "Wrap", editor->wordWrap() == QMultiLineEdit::WidgetWidth );
533 cfg.writeEntry ( "FileView", viewSelection ); 533 cfg.writeEntry ( "FileView", viewSelection );
534 534
535 cfg.writeEntry ( "PromptExit", promptExit ); 535 cfg.writeEntry ( "PromptExit", promptExit );
536 cfg.writeEntry ( "OpenDesktop", openDesktop ); 536 cfg.writeEntry ( "OpenDesktop", openDesktop );
537 cfg.writeEntry ( "FilePermissions", filePerms ); 537 cfg.writeEntry ( "FilePermissions", filePerms );
538 cfg.writeEntry ( "SearchBar", useSearchBar ); 538 cfg.writeEntry ( "SearchBar", useSearchBar );
539 cfg.writeEntry ( "startNew", startWithNew ); 539 cfg.writeEntry ( "startNew", startWithNew );
540 540
541} 541}
542 542
543 543
544void TextEdit::accept() { 544void TextEdit::accept() {
545 if( edited1) 545 if( edited1)
546 saveAs(); 546 saveAs();
547 qApp->quit(); 547 qApp->quit();
548} 548}
549 549
550void TextEdit::zoomIn() { 550void TextEdit::zoomIn() {
551 setFontSize(editor->font().pointSize()+1,false); 551 setFontSize(editor->font().pointSize()+1,false);
552} 552}
553 553
554void TextEdit::zoomOut() { 554void TextEdit::zoomOut() {
555 setFontSize(editor->font().pointSize()-1,true); 555 setFontSize(editor->font().pointSize()-1,true);
556} 556}
557 557
558 558
559void TextEdit::setFontSize(int sz, bool round_down_not_up) { 559void TextEdit::setFontSize(int sz, bool round_down_not_up) {
560 int s=10; 560 int s=10;
561 for (int i=0; i<nfontsizes; i++) { 561 for (int i=0; i<nfontsizes; i++) {
562 if ( fontsize[i] == sz ) { 562 if ( fontsize[i] == sz ) {
563 s = sz; 563 s = sz;
564 break; 564 break;
565 } else if ( round_down_not_up ) { 565 } else if ( round_down_not_up ) {
566 if ( fontsize[i] < sz ) 566 if ( fontsize[i] < sz )
567 s = fontsize[i]; 567 s = fontsize[i];
568 } else { 568 } else {
569 if ( fontsize[i] > sz ) { 569 if ( fontsize[i] > sz ) {
570 s = fontsize[i]; 570 s = fontsize[i];
571 break; 571 break;
572 } 572 }
573 } 573 }
574 } 574 }
575 575
576 QFont f = editor->font(); 576 QFont f = editor->font();
577 f.setPointSize(s); 577 f.setPointSize(s);
578 editor->setFont(f); 578 editor->setFont(f);
579 579
580 zin->setEnabled(s != fontsize[nfontsizes-1]); 580 zin->setEnabled(s != fontsize[nfontsizes-1]);
581 zout->setEnabled(s != fontsize[0]); 581 zout->setEnabled(s != fontsize[0]);
582} 582}
583 583
584void TextEdit::setBold(bool y) { 584void TextEdit::setBold(bool y) {
585 QFont f = editor->font(); 585 QFont f = editor->font();
586 f.setBold(y); 586 f.setBold(y);
587 editor->setFont(f); 587 editor->setFont(f);
588} 588}
589 589
590void TextEdit::setItalic(bool y) { 590void TextEdit::setItalic(bool y) {
591 QFont f = editor->font(); 591 QFont f = editor->font();
592 f.setItalic(y); 592 f.setItalic(y);
593 editor->setFont(f); 593 editor->setFont(f);
594} 594}
595 595
596void TextEdit::setWordWrap(bool y) { 596void TextEdit::setWordWrap(bool y) {
597 bool state = editor->edited(); 597 bool state = editor->edited();
598 QString captionStr = caption(); 598 QString captionStr = caption();
599 bool b1 = edited1; 599 bool b1 = edited1;
600 bool b2 = edited; 600 bool b2 = edited;
601 601
602 editor->setWordWrap(y ? QMultiLineEdit::WidgetWidth : QMultiLineEdit::NoWrap ); 602 editor->setWordWrap(y ? QMultiLineEdit::WidgetWidth : QMultiLineEdit::NoWrap );
603 editor->setEdited( state ); 603 editor->setEdited( state );
604 edited1=b1; 604 edited1=b1;
605 edited=b2; 605 edited=b2;
606 setCaption(captionStr); 606 setCaption(captionStr);
607} 607}
608 608
609void TextEdit::setSearchBar(bool b) { 609void TextEdit::setSearchBar(bool b) {
610 useSearchBar=b; 610 useSearchBar=b;
611 Config cfg("TextEdit"); 611 Config cfg("TextEdit");
612 cfg.setGroup("View"); 612 cfg.setGroup("View");
613 cfg.writeEntry ( "SearchBar", b ); 613 cfg.writeEntry ( "SearchBar", b );
614 searchBarAction->setOn(b); 614 searchBarAction->setOn(b);
615 if(b) 615 if(b)
616 searchBar->show(); 616 searchBar->show();
617 else 617 else
618 searchBar->hide(); 618 searchBar->hide();
619 editor->setFocus(); 619 editor->setFocus();
620} 620}
621 621
622void TextEdit::fileNew() { 622void TextEdit::fileNew() {
623// if( !bFromDocView ) { 623// if( !bFromDocView ) {
624// saveAs(); 624// saveAs();
625// } 625// }
626 newFile(DocLnk()); 626 newFile(DocLnk());
627} 627}
628 628
629void TextEdit::fileOpen() { 629void TextEdit::fileOpen() {
630 QMap<QString, QStringList> map; 630 QMap<QString, QStringList> map;
631 map.insert(tr("All"), QStringList() ); 631 map.insert(tr("All"), QStringList() );
632 QStringList text; 632 QStringList text;
633 text << "text/*"; 633 text << "text/*";
634 map.insert(tr("Text"), text ); 634 map.insert(tr("Text"), text );
635 text << "*"; 635 text << "*";
636 map.insert(tr("All"), text ); 636 map.insert(tr("All"), text );
637 QString str = OFileDialog::getOpenFileName( 2, 637 QString str = OFileDialog::getOpenFileName( 2,
638 QPEApplication::documentDir(), 638 QPEApplication::documentDir(),
639 QString::null, map); 639 QString::null, map);
640 if( QFile(str).exists() && !QFileInfo(str).isDir() ) 640 if( !str.isEmpty() && QFile(str).exists() && !QFileInfo(str).isDir() )
641 openFile( str ); 641 openFile( str );
642 else 642 else
643 updateCaption(); 643 updateCaption();
644} 644}
645 645
646void TextEdit::doSearchBar() { 646void TextEdit::doSearchBar() {
647 if(!useSearchBar) 647 if(!useSearchBar)
648 searchBar->hide(); 648 searchBar->hide();
649 else 649 else
650 searchBar->show(); 650 searchBar->show();
651} 651}
652 652
653#if 0 653#if 0
654void TextEdit::slotFind() { 654void TextEdit::slotFind() {
655 FindDialog frmFind( tr("Text Editor"), this ); 655 FindDialog frmFind( tr("Text Editor"), this );
656 connect( &frmFind, SIGNAL(signalFindClicked(const QString &, bool, bool, int)), 656 connect( &frmFind, SIGNAL(signalFindClicked(const QString &, bool, bool, int)),
657 editor, SLOT(slotDoFind( const QString&,bool,bool))); 657 editor, SLOT(slotDoFind( const QString&,bool,bool)));
658 658
659 //case sensitive, backwards, [category] 659 //case sensitive, backwards, [category]
660 660
661 connect( editor, SIGNAL(notFound()), 661 connect( editor, SIGNAL(notFound()),
662 &frmFind, SLOT(slotNotFound()) ); 662 &frmFind, SLOT(slotNotFound()) );
663 connect( editor, SIGNAL(searchWrapped()), 663 connect( editor, SIGNAL(searchWrapped()),
664 &frmFind, SLOT(slotWrapAround()) ); 664 &frmFind, SLOT(slotWrapAround()) );
665 665
666 frmFind.exec(); 666 frmFind.exec();
667 667
668 668
669} 669}
670#endif 670#endif
671 671
672void TextEdit::fileRevert() { 672void TextEdit::fileRevert() {
673 clear(); 673 clear();
674 fileOpen(); 674 fileOpen();
675} 675}
676 676
677void TextEdit::editCut() { 677void TextEdit::editCut() {
678#ifndef QT_NO_CLIPBOARD 678#ifndef QT_NO_CLIPBOARD
679 editor->cut(); 679 editor->cut();
680#endif 680#endif
681} 681}
682 682
683void TextEdit::editCopy() { 683void TextEdit::editCopy() {
684#ifndef QT_NO_CLIPBOARD 684#ifndef QT_NO_CLIPBOARD
685 editor->copy(); 685 editor->copy();
686#endif 686#endif
687} 687}
688 688
689void TextEdit::editPaste() { 689void TextEdit::editPaste() {
690#ifndef QT_NO_CLIPBOARD 690#ifndef QT_NO_CLIPBOARD
691 editor->paste(); 691 editor->paste();
692#endif 692#endif
693} 693}
694 694
695void TextEdit::editFind() { 695void TextEdit::editFind() {
696 searchBar->show(); 696 searchBar->show();
697 searchEdit->setFocus(); 697 searchEdit->setFocus();
698} 698}
699 699
700void TextEdit::findNext() { 700void TextEdit::findNext() {
701 editor->find( searchEdit->text(), false, false ); 701 editor->find( searchEdit->text(), false, false );
702 702
703} 703}
704 704
705void TextEdit::findClose() { 705void TextEdit::findClose() {
706 searchBar->hide(); 706 searchBar->hide();
707} 707}
708 708
709void TextEdit::search() { 709void TextEdit::search() {
710 editor->find( searchEdit->text(), false, false ); 710 editor->find( searchEdit->text(), false, false );
711} 711}
712 712
713void TextEdit::newFile( const DocLnk &f ) { 713void TextEdit::newFile( const DocLnk &f ) {
714 DocLnk nf = f; 714 DocLnk nf = f;
715 nf.setType("text/plain"); 715 nf.setType("text/plain");
716 clear(); 716 clear();
717 setWState (WState_Reserved1 ); 717 setWState (WState_Reserved1 );
718 editor->setFocus(); 718 editor->setFocus();
719 doc = new DocLnk(nf); 719 doc = new DocLnk(nf);
720 currentFileName = "Unnamed"; 720 currentFileName = "Unnamed";
721 qDebug("newFile "+currentFileName); 721 qDebug("newFile "+currentFileName);
722 updateCaption( currentFileName); 722 updateCaption( currentFileName);
723// editor->setEdited( false); 723// editor->setEdited( false);
724} 724}
725 725
726void TextEdit::openDotFile( const QString &f ) { 726void TextEdit::openDotFile( const QString &f ) {
727 if(!currentFileName.isEmpty()) { 727 if(!currentFileName.isEmpty()) {
728 currentFileName=f; 728 currentFileName=f;
729 729
730 qDebug("openFile dotfile " + currentFileName); 730 qDebug("openFile dotfile " + currentFileName);
731 QString txt; 731 QString txt;
732 QFile file(f); 732 QFile file(f);
733 file.open(IO_ReadWrite); 733 file.open(IO_ReadWrite);
734 QTextStream t(&file); 734 QTextStream t(&file);
735 while ( !t.atEnd()) { 735 while ( !t.atEnd()) {
736 txt+=t.readLine()+"\n"; 736 txt+=t.readLine()+"\n";
737 } 737 }
738 editor->setText(txt); 738 editor->setText(txt);
739 editor->setEdited( false); 739 editor->setEdited( false);
740 edited1=false; 740 edited1=false;
741 edited=false; 741 edited=false;
742 742
743 743
744 } 744 }
745 updateCaption( currentFileName); 745 updateCaption( currentFileName);
746} 746}
747 747
748void TextEdit::openFile( const QString &f ) { 748void TextEdit::openFile( const QString &f ) {
749 qDebug("filename is "+ f); 749 qDebug("filename is "+ f);
750 QString filer; 750 QString filer;
751 QFileInfo fi( f); 751 QFileInfo fi( f);
752// bFromDocView = true; 752// bFromDocView = true;
753 if(f.find(".desktop",0,true) != -1 && !openDesktop ) { 753 if(f.find(".desktop",0,true) != -1 && !openDesktop ) {
754 switch ( QMessageBox::warning(this,tr("Text Editor"), 754 switch ( QMessageBox::warning(this,tr("Text Editor"),
755 tr("Text Editor has detected<BR>you selected a <B>.desktop</B> 755 tr("Text Editor has detected<BR>you selected a <B>.desktop</B>
756file.<BR>Open <B>.desktop</B> file or <B>linked</B> file?"), 756file.<BR>Open <B>.desktop</B> file or <B>linked</B> file?"),
757 tr(".desktop File"),tr("Linked Document"),0,1,1) ) { 757 tr(".desktop File"),tr("Linked Document"),0,1,1) ) {
758 case 0: 758 case 0:
759 filer = f; 759 filer = f;
760 break; 760 break;
761 case 1: 761 case 1:
762 DocLnk sf(f); 762 DocLnk sf(f);
763 filer = sf.file(); 763 filer = sf.file();
764 break; 764 break;
765 } 765 }
766 } else if(fi.baseName().left(1) == "") { 766 } else if(fi.baseName().left(1) == "") {
767 currentFileName=f; 767 currentFileName=f;
768 openDotFile(currentFileName); 768 openDotFile(currentFileName);
769 } else { 769 } else {
770 DocLnk sf(f); 770 DocLnk sf(f);
771 filer = sf.file(); 771 filer = sf.file();
772 if(filer.right(1) == "/") 772 if(filer.right(1) == "/")
773 filer = f; 773 filer = f;
774 774
775 DocLnk nf; 775 DocLnk nf;
776 nf.setType("text/plain"); 776 nf.setType("text/plain");
777 nf.setFile(filer); 777 nf.setFile(filer);
778 currentFileName=filer; 778 currentFileName=filer;
779 779
780 nf.setName(fi.baseName()); 780 nf.setName(fi.baseName());
781 openFile(nf); 781 openFile(nf);
782 782
783 qDebug("openFile string "+currentFileName); 783 qDebug("openFile string "+currentFileName);
784 784
785 } 785 }
786 showEditTools(); 786 showEditTools();
787 // Show filename in caption 787 // Show filename in caption
788 QString name = filer; 788 QString name = filer;
789 int sep = name.findRev( '/' ); 789 int sep = name.findRev( '/' );
790 if ( sep > 0 ) 790 if ( sep > 0 )
791 name = name.mid( sep+1 ); 791 name = name.mid( sep+1 );
792 updateCaption( name ); 792 updateCaption( name );
793} 793}
794 794
795void TextEdit::openFile( const DocLnk &f ) { 795void TextEdit::openFile( const DocLnk &f ) {
796// clear(); 796// clear();
797// bFromDocView = true; 797// bFromDocView = true;
798 FileManager fm; 798 FileManager fm;
799 QString txt; 799 QString txt;
800 currentFileName=f.file(); 800 currentFileName=f.file();
801 qDebug("openFile doclnk " + currentFileName); 801 qDebug("openFile doclnk " + currentFileName);
802 if ( !fm.loadFile( f, txt ) ) { 802 if ( !fm.loadFile( f, txt ) ) {
803 // ####### could be a new file 803 // ####### could be a new file
804 qDebug( "Cannot open file" ); 804 qDebug( "Cannot open file" );
805 } 805 }
806// fileNew(); 806// fileNew();
807 if ( doc ) 807 if ( doc )
808 delete doc; 808 delete doc;
809 doc = new DocLnk(f); 809 doc = new DocLnk(f);
810 editor->setText(txt); 810 editor->setText(txt);
811 editor->setEdited( false); 811 editor->setEdited( false);
812 edited1=false; 812 edited1=false;
813 edited=false; 813 edited=false;
814 814
815 doc->setName(currentFileName); 815 doc->setName(currentFileName);
816 updateCaption(); 816 updateCaption();
817} 817}
818 818
819void TextEdit::showEditTools() { 819void TextEdit::showEditTools() {
820 menu->show(); 820 menu->show();
821 editBar->show(); 821 editBar->show();
822 if(!useSearchBar) 822 if(!useSearchBar)
823 searchBar->hide(); 823 searchBar->hide();
824 else 824 else
825 searchBar->show(); 825 searchBar->show();
826 setWState (WState_Reserved1 ); 826 setWState (WState_Reserved1 );
827} 827}
828 828
829/*! 829/*!
830 unprompted save */ 830 unprompted save */
831bool TextEdit::save() { 831bool TextEdit::save() {
832 qDebug("saveAsFile " + currentFileName); 832 qDebug("saveAsFile " + currentFileName);
833 if(currentFileName.isEmpty()) { 833 if(currentFileName.isEmpty()) {
834 saveAs(); 834 saveAs();
835 return false; 835 return false;
836 } 836 }
837 QString file = doc->file(); 837 QString file = doc->file();
838 qDebug("saver file "+file); 838 qDebug("saver file "+file);
839 QString name= doc->name(); 839 QString name= doc->name();
840 qDebug("File named "+name); 840 qDebug("File named "+name);
841 QString rt = editor->text(); 841 QString rt = editor->text();
842 if( !rt.isEmpty() ) { 842 if( !rt.isEmpty() ) {
843 if(name.isEmpty()) { 843 if(name.isEmpty()) {
844 saveAs(); 844 saveAs();
845 } else { 845 } else {
846 currentFileName= name ; 846 currentFileName= name ;
847 qDebug("saveFile "+currentFileName); 847 qDebug("saveFile "+currentFileName);
848 848
849 struct stat buf; 849 struct stat buf;
850 mode_t mode; 850 mode_t mode;
851 stat(file.latin1(), &buf); 851 stat(file.latin1(), &buf);
852 mode = buf.st_mode; 852 mode = buf.st_mode;
853 853
854 if(!fileIs) { 854 if(!fileIs) {
855 doc->setName( name); 855 doc->setName( name);
856 FileManager fm; 856 FileManager fm;
857 if ( !fm.saveFile( *doc, rt ) ) { 857 if ( !fm.saveFile( *doc, rt ) ) {
858 return false; 858 return false;
859 } 859 }
860 } else { 860 } else {
861 qDebug("regular save file"); 861 qDebug("regular save file");
862 QFile f(file); 862 QFile f(file);
863 if( f.open(IO_WriteOnly)) { 863 if( f.open(IO_WriteOnly)) {
864 QCString crt = rt.utf8(); 864 QCString crt = rt.utf8();
865 f.writeBlock(crt,crt.length()); 865 f.writeBlock(crt,crt.length());
866 } else { 866 } else {
867 QMessageBox::message(tr("Text Edit"),tr("Write Failed")); 867 QMessageBox::message(tr("Text Edit"),tr("Write Failed"));
868 return false; 868 return false;
869 } 869 }
870 870
871 } 871 }
872 editor->setEdited( false); 872 editor->setEdited( false);
873 edited1=false; 873 edited1=false;
874 edited=false; 874 edited=false;
875 if(caption().left(1)=="*") 875 if(caption().left(1)=="*")
876 setCaption(caption().right(caption().length()-1)); 876 setCaption(caption().right(caption().length()-1));
877 877
878 878
879 chmod( file.latin1(), mode); 879 chmod( file.latin1(), mode);
880 } 880 }
881 return true; 881 return true;
882 } 882 }
883 return false; 883 return false;
884} 884}
885 885
886/*! 886/*!
887 prompted save */ 887 prompted save */
888bool TextEdit::saveAs() { 888bool TextEdit::saveAs() {
889 if(caption() == tr("Text Editor")) 889 if(caption() == tr("Text Editor"))
890 return false; 890 return false;
891 qDebug("saveAsFile " + currentFileName); 891 qDebug("saveAsFile " + currentFileName);
892 // case of nothing to save... 892 // case of nothing to save...
893// if ( !doc && !currentFileName.isEmpty()) { 893// if ( !doc && !currentFileName.isEmpty()) {
894// //|| !bFromDocView) 894// //|| !bFromDocView)
895// qDebug("no doc"); 895// qDebug("no doc");
896// return true; 896// return true;