summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/confedit/listviewitemconf.h1
-rw-r--r--noncore/apps/confedit/listviewitemconffile.cpp30
-rw-r--r--noncore/apps/confedit/listviewitemconffile.h2
-rw-r--r--noncore/apps/confedit/mainwindow.cpp47
-rw-r--r--noncore/apps/confedit/mainwindow.h10
5 files changed, 71 insertions, 19 deletions
diff --git a/noncore/apps/confedit/listviewitemconf.h b/noncore/apps/confedit/listviewitemconf.h
index 5837625..c6e60ba 100644
--- a/noncore/apps/confedit/listviewitemconf.h
+++ b/noncore/apps/confedit/listviewitemconf.h
@@ -12,24 +12,25 @@
12 12
13#include <qlistview.h> 13#include <qlistview.h>
14 14
15 15
16class ListViewItemConf : public QListViewItem 16class ListViewItemConf : public QListViewItem
17{ 17{
18public: 18public:
19 enum {File, Group, Key}; 19 enum {File, Group, Key};
20 20
21 ListViewItemConf(ListViewItemConf *parent); 21 ListViewItemConf(ListViewItemConf *parent);
22 ListViewItemConf(QListView *parent); 22 ListViewItemConf(QListView *parent);
23 ~ListViewItemConf(); 23 ~ListViewItemConf();
24 24
25 int getType(); 25 int getType();
26 virtual void displayText() = 0; 26 virtual void displayText() = 0;
27 virtual void changed(); 27 virtual void changed();
28 bool isChanged() {return _changed;};
28 virtual void unchanged(); 29 virtual void unchanged();
29 30
30protected: 31protected:
31 int _type; 32 int _type;
32 bool _changed; 33 bool _changed;
33}; 34};
34 35
35#endif 36#endif
diff --git a/noncore/apps/confedit/listviewitemconffile.cpp b/noncore/apps/confedit/listviewitemconffile.cpp
index 858726d..b075063 100644
--- a/noncore/apps/confedit/listviewitemconffile.cpp
+++ b/noncore/apps/confedit/listviewitemconffile.cpp
@@ -60,47 +60,75 @@ void ListViewItemConfFile::parseFile()
60 }else 60 }else
61 if ( s[0] == '[' && s[s.length()-1] == ']' ) 61 if ( s[0] == '[' && s[s.length()-1] == ']' )
62 { 62 {
63 // qDebug("got group"+s); 63 // qDebug("got group"+s);
64 group = s.mid(1,s.length()-2); 64 group = s.mid(1,s.length()-2);
65 groupItem = new ListViewItemConfigEntry(this, group ); 65 groupItem = new ListViewItemConfigEntry(this, group );
66 insertItem( groupItem ); 66 insertItem( groupItem );
67 } else 67 } else
68 if ( int pos = s.find('=') ) 68 if ( int pos = s.find('=') )
69 { 69 {
70 // qDebug("got key"+s); 70 // qDebug("got key"+s);
71 item = new ListViewItemConfigEntry(this, group, s ); 71 item = new ListViewItemConfigEntry(this, group, s );
72 groupItem->insertItem( item ); 72 groupItem->insertItem( item );
73 } 73 }
74 } 74 }
75 confFile.close(); 75 confFile.close();
76 unchanged();
76 setExpandable( _valid ); 77 setExpandable( _valid );
77} 78}
78 79
80
81void ListViewItemConfFile::revert()
82{
83 if (_changed)
84 {
85 parseFile();
86 }else{
87 QString backup = confFileInfo->absFilePath()+"~";
88 QFile conf(confFileInfo->absFilePath());
89 QFile back(backup);
90
91 if (!back.open(IO_ReadOnly)) return;
92 if (!conf.open(IO_WriteOnly)) return;
93
94 #define SIZE 124
95 char buf[SIZE];
96 while (int c = back.readBlock(buf, SIZE) ) conf.writeBlock(buf,c);
97 conf.close();
98 back.close();
99 }
100}
101
79void ListViewItemConfFile::save() 102void ListViewItemConfFile::save()
80{ 103{
81 if (!_changed) return; 104 if (!_changed) return;
82 QString backup = confFileInfo->absFilePath()+"~"; 105 QString backup = confFileInfo->absFilePath()+"~";
83 qDebug("make backup to "+backup); 106 qDebug("make backup to "+backup);
84 QFile conf(confFileInfo->absFilePath()); 107 QFile conf(confFileInfo->absFilePath());
85 QFile back(backup); 108 QFile back(backup);
86 109
87 if (!conf.open(IO_ReadOnly)) return; 110 if (!conf.open(IO_ReadOnly)) return;
88 if (!back.open(IO_WriteOnly)) return; 111 if (!back.open(IO_WriteOnly)) return;
89 112
90 #define SIZE 124 113 #define SIZE 124
91 char buf[SIZE]; 114 char buf[SIZE];
92 while (int c = conf.readBlock(buf, SIZE) ) back.writeBlock(buf,c); 115 while (int c = conf.readBlock(buf, SIZE) ) back.writeBlock(buf,c);
93 conf.close(); 116 conf.close();
94 back.close(); 117 back.close();
95 118
96 119
97 if (!conf.open(IO_WriteOnly)) return; 120 if (!conf.open(IO_WriteOnly)) return;
98 QTextStream *t = new QTextStream( &conf ); 121 QTextStream *t = new QTextStream( &conf );
99 for (QListViewItem *it = firstChild(); it!=0;it = it->nextSibling()) 122 for (QListViewItem *it = firstChild(); it!=0;it = it->nextSibling())
100 { 123 {
101 ((ListViewItemConfigEntry*)it)->save(t); 124 ((ListViewItemConfigEntry*)it)->save(t);
102 } 125 }
103 conf.close(); 126 conf.close();
104 qDebug("no saveing yet...");
105 unchanged(); 127 unchanged();
106} 128}
129
130
131bool ListViewItemConfFile::revertable()
132{
133 return _changed || QFile(confFileInfo->absFilePath()+"~").exists();
134} \ No newline at end of file
diff --git a/noncore/apps/confedit/listviewitemconffile.h b/noncore/apps/confedit/listviewitemconffile.h
index d89b19c..ae23eab 100644
--- a/noncore/apps/confedit/listviewitemconffile.h
+++ b/noncore/apps/confedit/listviewitemconffile.h
@@ -12,24 +12,26 @@
12#define LISTVIEWITEMCONFFILE_H 12#define LISTVIEWITEMCONFFILE_H
13 13
14#include <qwidget.h> 14#include <qwidget.h>
15#include <qlistview.h> 15#include <qlistview.h>
16#include <qfile.h> 16#include <qfile.h>
17#include <qfileinfo.h> 17#include <qfileinfo.h>
18#include "listviewitemconf.h" 18#include "listviewitemconf.h"
19 19
20 20
21class ListViewItemConfFile : public ListViewItemConf { 21class ListViewItemConfFile : public ListViewItemConf {
22public: 22public:
23 ListViewItemConfFile(QFileInfo *file, QListView *parent=0); 23 ListViewItemConfFile(QFileInfo *file, QListView *parent=0);
24 ~ListViewItemConfFile(); 24 ~ListViewItemConfFile();
25 void parseFile(); 25 void parseFile();
26 QString fileName(); 26 QString fileName();
27 virtual void displayText(); 27 virtual void displayText();
28 bool revertable();
28 void save(); 29 void save();
30 void revert();
29protected: 31protected:
30private: 32private:
31 bool _valid; 33 bool _valid;
32 QFileInfo *confFileInfo; 34 QFileInfo *confFileInfo;
33}; 35};
34 36
35#endif 37#endif
diff --git a/noncore/apps/confedit/mainwindow.cpp b/noncore/apps/confedit/mainwindow.cpp
index 47d9518..77b91f6 100644
--- a/noncore/apps/confedit/mainwindow.cpp
+++ b/noncore/apps/confedit/mainwindow.cpp
@@ -25,70 +25,79 @@
25#include <qlabel.h> 25#include <qlabel.h>
26#include <qfile.h> 26#include <qfile.h>
27#include <qpushbutton.h> 27#include <qpushbutton.h>
28#include <qlayout.h> 28#include <qlayout.h>
29#include <qlineedit.h> 29#include <qlineedit.h>
30 30
31#include "listviewconfdir.h" 31#include "listviewconfdir.h"
32#include "listviewitemconf.h" 32#include "listviewitemconf.h"
33#include "listviewitemconfigentry.h" 33#include "listviewitemconfigentry.h"
34 34
35 35
36MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f ) : 36MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f ) :
37 QMainWindow( parent, name, f ), _currentItem(0), _fileItem(0) 37 QMainWindow( parent, name, f ), _currentItem(0), _fileItem(0)
38 { 38 {
39 setCaption( tr("Conf File Editor") ); 39 setCaption( tr("Conf File Editor") );
40 40
41 popupTimer = new QTimer(this);
42 popupMenu = new QPopupMenu(this);
43
44 QWidget *mainWidget = new QWidget(this); 41 QWidget *mainWidget = new QWidget(this);
45 setCentralWidget( mainWidget); 42 setCentralWidget( mainWidget);
46 43
47 QGridLayout *mainLayout = new QGridLayout( mainWidget ); 44 QGridLayout *mainLayout = new QGridLayout( mainWidget );
48 mainLayout->setSpacing( 3 ); 45 mainLayout->setSpacing( 3 );
49 mainLayout->setMargin( 3 ); 46 mainLayout->setMargin( 3 );
50 47
51 48
52 settingList = new ListViewConfDir( "/root/Settings/", this, "settingslist"); 49 settingList = new ListViewConfDir( "/root/Settings/", this, "settingslist");
53 mainLayout->addWidget( settingList, 0, 0 ); 50 mainLayout->addWidget( settingList, 0, 0 );
54 51
55 editor = new EditWidget(this); 52 editor = new EditWidget(this);
56 mainLayout->addWidget( editor, 1, 0 ); 53 mainLayout->addWidget( editor, 1, 0 );
57 54
58 connect(settingList, SIGNAL( pressed(QListViewItem*) ), 55 connect(settingList, SIGNAL( pressed(QListViewItem*) ),
59 this, SLOT(setCurrent(QListViewItem*))); 56 this, SLOT(setCurrent(QListViewItem*)));
60 57
61 connect( popupTimer, SIGNAL(timeout()),
62 this, SLOT(showPopup()) );
63 connect( settingList, SIGNAL( clicked( QListViewItem* ) ),
64 this, SLOT( stopTimer( QListViewItem* ) ) );
65 58
66 connect( editor->LineEditGroup, SIGNAL( textChanged(const QString&) ), 59 connect( editor->LineEditGroup, SIGNAL( textChanged(const QString&) ),
67 SLOT( groupChanged(const QString&) ) ); 60 SLOT( groupChanged(const QString&) ) );
68 connect( editor->LineEditKey, SIGNAL( textChanged(const QString&) ), 61 connect( editor->LineEditKey, SIGNAL( textChanged(const QString&) ),
69 SLOT( keyChanged(const QString&) ) ); 62 SLOT( keyChanged(const QString&) ) );
70 connect( editor->LineEditValue, SIGNAL( textChanged(const QString&) ), 63 connect( editor->LineEditValue, SIGNAL( textChanged(const QString&) ),
71 SLOT( valueChanged(const QString&) ) ); 64 SLOT( valueChanged(const QString&) ) );
72 makeMenu(); 65 makeMenu();
73} 66}
74 67
75void MainWindow::makeMenu() 68void MainWindow::makeMenu()
76{ 69{
77 70
78 71
72 popupTimer = new QTimer(this);
73 popupMenuFile = new QPopupMenu(this);
74
75 popupActionSave = new QAction( tr("Save"),QString::null, 0, this, 0 );
76 popupActionSave->addTo( popupMenuFile );
77 connect( popupActionSave, SIGNAL( activated() ),
78 this , SLOT( saveConfFile() ) );
79 popupActionRevert = new QAction( tr("Revert"),QString::null, 0, this, 0 );
80 popupActionRevert->addTo( popupMenuFile );
81 connect( popupActionRevert, SIGNAL( activated() ),
82 this , SLOT( revertConfFile() ) );
83
84 connect( popupTimer, SIGNAL(timeout()),
85 this, SLOT(showPopup()) );
86 connect( settingList, SIGNAL( clicked( QListViewItem* ) ),
87 this, SLOT( stopTimer( QListViewItem* ) ) );
79} 88}
80 89
81MainWindow::~MainWindow() 90MainWindow::~MainWindow()
82{ 91{
83} 92}
84 93
85 94
86 95
87void MainWindow::setCurrent(QListViewItem *item) 96void MainWindow::setCurrent(QListViewItem *item)
88{ 97{
89 if (!item) return; 98 if (!item) return;
90 ListViewItemConf *i = (ListViewItemConf*) item; 99 ListViewItemConf *i = (ListViewItemConf*) item;
91 if (!i) return; 100 if (!i) return;
92 if (i->getType() == ListViewItemConf::File) 101 if (i->getType() == ListViewItemConf::File)
93 { 102 {
94 qDebug("start timer"); 103 qDebug("start timer");
@@ -138,31 +147,35 @@ void MainWindow::valueChanged(const QString &v)
138 _currentItem->valueChanged(v); 147 _currentItem->valueChanged(v);
139} 148}
140 149
141 150
142void MainWindow::stopTimer( QListViewItem* ) 151void MainWindow::stopTimer( QListViewItem* )
143{ 152{
144 qDebug("stopTimer"); 153 qDebug("stopTimer");
145 popupTimer->stop(); 154 popupTimer->stop();
146} 155}
147 156
148void MainWindow::saveConfFile() 157void MainWindow::saveConfFile()
149{ 158{
150 if (!_fileItem) return; 159 if (!_fileItem) return;
151 _fileItem->save(); 160 _fileItem->save();
152} 161}
153 162
163void MainWindow::revertConfFile()
164{
165 if (!_fileItem) return;
166 _fileItem->revert();
167}
168
154void MainWindow::showPopup() 169void MainWindow::showPopup()
155{ 170{
156 qDebug("showPopup"); 171 qDebug("showPopup");
157 if (!_fileItem) return; 172 if (_fileItem)
158 popupMenu->clear(); 173 {
159 174 popupActionSave->setEnabled(_fileItem->isChanged());
160 QAction *popupAction; 175 popupActionRevert->setEnabled(_fileItem->revertable());
161 popupAction = new QAction( tr("Save"),QString::null, 0, this, 0 ); 176 popupMenuFile->popup( QCursor::pos() );
162 popupAction->addTo( popupMenu ); 177 }else if(_currentItem->isChanged())
163 connect( popupAction, SIGNAL( activated() ), 178 {
164 this , SLOT( saveConfFile() ) );
165
166 179
167 popupMenu->popup( QCursor::pos() ); 180 }
168} 181}
diff --git a/noncore/apps/confedit/mainwindow.h b/noncore/apps/confedit/mainwindow.h
index b015dac..e0dc0b0 100644
--- a/noncore/apps/confedit/mainwindow.h
+++ b/noncore/apps/confedit/mainwindow.h
@@ -28,29 +28,37 @@ class MainWindow : public QMainWindow
28 Q_OBJECT 28 Q_OBJECT
29 29
30 30
31public: 31public:
32 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); 32 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags f = 0 );
33 ~MainWindow(); 33 ~MainWindow();
34 34
35 35
36public slots: 36public slots:
37 void setCurrent(QListViewItem*); 37 void setCurrent(QListViewItem*);
38 void groupChanged(const QString&); 38 void groupChanged(const QString&);
39 void keyChanged(const QString&); 39 void keyChanged(const QString&);
40 void valueChanged(const QString&); 40 void valueChanged(const QString&);
41 void showPopup(); 41 void showPopup();
42 void stopTimer( QListViewItem* ); 42 void stopTimer( QListViewItem* );
43 void saveConfFile(); 43 void saveConfFile();
44 void revertConfFile();
44 45
45private: 46private:
46 ListViewConfDir *settingList; 47 ListViewConfDir *settingList;
47 EditWidget *editor; 48 EditWidget *editor;
48 ListViewItemConfigEntry *_currentItem; 49 ListViewItemConfigEntry *_currentItem;
49 ListViewItemConfFile *_fileItem; 50 ListViewItemConfFile *_fileItem;
50 QTimer *popupTimer; 51 QTimer *popupTimer;
51 QPopupMenu *popupMenu; 52 QPopupMenu *popupMenuFile;
53 QPopupMenu *popupMenuEntry;
54 QAction *popupActionSave;
55 QAction *popupActionRevert;
56 QAction *popupActionDelete;
57 QAction *popupActionNew;
58 //QAction *popupAction;
59 //QAction *popupAction;
52 60
53 void makeMenu(); 61 void makeMenu();
54}; 62};
55 63
56#endif 64#endif