summaryrefslogtreecommitdiff
authortille <tille>2002-07-08 14:12:26 (UTC)
committer tille <tille>2002-07-08 14:12:26 (UTC)
commitc92049007eaf6615a059425073b03a827d11831e (patch) (unidiff)
tree6d4d0b05a597d46eb6969cd728174fa6345a1099
parent0d6ff4c6b10524943b43240489182138694f2759 (diff)
downloadopie-c92049007eaf6615a059425073b03a827d11831e.zip
opie-c92049007eaf6615a059425073b03a827d11831e.tar.gz
opie-c92049007eaf6615a059425073b03a827d11831e.tar.bz2
parse files when needed
an other oipkg test ;)
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/confedit/listviewitemconffile.cpp15
-rw-r--r--noncore/apps/confedit/mainwindow.cpp1
2 files changed, 13 insertions, 3 deletions
diff --git a/noncore/apps/confedit/listviewitemconffile.cpp b/noncore/apps/confedit/listviewitemconffile.cpp
index 1f85095..ce6504c 100644
--- a/noncore/apps/confedit/listviewitemconffile.cpp
+++ b/noncore/apps/confedit/listviewitemconffile.cpp
@@ -1,151 +1,160 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * This program is free software; you can redistribute it and/or modify * 3 * This program is free software; you can redistribute it and/or modify *
4 * it under the terms of the GNU General Public License as published by * 4 * it under the terms of the GNU General Public License as published by *
5 * the Free Software Foundation; either version 2 of the License, or * 5 * the Free Software Foundation; either version 2 of the License, or *
6 * (at your option) any later version. * 6 * (at your option) any later version. *
7 * * 7 * *
8 ***************************************************************************/ 8 ***************************************************************************/
9// (c) 2002 Patrick S. Vogt <tille@handhelds.org> 9// (c) 2002 Patrick S. Vogt <tille@handhelds.org>
10 10
11#include "listviewitemconffile.h" 11#include "listviewitemconffile.h"
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13#include <qtextstream.h> 13#include <qtextstream.h>
14#include <qstring.h> 14#include <qstring.h>
15#include "listviewitemconfigentry.h" 15#include "listviewitemconfigentry.h"
16 16
17#define tr QObject::tr 17#define tr QObject::tr
18 18
19ListViewItemConfFile::ListViewItemConfFile(QFileInfo *file, QListView *parent) 19ListViewItemConfFile::ListViewItemConfFile(QFileInfo *file, QListView *parent)
20 : ListViewItemConf(parent), _valid(false) 20 : ListViewItemConf(parent), _valid(false)
21{ 21{
22 confFileInfo = file; 22 confFileInfo = file;
23// parseFile(); 23// parseFile();
24 displayText(); 24 displayText();
25} 25}
26 26
27ListViewItemConfFile::~ListViewItemConfFile() 27ListViewItemConfFile::~ListViewItemConfFile()
28{ 28{
29} 29}
30 30
31 31
32void ListViewItemConfFile::displayText() 32void ListViewItemConfFile::displayText()
33{ 33{
34 setText(0,(_changed?"*":"")+confFileInfo->fileName()); 34 setText(0,(_changed?"*":"")+confFileInfo->fileName());
35} 35}
36 36
37QString ListViewItemConfFile::fileName() 37QString ListViewItemConfFile::fileName()
38{ 38{
39 return confFileInfo->fileName(); 39 return confFileInfo->fileName();
40} 40}
41 41
42void ListViewItemConfFile::parseFile() 42void ListViewItemConfFile::parseFile()
43{ 43{
44 //qDebug("ListViewItemConfFile::parseFile BEGIN"); 44 //qDebug("ListViewItemConfFile::parseFile BEGIN");
45 QFile confFile(confFileInfo->absFilePath()); 45 QFile confFile(confFileInfo->absFilePath());
46 if(! confFile.open(IO_ReadOnly)) 46 if(! confFile.open(IO_ReadOnly))
47 QMessageBox::critical(0,tr("Could not open"),tr("The file ")+confFileInfo->fileName()+tr(" could not be opened."),1,0); 47 QMessageBox::critical(0,tr("Could not open"),tr("The file ")+confFileInfo->fileName()+tr(" could not be opened."),1,0);
48 QTextStream t( &confFile ); 48 QTextStream t( &confFile );
49 QString s; 49 QString s;
50 QString group; 50 QString group;
51 ListViewItemConfigEntry *groupItem; 51 ListViewItemConfigEntry *groupItem;
52 ListViewItemConfigEntry *item; 52 ListViewItemConfigEntry *item;
53 while ( !t.atEnd() ) 53 while ( !t.atEnd() )
54 { 54 {
55 s = t.readLine().stripWhiteSpace(); 55 s = t.readLine().stripWhiteSpace();
56 //qDebug( "line: >%s<\n", s.latin1() ); 56 //qDebug( "line: >%s<\n", s.latin1() );
57 if (s.contains("<?xml")) 57 if (s.contains("<?xml"))
58 { 58 {
59 _valid = false; 59 _valid = false;
60 break; 60 break;
61 }else 61 }else
62 if ( s[0] == '[' && s[s.length()-1] == ']' ) 62 if ( s[0] == '[' && s[s.length()-1] == ']' )
63 { 63 {
64 // qDebug("got group"+s); 64 // qDebug("got group"+s);
65 group = s.mid(1,s.length()-2); 65 group = s.mid(1,s.length()-2);
66 if (!groupItem) groupItem = new ListViewItemConfigEntry(this, tr("no group") ); 66 if (!groupItem) groupItem = new ListViewItemConfigEntry(this, tr("no group") );
67 groupItem = new ListViewItemConfigEntry(this, group ); 67 groupItem = new ListViewItemConfigEntry(this, group );
68 insertItem( groupItem ); 68 insertItem( groupItem );
69 } else 69 } else
70 if ( int pos = s.find('=') ) 70 if ( int pos = s.find('=') )
71 { 71 {
72// qDebug("got key"+s); 72// qDebug("got key"+s);
73 if (!groupItem) qDebug("PANIK NO GROUP! >%s<",group.latin1()); 73 if (!groupItem) qDebug("PANIK NO GROUP! >%s<",group.latin1());
74 item = new ListViewItemConfigEntry(this, group, s ); 74 item = new ListViewItemConfigEntry(this, group, s );
75 groupItem->insertItem( item ); 75 groupItem->insertItem( item );
76 } 76 }
77 } 77 }
78 confFile.close(); 78 confFile.close();
79 setExpandable( _valid ); 79 setExpandable( _valid );
80 //qDebug("ListViewItemConfFile::parseFile END"); 80 //qDebug("ListViewItemConfFile::parseFile END");
81} 81}
82 82
83 83
84void ListViewItemConfFile::remove() 84void ListViewItemConfFile::remove()
85{ 85{
86 QFile::remove(confFileInfo->absFilePath()); 86 QFile::remove(confFileInfo->absFilePath());
87 QFile::remove(backupFileName()); 87 QFile::remove(backupFileName());
88 delete this; 88 delete this;
89} 89}
90 90
91void ListViewItemConfFile::revert() 91void ListViewItemConfFile::revert()
92{ 92{
93 if (_changed) 93 if (!_changed)
94 { 94 {
95 parseFile(); 95 // read the backup file
96 }else{
97 QFile conf(confFileInfo->absFilePath()); 96 QFile conf(confFileInfo->absFilePath());
98 QFile back(backupFileName()); 97 QFile back(backupFileName());
99 98
100 if (!back.open(IO_ReadOnly)) return; 99 if (!back.open(IO_ReadOnly)) return;
101 if (!conf.open(IO_WriteOnly)) return; 100 if (!conf.open(IO_WriteOnly)) return;
102 101
103 #define SIZE 124 102 #define SIZE 124
104 char buf[SIZE]; 103 char buf[SIZE];
105 while (int c = back.readBlock(buf, SIZE) ) conf.writeBlock(buf,c); 104 while (int c = back.readBlock(buf, SIZE) ) conf.writeBlock(buf,c);
106 conf.close(); 105 conf.close();
107 back.close(); 106 back.close();
108 } 107 }
108 parseFile();
109 expand();
109} 110}
110 111
111void ListViewItemConfFile::save() 112void ListViewItemConfFile::save()
112{ 113{
113 if (!_changed) return; 114 if (!_changed) return;
114 QFile conf(confFileInfo->absFilePath()); 115 QFile conf(confFileInfo->absFilePath());
115 QFile back(backupFileName()); 116 QFile back(backupFileName());
116 117
117 if (!conf.open(IO_ReadOnly)) return; 118 if (!conf.open(IO_ReadOnly)) return;
118 if (!back.open(IO_WriteOnly)) return; 119 if (!back.open(IO_WriteOnly)) return;
119 120
120 char buf[SIZE]; 121 char buf[SIZE];
121 while (int c = conf.readBlock(buf, SIZE) ) back.writeBlock(buf,c); 122 while (int c = conf.readBlock(buf, SIZE) ) back.writeBlock(buf,c);
122 conf.close(); 123 conf.close();
123 back.close(); 124 back.close();
124 125
125 126
126 if (!conf.open(IO_WriteOnly)) return; 127 if (!conf.open(IO_WriteOnly)) return;
127 QTextStream *t = new QTextStream( &conf ); 128 QTextStream *t = new QTextStream( &conf );
128 for (QListViewItem *it = firstChild(); it!=0;it = it->nextSibling()) 129 for (QListViewItem *it = firstChild(); it!=0;it = it->nextSibling())
129 { 130 {
130 ((ListViewItemConfigEntry*)it)->save(t); 131 ((ListViewItemConfigEntry*)it)->save(t);
131 } 132 }
132 conf.close(); 133 conf.close();
133 unchanged(); 134 unchanged();
134} 135}
135 136
136 137
137bool ListViewItemConfFile::revertable() 138bool ListViewItemConfFile::revertable()
138{ 139{
139 return _changed || QFile(backupFileName()).exists(); 140 return _changed || QFile(backupFileName()).exists();
140} 141}
141 142
142QString ListViewItemConfFile::backupFileName() 143QString ListViewItemConfFile::backupFileName()
143{ 144{
144 return confFileInfo->absFilePath()+"~"; 145 return confFileInfo->absFilePath()+"~";
145} 146}
146 147
147 148
148void ListViewItemConfFile::expand() 149void ListViewItemConfFile::expand()
149{ 150{
151 QListViewItem *subItem = firstChild();
152 QListViewItem *toDel;
153 while(subItem)
154 {
155 toDel = subItem;
156 subItem = subItem->nextSibling();
157 delete toDel;
158 }
150 parseFile(); 159 parseFile();
151} 160}
diff --git a/noncore/apps/confedit/mainwindow.cpp b/noncore/apps/confedit/mainwindow.cpp
index 6de8741..c91c846 100644
--- a/noncore/apps/confedit/mainwindow.cpp
+++ b/noncore/apps/confedit/mainwindow.cpp
@@ -1,171 +1,172 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * This program is free software; you can redistribute it and/or modify * 3 * This program is free software; you can redistribute it and/or modify *
4 * it under the terms of the GNU General Public License as published by * 4 * it under the terms of the GNU General Public License as published by *
5 * the Free Software Foundation; either version 2 of the License, or * 5 * the Free Software Foundation; either version 2 of the License, or *
6 * (at your option) any later version. * 6 * (at your option) any later version. *
7 * * 7 * *
8 ***************************************************************************/ 8 ***************************************************************************/
9 9
10// (c) 2002 Patrick S. Vogt <tille@handhelds.org> 10// (c) 2002 Patrick S. Vogt <tille@handhelds.org>
11 11
12 12
13#include "mainwindow.h" 13#include "mainwindow.h"
14 14
15#include <qpe/qpemenubar.h> 15#include <qpe/qpemenubar.h>
16#include <qpe/qpemessagebox.h> 16#include <qpe/qpemessagebox.h>
17#include <qpe/resource.h> 17#include <qpe/resource.h>
18#include <qpe/config.h> 18#include <qpe/config.h>
19#include <qpe/qpetoolbar.h> 19#include <qpe/qpetoolbar.h>
20#include <qpe/qpeapplication.h> 20#include <qpe/qpeapplication.h>
21#include <qaction.h> 21#include <qaction.h>
22#include <qmessagebox.h> 22#include <qmessagebox.h>
23#include <qpopupmenu.h> 23#include <qpopupmenu.h>
24#include <qtoolbutton.h> 24#include <qtoolbutton.h>
25#include <qstring.h> 25#include <qstring.h>
26#include <qlabel.h> 26#include <qlabel.h>
27#include <qfile.h> 27#include <qfile.h>
28#include <qpushbutton.h> 28#include <qpushbutton.h>
29#include <qlayout.h> 29#include <qlayout.h>
30#include <qlineedit.h> 30#include <qlineedit.h>
31 31
32#include "listviewconfdir.h" 32#include "listviewconfdir.h"
33#include "listviewitemconf.h" 33#include "listviewitemconf.h"
34#include "listviewitemconfigentry.h" 34#include "listviewitemconfigentry.h"
35 35
36 36
37MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f ) : 37MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f ) :
38 QDialog( parent, name, f ), _currentItem(0), _fileItem(0) 38 QDialog( parent, name, f ), _currentItem(0), _fileItem(0)
39 { 39 {
40 setCaption( tr("Conf File Editor") ); 40 setCaption( tr("Conf File Editor") );
41 41
42 //setBaseSize( qApp->globalStrut() ); 42 //setBaseSize( qApp->globalStrut() );
43 setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding));//, sizePolicy().hasHeightForWidth() ) ); 43 setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding));//, sizePolicy().hasHeightForWidth() ) );
44 44
45 mainLayout = new QVBoxLayout( this ); 45 mainLayout = new QVBoxLayout( this );
46 mainLayout->setSpacing( 0 ); 46 mainLayout->setSpacing( 0 );
47 mainLayout->setMargin( 0 ); 47 mainLayout->setMargin( 0 );
48 48
49 49
50 qDebug("creating settingList"); 50 qDebug("creating settingList");
51 settingList = new ListViewConfDir( "/root/Settings/", this, "settingslist"); 51 settingList = new ListViewConfDir( "/root/Settings/", this, "settingslist");
52 settingList->setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding));//, sizePolicy().hasHeightForWidth() ) ); 52 settingList->setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding));//, sizePolicy().hasHeightForWidth() ) );
53 mainLayout->addWidget( settingList, 0); 53 mainLayout->addWidget( settingList, 0);
54 54
55 qDebug("creating editor"); 55 qDebug("creating editor");
56 editor = new EditWidget(this); 56 editor = new EditWidget(this);
57 editor->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Maximum));//, sizePolicy().hasHeightForWidth() ) ); 57 editor->setSizePolicy( QSizePolicy( QSizePolicy::Minimum, QSizePolicy::Maximum));//, sizePolicy().hasHeightForWidth() ) );
58 mainLayout->addWidget( editor, 1 ); 58 mainLayout->addWidget( editor, 1 );
59 editor->layoutType( ListViewItemConf::File ); 59 editor->layoutType( ListViewItemConf::File );
60 60
61 makeMenu(); 61 makeMenu();
62 62
63 connect(settingList, SIGNAL( pressed(QListViewItem*) ), 63 connect(settingList, SIGNAL( pressed(QListViewItem*) ),
64 this, SLOT(setCurrent(QListViewItem*))); 64 this, SLOT(setCurrent(QListViewItem*)));
65 connect( settingList, SIGNAL( clicked( QListViewItem* ) ), 65 connect( settingList, SIGNAL( clicked( QListViewItem* ) ),
66 this, SLOT( stopTimer( QListViewItem* ) ) ); 66 this, SLOT( stopTimer( QListViewItem* ) ) );
67 67
68 connect( editor->LineEditGroup, SIGNAL( textChanged(const QString&) ), 68 connect( editor->LineEditGroup, SIGNAL( textChanged(const QString&) ),
69 SLOT( groupChanged(const QString&) ) ); 69 SLOT( groupChanged(const QString&) ) );
70 connect( editor->LineEditKey, SIGNAL( textChanged(const QString&) ), 70 connect( editor->LineEditKey, SIGNAL( textChanged(const QString&) ),
71 SLOT( keyChanged(const QString&) ) ); 71 SLOT( keyChanged(const QString&) ) );
72 connect( editor->LineEditValue, SIGNAL( textChanged(const QString&) ), 72 connect( editor->LineEditValue, SIGNAL( textChanged(const QString&) ),
73 SLOT( valueChanged(const QString&) ) ); 73 SLOT( valueChanged(const QString&) ) );
74 74
75 setCurrent(0); 75 setCurrent(0);
76 editor->layoutType(EditWidget::File);
76} 77}
77 78
78void MainWindow::makeMenu() 79void MainWindow::makeMenu()
79{ 80{
80 popupTimer = new QTimer(this); 81 popupTimer = new QTimer(this);
81 popupMenuFile = new QPopupMenu(this); 82 popupMenuFile = new QPopupMenu(this);
82 popupMenuEntry = new QPopupMenu(this); 83 popupMenuEntry = new QPopupMenu(this);
83 84
84 popupActionSave = new QAction( tr("Save"),QString::null, 0, this, 0 ); 85 popupActionSave = new QAction( tr("Save"),QString::null, 0, this, 0 );
85 popupActionSave->addTo( popupMenuFile ); 86 popupActionSave->addTo( popupMenuFile );
86 // popupActionSave->addTo( popupMenuEntry ); 87 // popupActionSave->addTo( popupMenuEntry );
87 connect( popupActionSave, SIGNAL( activated() ), 88 connect( popupActionSave, SIGNAL( activated() ),
88 this , SLOT( saveConfFile() ) ); 89 this , SLOT( saveConfFile() ) );
89 90
90 popupActionRevert = new QAction( tr("Revert"),QString::null, 0, this, 0 ); 91 popupActionRevert = new QAction( tr("Revert"),QString::null, 0, this, 0 );
91 popupActionRevert->addTo( popupMenuFile ); 92 popupActionRevert->addTo( popupMenuFile );
92 popupActionRevert->addTo( popupMenuEntry ); 93 popupActionRevert->addTo( popupMenuEntry );
93 connect( popupActionRevert, SIGNAL( activated() ), 94 connect( popupActionRevert, SIGNAL( activated() ),
94 this , SLOT( revertConfFile() ) ); 95 this , SLOT( revertConfFile() ) );
95 96
96 popupActionDelete = new QAction( tr("Delete"),QString::null, 0, this, 0 ); 97 popupActionDelete = new QAction( tr("Delete"),QString::null, 0, this, 0 );
97 popupActionDelete->addTo( popupMenuFile ); 98 popupActionDelete->addTo( popupMenuFile );
98 popupActionDelete->addTo( popupMenuEntry ); 99 popupActionDelete->addTo( popupMenuEntry );
99 connect( popupActionDelete, SIGNAL( activated() ), 100 connect( popupActionDelete, SIGNAL( activated() ),
100 this , SLOT( removeConfFile() ) ); 101 this , SLOT( removeConfFile() ) );
101 102
102 connect( popupTimer, SIGNAL(timeout()), 103 connect( popupTimer, SIGNAL(timeout()),
103 this, SLOT(showPopup()) ); 104 this, SLOT(showPopup()) );
104} 105}
105 106
106MainWindow::~MainWindow() 107MainWindow::~MainWindow()
107{ 108{
108} 109}
109 110
110 111
111 112
112void MainWindow::setCurrent(QListViewItem *item) 113void MainWindow::setCurrent(QListViewItem *item)
113{ 114{
114 //qDebug("MainWindow::setCurrent"); 115 //qDebug("MainWindow::setCurrent");
115 if (!item) return; 116 if (!item) return;
116 _item = (ListViewItemConf*) item; 117 _item = (ListViewItemConf*) item;
117 if (!_item) return; 118 if (!_item) return;
118 popupTimer->start( 750, true ); 119 popupTimer->start( 750, true );
119 if (_item->getType() == ListViewItemConf::File) 120 if (_item->getType() == ListViewItemConf::File)
120 { 121 {
121 editor->layoutType(EditWidget::File); 122 editor->layoutType(EditWidget::File);
122 _currentItem=0; 123 _currentItem=0;
123 _fileItem = (ListViewItemConfFile*)item; 124 _fileItem = (ListViewItemConfFile*)item;
124 return; 125 return;
125 } 126 }
126 _fileItem = 0; 127 _fileItem = 0;
127 _currentItem = (ListViewItemConfigEntry*)item; 128 _currentItem = (ListViewItemConfigEntry*)item;
128 if (!_currentItem) return; 129 if (!_currentItem) return;
129 QString file = _currentItem->getFile(); 130 QString file = _currentItem->getFile();
130 QString group = _currentItem->getGroup(); 131 QString group = _currentItem->getGroup();
131 QString key = _currentItem->getKey(); 132 QString key = _currentItem->getKey();
132 QString val = _currentItem->getValue(); 133 QString val = _currentItem->getValue();
133 editor->TextFileName->setText(file); 134 editor->TextFileName->setText(file);
134 editor->LineEditGroup->setText(group); 135 editor->LineEditGroup->setText(group);
135 if (!key.isEmpty()) 136 if (!key.isEmpty())
136 { 137 {
137 editor->layoutType(EditWidget::Entry); 138 editor->layoutType(EditWidget::Entry);
138 editor->LineEditKey->setText(key); 139 editor->LineEditKey->setText(key);
139 editor->LineEditValue->setText(val); 140 editor->LineEditValue->setText(val);
140 }else{ 141 }else{
141 editor->layoutType(EditWidget::Group); 142 editor->layoutType(EditWidget::Group);
142 } 143 }
143} 144}
144 145
145 146
146void MainWindow::groupChanged(const QString &g) 147void MainWindow::groupChanged(const QString &g)
147{ 148{
148 if (!_currentItem) return; 149 if (!_currentItem) return;
149 _currentItem->setGroup(g); 150 _currentItem->setGroup(g);
150} 151}
151 152
152void MainWindow::keyChanged(const QString &k) 153void MainWindow::keyChanged(const QString &k)
153{ 154{
154 if (!_currentItem) return; 155 if (!_currentItem) return;
155 _currentItem->keyChanged(k); 156 _currentItem->keyChanged(k);
156} 157}
157 158
158void MainWindow::valueChanged(const QString &v) 159void MainWindow::valueChanged(const QString &v)
159{ 160{
160 if (!_currentItem) return; 161 if (!_currentItem) return;
161 _currentItem->valueChanged(v); 162 _currentItem->valueChanged(v);
162} 163}
163 164
164 165
165void MainWindow::stopTimer( QListViewItem* ) 166void MainWindow::stopTimer( QListViewItem* )
166{ 167{
167 popupTimer->stop(); 168 popupTimer->stop();
168} 169}
169 170
170void MainWindow::saveConfFile() 171void MainWindow::saveConfFile()
171{ 172{