summaryrefslogtreecommitdiff
path: root/core
authorbipolar <bipolar>2002-03-08 00:12:12 (UTC)
committer bipolar <bipolar>2002-03-08 00:12:12 (UTC)
commit11b56113b6641e0b85c6015eafab802dd7663198 (patch) (unidiff)
tree1899707c9144a342519acf9693ec69d2d4edffc7 /core
parent50f8f55346f369787063f42c571d2dc832eb58aa (diff)
downloadopie-11b56113b6641e0b85c6015eafab802dd7663198.zip
opie-11b56113b6641e0b85c6015eafab802dd7663198.tar.gz
opie-11b56113b6641e0b85c6015eafab802dd7663198.tar.bz2
ljp: added startup option,a dn fixed save when closing with no file edited
Diffstat (limited to 'core') (more/less context) (ignore whitespace changes)
-rw-r--r--core/apps/textedit/fileSaver.cpp2
-rw-r--r--core/apps/textedit/textedit.cpp88
-rw-r--r--core/apps/textedit/textedit.h6
3 files changed, 69 insertions, 27 deletions
diff --git a/core/apps/textedit/fileSaver.cpp b/core/apps/textedit/fileSaver.cpp
index d78f2e8..4e80735 100644
--- a/core/apps/textedit/fileSaver.cpp
+++ b/core/apps/textedit/fileSaver.cpp
@@ -54,49 +54,49 @@ fileSaver::fileSaver( QWidget* parent, const char* name, bool modal, WFlags fl
54 ListView->setColumnAlignment(1,QListView::AlignRight); 54 ListView->setColumnAlignment(1,QListView::AlignRight);
55// ListView->setMultiSelection(true); 55// ListView->setMultiSelection(true);
56// ListView->setSelectionMode(QListView::Extended); 56// ListView->setSelectionMode(QListView::Extended);
57 57
58 ListView->setAllColumnsShowFocus( TRUE ); 58 ListView->setAllColumnsShowFocus( TRUE );
59 ListView->setGeometry( QRect( 10,35,220,125)); 59 ListView->setGeometry( QRect( 10,35,220,125));
60 60
61 fileEdit= new QLineEdit(this); 61 fileEdit= new QLineEdit(this);
62 fileEdit->setGeometry( QRect( 10, 162, 205, 17)); 62 fileEdit->setGeometry( QRect( 10, 162, 205, 17));
63 63
64 fileEdit->setText( tmpFileName); 64 fileEdit->setText( tmpFileName);
65 65
66 filePermCheck = new QCheckBox( this, "SetFilePerms" ); 66 filePermCheck = new QCheckBox( this, "SetFilePerms" );
67 filePermCheck->setText("set file permissions"); 67 filePermCheck->setText("set file permissions");
68 filePermCheck->setGeometry(10, 178, 150,17); 68 filePermCheck->setGeometry(10, 178, 150,17);
69 // signals and slots connections 69 // signals and slots connections
70 connect( ListView, SIGNAL(doubleClicked( QListViewItem*)), SLOT(listDoubleClicked(QListViewItem *)) ); 70 connect( ListView, SIGNAL(doubleClicked( QListViewItem*)), SLOT(listDoubleClicked(QListViewItem *)) );
71 connect( ListView, SIGNAL(pressed( QListViewItem*)), SLOT(listClicked(QListViewItem *)) ); 71 connect( ListView, SIGNAL(pressed( QListViewItem*)), SLOT(listClicked(QListViewItem *)) );
72 72
73// tmpFileName=fi.FilePath(); 73// tmpFileName=fi.FilePath();
74// qDebug( tmpFileName); 74// qDebug( tmpFileName);
75 currentDir.setPath( QDir::currentDirPath() ); 75 currentDir.setPath( QDir::currentDirPath() );
76 populateList(); 76 populateList();
77 move(0,15); 77 move(0,15);
78 78 fileEdit->setFocus();
79} 79}
80 80
81fileSaver::~fileSaver() 81fileSaver::~fileSaver()
82{ 82{
83} 83}
84 84
85void fileSaver::populateList() 85void fileSaver::populateList()
86{ 86{
87 ListView->clear(); 87 ListView->clear();
88 currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden ); 88 currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden );
89 currentDir.setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); 89 currentDir.setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst);
90 currentDir.setMatchAllDirs(TRUE); 90 currentDir.setMatchAllDirs(TRUE);
91 91
92 currentDir.setNameFilter("*"); 92 currentDir.setNameFilter("*");
93 QString fileL, fileS; 93 QString fileL, fileS;
94 const QFileInfoList *list = currentDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); 94 const QFileInfoList *list = currentDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/);
95 QFileInfoListIterator it(*list); 95 QFileInfoListIterator it(*list);
96 QFileInfo *fi; 96 QFileInfo *fi;
97 while ( (fi=it.current()) ) { 97 while ( (fi=it.current()) ) {
98 98
99 if (fi->isSymLink() ){ 99 if (fi->isSymLink() ){
100 QString symLink=fi->readLink(); 100 QString symLink=fi->readLink();
101// qDebug("Symlink detected "+symLink); 101// qDebug("Symlink detected "+symLink);
102 QFileInfo sym( symLink); 102 QFileInfo sym( symLink);
diff --git a/core/apps/textedit/textedit.cpp b/core/apps/textedit/textedit.cpp
index 0f19da9..03f3a1e 100644
--- a/core/apps/textedit/textedit.cpp
+++ b/core/apps/textedit/textedit.cpp
@@ -231,49 +231,49 @@ static int u_id = 1;
231static int get_unique_id() 231static int get_unique_id()
232{ 232{
233 return u_id++; 233 return u_id++;
234} 234}
235 235
236static const int nfontsizes = 6; 236static const int nfontsizes = 6;
237static const int fontsize[nfontsizes] = {8,10,12,14,18,24}; 237static const int fontsize[nfontsizes] = {8,10,12,14,18,24};
238 238
239TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f ) 239TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
240 : QMainWindow( parent, name, f ), bFromDocView( FALSE ) 240 : QMainWindow( parent, name, f ), bFromDocView( FALSE )
241{ 241{
242 doc = 0; 242 doc = 0;
243 243
244 setToolBarsMovable( FALSE ); 244 setToolBarsMovable( FALSE );
245 245
246 setIcon( Resource::loadPixmap( "TextEditor" ) ); 246 setIcon( Resource::loadPixmap( "TextEditor" ) );
247 247
248 QPEToolBar *bar = new QPEToolBar( this ); 248 QPEToolBar *bar = new QPEToolBar( this );
249 bar->setHorizontalStretchable( TRUE ); 249 bar->setHorizontalStretchable( TRUE );
250 menu = bar; 250 menu = bar;
251 251
252 QPEMenuBar *mb = new QPEMenuBar( bar ); 252 QPEMenuBar *mb = new QPEMenuBar( bar );
253 QPopupMenu *file = new QPopupMenu( this ); 253 QPopupMenu *file = new QPopupMenu( this );
254 QPopupMenu *edit = new QPopupMenu( this ); 254 QPopupMenu *edit = new QPopupMenu( this );
255 QPopupMenu *font = new QPopupMenu( this ); 255 font = new QPopupMenu( this );
256 256
257 bar = new QPEToolBar( this ); 257 bar = new QPEToolBar( this );
258 editBar = bar; 258 editBar = bar;
259 259
260 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); 260 QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 );
261 connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); 261 connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) );
262 a->addTo( bar ); 262 a->addTo( bar );
263 a->addTo( file ); 263 a->addTo( file );
264 264
265 a = new QAction( tr( "Open" ), Resource::loadPixmap( "fileopen" ), QString::null, 0, this, 0 ); 265 a = new QAction( tr( "Open" ), Resource::loadPixmap( "fileopen" ), QString::null, 0, this, 0 );
266 connect( a, SIGNAL( activated() ), this, SLOT( fileOpen() ) ); 266 connect( a, SIGNAL( activated() ), this, SLOT( fileOpen() ) );
267// a->addTo( bar ); 267// a->addTo( bar );
268 a->addTo( file ); 268 a->addTo( file );
269 269
270 a = new QAction( tr( "Browse" ), Resource::loadPixmap( "fileopen" ), QString::null, 0, this, 0 ); 270 a = new QAction( tr( "Browse" ), Resource::loadPixmap( "fileopen" ), QString::null, 0, this, 0 );
271 connect( a, SIGNAL( activated() ), this, SLOT( newFileOpen() ) ); 271 connect( a, SIGNAL( activated() ), this, SLOT( newFileOpen() ) );
272 a->addTo( bar ); 272 a->addTo( bar );
273 a->addTo( file ); 273 a->addTo( file );
274 274
275 a = new QAction( tr( "Save" ), QPixmap(( const char** ) filesave_xpm ) , QString::null, 0, this, 0 ); 275 a = new QAction( tr( "Save" ), QPixmap(( const char** ) filesave_xpm ) , QString::null, 0, this, 0 );
276 connect( a, SIGNAL( activated() ), this, SLOT( save() ) ); 276 connect( a, SIGNAL( activated() ), this, SLOT( save() ) );
277// a->addTo( bar ); 277// a->addTo( bar );
278 file->insertSeparator(); 278 file->insertSeparator();
279 a->addTo( file ); 279 a->addTo( file );
@@ -328,48 +328,54 @@ TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
328 QAction *ba = new QAction( tr("Bold"), QString::null, 0, this, 0 ); 328 QAction *ba = new QAction( tr("Bold"), QString::null, 0, this, 0 );
329 connect( ba, SIGNAL( toggled(bool) ), this, SLOT( setBold(bool) ) ); 329 connect( ba, SIGNAL( toggled(bool) ), this, SLOT( setBold(bool) ) );
330 ba->setToggleAction(TRUE); 330 ba->setToggleAction(TRUE);
331 ba->addTo( font ); 331 ba->addTo( font );
332 332
333 QAction *ia = new QAction( tr("Italic"), QString::null, 0, this, 0 ); 333 QAction *ia = new QAction( tr("Italic"), QString::null, 0, this, 0 );
334 connect( ia, SIGNAL( toggled(bool) ), this, SLOT( setItalic(bool) ) ); 334 connect( ia, SIGNAL( toggled(bool) ), this, SLOT( setItalic(bool) ) );
335 ia->setToggleAction(TRUE); 335 ia->setToggleAction(TRUE);
336 ia->addTo( font ); 336 ia->addTo( font );
337 337
338 ba->setOn(defb); 338 ba->setOn(defb);
339 ia->setOn(defi); 339 ia->setOn(defi);
340 340
341 font->insertSeparator(); 341 font->insertSeparator();
342#endif 342#endif
343 343
344 QAction *wa = new QAction( tr("Wrap lines"), QString::null, 0, this, 0 ); 344 QAction *wa = new QAction( tr("Wrap lines"), QString::null, 0, this, 0 );
345 connect( wa, SIGNAL( toggled(bool) ), this, SLOT( setWordWrap(bool) ) ); 345 connect( wa, SIGNAL( toggled(bool) ), this, SLOT( setWordWrap(bool) ) );
346 wa->setToggleAction(TRUE); 346 wa->setToggleAction(TRUE);
347 wa->addTo( font ); 347 wa->addTo( font );
348 348
349 font->insertSeparator(); 349 font->insertSeparator();
350 font->insertItem("Font", this, SLOT(changeFont()) ); 350 font->insertItem("Font", this, SLOT(changeFont()) );
351 351
352 font->insertSeparator();
353 nStart = new QAction( tr("Start with new file"), QString::null, 0, this, 0 );
354 connect( nStart, SIGNAL( toggled(bool) ), this, SLOT( changeStartConfig(bool) ) );
355 nStart->setToggleAction(TRUE);
356 nStart->addTo( font );
357
352 mb->insertItem( tr( "File" ), file ); 358 mb->insertItem( tr( "File" ), file );
353 mb->insertItem( tr( "Edit" ), edit ); 359 mb->insertItem( tr( "Edit" ), edit );
354 mb->insertItem( tr( "View" ), font ); 360 mb->insertItem( tr( "View" ), font );
355 361
356 searchBar = new QPEToolBar(this); 362 searchBar = new QPEToolBar(this);
357 addToolBar( searchBar, "Search", QMainWindow::Top, TRUE ); 363 addToolBar( searchBar, "Search", QMainWindow::Top, TRUE );
358 364
359 searchBar->setHorizontalStretchable( TRUE ); 365 searchBar->setHorizontalStretchable( TRUE );
360 366
361 searchEdit = new QLineEdit( searchBar, "searchEdit" ); 367 searchEdit = new QLineEdit( searchBar, "searchEdit" );
362 searchBar->setStretchableWidget( searchEdit ); 368 searchBar->setStretchableWidget( searchEdit );
363 connect( searchEdit, SIGNAL( textChanged( const QString & ) ), 369 connect( searchEdit, SIGNAL( textChanged( const QString & ) ),
364 this, SLOT( search() ) ); 370 this, SLOT( search() ) );
365 371
366 372
367 a = new QAction( tr( "Find Next" ), Resource::loadPixmap( "next" ), QString::null, 0, this, 0 ); 373 a = new QAction( tr( "Find Next" ), Resource::loadPixmap( "next" ), QString::null, 0, this, 0 );
368 connect( a, SIGNAL( activated() ), this, SLOT( findNext() ) ); 374 connect( a, SIGNAL( activated() ), this, SLOT( findNext() ) );
369 a->addTo( searchBar ); 375 a->addTo( searchBar );
370 a->addTo( edit ); 376 a->addTo( edit );
371 377
372 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 378 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
373 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) ); 379 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) );
374 a->addTo( searchBar ); 380 a->addTo( searchBar );
375 381
@@ -393,49 +399,56 @@ TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
393 399
394 editor = new QpeEditor( editorStack ); 400 editor = new QpeEditor( editorStack );
395 editor->setFrameStyle( QFrame::Panel | QFrame::Sunken ); 401 editor->setFrameStyle( QFrame::Panel | QFrame::Sunken );
396 editorStack->addWidget( editor, get_unique_id() ); 402 editorStack->addWidget( editor, get_unique_id() );
397 403
398 resize( 200, 300 ); 404 resize( 200, 300 );
399 405
400// setFontSize(defsize,TRUE); 406// setFontSize(defsize,TRUE);
401 FontDatabase fdb; 407 FontDatabase fdb;
402 QFont defaultFont=editor->font(); 408 QFont defaultFont=editor->font();
403 QFontInfo fontInfo(defaultFont); 409 QFontInfo fontInfo(defaultFont);
404 410
405 cfg.setGroup("Font"); 411 cfg.setGroup("Font");
406 QString family = cfg.readEntry("Family", fontInfo.family()); 412 QString family = cfg.readEntry("Family", fontInfo.family());
407 QString style = cfg.readEntry("Style", fdb.styleString(defaultFont)); 413 QString style = cfg.readEntry("Style", fdb.styleString(defaultFont));
408 int i_size = cfg.readNumEntry("Size", fontInfo.pointSize()/10); 414 int i_size = cfg.readNumEntry("Size", fontInfo.pointSize()/10);
409 QString charSet = cfg.readEntry("CharSet", QFont::encodingName( fontInfo.charSet()) ); 415 QString charSet = cfg.readEntry("CharSet", QFont::encodingName( fontInfo.charSet()) );
410 416
411 defaultFont = fdb.font(family,style,i_size,charSet); 417 defaultFont = fdb.font(family,style,i_size,charSet);
412 editor->setFont( defaultFont); 418 editor->setFont( defaultFont);
413 419
414 wa->setOn(wrap); 420 wa->setOn(wrap);
415 updateCaption(); 421 updateCaption();
416 422
417 fileNew(); 423 cfg.setGroup("View");
424 if(cfg.readEntry("startNew","TRUE") == "TRUE") {
425 nStart->setOn(TRUE);
426 fileNew();
427 } else {
428 fileOpen();
429 }
430
418} 431}
419 432
420TextEdit::~TextEdit() 433TextEdit::~TextEdit()
421{ 434{
422// save(); 435// save();
423 436
424 Config cfg("TextEdit"); 437 Config cfg("TextEdit");
425 cfg.setGroup("View"); 438 cfg.setGroup("View");
426 QFont f = editor->font(); 439 QFont f = editor->font();
427 cfg.writeEntry("FontSize",f.pointSize()); 440 cfg.writeEntry("FontSize",f.pointSize());
428 cfg.writeEntry("Bold",f.bold()); 441 cfg.writeEntry("Bold",f.bold());
429 cfg.writeEntry("Italic",f.italic()); 442 cfg.writeEntry("Italic",f.italic());
430 cfg.writeEntry("Wrap",editor->wordWrap() == QMultiLineEdit::WidgetWidth); 443 cfg.writeEntry("Wrap",editor->wordWrap() == QMultiLineEdit::WidgetWidth);
431} 444}
432 445
433void TextEdit::zoomIn() 446void TextEdit::zoomIn()
434{ 447{
435 setFontSize(editor->font().pointSize()+1,FALSE); 448 setFontSize(editor->font().pointSize()+1,FALSE);
436} 449}
437 450
438void TextEdit::zoomOut() 451void TextEdit::zoomOut()
439{ 452{
440 setFontSize(editor->font().pointSize()-1,TRUE); 453 setFontSize(editor->font().pointSize()-1,TRUE);
441} 454}
@@ -676,133 +689,140 @@ void TextEdit::openFile( const DocLnk &f )
676 doc->setName(currentFileName); 689 doc->setName(currentFileName);
677 updateCaption(); 690 updateCaption();
678} 691}
679 692
680void TextEdit::showEditTools() 693void TextEdit::showEditTools()
681{ 694{
682// if ( !doc ) 695// if ( !doc )
683// close(); 696// close();
684// clear(); 697// clear();
685 fileSelector->hide(); 698 fileSelector->hide();
686 menu->show(); 699 menu->show();
687 editBar->show(); 700 editBar->show();
688 if ( searchVisible ) 701 if ( searchVisible )
689 searchBar->show(); 702 searchBar->show();
690// updateCaption(); 703// updateCaption();
691 editorStack->raiseWidget( editor ); 704 editorStack->raiseWidget( editor );
692 setWState (WState_Reserved1 ); 705 setWState (WState_Reserved1 );
693} 706}
694 707
695/*! 708/*!
696 unprompted save */ 709 unprompted save */
697bool TextEdit::save() 710bool TextEdit::save()
698{ 711{
699 QString file = doc->file(); 712 QString file = doc->file();
713 qDebug(file);
700 QString name= doc->name(); 714 QString name= doc->name();
701 715 qDebug(name);
702 QString rt = editor->text(); 716 QString rt = editor->text();
703 currentFileName= name ; 717 if( !rt.isEmpty() ) {
704 qDebug("saveFile "+currentFileName); 718 if(name.isEmpty()) {
705 719 saveAs();
706 struct stat buf; 720 } else {
707 mode_t mode; 721 currentFileName= name ;
708 stat(file.latin1(), &buf); 722 qDebug("saveFile "+currentFileName);
709 mode = buf.st_mode; 723
724 struct stat buf;
725 mode_t mode;
726 stat(file.latin1(), &buf);
727 mode = buf.st_mode;
728
729 doc->setName( name);
730 FileManager fm;
731 if ( !fm.saveFile( *doc, rt ) ) {
732 return false;
733 }
734 editor->setEdited( false );
710 735
711 doc->setName( name); 736 chmod( file.latin1(), mode);
712 FileManager fm; 737 }
713 if ( !fm.saveFile( *doc, rt ) ) { 738 return true;
714 return false;
715 } 739 }
716 editor->setEdited( false ); 740 return false;
717
718 chmod( file.latin1(), mode);
719 return true;
720} 741}
721 742
722/*! 743/*!
723 prompted save */ 744 prompted save */
724bool TextEdit::saveAs() 745bool TextEdit::saveAs()
725{ 746{
726// qDebug("saveAsFile "+currentFileName); 747// qDebug("saveAsFile "+currentFileName);
727 748
728 // case of nothing to save... /// there's always something to save 749 // case of nothing to save... /// there's always something to save
729// if ( !doc )//|| !bFromDocView) 750// if ( !doc )//|| !bFromDocView)
730// { 751// {
731// qDebug("no doc"); 752// qDebug("no doc");
732// return true; 753// return true;
733// } 754// }
734 if ( !editor->edited() ) { 755 if ( !editor->edited() ) {
735 delete doc; 756 delete doc;
736 doc = 0; 757 doc = 0;
737 return true; 758 return true;
738 } 759 }
739 760
740 QString rt = editor->text(); 761 QString rt = editor->text();
741 qDebug(currentFileName); 762 qDebug(currentFileName);
742 763
743 if( currentFileName.isEmpty() || currentFileName == "Unnamed") { 764 if( currentFileName.isEmpty() || currentFileName == "Unnamed") {
744 qDebug("do silly TT filename thing"); 765 qDebug("do silly TT filename thing");
745 if ( doc->name().isEmpty() ) { 766 if ( doc->name().isEmpty() ) {
746 QString pt = rt.simplifyWhiteSpace(); 767 QString pt = rt.simplifyWhiteSpace();
747 int i = pt.find( ' ' ); 768 int i = pt.find( ' ' );
748 QString docname = pt; 769 QString docname = pt;
749 if ( i > 0 ) 770 if ( i > 0 )
750 docname = pt.left( i ); 771 docname = pt.left( i );
751 // remove "." at the beginning 772 // remove "." at the beginning
752 while( docname.startsWith( "." ) ) 773 while( docname.startsWith( "." ) )
753 docname = docname.mid( 1 ); 774 docname = docname.mid( 1 );
754 docname.replace( QRegExp("/"), "_" ); 775 docname.replace( QRegExp("/"), "_" );
755 // cut the length. filenames longer than that don't make sense and something goes wrong when they get too long. 776 // cut the length. filenames longer than that don't make sense and something goes wrong when they get too long.
756 if ( docname.length() > 40 ) 777 if ( docname.length() > 40 )
757 docname = docname.left(40); 778 docname = docname.left(40);
758 if ( docname.isEmpty() ) 779 if ( docname.isEmpty() )
759 docname = "Unnamed"; 780 docname = "Unnamed";
760 doc->setName(docname); 781 doc->setName(docname);
761 currentFileName=docname; 782 currentFileName=docname;
762 } 783 }
763 } 784 }
764 785
765 786
766 fileSaveDlg=new fileSaver(this,"Save File",TRUE, 0, currentFileName); 787 fileSaveDlg=new fileSaver(this,"Save File As?",TRUE, 0, currentFileName);
767 qDebug("wanna save filename "+currentFileName); 788 qDebug("wanna save filename "+currentFileName);
768 fileSaveDlg->exec(); 789 fileSaveDlg->exec();
769 if( fileSaveDlg->result() == 1 ) { 790 if( fileSaveDlg->result() == 1 ) {
770 QString fileNm=fileSaveDlg->selectedFileName; 791 QString fileNm=fileSaveDlg->selectedFileName;
771 qDebug("saving filename "+fileNm); 792 qDebug("saving filename "+fileNm);
772 QFileInfo fi(fileNm); 793 QFileInfo fi(fileNm);
773 currentFileName=fi.fileName(); 794 currentFileName=fi.fileName();
774 if(doc) { 795 if(doc) {
775 qDebug("doclnk exists");
776// QString file = doc->file(); 796// QString file = doc->file();
777// doc->removeFiles(); 797// doc->removeFiles();
778 delete doc; 798 delete doc;
779 DocLnk nf; 799 DocLnk nf;
780 nf.setType("text/plain"); 800 nf.setType("text/plain");
781 nf.setFile( fileNm); 801 nf.setFile( fileNm);
782 doc = new DocLnk(nf); 802 doc = new DocLnk(nf);
783// editor->setText(rt); 803// editor->setText(rt);
784 qDebug("openFile doclnk "+currentFileName); 804// qDebug("openFile doclnk "+currentFileName);
785 doc->setName( currentFileName); 805 doc->setName( currentFileName);
786 updateCaption( currentFileName); 806 updateCaption( currentFileName);
787 807
788 FileManager fm; 808 FileManager fm;
789 if ( !fm.saveFile( *doc, rt ) ) { 809 if ( !fm.saveFile( *doc, rt ) ) {
790 return false; 810 return false;
791 } 811 }
792 if( fileSaveDlg->filePermCheck->isChecked() ) { 812 if( fileSaveDlg->filePermCheck->isChecked() ) {
793 filePermissions *filePerm; 813 filePermissions *filePerm;
794 filePerm = new filePermissions(this, "Permissions",true,0,(const QString &)fileNm); 814 filePerm = new filePermissions(this, "Permissions",true,0,(const QString &)fileNm);
795 filePerm->exec(); 815 filePerm->exec();
796 editor->setEdited( false ); 816 editor->setEdited( false );
797 if( filePerm) 817 if( filePerm)
798 delete filePerm; 818 delete filePerm;
799 } 819 }
800 } 820 }
801 } 821 }
802 822
803 if(fileSaveDlg) 823 if(fileSaveDlg)
804 delete fileSaveDlg; 824 delete fileSaveDlg;
805 return true; 825 return true;
806} 826}
807 827
808void TextEdit::clear() 828void TextEdit::clear()
@@ -834,69 +854,87 @@ void TextEdit::setDocument(const QString& fileref)
834 bFromDocView = TRUE; 854 bFromDocView = TRUE;
835 qDebug("setDocument "+fileref); 855 qDebug("setDocument "+fileref);
836 bFromDocView = TRUE; 856 bFromDocView = TRUE;
837 if(fileref.find(".desktop",0,TRUE) == -1) { 857 if(fileref.find(".desktop",0,TRUE) == -1) {
838 openFile(fileref); 858 openFile(fileref);
839 } else { 859 } else {
840 openFile(DocLnk(fileref)); 860 openFile(DocLnk(fileref));
841 } 861 }
842} 862}
843 863
844void TextEdit::closeEvent( QCloseEvent *e ) 864void TextEdit::closeEvent( QCloseEvent *e )
845{ 865{
846 if ( editorStack->visibleWidget() == fileSelector && !bFromDocView ) { 866 if ( editorStack->visibleWidget() == fileSelector && !bFromDocView ) {
847 e->ignore(); 867 e->ignore();
848 repaint(); 868 repaint();
849// fileRevert(); 869// fileRevert();
850 870
851 } else { 871 } else {
852 bFromDocView = FALSE; 872 bFromDocView = FALSE;
853 e->accept(); 873 e->accept();
854 } 874 }
855} 875}
856 876
857void TextEdit::accept() 877void TextEdit::accept()
858{ 878 {
859 save(); 879 QString file = doc->file();
860 close(); 880 if (file.find("_.txt",0,TRUE) ==-1)
861// fileOpen(); //godamn thats obnoxious! lemme out!!! 881 save();
882 else {
883 QFile(file).remove();
884 }
885 exit(0);
886
862} 887}
863 888
864void TextEdit::changeFont() { 889void TextEdit::changeFont() {
865 FontDatabase fdb; 890 FontDatabase fdb;
866 QFont defaultFont=editor->font(); 891 QFont defaultFont=editor->font();
867 QFontInfo fontInfo(defaultFont); 892 QFontInfo fontInfo(defaultFont);
868 Config cfg("TextEdit"); 893 Config cfg("TextEdit");
869 cfg.setGroup("Font"); 894 cfg.setGroup("Font");
870 QString family = cfg.readEntry("Family", fontInfo.family()); 895 QString family = cfg.readEntry("Family", fontInfo.family());
871 QString style = cfg.readEntry("Style", fdb.styleString(defaultFont)); 896 QString style = cfg.readEntry("Style", fdb.styleString(defaultFont));
872 int i_size = cfg.readNumEntry("Size", fontInfo.pointSize()/10); 897 int i_size = cfg.readNumEntry("Size", fontInfo.pointSize()/10);
873 QString charSet = cfg.readEntry("CharSet", QFont::encodingName( fontInfo.charSet()) ); 898 QString charSet = cfg.readEntry("CharSet", QFont::encodingName( fontInfo.charSet()) );
874 899
875 defaultFont = fdb.font(family,style,i_size,charSet); 900 defaultFont = fdb.font(family,style,i_size,charSet);
876 901
877 FontDialog *fontDlg; 902 FontDialog *fontDlg;
878 fontDlg=new FontDialog(this,"FontDialog",TRUE); 903 fontDlg=new FontDialog(this,"FontDialog",TRUE);
879 904
880 fontDlg->exec(); 905 fontDlg->exec();
881 906
882 QFont myFont=fontDlg->selectedFont; 907 QFont myFont=fontDlg->selectedFont;
883 editor->setFont( myFont); 908 editor->setFont( myFont);
884 delete fontDlg; 909 delete fontDlg;
885 910
886} 911}
887 912
888void TextEdit::editDelete() 913void TextEdit::editDelete()
889{ 914{
890 switch ( QMessageBox::warning(this,"Text Editor","Do you really want\nto delete the current file\nfrom the disk?\nThis is irreversable!!","Yes","No",0,0,1) ) { 915 switch ( QMessageBox::warning(this,"Text Editor","Do you really want\nto delete the current file\nfrom the disk?\nThis is irreversable!!","Yes","No",0,0,1) ) {
891 case 0: 916 case 0:
892 if(doc) { 917 if(doc) {
893 doc->removeFiles(); 918 doc->removeFiles();
894 clear(); 919 clear();
895 setCaption( tr("Text Editor") ); 920 setCaption( tr("Text Editor") );
896 } 921 }
897 break; 922 break;
898 case 1: 923 case 1:
899 // exit 924 // exit
900 break; 925 break;
901 }; 926 };
902} 927}
928
929void TextEdit::changeStartConfig( bool b ) {
930
931 Config cfg("TextEdit");
932 cfg.setGroup("View");
933 if(b) {
934 qDebug("bool");
935 cfg.writeEntry("startNew","TRUE");
936 } else {
937 cfg.writeEntry("startNew","FALSE");
938 }
939 update();
940}
diff --git a/core/apps/textedit/textedit.h b/core/apps/textedit/textedit.h
index 781061a..fb58738 100644
--- a/core/apps/textedit/textedit.h
+++ b/core/apps/textedit/textedit.h
@@ -13,77 +13,81 @@
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20// additions made by L.J. Potter Sun 02-17-2002 22:27:46 20// additions made by L.J. Potter Sun 02-17-2002 22:27:46
21 21
22#ifndef TEXTEDIT_H 22#ifndef TEXTEDIT_H
23#define TEXTEDIT_H 23#define TEXTEDIT_H
24 24
25#define QTEXTEDIT_OPEN_API 25#define QTEXTEDIT_OPEN_API
26 26
27#include "fileBrowser.h" 27#include "fileBrowser.h"
28#include "fileSaver.h" 28#include "fileSaver.h"
29 29
30#include <qpe/filemanager.h> 30#include <qpe/filemanager.h>
31 31
32#include <qmainwindow.h> 32#include <qmainwindow.h>
33#include <qmultilineedit.h> 33#include <qmultilineedit.h>
34#include <qlist.h> 34#include <qlist.h>
35#include <qmap.h> 35#include <qmap.h>
36 36
37class QAction;
37class QWidgetStack; 38class QWidgetStack;
38class QToolButton; 39class QToolButton;
39class QPopupMenu; 40class QPopupMenu;
40class QToolBar; 41class QToolBar;
41class QLineEdit; 42class QLineEdit;
42class QAction; 43class QAction;
43class FileSelector; 44class FileSelector;
44class QpeEditor; 45class QpeEditor;
46class QPopupMenu;
45 47
46class TextEdit : public QMainWindow 48class TextEdit : public QMainWindow
47{ 49{
48 Q_OBJECT 50 Q_OBJECT
49 51
50public: 52public:
51 TextEdit( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); 53 TextEdit( QWidget *parent = 0, const char *name = 0, WFlags f = 0 );
52 ~TextEdit(); 54 ~TextEdit();
53 55 QPopupMenu *font;
56 QAction *nStart;
54 void openFile( const QString & ); 57 void openFile( const QString & );
55 58
56protected: 59protected:
57 void closeEvent( QCloseEvent *e ); 60 void closeEvent( QCloseEvent *e );
58 61
59private slots: 62private slots:
60 void setDocument(const QString&); 63 void setDocument(const QString&);
61 void changeFont(); 64 void changeFont();
62 void fileNew(); 65 void fileNew();
63 void fileRevert(); 66 void fileRevert();
64 void fileOpen(); 67 void fileOpen();
65 void newFileOpen(); 68 void newFileOpen();
69 void changeStartConfig(bool);
66 bool save(); 70 bool save();
67 bool saveAs(); 71 bool saveAs();
68 72
69 73
70 void editCut(); 74 void editCut();
71 void editCopy(); 75 void editCopy();
72 void editPaste(); 76 void editPaste();
73 void editFind(); 77 void editFind();
74 void editDelete(); 78 void editDelete();
75 79
76 void findNext(); 80 void findNext();
77 void findClose(); 81 void findClose();
78 82
79 void search(); 83 void search();
80 void accept(); 84 void accept();
81 85
82 void newFile( const DocLnk & ); 86 void newFile( const DocLnk & );
83 void openFile( const DocLnk & ); 87 void openFile( const DocLnk & );
84 void showEditTools(); 88 void showEditTools();
85 89
86 void zoomIn(); 90 void zoomIn();
87 void zoomOut(); 91 void zoomOut();
88 void setBold(bool y); 92 void setBold(bool y);
89 void setItalic(bool y); 93 void setItalic(bool y);