author | zecke <zecke> | 2004-03-13 22:41:59 (UTC) |
---|---|---|
committer | zecke <zecke> | 2004-03-13 22:41:59 (UTC) |
commit | 3d27828732fe7e499219ad6e208dc13dead86431 (patch) (unidiff) | |
tree | faa42dec364ad1e0470a370c81d0a7dc0cd2f9bc | |
parent | ee753c0009da5bec4a71d3263e9623d04dddc5c4 (diff) | |
download | opie-3d27828732fe7e499219ad6e208dc13dead86431.zip opie-3d27828732fe7e499219ad6e208dc13dead86431.tar.gz opie-3d27828732fe7e499219ad6e208dc13dead86431.tar.bz2 |
Namespace changes for Apps
QAshMoney and Reader need to be valgrinded
43 files changed, 90 insertions, 63 deletions
diff --git a/noncore/apps/advancedfm/advancedfm.cpp b/noncore/apps/advancedfm/advancedfm.cpp index 2ba3dca..a60d6ce 100644 --- a/noncore/apps/advancedfm/advancedfm.cpp +++ b/noncore/apps/advancedfm/advancedfm.cpp | |||
@@ -1,547 +1,549 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | AdvancedFm.cpp | 2 | AdvancedFm.cpp |
3 | ------------------- | 3 | ------------------- |
4 | ** Created: Sat Mar 9 23:33:09 2002 | 4 | ** Created: Sat Mar 9 23:33:09 2002 |
5 | copyright : (C) 2002 by ljp | 5 | copyright : (C) 2002 by ljp |
6 | email : ljp@llornkcor.com | 6 | email : ljp@llornkcor.com |
7 | * This program is free software; you can redistribute it and/or modify * | 7 | * This program is free software; you can redistribute it and/or modify * |
8 | * it under the terms of the GNU General Public License as published by * | 8 | * it under the terms of the GNU General Public License as published by * |
9 | * the Free Software Foundation; either version 2 of the License, or * | 9 | * the Free Software Foundation; either version 2 of the License, or * |
10 | * (at your option) any later version. * | 10 | * (at your option) any later version. * |
11 | ***************************************************************************/ | 11 | ***************************************************************************/ |
12 | #define DEVELOPERS_VERSION | 12 | #define DEVELOPERS_VERSION |
13 | #include "advancedfm.h" | 13 | #include "advancedfm.h" |
14 | 14 | ||
15 | #include <qpe/qpeapplication.h> | 15 | #include <qpe/qpeapplication.h> |
16 | #include <qpe/config.h> | 16 | #include <qpe/config.h> |
17 | #include <qpe/mimetype.h> | 17 | #include <qpe/mimetype.h> |
18 | #include <qpe/applnk.h> | 18 | #include <qpe/applnk.h> |
19 | #include <qpe/resource.h> | 19 | #include <qpe/resource.h> |
20 | #include <qpe/menubutton.h> | 20 | #include <qpe/menubutton.h> |
21 | 21 | ||
22 | #include <qcombobox.h> | 22 | #include <qcombobox.h> |
23 | #include <qpopupmenu.h> | 23 | #include <qpopupmenu.h> |
24 | #include <qlistview.h> | 24 | #include <qlistview.h> |
25 | #include <qmessagebox.h> | 25 | #include <qmessagebox.h> |
26 | #include <qlineedit.h> | 26 | #include <qlineedit.h> |
27 | 27 | ||
28 | 28 | ||
29 | #include <sys/stat.h> | 29 | #include <sys/stat.h> |
30 | #include <time.h> | 30 | #include <time.h> |
31 | #include <dirent.h> | 31 | #include <dirent.h> |
32 | #include <fcntl.h> | 32 | #include <fcntl.h> |
33 | #include <sys/vfs.h> | 33 | #include <sys/vfs.h> |
34 | #include <mntent.h> | 34 | #include <mntent.h> |
35 | 35 | ||
36 | using namespace Opie::Ui; | ||
37 | |||
36 | #ifdef NOQUICKLAUNCH | 38 | #ifdef NOQUICKLAUNCH |
37 | AdvancedFm::AdvancedFm( ) | 39 | AdvancedFm::AdvancedFm( ) |
38 | #else | 40 | #else |
39 | AdvancedFm::AdvancedFm(QWidget *,const char*, WFlags ) | 41 | AdvancedFm::AdvancedFm(QWidget *,const char*, WFlags ) |
40 | #endif | 42 | #endif |
41 | : QMainWindow( ) { | 43 | : QMainWindow( ) { |
42 | init(); | 44 | init(); |
43 | renameBox = 0; | 45 | renameBox = 0; |
44 | 46 | ||
45 | unknownXpm = Resource::loadImage( "UnknownDocument" ).smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); | 47 | unknownXpm = Resource::loadImage( "UnknownDocument" ).smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); |
46 | 48 | ||
47 | initConnections(); | 49 | initConnections(); |
48 | whichTab=1; | 50 | whichTab=1; |
49 | rePopulate(); | 51 | rePopulate(); |
50 | currentPathCombo->setFocus(); | 52 | currentPathCombo->setFocus(); |
51 | channel = new QCopChannel( "QPE/Application/advancedfm", this ); | 53 | channel = new QCopChannel( "QPE/Application/advancedfm", this ); |
52 | connect( channel, SIGNAL(received(const QCString&,const QByteArray&)), | 54 | connect( channel, SIGNAL(received(const QCString&,const QByteArray&)), |
53 | this, SLOT( qcopReceive(const QCString&,const QByteArray&)) ); | 55 | this, SLOT( qcopReceive(const QCString&,const QByteArray&)) ); |
54 | } | 56 | } |
55 | 57 | ||
56 | AdvancedFm::~AdvancedFm() { | 58 | AdvancedFm::~AdvancedFm() { |
57 | } | 59 | } |
58 | 60 | ||
59 | 61 | ||
60 | void AdvancedFm::cleanUp() { | 62 | void AdvancedFm::cleanUp() { |
61 | QString sfile=QDir::homeDirPath(); | 63 | QString sfile=QDir::homeDirPath(); |
62 | if(sfile.right(1) != "/") | 64 | if(sfile.right(1) != "/") |
63 | sfile+="/._temp"; | 65 | sfile+="/._temp"; |
64 | else | 66 | else |
65 | sfile+="._temp"; | 67 | sfile+="._temp"; |
66 | QFile file( sfile); | 68 | QFile file( sfile); |
67 | if(file.exists()) | 69 | if(file.exists()) |
68 | file.remove(); | 70 | file.remove(); |
69 | } | 71 | } |
70 | 72 | ||
71 | void AdvancedFm::tabChanged(QWidget *) { | 73 | void AdvancedFm::tabChanged(QWidget *) { |
72 | // qWarning("tab changed"); | 74 | // qWarning("tab changed"); |
73 | QString path = CurrentDir()->canonicalPath(); | 75 | QString path = CurrentDir()->canonicalPath(); |
74 | currentPathCombo->lineEdit()->setText( path ); | 76 | currentPathCombo->lineEdit()->setText( path ); |
75 | 77 | ||
76 | if(whichTab == 1) { | 78 | if(whichTab == 1) { |
77 | viewMenu->setItemChecked(viewMenu->idAt(0), true); | 79 | viewMenu->setItemChecked(viewMenu->idAt(0), true); |
78 | viewMenu->setItemChecked(viewMenu->idAt(1), false); | 80 | viewMenu->setItemChecked(viewMenu->idAt(1), false); |
79 | } else { | 81 | } else { |
80 | viewMenu->setItemChecked(viewMenu->idAt(0), false); | 82 | viewMenu->setItemChecked(viewMenu->idAt(0), false); |
81 | viewMenu->setItemChecked(viewMenu->idAt(1), true); | 83 | viewMenu->setItemChecked(viewMenu->idAt(1), true); |
82 | } | 84 | } |
83 | 85 | ||
84 | QString fs= getFileSystemType( (const QString &) path); | 86 | QString fs= getFileSystemType( (const QString &) path); |
85 | 87 | ||
86 | setCaption(tr("AdvancedFm :: ")+fs+" :: " | 88 | setCaption(tr("AdvancedFm :: ")+fs+" :: " |
87 | +checkDiskSpace( (const QString &) path )+ tr(" kB free") ); | 89 | +checkDiskSpace( (const QString &) path )+ tr(" kB free") ); |
88 | chdir( path.latin1()); | 90 | chdir( path.latin1()); |
89 | } | 91 | } |
90 | 92 | ||
91 | 93 | ||
92 | void AdvancedFm::populateView() { | 94 | void AdvancedFm::populateView() { |
93 | 95 | ||
94 | // qWarning("PopulateView"); | 96 | // qWarning("PopulateView"); |
95 | QPixmap pm; | 97 | QPixmap pm; |
96 | QListView *thisView = CurrentView(); | 98 | QListView *thisView = CurrentView(); |
97 | QDir *thisDir = CurrentDir(); | 99 | QDir *thisDir = CurrentDir(); |
98 | QString path = thisDir->canonicalPath(); | 100 | QString path = thisDir->canonicalPath(); |
99 | 101 | ||
100 | //qWarning("path is "+path); | 102 | //qWarning("path is "+path); |
101 | thisView->clear(); | 103 | thisView->clear(); |
102 | thisDir->setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); | 104 | thisDir->setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); |
103 | thisDir->setMatchAllDirs(TRUE); | 105 | thisDir->setMatchAllDirs(TRUE); |
104 | thisDir->setNameFilter(filterStr); | 106 | thisDir->setNameFilter(filterStr); |
105 | QString fileL, fileS, fileDate; | 107 | QString fileL, fileS, fileDate; |
106 | QString fs= getFileSystemType((const QString &) path); | 108 | QString fs= getFileSystemType((const QString &) path); |
107 | setCaption(tr("AdvancedFm :: ")+fs+" :: " | 109 | setCaption(tr("AdvancedFm :: ")+fs+" :: " |
108 | +checkDiskSpace((const QString &) path)+ tr(" kB free") ); | 110 | +checkDiskSpace((const QString &) path)+ tr(" kB free") ); |
109 | bool isDir=FALSE; | 111 | bool isDir=FALSE; |
110 | const QFileInfoList *list = thisDir->entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); | 112 | const QFileInfoList *list = thisDir->entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); |
111 | QFileInfoListIterator it(*list); | 113 | QFileInfoListIterator it(*list); |
112 | QFileInfo *fi; | 114 | QFileInfo *fi; |
113 | while ( (fi=it.current()) ) { | 115 | while ( (fi=it.current()) ) { |
114 | if (fi->isSymLink() ) { | 116 | if (fi->isSymLink() ) { |
115 | QString symLink=fi->readLink(); | 117 | QString symLink=fi->readLink(); |
116 | QFileInfo sym( symLink); | 118 | QFileInfo sym( symLink); |
117 | fileS.sprintf( "%10i", sym.size() ); | 119 | fileS.sprintf( "%10i", sym.size() ); |
118 | fileL = fi->fileName() +" -> " + sym.filePath().data(); | 120 | fileL = fi->fileName() +" -> " + sym.filePath().data(); |
119 | fileDate = sym.lastModified().toString(); | 121 | fileDate = sym.lastModified().toString(); |
120 | } else { | 122 | } else { |
121 | fileS.sprintf( "%10i", fi->size() ); | 123 | fileS.sprintf( "%10i", fi->size() ); |
122 | fileL = fi->fileName(); | 124 | fileL = fi->fileName(); |
123 | fileDate= fi->lastModified().toString(); | 125 | fileDate= fi->lastModified().toString(); |
124 | if( QDir(QDir::cleanDirPath( path +"/"+fileL)).exists() ) { | 126 | if( QDir(QDir::cleanDirPath( path +"/"+fileL)).exists() ) { |
125 | // if(fileL == "..") | 127 | // if(fileL == "..") |
126 | fileL += "/"; | 128 | fileL += "/"; |
127 | isDir=TRUE; | 129 | isDir=TRUE; |
128 | } | 130 | } |
129 | } | 131 | } |
130 | QFileInfo fileInfo( path + "/" + fileL); | 132 | QFileInfo fileInfo( path + "/" + fileL); |
131 | 133 | ||
132 | if(fileL !="./" && fi->exists()) { | 134 | if(fileL !="./" && fi->exists()) { |
133 | item = new QListViewItem( thisView, fileL, fileS , fileDate); | 135 | item = new QListViewItem( thisView, fileL, fileS , fileDate); |
134 | 136 | ||
135 | if(isDir || fileL.find("/",0,TRUE) != -1) { | 137 | if(isDir || fileL.find("/",0,TRUE) != -1) { |
136 | 138 | ||
137 | if( !QDir( fi->filePath() ).isReadable()) //is directory | 139 | if( !QDir( fi->filePath() ).isReadable()) //is directory |
138 | pm = Resource::loadPixmap( "lockedfolder" ); | 140 | pm = Resource::loadPixmap( "lockedfolder" ); |
139 | else | 141 | else |
140 | pm= Resource::loadPixmap( "folder" ); | 142 | pm= Resource::loadPixmap( "folder" ); |
141 | } | 143 | } |
142 | else if ( fs == "vfat" && fileInfo.filePath().contains("/bin") ) { | 144 | else if ( fs == "vfat" && fileInfo.filePath().contains("/bin") ) { |
143 | pm = Resource::loadPixmap( "exec"); | 145 | pm = Resource::loadPixmap( "exec"); |
144 | } | 146 | } |
145 | else if( (fileInfo.permission( QFileInfo::ExeUser) | 147 | else if( (fileInfo.permission( QFileInfo::ExeUser) |
146 | | fileInfo.permission( QFileInfo::ExeGroup) | 148 | | fileInfo.permission( QFileInfo::ExeGroup) |
147 | | fileInfo.permission( QFileInfo::ExeOther)) && fs != "vfat" ) { | 149 | | fileInfo.permission( QFileInfo::ExeOther)) && fs != "vfat" ) { |
148 | pm = Resource::loadPixmap( "exec"); | 150 | pm = Resource::loadPixmap( "exec"); |
149 | } | 151 | } |
150 | else if( !fi->isReadable() ) { | 152 | else if( !fi->isReadable() ) { |
151 | pm = Resource::loadPixmap( "locked" ); | 153 | pm = Resource::loadPixmap( "locked" ); |
152 | } | 154 | } |
153 | else { //everything else goes by mimetype | 155 | else { //everything else goes by mimetype |
154 | MimeType mt(fi->filePath()); | 156 | MimeType mt(fi->filePath()); |
155 | pm=mt.pixmap(); //sets the correct pixmap for mimetype | 157 | pm=mt.pixmap(); //sets the correct pixmap for mimetype |
156 | if(pm.isNull()) { | 158 | if(pm.isNull()) { |
157 | pm = unknownXpm; | 159 | pm = unknownXpm; |
158 | } | 160 | } |
159 | } | 161 | } |
160 | if( fi->isSymLink() || fileL.find("->",0,TRUE) != -1) { | 162 | if( fi->isSymLink() || fileL.find("->",0,TRUE) != -1) { |
161 | // qDebug(" overlay link image"); | 163 | // qDebug(" overlay link image"); |
162 | pm= Resource::loadPixmap( "advancedfm/symlink" ); | 164 | pm= Resource::loadPixmap( "advancedfm/symlink" ); |
163 | // pm= Resource::loadPixmap( "folder" ); | 165 | // pm= Resource::loadPixmap( "folder" ); |
164 | // QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); | 166 | // QPixmap lnk = Resource::loadPixmap( "opie/symlink" ); |
165 | // QPainter painter( &pm ); | 167 | // QPainter painter( &pm ); |
166 | // painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); | 168 | // painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); |
167 | // pm.setMask( pm.createHeuristicMask( FALSE ) ); | 169 | // pm.setMask( pm.createHeuristicMask( FALSE ) ); |
168 | } | 170 | } |
169 | item->setPixmap( 0,pm); | 171 | item->setPixmap( 0,pm); |
170 | 172 | ||
171 | } | 173 | } |
172 | isDir=FALSE; | 174 | isDir=FALSE; |
173 | ++it; | 175 | ++it; |
174 | } | 176 | } |
175 | 177 | ||
176 | if( path.find("dev",0,TRUE) != -1) { | 178 | if( path.find("dev",0,TRUE) != -1) { |
177 | struct stat buf; | 179 | struct stat buf; |
178 | dev_t devT; | 180 | dev_t devT; |
179 | DIR *dir; | 181 | DIR *dir; |
180 | struct dirent *mydirent; | 182 | struct dirent *mydirent; |
181 | 183 | ||
182 | if((dir = opendir( path.latin1())) != NULL) | 184 | if((dir = opendir( path.latin1())) != NULL) |
183 | while ((mydirent = readdir(dir)) != NULL) { | 185 | while ((mydirent = readdir(dir)) != NULL) { |
184 | lstat( mydirent->d_name, &buf); | 186 | lstat( mydirent->d_name, &buf); |
185 | // qDebug(mydirent->d_name); | 187 | // qDebug(mydirent->d_name); |
186 | fileL.sprintf("%s", mydirent->d_name); | 188 | fileL.sprintf("%s", mydirent->d_name); |
187 | devT = buf.st_dev; | 189 | devT = buf.st_dev; |
188 | fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); | 190 | fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); |
189 | fileDate.sprintf("%s", ctime( &buf.st_mtime)); | 191 | fileDate.sprintf("%s", ctime( &buf.st_mtime)); |
190 | if( fileL.find(".") == -1 ) { | 192 | if( fileL.find(".") == -1 ) { |
191 | item= new QListViewItem( thisView, fileL, fileS, fileDate); | 193 | item= new QListViewItem( thisView, fileL, fileS, fileDate); |
192 | pm = unknownXpm; | 194 | pm = unknownXpm; |
193 | item->setPixmap( 0,pm); | 195 | item->setPixmap( 0,pm); |
194 | } | 196 | } |
195 | } | 197 | } |
196 | 198 | ||
197 | closedir(dir); | 199 | closedir(dir); |
198 | } | 200 | } |
199 | 201 | ||
200 | thisView->setSorting( 3,FALSE); | 202 | thisView->setSorting( 3,FALSE); |
201 | fillCombo( (const QString &) path ); | 203 | fillCombo( (const QString &) path ); |
202 | } | 204 | } |
203 | 205 | ||
204 | void AdvancedFm::rePopulate() { | 206 | void AdvancedFm::rePopulate() { |
205 | populateView(); | 207 | populateView(); |
206 | setOtherTabCurrent(); | 208 | setOtherTabCurrent(); |
207 | populateView(); | 209 | populateView(); |
208 | 210 | ||
209 | // int tmpTab = whichTab; | 211 | // int tmpTab = whichTab; |
210 | // // qDebug("%d", tmpTab); | 212 | // // qDebug("%d", tmpTab); |
211 | 213 | ||
212 | // for(int i =1; i < 3; i++) { | 214 | // for(int i =1; i < 3; i++) { |
213 | // TabWidget->setCurrentWidget(i - 1); | 215 | // TabWidget->setCurrentWidget(i - 1); |
214 | // populateView(); | 216 | // populateView(); |
215 | // } | 217 | // } |
216 | // TabWidget->setCurrentWidget( tmpTab - 1); | 218 | // TabWidget->setCurrentWidget( tmpTab - 1); |
217 | } | 219 | } |
218 | 220 | ||
219 | void AdvancedFm::ListClicked(QListViewItem *selectedItem) { | 221 | void AdvancedFm::ListClicked(QListViewItem *selectedItem) { |
220 | //qWarning("listclicked"); | 222 | //qWarning("listclicked"); |
221 | if(selectedItem) { | 223 | if(selectedItem) { |
222 | QString strItem=selectedItem->text(0); | 224 | QString strItem=selectedItem->text(0); |
223 | // qWarning(strItem); | 225 | // qWarning(strItem); |
224 | QString strSize=selectedItem->text(1); | 226 | QString strSize=selectedItem->text(1); |
225 | strSize=strSize.stripWhiteSpace(); | 227 | strSize=strSize.stripWhiteSpace(); |
226 | bool isDirectory = false; | 228 | bool isDirectory = false; |
227 | QString strItem2; | 229 | QString strItem2; |
228 | 230 | ||
229 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 ) {//if symlink | 231 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 ) {//if symlink |
230 | strItem2 = dealWithSymName((const QString&)strItem); | 232 | strItem2 = dealWithSymName((const QString&)strItem); |
231 | if(QDir(strItem2).exists() ) | 233 | if(QDir(strItem2).exists() ) |
232 | strItem = strItem2; | 234 | strItem = strItem2; |
233 | } | 235 | } |
234 | 236 | ||
235 | if( strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) { | 237 | if( strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) { |
236 | 238 | ||
237 | if(QDir(strItem).exists()) | 239 | if(QDir(strItem).exists()) |
238 | isDirectory = true; | 240 | isDirectory = true; |
239 | } | 241 | } |
240 | 242 | ||
241 | if( isDirectory ) { | 243 | if( isDirectory ) { |
242 | CurrentDir()->cd( strItem, TRUE); | 244 | CurrentDir()->cd( strItem, TRUE); |
243 | populateView(); | 245 | populateView(); |
244 | CurrentView()->ensureItemVisible( CurrentView()->firstChild()); | 246 | CurrentView()->ensureItemVisible( CurrentView()->firstChild()); |
245 | } | 247 | } |
246 | chdir( strItem.latin1()); | 248 | chdir( strItem.latin1()); |
247 | } | 249 | } |
248 | } | 250 | } |
249 | 251 | ||
250 | void AdvancedFm::ListPressed( int mouse, QListViewItem *item, const QPoint& , int ) { | 252 | void AdvancedFm::ListPressed( int mouse, QListViewItem *item, const QPoint& , int ) { |
251 | dealWithSchmooSchmaa( item->listView()); | 253 | dealWithSchmooSchmaa( item->listView()); |
252 | switch (mouse) { | 254 | switch (mouse) { |
253 | case 1: | 255 | case 1: |
254 | { | 256 | { |
255 | if(renameBox != 0 ) { | 257 | if(renameBox != 0 ) { |
256 | cancelRename(); | 258 | cancelRename(); |
257 | } | 259 | } |
258 | } | 260 | } |
259 | break; | 261 | break; |
260 | case 2: | 262 | case 2: |
261 | menuTimer.start( 500, TRUE ); | 263 | menuTimer.start( 500, TRUE ); |
262 | break; | 264 | break; |
263 | }; | 265 | }; |
264 | } | 266 | } |
265 | 267 | ||
266 | 268 | ||
267 | void AdvancedFm::switchToLocalTab() { | 269 | void AdvancedFm::switchToLocalTab() { |
268 | //qWarning("switch to local view"); | 270 | //qWarning("switch to local view"); |
269 | TabWidget->setCurrentWidget(0); | 271 | TabWidget->setCurrentWidget(0); |
270 | Local_View->setFocus(); | 272 | Local_View->setFocus(); |
271 | } | 273 | } |
272 | 274 | ||
273 | void AdvancedFm::switchToRemoteTab() { | 275 | void AdvancedFm::switchToRemoteTab() { |
274 | //qWarning("switch to local view"); | 276 | //qWarning("switch to local view"); |
275 | TabWidget->setCurrentWidget(1); | 277 | TabWidget->setCurrentWidget(1); |
276 | Remote_View->setFocus(); | 278 | Remote_View->setFocus(); |
277 | } | 279 | } |
278 | 280 | ||
279 | void AdvancedFm::readConfig() { | 281 | void AdvancedFm::readConfig() { |
280 | Config cfg("AdvancedFm"); | 282 | Config cfg("AdvancedFm"); |
281 | } | 283 | } |
282 | 284 | ||
283 | void AdvancedFm::writeConfig() { | 285 | void AdvancedFm::writeConfig() { |
284 | Config cfg("AdvancedFm"); | 286 | Config cfg("AdvancedFm"); |
285 | } | 287 | } |
286 | 288 | ||
287 | void AdvancedFm::currentPathComboChanged() { | 289 | void AdvancedFm::currentPathComboChanged() { |
288 | if(QDir( currentPathCombo->lineEdit()->text()).exists()) { | 290 | if(QDir( currentPathCombo->lineEdit()->text()).exists()) { |
289 | CurrentDir()->setPath( currentPathCombo->lineEdit()->text() ); | 291 | CurrentDir()->setPath( currentPathCombo->lineEdit()->text() ); |
290 | populateView(); | 292 | populateView(); |
291 | } else { | 293 | } else { |
292 | QMessageBox::message(tr("Note"),tr("That directory does not exist")); | 294 | QMessageBox::message(tr("Note"),tr("That directory does not exist")); |
293 | } | 295 | } |
294 | } | 296 | } |
295 | 297 | ||
296 | void AdvancedFm::fillCombo(const QString ¤tPath) { | 298 | void AdvancedFm::fillCombo(const QString ¤tPath) { |
297 | 299 | ||
298 | if ( whichTab == 1) { | 300 | if ( whichTab == 1) { |
299 | currentPathCombo->lineEdit()->setText( currentPath); | 301 | currentPathCombo->lineEdit()->setText( currentPath); |
300 | if( localDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { | 302 | if( localDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { |
301 | currentPathCombo->clear(); | 303 | currentPathCombo->clear(); |
302 | localDirPathStringList.prepend( currentPath ); | 304 | localDirPathStringList.prepend( currentPath ); |
303 | currentPathCombo->insertStringList( localDirPathStringList,-1); | 305 | currentPathCombo->insertStringList( localDirPathStringList,-1); |
304 | } | 306 | } |
305 | } else { | 307 | } else { |
306 | currentPathCombo->lineEdit()->setText( currentPath); | 308 | currentPathCombo->lineEdit()->setText( currentPath); |
307 | if( remoteDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { | 309 | if( remoteDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { |
308 | currentPathCombo->clear(); | 310 | currentPathCombo->clear(); |
309 | remoteDirPathStringList.prepend( currentPath ); | 311 | remoteDirPathStringList.prepend( currentPath ); |
310 | currentPathCombo->insertStringList( remoteDirPathStringList,-1); | 312 | currentPathCombo->insertStringList( remoteDirPathStringList,-1); |
311 | } | 313 | } |
312 | } | 314 | } |
313 | } | 315 | } |
314 | 316 | ||
315 | void AdvancedFm::currentPathComboActivated(const QString & currentPath) { | 317 | void AdvancedFm::currentPathComboActivated(const QString & currentPath) { |
316 | chdir( currentPath.latin1() ); | 318 | chdir( currentPath.latin1() ); |
317 | CurrentDir()->cd( currentPath, TRUE); | 319 | CurrentDir()->cd( currentPath, TRUE); |
318 | populateView(); | 320 | populateView(); |
319 | update(); | 321 | update(); |
320 | } | 322 | } |
321 | 323 | ||
322 | QStringList AdvancedFm::getPath() { | 324 | QStringList AdvancedFm::getPath() { |
323 | QStringList strList; | 325 | QStringList strList; |
324 | QListView *thisView=CurrentView(); | 326 | QListView *thisView=CurrentView(); |
325 | QList<QListViewItem> * getSelectedItems( QListView * thisView ); | 327 | QList<QListViewItem> * getSelectedItems( QListView * thisView ); |
326 | QListViewItemIterator it( thisView ); | 328 | QListViewItemIterator it( thisView ); |
327 | for ( ; it.current(); ++it ) { | 329 | for ( ; it.current(); ++it ) { |
328 | if ( it.current()->isSelected() ) { | 330 | if ( it.current()->isSelected() ) { |
329 | strList << it.current()->text(0); | 331 | strList << it.current()->text(0); |
330 | // qDebug(it.current()->text(0)); | 332 | // qDebug(it.current()->text(0)); |
331 | } | 333 | } |
332 | } | 334 | } |
333 | return strList; | 335 | return strList; |
334 | } | 336 | } |
335 | 337 | ||
336 | void AdvancedFm::homeButtonPushed() { | 338 | void AdvancedFm::homeButtonPushed() { |
337 | QString current = QDir::homeDirPath(); | 339 | QString current = QDir::homeDirPath(); |
338 | chdir( current.latin1() ); | 340 | chdir( current.latin1() ); |
339 | CurrentDir()->cd( current, TRUE); | 341 | CurrentDir()->cd( current, TRUE); |
340 | populateView(); | 342 | populateView(); |
341 | update(); | 343 | update(); |
342 | } | 344 | } |
343 | 345 | ||
344 | void AdvancedFm::docButtonPushed() { | 346 | void AdvancedFm::docButtonPushed() { |
345 | QString current = QPEApplication::documentDir(); | 347 | QString current = QPEApplication::documentDir(); |
346 | chdir( current.latin1() ); | 348 | chdir( current.latin1() ); |
347 | CurrentDir()->cd( current, TRUE); | 349 | CurrentDir()->cd( current, TRUE); |
348 | populateView(); | 350 | populateView(); |
349 | update(); | 351 | update(); |
350 | } | 352 | } |
351 | 353 | ||
352 | void AdvancedFm::SDButtonPushed() { | 354 | void AdvancedFm::SDButtonPushed() { |
353 | QString current = "/mnt/card";// this can change so fix | 355 | QString current = "/mnt/card";// this can change so fix |
354 | chdir( current.latin1() ); | 356 | chdir( current.latin1() ); |
355 | CurrentDir()->cd( current, TRUE); | 357 | CurrentDir()->cd( current, TRUE); |
356 | populateView(); | 358 | populateView(); |
357 | update(); | 359 | update(); |
358 | } | 360 | } |
359 | 361 | ||
360 | void AdvancedFm::CFButtonPushed() { | 362 | void AdvancedFm::CFButtonPushed() { |
361 | QString current; | 363 | QString current; |
362 | if(zaurusDevice) | 364 | if(zaurusDevice) |
363 | current= "/mnt/cf"; //zaurus | 365 | current= "/mnt/cf"; //zaurus |
364 | else | 366 | else |
365 | current = "/mnt/hda"; //ipaq | 367 | current = "/mnt/hda"; //ipaq |
366 | chdir( current.latin1() ); | 368 | chdir( current.latin1() ); |
367 | CurrentDir()->cd( current, TRUE); | 369 | CurrentDir()->cd( current, TRUE); |
368 | populateView(); | 370 | populateView(); |
369 | update(); | 371 | update(); |
370 | } | 372 | } |
371 | 373 | ||
372 | 374 | ||
373 | void AdvancedFm::doAbout() { | 375 | void AdvancedFm::doAbout() { |
374 | QMessageBox::message("AdvancedFm",tr("Advanced FileManager\n" | 376 | QMessageBox::message("AdvancedFm",tr("Advanced FileManager\n" |
375 | "is copyright 2002-2003 by\n" | 377 | "is copyright 2002-2003 by\n" |
376 | "L.J.Potter<llornkcor@handhelds.org>\n" | 378 | "L.J.Potter<llornkcor@handhelds.org>\n" |
377 | "and is licensed by the GPL")); | 379 | "and is licensed by the GPL")); |
378 | } | 380 | } |
379 | 381 | ||
380 | void AdvancedFm::keyPressEvent( QKeyEvent *e) { | 382 | void AdvancedFm::keyPressEvent( QKeyEvent *e) { |
381 | // qWarning("key %d", e->key()); | 383 | // qWarning("key %d", e->key()); |
382 | // if( CurrentView()->hasFocus() ) | 384 | // if( CurrentView()->hasFocus() ) |
383 | { | 385 | { |
384 | switch ( e->key() ) { | 386 | switch ( e->key() ) { |
385 | case Key_Left: | 387 | case Key_Left: |
386 | upDir(); | 388 | upDir(); |
387 | break; | 389 | break; |
388 | case Key_Next: | 390 | case Key_Next: |
389 | break; | 391 | break; |
390 | case Key_Return: | 392 | case Key_Return: |
391 | case Key_Enter: | 393 | case Key_Enter: |
392 | navigateToSelected(); | 394 | navigateToSelected(); |
393 | break; | 395 | break; |
394 | case Key_Tab: { | 396 | case Key_Tab: { |
395 | setOtherTabCurrent(); | 397 | setOtherTabCurrent(); |
396 | } | 398 | } |
397 | break; | 399 | break; |
398 | case Key_Delete: | 400 | case Key_Delete: |
399 | del(); | 401 | del(); |
400 | break; | 402 | break; |
401 | case Key_A: | 403 | case Key_A: |
402 | copyAs(); | 404 | copyAs(); |
403 | break; | 405 | break; |
404 | case Key_C: | 406 | case Key_C: |
405 | copy(); | 407 | copy(); |
406 | break; | 408 | break; |
407 | case Key_E: | 409 | case Key_E: |
408 | runThis(); | 410 | runThis(); |
409 | break; | 411 | break; |
410 | case Key_G: | 412 | case Key_G: |
411 | { | 413 | { |
412 | currentPathCombo->lineEdit()->setFocus(); | 414 | currentPathCombo->lineEdit()->setFocus(); |
413 | } | 415 | } |
414 | break; | 416 | break; |
415 | 417 | ||
416 | case Key_H: | 418 | case Key_H: |
417 | showHidden(); | 419 | showHidden(); |
418 | break; | 420 | break; |
419 | case Key_I: | 421 | case Key_I: |
420 | fileStatus(); | 422 | fileStatus(); |
421 | break; | 423 | break; |
422 | case Key_M: | 424 | case Key_M: |
423 | move(); | 425 | move(); |
424 | break; | 426 | break; |
425 | case Key_N: | 427 | case Key_N: |
426 | mkDir(); | 428 | mkDir(); |
427 | break; | 429 | break; |
428 | case Key_P: | 430 | case Key_P: |
429 | filePerms(); | 431 | filePerms(); |
430 | break; | 432 | break; |
431 | case Key_R: | 433 | case Key_R: |
432 | rn(); | 434 | rn(); |
433 | break; | 435 | break; |
434 | case Key_U: | 436 | case Key_U: |
435 | upDir(); | 437 | upDir(); |
436 | break; | 438 | break; |
437 | case Key_1: | 439 | case Key_1: |
438 | switchToLocalTab(); | 440 | switchToLocalTab(); |
439 | break; | 441 | break; |
440 | case Key_2: | 442 | case Key_2: |
441 | switchToRemoteTab(); | 443 | switchToRemoteTab(); |
442 | break; | 444 | break; |
443 | case Key_3: | 445 | case Key_3: |
444 | CFButtonPushed(); | 446 | CFButtonPushed(); |
445 | break; | 447 | break; |
446 | case Key_4: | 448 | case Key_4: |
447 | SDButtonPushed(); | 449 | SDButtonPushed(); |
448 | break; | 450 | break; |
449 | case Key_5: | 451 | case Key_5: |
450 | homeButtonPushed(); | 452 | homeButtonPushed(); |
451 | break; | 453 | break; |
452 | case Key_6: | 454 | case Key_6: |
453 | docButtonPushed(); | 455 | docButtonPushed(); |
454 | break; | 456 | break; |
455 | case Key_7: | 457 | case Key_7: |
456 | break; | 458 | break; |
457 | case Key_8: | 459 | case Key_8: |
458 | break; | 460 | break; |
459 | case Key_9: | 461 | case Key_9: |
460 | break; | 462 | break; |
461 | case Key_0: | 463 | case Key_0: |
462 | break; | 464 | break; |
463 | }; | 465 | }; |
464 | e->accept(); | 466 | e->accept(); |
465 | } | 467 | } |
466 | } | 468 | } |
467 | 469 | ||
468 | void AdvancedFm::keyReleaseEvent( QKeyEvent *e) { | 470 | void AdvancedFm::keyReleaseEvent( QKeyEvent *e) { |
469 | if( CurrentView()->hasFocus() ) | 471 | if( CurrentView()->hasFocus() ) |
470 | e->ignore(); | 472 | e->ignore(); |
471 | } | 473 | } |
472 | 474 | ||
473 | 475 | ||
474 | void AdvancedFm::QPEButtonPushed() { | 476 | void AdvancedFm::QPEButtonPushed() { |
475 | QString current = QPEApplication::qpeDir(); | 477 | QString current = QPEApplication::qpeDir(); |
476 | chdir( current.latin1() ); | 478 | chdir( current.latin1() ); |
477 | CurrentDir()->cd( current, TRUE); | 479 | CurrentDir()->cd( current, TRUE); |
478 | populateView(); | 480 | populateView(); |
479 | update(); | 481 | update(); |
480 | } | 482 | } |
481 | 483 | ||
482 | void AdvancedFm::parsetab(const QString &fileName) { | 484 | void AdvancedFm::parsetab(const QString &fileName) { |
483 | 485 | ||
484 | fileSystemTypeList.clear(); | 486 | fileSystemTypeList.clear(); |
485 | fsList.clear(); | 487 | fsList.clear(); |
486 | struct mntent *me; | 488 | struct mntent *me; |
487 | FILE *mntfp = setmntent( fileName.latin1(), "r" ); | 489 | FILE *mntfp = setmntent( fileName.latin1(), "r" ); |
488 | if ( mntfp ) { | 490 | if ( mntfp ) { |
489 | while ( (me = getmntent( mntfp )) != 0 ) { | 491 | while ( (me = getmntent( mntfp )) != 0 ) { |
490 | QString deviceName = me->mnt_fsname; | 492 | QString deviceName = me->mnt_fsname; |
491 | QString filesystemType = me->mnt_type; | 493 | QString filesystemType = me->mnt_type; |
492 | QString mountDir = me->mnt_dir; | 494 | QString mountDir = me->mnt_dir; |
493 | if(deviceName != "none") { | 495 | if(deviceName != "none") { |
494 | if( fsList.contains(filesystemType) == 0 | 496 | if( fsList.contains(filesystemType) == 0 |
495 | & filesystemType.find("proc",0,TRUE) == -1 | 497 | & filesystemType.find("proc",0,TRUE) == -1 |
496 | & filesystemType.find("cramfs",0,TRUE) == -1 | 498 | & filesystemType.find("cramfs",0,TRUE) == -1 |
497 | & filesystemType.find("auto",0,TRUE) == -1) | 499 | & filesystemType.find("auto",0,TRUE) == -1) |
498 | fsList << filesystemType; | 500 | fsList << filesystemType; |
499 | fileSystemTypeList << mountDir+"::"+filesystemType; | 501 | fileSystemTypeList << mountDir+"::"+filesystemType; |
500 | } | 502 | } |
501 | } | 503 | } |
502 | } | 504 | } |
503 | endmntent( mntfp ); | 505 | endmntent( mntfp ); |
504 | } | 506 | } |
505 | 507 | ||
506 | QString AdvancedFm::getFileSystemType(const QString ¤tText) { | 508 | QString AdvancedFm::getFileSystemType(const QString ¤tText) { |
507 | parsetab("/etc/mtab"); //why did TT forget filesystem type? | 509 | parsetab("/etc/mtab"); //why did TT forget filesystem type? |
508 | QString current = currentText;//.right( currentText.length()-1); | 510 | QString current = currentText;//.right( currentText.length()-1); |
509 | QString baseFs; | 511 | QString baseFs; |
510 | for ( QStringList::Iterator it = fileSystemTypeList.begin(); it != fileSystemTypeList.end(); ++it ) { | 512 | for ( QStringList::Iterator it = fileSystemTypeList.begin(); it != fileSystemTypeList.end(); ++it ) { |
511 | QString temp = (*it); | 513 | QString temp = (*it); |
512 | QString path = temp.left(temp.find("::",0,TRUE) ); | 514 | QString path = temp.left(temp.find("::",0,TRUE) ); |
513 | path = path.right( path.length()-1); | 515 | path = path.right( path.length()-1); |
514 | if(path.isEmpty()) baseFs = temp.right( temp.length() - temp.find("::",0,TRUE) - 2); | 516 | if(path.isEmpty()) baseFs = temp.right( temp.length() - temp.find("::",0,TRUE) - 2); |
515 | if( current.find( path,0,TRUE) != -1 && !path.isEmpty()) { | 517 | if( current.find( path,0,TRUE) != -1 && !path.isEmpty()) { |
516 | return temp.right( temp.length() - temp.find("::",0,TRUE) - 2); | 518 | return temp.right( temp.length() - temp.find("::",0,TRUE) - 2); |
517 | } | 519 | } |
518 | } | 520 | } |
519 | return baseFs; | 521 | return baseFs; |
520 | } | 522 | } |
521 | 523 | ||
522 | QString AdvancedFm::getDiskSpace( const QString &path) { | 524 | QString AdvancedFm::getDiskSpace( const QString &path) { |
523 | struct statfs fss; | 525 | struct statfs fss; |
524 | if ( !statfs( path.latin1(), &fss ) ) { | 526 | if ( !statfs( path.latin1(), &fss ) ) { |
525 | int blkSize = fss.f_bsize; | 527 | int blkSize = fss.f_bsize; |
526 | // int totalBlks = fs.f_blocks; | 528 | // int totalBlks = fs.f_blocks; |
527 | int availBlks = fss.f_bavail; | 529 | int availBlks = fss.f_bavail; |
528 | 530 | ||
529 | long mult = blkSize / 1024; | 531 | long mult = blkSize / 1024; |
530 | long div = 1024 / blkSize; | 532 | long div = 1024 / blkSize; |
531 | if ( !mult ) mult = 1; | 533 | if ( !mult ) mult = 1; |
532 | if ( !div ) div = 1; | 534 | if ( !div ) div = 1; |
533 | 535 | ||
534 | return QString::number(availBlks * mult / div); | 536 | return QString::number(availBlks * mult / div); |
535 | } | 537 | } |
536 | return ""; | 538 | return ""; |
537 | } | 539 | } |
538 | 540 | ||
539 | 541 | ||
540 | void AdvancedFm::showFileMenu() { | 542 | void AdvancedFm::showFileMenu() { |
541 | QString curApp; | 543 | QString curApp; |
542 | curApp = CurrentView()->currentItem()->text(0); | 544 | curApp = CurrentView()->currentItem()->text(0); |
543 | 545 | ||
544 | MimeType mt( curApp ); | 546 | MimeType mt( curApp ); |
545 | const AppLnk* app = mt.application(); | 547 | const AppLnk* app = mt.application(); |
546 | QFile fi(curApp); | 548 | QFile fi(curApp); |
547 | QPopupMenu *m = new QPopupMenu(0); | 549 | QPopupMenu *m = new QPopupMenu(0); |
diff --git a/noncore/apps/advancedfm/advancedfm.h b/noncore/apps/advancedfm/advancedfm.h index 547fa7c..4eaa6d6 100644 --- a/noncore/apps/advancedfm/advancedfm.h +++ b/noncore/apps/advancedfm/advancedfm.h | |||
@@ -1,192 +1,191 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | advancedfm.h | 2 | advancedfm.h |
3 | ------------------- | 3 | ------------------- |
4 | ** Created: Sat Mar 9 23:33:09 2002 | 4 | ** Created: Sat Mar 9 23:33:09 2002 |
5 | copyright : (C) 2002 by ljp | 5 | copyright : (C) 2002 by ljp |
6 | email : ljp@llornkcor.com | 6 | email : ljp@llornkcor.com |
7 | * This program is free software; you can redistribute it and/or modify * | 7 | * This program is free software; you can redistribute it and/or modify * |
8 | * it under the terms of the GNU General Public License as published by * | 8 | * it under the terms of the GNU General Public License as published by * |
9 | * the Free Software Foundation; either version 2 of the License, or * | 9 | * the Free Software Foundation; either version 2 of the License, or * |
10 | * (at your option) any later version. * | 10 | * (at your option) any later version. * |
11 | ***************************************************************************/ | 11 | ***************************************************************************/ |
12 | #ifndef ADVANCEDFM_H | 12 | #ifndef ADVANCEDFM_H |
13 | #define ADVANCEDFM_H | 13 | #define ADVANCEDFM_H |
14 | #define QTOPIA_INTERNAL_FSLP // to get access to fileproperties | 14 | #define QTOPIA_INTERNAL_FSLP // to get access to fileproperties |
15 | #define QT_QWS_OPIE | 15 | #define QT_QWS_OPIE |
16 | 16 | ||
17 | #include <opie2/oprocess.h> | 17 | #include <opie2/oprocess.h> |
18 | #include <opie2/osplitter.h> | 18 | #include <opie2/osplitter.h> |
19 | 19 | ||
20 | #include <qpe/ir.h> | 20 | #include <qpe/ir.h> |
21 | #include <qpe/qcopenvelope_qws.h> | 21 | #include <qpe/qcopenvelope_qws.h> |
22 | 22 | ||
23 | #include <qvariant.h> | 23 | #include <qvariant.h> |
24 | #include <qdialog.h> | 24 | #include <qdialog.h> |
25 | #include <qmainwindow.h> | 25 | #include <qmainwindow.h> |
26 | #include <qstringlist.h> | 26 | #include <qstringlist.h> |
27 | #include <qdir.h> | 27 | #include <qdir.h> |
28 | #include <qstring.h> | 28 | #include <qstring.h> |
29 | #include <qpoint.h> | 29 | #include <qpoint.h> |
30 | #include <qtimer.h> | 30 | #include <qtimer.h> |
31 | #include <qpixmap.h> | 31 | #include <qpixmap.h> |
32 | 32 | ||
33 | using Opie::OSplitter; | ||
34 | 33 | ||
35 | class QVBoxLayout; | 34 | class QVBoxLayout; |
36 | class QHBoxLayout; | 35 | class QHBoxLayout; |
37 | class QGridLayout; | 36 | class QGridLayout; |
38 | class QComboBox; | 37 | class QComboBox; |
39 | class QListView; | 38 | class QListView; |
40 | class QListviewItem; | 39 | class QListviewItem; |
41 | class QLabel; | 40 | class QLabel; |
42 | class QProgressBar; | 41 | class QProgressBar; |
43 | class QSpinBox; | 42 | class QSpinBox; |
44 | class QWidget; | 43 | class QWidget; |
45 | class QPopupMenu; | 44 | class QPopupMenu; |
46 | class QFile; | 45 | class QFile; |
47 | class QListViewItem; | 46 | class QListViewItem; |
48 | class QLineEdit; | 47 | class QLineEdit; |
49 | class MenuButton; | 48 | class MenuButton; |
50 | 49 | ||
51 | class QToolButton; | 50 | class QToolButton; |
52 | class Ir; | 51 | class Ir; |
53 | 52 | ||
54 | class AdvancedFm : public QMainWindow | 53 | class AdvancedFm : public QMainWindow |
55 | { | 54 | { |
56 | Q_OBJECT | 55 | Q_OBJECT |
57 | public: | 56 | public: |
58 | static QString appName() { return QString::fromLatin1("advancedfm"); } | 57 | static QString appName() { return QString::fromLatin1("advancedfm"); } |
59 | #ifdef NOQUICKLAUNCH | 58 | #ifdef NOQUICKLAUNCH |
60 | AdvancedFm(); | 59 | AdvancedFm(); |
61 | #else | 60 | #else |
62 | AdvancedFm(QWidget *p = 0, const char* name = 0, WFlags fl = 0); | 61 | AdvancedFm(QWidget *p = 0, const char* name = 0, WFlags fl = 0); |
63 | #endif | 62 | #endif |
64 | ~AdvancedFm(); | 63 | ~AdvancedFm(); |
65 | protected slots: | 64 | protected slots: |
66 | void slotSwitchMenu(int); | 65 | void slotSwitchMenu(int); |
67 | void selectAll(); | 66 | void selectAll(); |
68 | void addToDocs(); | 67 | void addToDocs(); |
69 | void doDirChange(); | 68 | void doDirChange(); |
70 | void mkDir(); | 69 | void mkDir(); |
71 | void del(); | 70 | void del(); |
72 | void rn(); | 71 | void rn(); |
73 | void populateView(); | 72 | void populateView(); |
74 | void rePopulate(); | 73 | void rePopulate(); |
75 | void showHidden(); | 74 | void showHidden(); |
76 | void showMenuHidden(); | 75 | void showMenuHidden(); |
77 | void writeConfig(); | 76 | void writeConfig(); |
78 | void readConfig(); | 77 | void readConfig(); |
79 | void ListClicked(QListViewItem *); | 78 | void ListClicked(QListViewItem *); |
80 | void ListPressed( int, QListViewItem *, const QPoint&, int); | 79 | void ListPressed( int, QListViewItem *, const QPoint&, int); |
81 | void makeDir(); | 80 | void makeDir(); |
82 | void doDelete(); | 81 | void doDelete(); |
83 | void tabChanged(QWidget*); | 82 | void tabChanged(QWidget*); |
84 | void cleanUp(); | 83 | void cleanUp(); |
85 | void renameIt(); | 84 | void renameIt(); |
86 | void runThis(); | 85 | void runThis(); |
87 | void runText(); | 86 | void runText(); |
88 | void filePerms(); | 87 | void filePerms(); |
89 | void doProperties(); | 88 | void doProperties(); |
90 | void runCommand(); | 89 | void runCommand(); |
91 | void runCommandStd(); | 90 | void runCommandStd(); |
92 | QStringList getPath(); | 91 | QStringList getPath(); |
93 | void mkSym(); | 92 | void mkSym(); |
94 | void switchToLocalTab(); | 93 | void switchToLocalTab(); |
95 | void switchToRemoteTab(); | 94 | void switchToRemoteTab(); |
96 | 95 | ||
97 | protected: | 96 | protected: |
98 | 97 | ||
99 | OSplitter *TabWidget; | 98 | Opie::Ui::OSplitter *TabWidget; |
100 | QCopChannel * channel; | 99 | QCopChannel * channel; |
101 | QPixmap unknownXpm; | 100 | QPixmap unknownXpm; |
102 | int whichTab; | 101 | int whichTab; |
103 | // QTabWidget *TabWidget; | 102 | // QTabWidget *TabWidget; |
104 | QWidget *tab, *tab_2, *tab_3; | 103 | QWidget *tab, *tab_2, *tab_3; |
105 | QListView *Local_View, *Remote_View; | 104 | QListView *Local_View, *Remote_View; |
106 | 105 | ||
107 | QLineEdit *currentPathEdit; | 106 | QLineEdit *currentPathEdit; |
108 | QPopupMenu *fileMenu, *localMenu, *remoteMenu, *viewMenu /*, *customDirMenu*/; | 107 | QPopupMenu *fileMenu, *localMenu, *remoteMenu, *viewMenu /*, *customDirMenu*/; |
109 | QToolButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; | 108 | QToolButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; |
110 | // QPushButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; | 109 | // QPushButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; |
111 | QDir currentDir, currentRemoteDir; | 110 | QDir currentDir, currentRemoteDir; |
112 | QComboBox *currentPathCombo; | 111 | QComboBox *currentPathCombo; |
113 | QString filterStr, s_addBookmark, s_removeBookmark; | 112 | QString filterStr, s_addBookmark, s_removeBookmark; |
114 | QListViewItem * item; | 113 | QListViewItem * item; |
115 | bool b; | 114 | bool b; |
116 | QStringList fileSystemTypeList, fsList; | 115 | QStringList fileSystemTypeList, fsList; |
117 | int currentServerConfig; | 116 | int currentServerConfig; |
118 | bool zaurusDevice; | 117 | bool zaurusDevice; |
119 | QGridLayout *tabLayout, *tabLayout_2, *tabLayout_3; | 118 | QGridLayout *tabLayout, *tabLayout_2, *tabLayout_3; |
120 | QStringList remoteDirPathStringList, localDirPathStringList; | 119 | QStringList remoteDirPathStringList, localDirPathStringList; |
121 | QLineEdit *renameBox; | 120 | QLineEdit *renameBox; |
122 | 121 | ||
123 | void init(); | 122 | void init(); |
124 | void initConnections(); | 123 | void initConnections(); |
125 | void keyReleaseEvent( QKeyEvent *); | 124 | void keyReleaseEvent( QKeyEvent *); |
126 | void keyPressEvent( QKeyEvent *); | 125 | void keyPressEvent( QKeyEvent *); |
127 | QString getFileSystemType(const QString &); | 126 | QString getFileSystemType(const QString &); |
128 | QString getDiskSpace(const QString &); | 127 | QString getDiskSpace(const QString &); |
129 | void parsetab(const QString &fileName); | 128 | void parsetab(const QString &fileName); |
130 | QString checkDiskSpace(const QString &); | 129 | QString checkDiskSpace(const QString &); |
131 | QString dealWithSymName(const QString &); | 130 | QString dealWithSymName(const QString &); |
132 | QDir *CurrentDir(); | 131 | QDir *CurrentDir(); |
133 | QDir *OtherDir(); | 132 | QDir *OtherDir(); |
134 | QListView *CurrentView(); | 133 | QListView *CurrentView(); |
135 | QListView *OtherView(); | 134 | QListView *OtherView(); |
136 | void setOtherTabCurrent(); | 135 | void setOtherTabCurrent(); |
137 | void dealWithSchmooSchmaa(QWidget *); | 136 | void dealWithSchmooSchmaa(QWidget *); |
138 | 137 | ||
139 | protected slots: | 138 | protected slots: |
140 | void openSearch(); | 139 | void openSearch(); |
141 | void dirMenuSelected(int); | 140 | void dirMenuSelected(int); |
142 | void showFileMenu(); | 141 | void showFileMenu(); |
143 | void cancelMenuTimer(); | 142 | void cancelMenuTimer(); |
144 | void homeButtonPushed(); | 143 | void homeButtonPushed(); |
145 | void docButtonPushed(); | 144 | void docButtonPushed(); |
146 | void SDButtonPushed(); | 145 | void SDButtonPushed(); |
147 | void CFButtonPushed(); | 146 | void CFButtonPushed(); |
148 | void QPEButtonPushed(); | 147 | void QPEButtonPushed(); |
149 | void upDir(); | 148 | void upDir(); |
150 | void currentPathComboChanged(); | 149 | void currentPathComboChanged(); |
151 | void copy(); | 150 | void copy(); |
152 | void copyAs(); | 151 | void copyAs(); |
153 | void copySameDir(); | 152 | void copySameDir(); |
154 | void currentPathComboActivated(const QString &); | 153 | void currentPathComboActivated(const QString &); |
155 | void fillCombo(const QString &); | 154 | void fillCombo(const QString &); |
156 | bool copyFile( const QString & , const QString & ); | 155 | bool copyFile( const QString & , const QString & ); |
157 | void move(); | 156 | void move(); |
158 | void fileStatus(); | 157 | void fileStatus(); |
159 | void doAbout(); | 158 | void doAbout(); |
160 | void doBeam(); | 159 | void doBeam(); |
161 | void fileBeamFinished( Ir *); | 160 | void fileBeamFinished( Ir *); |
162 | bool copyDirectory( const QString & , const QString & ); | 161 | bool copyDirectory( const QString & , const QString & ); |
163 | // void navigateToSelected(); | 162 | // void navigateToSelected(); |
164 | bool moveDirectory( const QString & , const QString & ); | 163 | bool moveDirectory( const QString & , const QString & ); |
165 | // void slotSwitchtoLocal(int); | 164 | // void slotSwitchtoLocal(int); |
166 | 165 | ||
167 | private: | 166 | private: |
168 | MenuButton *menuButton; | 167 | MenuButton *menuButton; |
169 | QString oldName; | 168 | QString oldName; |
170 | QTimer menuTimer; | 169 | QTimer menuTimer; |
171 | void startProcess(const QString &); | 170 | void startProcess(const QString &); |
172 | bool eventFilter( QObject * , QEvent * ); | 171 | bool eventFilter( QObject * , QEvent * ); |
173 | void cancelRename(); | 172 | void cancelRename(); |
174 | void doRename(QListView *); | 173 | void doRename(QListView *); |
175 | void okRename(); | 174 | void okRename(); |
176 | void customDirsToMenu(); | 175 | void customDirsToMenu(); |
177 | void addCustomDir(); | 176 | void addCustomDir(); |
178 | void removeCustomDir(); | 177 | void removeCustomDir(); |
179 | void gotoDirectory(const QString &); | 178 | void gotoDirectory(const QString &); |
180 | void navigateToSelected(); | 179 | void navigateToSelected(); |
181 | void findFile(const QString &); | 180 | void findFile(const QString &); |
182 | 181 | ||
183 | private slots: | 182 | private slots: |
184 | void processEnded(OProcess *); | 183 | void processEnded(Opie::Core::OProcess *); |
185 | void oprocessStderr(OProcess *, char *, int); | 184 | void oprocessStderr(Opie::Core::OProcess *, char *, int); |
186 | void gotoCustomDir(const QString &); | 185 | void gotoCustomDir(const QString &); |
187 | void qcopReceive(const QCString&, const QByteArray&); | 186 | void qcopReceive(const QCString&, const QByteArray&); |
188 | void setDocument(const QString &); | 187 | void setDocument(const QString &); |
189 | 188 | ||
190 | }; | 189 | }; |
191 | 190 | ||
192 | #endif // ADVANCEDFM_H | 191 | #endif // ADVANCEDFM_H |
diff --git a/noncore/apps/advancedfm/advancedfmData.cpp b/noncore/apps/advancedfm/advancedfmData.cpp index f791c77..73ef8f9 100644 --- a/noncore/apps/advancedfm/advancedfmData.cpp +++ b/noncore/apps/advancedfm/advancedfmData.cpp | |||
@@ -1,286 +1,287 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | advancedfmData.cpp | 2 | advancedfmData.cpp |
3 | ------------------- | 3 | ------------------- |
4 | ** Created: Mon 09-23-2002 13:24:11 | 4 | ** Created: Mon 09-23-2002 13:24:11 |
5 | copyright : (C) 2002 by ljp | 5 | copyright : (C) 2002 by ljp |
6 | email : ljp@llornkcor.com | 6 | email : ljp@llornkcor.com |
7 | * This program is free software; you can redistribute it and/or modify * | 7 | * This program is free software; you can redistribute it and/or modify * |
8 | * it under the terms of the GNU General Public License as published by * | 8 | * it under the terms of the GNU General Public License as published by * |
9 | * the Free Software Foundation; either version 2 of the License, or * | 9 | * the Free Software Foundation; either version 2 of the License, or * |
10 | * (at your option) any later version. * | 10 | * (at your option) any later version. * |
11 | ***************************************************************************/ | 11 | ***************************************************************************/ |
12 | #include "advancedfm.h" | 12 | #include "advancedfm.h" |
13 | 13 | ||
14 | #include <qpe/storage.h> | 14 | #include <qpe/storage.h> |
15 | #include <qpe/qpeapplication.h> | 15 | #include <qpe/qpeapplication.h> |
16 | #include <qpe/resource.h> | 16 | #include <qpe/resource.h> |
17 | #include <qpe/menubutton.h> | 17 | #include <qpe/menubutton.h> |
18 | 18 | ||
19 | #include <qlayout.h> | 19 | #include <qlayout.h> |
20 | #include <qhbox.h> | 20 | #include <qhbox.h> |
21 | #include <qmenubar.h> | 21 | #include <qmenubar.h> |
22 | #include <qcombobox.h> | 22 | #include <qcombobox.h> |
23 | #include <qtoolbutton.h> | 23 | #include <qtoolbutton.h> |
24 | #include <qlineedit.h> | 24 | #include <qlineedit.h> |
25 | #include <qlistview.h> | 25 | #include <qlistview.h> |
26 | 26 | ||
27 | #include <sys/utsname.h> | 27 | #include <sys/utsname.h> |
28 | 28 | ||
29 | 29 | ||
30 | using namespace Opie::Ui; | ||
30 | void AdvancedFm::init() { | 31 | void AdvancedFm::init() { |
31 | #if defined(QT_QWS_OPIE) | 32 | #if defined(QT_QWS_OPIE) |
32 | qDebug("<<<<<<<<<<<<<<<<<<<<<<<< OPIE!!!"); | 33 | qDebug("<<<<<<<<<<<<<<<<<<<<<<<< OPIE!!!"); |
33 | #endif | 34 | #endif |
34 | setCaption( tr( "AdvancedFm" ) ); | 35 | setCaption( tr( "AdvancedFm" ) ); |
35 | 36 | ||
36 | QVBoxLayout *layout = new QVBoxLayout( this ); | 37 | QVBoxLayout *layout = new QVBoxLayout( this ); |
37 | layout->setSpacing( 2); | 38 | layout->setSpacing( 2); |
38 | layout->setMargin( 2); | 39 | layout->setMargin( 2); |
39 | 40 | ||
40 | QMenuBar *menuBar = new QMenuBar(this); | 41 | QMenuBar *menuBar = new QMenuBar(this); |
41 | fileMenu = new QPopupMenu( this ); | 42 | fileMenu = new QPopupMenu( this ); |
42 | viewMenu = new QPopupMenu( this ); | 43 | viewMenu = new QPopupMenu( this ); |
43 | // customDirMenu = new QPopupMenu( this ); | 44 | // customDirMenu = new QPopupMenu( this ); |
44 | 45 | ||
45 | layout->addWidget( menuBar ); | 46 | layout->addWidget( menuBar ); |
46 | 47 | ||
47 | menuBar->insertItem( tr( "File" ), fileMenu); | 48 | menuBar->insertItem( tr( "File" ), fileMenu); |
48 | menuBar->insertItem( tr( "View" ), viewMenu); | 49 | menuBar->insertItem( tr( "View" ), viewMenu); |
49 | 50 | ||
50 | cdUpButton = new QToolButton( 0,"cdUpButton"); | 51 | cdUpButton = new QToolButton( 0,"cdUpButton"); |
51 | cdUpButton->setPixmap(Resource::loadPixmap("up")); | 52 | cdUpButton->setPixmap(Resource::loadPixmap("up")); |
52 | cdUpButton->setAutoRaise( true ); | 53 | cdUpButton->setAutoRaise( true ); |
53 | menuBar->insertItem( cdUpButton ); | 54 | menuBar->insertItem( cdUpButton ); |
54 | 55 | ||
55 | 56 | ||
56 | QHBox *lineBox = new QHBox( this ); | 57 | QHBox *lineBox = new QHBox( this ); |
57 | 58 | ||
58 | qpeDirButton= new QToolButton( 0,"QPEButton"); | 59 | qpeDirButton= new QToolButton( 0,"QPEButton"); |
59 | qpeDirButton->setPixmap( Resource::loadPixmap("launcher/opielogo16x16"));//,"",this,"QPEButton"); | 60 | qpeDirButton->setPixmap( Resource::loadPixmap("launcher/opielogo16x16"));//,"",this,"QPEButton"); |
60 | qpeDirButton->setAutoRaise( true ); | 61 | qpeDirButton->setAutoRaise( true ); |
61 | menuBar->insertItem( qpeDirButton ); | 62 | menuBar->insertItem( qpeDirButton ); |
62 | 63 | ||
63 | cfButton = new QToolButton( 0, "CFButton"); | 64 | cfButton = new QToolButton( 0, "CFButton"); |
64 | cfButton->setPixmap(Resource::loadPixmap("cardmon/pcmcia")); | 65 | cfButton->setPixmap(Resource::loadPixmap("cardmon/pcmcia")); |
65 | cfButton->setAutoRaise( true ); | 66 | cfButton->setAutoRaise( true ); |
66 | menuBar->insertItem( cfButton ); | 67 | menuBar->insertItem( cfButton ); |
67 | 68 | ||
68 | sdButton = new QToolButton( 0, "SDButton"); | 69 | sdButton = new QToolButton( 0, "SDButton"); |
69 | sdButton->setPixmap(Resource::loadPixmap("advancedfm/sdcard")); | 70 | sdButton->setPixmap(Resource::loadPixmap("advancedfm/sdcard")); |
70 | sdButton->setAutoRaise( true ); | 71 | sdButton->setAutoRaise( true ); |
71 | menuBar->insertItem( sdButton ); | 72 | menuBar->insertItem( sdButton ); |
72 | 73 | ||
73 | docButton = new QToolButton( 0,"docsButton"); | 74 | docButton = new QToolButton( 0,"docsButton"); |
74 | docButton->setPixmap(Resource::loadPixmap("DocsIcon")); | 75 | docButton->setPixmap(Resource::loadPixmap("DocsIcon")); |
75 | docButton->setAutoRaise( true ); | 76 | docButton->setAutoRaise( true ); |
76 | menuBar->insertItem( docButton ); | 77 | menuBar->insertItem( docButton ); |
77 | 78 | ||
78 | homeButton = new QToolButton( 0, "homeButton"); | 79 | homeButton = new QToolButton( 0, "homeButton"); |
79 | homeButton->setPixmap(Resource::loadPixmap("home")); | 80 | homeButton->setPixmap(Resource::loadPixmap("home")); |
80 | homeButton->setAutoRaise( true ); | 81 | homeButton->setAutoRaise( true ); |
81 | menuBar->insertItem( homeButton ); | 82 | menuBar->insertItem( homeButton ); |
82 | 83 | ||
83 | fileMenu->insertItem( tr( "Show Hidden Files" ), this, SLOT( showMenuHidden() )); | 84 | fileMenu->insertItem( tr( "Show Hidden Files" ), this, SLOT( showMenuHidden() )); |
84 | fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); | 85 | fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); |
85 | fileMenu->insertSeparator(); | 86 | fileMenu->insertSeparator(); |
86 | fileMenu->insertItem( tr( "File Search" ), this, SLOT( openSearch() )); | 87 | fileMenu->insertItem( tr( "File Search" ), this, SLOT( openSearch() )); |
87 | fileMenu->insertSeparator(); | 88 | fileMenu->insertSeparator(); |
88 | fileMenu->insertItem( tr( "Make Directory" ), this, SLOT( mkDir() )); | 89 | fileMenu->insertItem( tr( "Make Directory" ), this, SLOT( mkDir() )); |
89 | fileMenu->insertItem( tr( "Rename" ), this, SLOT( rn() )); | 90 | fileMenu->insertItem( tr( "Rename" ), this, SLOT( rn() )); |
90 | fileMenu->insertItem( tr( "Run Command" ), this, SLOT( runCommandStd() )); | 91 | fileMenu->insertItem( tr( "Run Command" ), this, SLOT( runCommandStd() )); |
91 | fileMenu->insertItem( tr( "Run Command with Output" ), this, SLOT( runCommand() )); | 92 | fileMenu->insertItem( tr( "Run Command with Output" ), this, SLOT( runCommand() )); |
92 | fileMenu->insertSeparator(); | 93 | fileMenu->insertSeparator(); |
93 | fileMenu->insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); | 94 | fileMenu->insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); |
94 | fileMenu->insertItem( tr( "Select All" ), this, SLOT( selectAll() )); | 95 | fileMenu->insertItem( tr( "Select All" ), this, SLOT( selectAll() )); |
95 | fileMenu->insertItem( tr( "Add To Documents" ), this, SLOT( addToDocs() )); | 96 | fileMenu->insertItem( tr( "Add To Documents" ), this, SLOT( addToDocs() )); |
96 | fileMenu->insertItem( tr( "Delete" ), this, SLOT( del() )); | 97 | fileMenu->insertItem( tr( "Delete" ), this, SLOT( del() )); |
97 | fileMenu->setCheckable(TRUE); | 98 | fileMenu->setCheckable(TRUE); |
98 | 99 | ||
99 | viewMenu->insertItem( tr( "Switch to View 1" ), this, SLOT( switchToLocalTab())); | 100 | viewMenu->insertItem( tr( "Switch to View 1" ), this, SLOT( switchToLocalTab())); |
100 | viewMenu->insertItem( tr( "Switch to View 2" ), this, SLOT( switchToRemoteTab())); | 101 | viewMenu->insertItem( tr( "Switch to View 2" ), this, SLOT( switchToRemoteTab())); |
101 | // viewMenu->insertSeparator(); | 102 | // viewMenu->insertSeparator(); |
102 | // viewMenu->insertItem( tr( "About" ), this, SLOT( doAbout() )); | 103 | // viewMenu->insertItem( tr( "About" ), this, SLOT( doAbout() )); |
103 | viewMenu->setCheckable(true); | 104 | viewMenu->setCheckable(true); |
104 | viewMenu->setItemChecked( viewMenu->idAt(0), true); | 105 | viewMenu->setItemChecked( viewMenu->idAt(0), true); |
105 | viewMenu->setItemChecked( viewMenu->idAt(1), false); | 106 | viewMenu->setItemChecked( viewMenu->idAt(1), false); |
106 | 107 | ||
107 | s_addBookmark = tr("Bookmark Directory"); | 108 | s_addBookmark = tr("Bookmark Directory"); |
108 | s_removeBookmark = tr("Remove Current Directory from Bookmarks"); | 109 | s_removeBookmark = tr("Remove Current Directory from Bookmarks"); |
109 | 110 | ||
110 | // menuButton->insertItem(""); | 111 | // menuButton->insertItem(""); |
111 | 112 | ||
112 | // customDirMenu->insertItem(tr("Add This Directory")); | 113 | // customDirMenu->insertItem(tr("Add This Directory")); |
113 | // customDirMenu->insertItem(tr("Remove This Directory")); | 114 | // customDirMenu->insertItem(tr("Remove This Directory")); |
114 | // customDirMenu->insertSeparator(); | 115 | // customDirMenu->insertSeparator(); |
115 | 116 | ||
116 | menuButton = new MenuButton( lineBox ); | 117 | menuButton = new MenuButton( lineBox ); |
117 | 118 | ||
118 | menuButton->setUseLabel(false); | 119 | menuButton->setUseLabel(false); |
119 | menuButton->setMaximumWidth( 20 ); | 120 | menuButton->setMaximumWidth( 20 ); |
120 | menuButton->insertItem( s_addBookmark); | 121 | menuButton->insertItem( s_addBookmark); |
121 | menuButton->insertItem( s_removeBookmark); | 122 | menuButton->insertItem( s_removeBookmark); |
122 | menuButton->insertSeparator(); | 123 | menuButton->insertSeparator(); |
123 | menuButton->setFocusPolicy(NoFocus); | 124 | menuButton->setFocusPolicy(NoFocus); |
124 | 125 | ||
125 | customDirsToMenu(); | 126 | customDirsToMenu(); |
126 | 127 | ||
127 | currentPathCombo = new QComboBox( FALSE, lineBox, "currentPathCombo" ); | 128 | currentPathCombo = new QComboBox( FALSE, lineBox, "currentPathCombo" ); |
128 | currentPathCombo->setEditable(TRUE); | 129 | currentPathCombo->setEditable(TRUE); |
129 | currentPathCombo->lineEdit()->setText( currentDir.canonicalPath()); | 130 | currentPathCombo->lineEdit()->setText( currentDir.canonicalPath()); |
130 | currentPathCombo->setFocusPolicy(NoFocus); | 131 | currentPathCombo->setFocusPolicy(NoFocus); |
131 | layout->addWidget( lineBox ); | 132 | layout->addWidget( lineBox ); |
132 | 133 | ||
133 | 134 | ||
134 | TabWidget = new OSplitter( Horizontal, this, "TabWidget" ); | 135 | TabWidget = new OSplitter( Horizontal, this, "TabWidget" ); |
135 | // TabWidget = new QTabWidget( this, "TabWidget" ); | 136 | // TabWidget = new QTabWidget( this, "TabWidget" ); |
136 | layout->addWidget( TabWidget, 4 ); | 137 | layout->addWidget( TabWidget, 4 ); |
137 | 138 | ||
138 | tab = new QWidget( TabWidget, "tab" ); | 139 | tab = new QWidget( TabWidget, "tab" ); |
139 | tabLayout = new QGridLayout( tab ); | 140 | tabLayout = new QGridLayout( tab ); |
140 | tabLayout->setSpacing( 2); | 141 | tabLayout->setSpacing( 2); |
141 | tabLayout->setMargin( 2); | 142 | tabLayout->setMargin( 2); |
142 | 143 | ||
143 | Local_View = new QListView( tab, "Local_View" ); | 144 | Local_View = new QListView( tab, "Local_View" ); |
144 | Local_View->addColumn( tr("File"),130); | 145 | Local_View->addColumn( tr("File"),130); |
145 | Local_View->addColumn( tr("Size"),-1); | 146 | Local_View->addColumn( tr("Size"),-1); |
146 | Local_View->setColumnAlignment(1,QListView::AlignRight); | 147 | Local_View->setColumnAlignment(1,QListView::AlignRight); |
147 | Local_View->addColumn( tr("Date"),-1); | 148 | Local_View->addColumn( tr("Date"),-1); |
148 | Local_View->setColumnAlignment(2,QListView::AlignRight); | 149 | Local_View->setColumnAlignment(2,QListView::AlignRight); |
149 | Local_View->setAllColumnsShowFocus(TRUE); | 150 | Local_View->setAllColumnsShowFocus(TRUE); |
150 | Local_View->setMultiSelection( TRUE ); | 151 | Local_View->setMultiSelection( TRUE ); |
151 | Local_View->setSelectionMode(QListView::Extended); | 152 | Local_View->setSelectionMode(QListView::Extended); |
152 | Local_View->setFocusPolicy(StrongFocus); | 153 | Local_View->setFocusPolicy(StrongFocus); |
153 | Local_View->installEventFilter( this ); | 154 | Local_View->installEventFilter( this ); |
154 | 155 | ||
155 | QPEApplication::setStylusOperation( Local_View->viewport(),QPEApplication::RightOnHold); | 156 | QPEApplication::setStylusOperation( Local_View->viewport(),QPEApplication::RightOnHold); |
156 | 157 | ||
157 | tabLayout->addWidget( Local_View, 0, 0 ); | 158 | tabLayout->addWidget( Local_View, 0, 0 ); |
158 | 159 | ||
159 | TabWidget->addWidget( tab,"advancedfm/smFileBrowser.png", tr("1")); | 160 | TabWidget->addWidget( tab,"advancedfm/smFileBrowser.png", tr("1")); |
160 | // TabWidget->insertTab( tab, tr("1")); | 161 | // TabWidget->insertTab( tab, tr("1")); |
161 | 162 | ||
162 | tab_2 = new QWidget( TabWidget, "tab_2" ); | 163 | tab_2 = new QWidget( TabWidget, "tab_2" ); |
163 | tabLayout_2 = new QGridLayout( tab_2 ); | 164 | tabLayout_2 = new QGridLayout( tab_2 ); |
164 | tabLayout_2->setSpacing( 2); | 165 | tabLayout_2->setSpacing( 2); |
165 | tabLayout_2->setMargin( 2); | 166 | tabLayout_2->setMargin( 2); |
166 | 167 | ||
167 | Remote_View = new QListView( tab_2, "Remote_View" ); | 168 | Remote_View = new QListView( tab_2, "Remote_View" ); |
168 | Remote_View->addColumn( tr("File"),130); | 169 | Remote_View->addColumn( tr("File"),130); |
169 | Remote_View->addColumn( tr("Size"),-1); | 170 | Remote_View->addColumn( tr("Size"),-1); |
170 | Remote_View->setColumnAlignment(1,QListView::AlignRight); | 171 | Remote_View->setColumnAlignment(1,QListView::AlignRight); |
171 | Remote_View->addColumn( tr("Date"),-1); | 172 | Remote_View->addColumn( tr("Date"),-1); |
172 | Remote_View->setColumnAlignment(2,QListView::AlignRight); | 173 | Remote_View->setColumnAlignment(2,QListView::AlignRight); |
173 | Remote_View->setAllColumnsShowFocus(TRUE); | 174 | Remote_View->setAllColumnsShowFocus(TRUE); |
174 | Remote_View->setMultiSelection( TRUE ); | 175 | Remote_View->setMultiSelection( TRUE ); |
175 | Remote_View->setSelectionMode(QListView::Extended); | 176 | Remote_View->setSelectionMode(QListView::Extended); |
176 | Remote_View->setFocusPolicy(StrongFocus); | 177 | Remote_View->setFocusPolicy(StrongFocus); |
177 | Remote_View->installEventFilter( this ); | 178 | Remote_View->installEventFilter( this ); |
178 | 179 | ||
179 | QPEApplication::setStylusOperation( Remote_View->viewport(),QPEApplication::RightOnHold); | 180 | QPEApplication::setStylusOperation( Remote_View->viewport(),QPEApplication::RightOnHold); |
180 | 181 | ||
181 | tabLayout_2->addWidget( Remote_View, 0, 0 ); | 182 | tabLayout_2->addWidget( Remote_View, 0, 0 ); |
182 | 183 | ||
183 | TabWidget->addWidget( tab_2, "advancedfm/smFileBrowser.png",tr( "2")); | 184 | TabWidget->addWidget( tab_2, "advancedfm/smFileBrowser.png",tr( "2")); |
184 | TabWidget->setSizeChange( 370 ); | 185 | TabWidget->setSizeChange( 370 ); |
185 | // TabWidget->insertTab( tab_2, tr( "2")); | 186 | // TabWidget->insertTab( tab_2, tr( "2")); |
186 | 187 | ||
187 | /* tab_3 = new QWidget( TabWidget, "tab_3" ); | 188 | /* tab_3 = new QWidget( TabWidget, "tab_3" ); |
188 | tabLayout_3 = new QGridLayout( tab_3 ); | 189 | tabLayout_3 = new QGridLayout( tab_3 ); |
189 | tabLayout_3->setSpacing( 2); | 190 | tabLayout_3->setSpacing( 2); |
190 | tabLayout_3->setMargin( 2); | 191 | tabLayout_3->setMargin( 2); |
191 | 192 | ||
192 | 193 | ||
193 | // OFileDialog fileDialog; | 194 | // OFileDialog fileDialog; |
194 | // fileDialog; | 195 | // fileDialog; |
195 | // fileSelector = new FileSelector( "*",tab_3, "fileselector" , FALSE, FALSE); //buggy | 196 | // fileSelector = new FileSelector( "*",tab_3, "fileselector" , FALSE, FALSE); //buggy |
196 | // fileDialog = new OFileDialog("bangalow", tab_3, 4, 2, "Bungalow"); | 197 | // fileDialog = new OFileDialog("bangalow", tab_3, 4, 2, "Bungalow"); |
197 | // OFileSelector fileDialog = new OFileSelector( tab_3, 4, 2,"/"); | 198 | // OFileSelector fileDialog = new OFileSelector( tab_3, 4, 2,"/"); |
198 | 199 | ||
199 | QListView *fileTree; | 200 | QListView *fileTree; |
200 | fileTree = new QListView( tab_3, "tree" ); | 201 | fileTree = new QListView( tab_3, "tree" ); |
201 | 202 | ||
202 | 203 | ||
203 | tabLayout_3->addMultiCellWidget( fileTree, 0, 0, 0, 3 ); | 204 | tabLayout_3->addMultiCellWidget( fileTree, 0, 0, 0, 3 ); |
204 | 205 | ||
205 | TabWidget->insertTab( tab_3, tr( "Remote" ) ); | 206 | TabWidget->insertTab( tab_3, tr( "Remote" ) ); |
206 | */ | 207 | */ |
207 | 208 | ||
208 | /////////////// | 209 | /////////////// |
209 | 210 | ||
210 | if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) | 211 | if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) |
211 | zaurusDevice=TRUE; | 212 | zaurusDevice=TRUE; |
212 | else | 213 | else |
213 | zaurusDevice=FALSE; | 214 | zaurusDevice=FALSE; |
214 | 215 | ||
215 | 216 | ||
216 | if( !StorageInfo::hasSd() || !StorageInfo::hasMmc()) { | 217 | if( !StorageInfo::hasSd() || !StorageInfo::hasMmc()) { |
217 | qDebug("not have sd"); | 218 | qDebug("not have sd"); |
218 | sdButton->hide(); | 219 | sdButton->hide(); |
219 | } | 220 | } |
220 | if( !StorageInfo::hasCf() ) { | 221 | if( !StorageInfo::hasCf() ) { |
221 | qDebug("not have cf"); | 222 | qDebug("not have cf"); |
222 | cfButton->hide(); | 223 | cfButton->hide(); |
223 | } | 224 | } |
224 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 225 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
225 | currentDir.setPath( QDir::currentDirPath()); | 226 | currentDir.setPath( QDir::currentDirPath()); |
226 | 227 | ||
227 | currentRemoteDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 228 | currentRemoteDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
228 | currentRemoteDir.setPath( QDir::currentDirPath()); | 229 | currentRemoteDir.setPath( QDir::currentDirPath()); |
229 | 230 | ||
230 | // b = TRUE; | 231 | // b = TRUE; |
231 | 232 | ||
232 | filterStr="*"; | 233 | filterStr="*"; |
233 | b=FALSE; | 234 | b=FALSE; |
234 | showMenuHidden(); | 235 | showMenuHidden(); |
235 | TabWidget->setCurrentWidget(0); | 236 | TabWidget->setCurrentWidget(0); |
236 | 237 | ||
237 | } | 238 | } |
238 | 239 | ||
239 | void AdvancedFm::initConnections() | 240 | void AdvancedFm::initConnections() |
240 | { | 241 | { |
241 | 242 | ||
242 | connect( qApp,SIGNAL( aboutToQuit()), | 243 | connect( qApp,SIGNAL( aboutToQuit()), |
243 | this, SLOT( cleanUp()) ); | 244 | this, SLOT( cleanUp()) ); |
244 | connect( qpeDirButton ,SIGNAL(released()), | 245 | connect( qpeDirButton ,SIGNAL(released()), |
245 | this,SLOT( QPEButtonPushed()) ); | 246 | this,SLOT( QPEButtonPushed()) ); |
246 | connect( cfButton ,SIGNAL(released()), | 247 | connect( cfButton ,SIGNAL(released()), |
247 | this,SLOT( CFButtonPushed()) ); | 248 | this,SLOT( CFButtonPushed()) ); |
248 | connect( sdButton ,SIGNAL(released()), | 249 | connect( sdButton ,SIGNAL(released()), |
249 | this,SLOT( SDButtonPushed()) ); | 250 | this,SLOT( SDButtonPushed()) ); |
250 | connect( cdUpButton ,SIGNAL(released()), | 251 | connect( cdUpButton ,SIGNAL(released()), |
251 | this,SLOT( upDir()) ); | 252 | this,SLOT( upDir()) ); |
252 | connect( docButton,SIGNAL(released()), | 253 | connect( docButton,SIGNAL(released()), |
253 | this,SLOT( docButtonPushed()) ); | 254 | this,SLOT( docButtonPushed()) ); |
254 | connect( homeButton,SIGNAL(released()), | 255 | connect( homeButton,SIGNAL(released()), |
255 | this,SLOT( homeButtonPushed()) ); | 256 | this,SLOT( homeButtonPushed()) ); |
256 | connect( currentPathCombo, SIGNAL( activated(const QString&) ), | 257 | connect( currentPathCombo, SIGNAL( activated(const QString&) ), |
257 | this, SLOT( currentPathComboActivated(const QString&) ) ); | 258 | this, SLOT( currentPathComboActivated(const QString&) ) ); |
258 | 259 | ||
259 | connect( currentPathCombo->lineEdit(),SIGNAL(returnPressed()), | 260 | connect( currentPathCombo->lineEdit(),SIGNAL(returnPressed()), |
260 | this,SLOT(currentPathComboChanged())); | 261 | this,SLOT(currentPathComboChanged())); |
261 | 262 | ||
262 | connect( Local_View, SIGNAL( clicked(QListViewItem*)), | 263 | connect( Local_View, SIGNAL( clicked(QListViewItem*)), |
263 | this,SLOT( ListClicked(QListViewItem*)) ); | 264 | this,SLOT( ListClicked(QListViewItem*)) ); |
264 | 265 | ||
265 | connect( Local_View, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int)), | 266 | connect( Local_View, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int)), |
266 | this,SLOT( ListPressed(int,QListViewItem*,const QPoint&,int)) ); | 267 | this,SLOT( ListPressed(int,QListViewItem*,const QPoint&,int)) ); |
267 | 268 | ||
268 | connect( Local_View, SIGNAL( selectionChanged() ), SLOT( cancelMenuTimer() ) ); | 269 | connect( Local_View, SIGNAL( selectionChanged() ), SLOT( cancelMenuTimer() ) ); |
269 | 270 | ||
270 | connect( Remote_View, SIGNAL( clicked(QListViewItem*)), | 271 | connect( Remote_View, SIGNAL( clicked(QListViewItem*)), |
271 | this,SLOT( ListClicked(QListViewItem*)) ); | 272 | this,SLOT( ListClicked(QListViewItem*)) ); |
272 | connect( Remote_View, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int)), | 273 | connect( Remote_View, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int)), |
273 | this,SLOT( ListPressed(int,QListViewItem*,const QPoint&,int)) ); | 274 | this,SLOT( ListPressed(int,QListViewItem*,const QPoint&,int)) ); |
274 | 275 | ||
275 | connect( TabWidget,SIGNAL(currentChanged(QWidget*)), | 276 | connect( TabWidget,SIGNAL(currentChanged(QWidget*)), |
276 | this,SLOT(tabChanged(QWidget*))); | 277 | this,SLOT(tabChanged(QWidget*))); |
277 | 278 | ||
278 | connect( &menuTimer, SIGNAL( timeout() ), SLOT( showFileMenu() ) ); | 279 | connect( &menuTimer, SIGNAL( timeout() ), SLOT( showFileMenu() ) ); |
279 | 280 | ||
280 | connect( menuButton, SIGNAL( selected(const QString&)), SLOT(gotoCustomDir(const QString&))); | 281 | connect( menuButton, SIGNAL( selected(const QString&)), SLOT(gotoCustomDir(const QString&))); |
281 | // connect( menuButton, SIGNAL( selected(int)), SLOT( dirMenuSelected(int))); | 282 | // connect( menuButton, SIGNAL( selected(int)), SLOT( dirMenuSelected(int))); |
282 | connect( viewMenu, SIGNAL( activated(int)), this, SLOT(slotSwitchMenu(int))); | 283 | connect( viewMenu, SIGNAL( activated(int)), this, SLOT(slotSwitchMenu(int))); |
283 | // connect( customDirMenu, SIGNAL( activated(int)), this, SLOT( dirMenuSelected(int))); | 284 | // connect( customDirMenu, SIGNAL( activated(int)), this, SLOT( dirMenuSelected(int))); |
284 | 285 | ||
285 | } | 286 | } |
286 | 287 | ||
diff --git a/noncore/apps/advancedfm/advancedfmMenu.cpp b/noncore/apps/advancedfm/advancedfmMenu.cpp index 9e740d0..a694b70 100644 --- a/noncore/apps/advancedfm/advancedfmMenu.cpp +++ b/noncore/apps/advancedfm/advancedfmMenu.cpp | |||
@@ -1,836 +1,838 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | AdvancedFm.cpp | 2 | AdvancedFm.cpp |
3 | ------------------- | 3 | ------------------- |
4 | ** Created: Sat Mar 9 23:33:09 2002 | 4 | ** Created: Sat Mar 9 23:33:09 2002 |
5 | copyright : (C) 2002 by ljp | 5 | copyright : (C) 2002 by ljp |
6 | email : ljp@llornkcor.com | 6 | email : ljp@llornkcor.com |
7 | * This program is free software; you can redistribute it and/or modify * | 7 | * This program is free software; you can redistribute it and/or modify * |
8 | * it under the terms of the GNU General Public License as published by * | 8 | * it under the terms of the GNU General Public License as published by * |
9 | * the Free Software Foundation; either version 2 of the License, or * | 9 | * the Free Software Foundation; either version 2 of the License, or * |
10 | * (at your option) any later version. * | 10 | * (at your option) any later version. * |
11 | ***************************************************************************/ | 11 | ***************************************************************************/ |
12 | #include "advancedfm.h" | 12 | #include "advancedfm.h" |
13 | #include "output.h" | 13 | #include "output.h" |
14 | #include "filePermissions.h" | 14 | #include "filePermissions.h" |
15 | 15 | ||
16 | #include <qpe/lnkproperties.h> | 16 | #include <qpe/lnkproperties.h> |
17 | #include <qpe/qpeapplication.h> | 17 | #include <qpe/qpeapplication.h> |
18 | #include <qpe/applnk.h> | 18 | #include <qpe/applnk.h> |
19 | 19 | ||
20 | #include <qmessagebox.h> | 20 | #include <qmessagebox.h> |
21 | 21 | ||
22 | 22 | ||
23 | #include <qpopupmenu.h> | 23 | #include <qpopupmenu.h> |
24 | #include <qlistview.h> | 24 | #include <qlistview.h> |
25 | 25 | ||
26 | #include <errno.h> | 26 | #include <errno.h> |
27 | #include <stdlib.h> | 27 | #include <stdlib.h> |
28 | #include <unistd.h> | 28 | #include <unistd.h> |
29 | #include <sys/stat.h> | 29 | #include <sys/stat.h> |
30 | #include <dirent.h> | 30 | #include <dirent.h> |
31 | #include <sys/sendfile.h> | 31 | #include <sys/sendfile.h> |
32 | #include <fcntl.h> | 32 | #include <fcntl.h> |
33 | 33 | ||
34 | 34 | ||
35 | using namespace Opie::Core; | ||
36 | using namespace Opie::Core; | ||
35 | void AdvancedFm::doDirChange() { | 37 | void AdvancedFm::doDirChange() { |
36 | QString pathItem = CurrentView()->currentItem()->text(0); | 38 | QString pathItem = CurrentView()->currentItem()->text(0); |
37 | if( pathItem == "../") { | 39 | if( pathItem == "../") { |
38 | ListClicked( CurrentView()->currentItem()); | 40 | ListClicked( CurrentView()->currentItem()); |
39 | } else { | 41 | } else { |
40 | if( pathItem.find(" -> ",0,TRUE) != -1) | 42 | if( pathItem.find(" -> ",0,TRUE) != -1) |
41 | pathItem = dealWithSymName((const QString&)pathItem)+"/"; | 43 | pathItem = dealWithSymName((const QString&)pathItem)+"/"; |
42 | // qWarning(pathItem); | 44 | // qWarning(pathItem); |
43 | gotoDirectory( CurrentDir()->path()+"/"+pathItem.left( pathItem.length() - 1) ); | 45 | gotoDirectory( CurrentDir()->path()+"/"+pathItem.left( pathItem.length() - 1) ); |
44 | } | 46 | } |
45 | } | 47 | } |
46 | 48 | ||
47 | void AdvancedFm::showMenuHidden() { | 49 | void AdvancedFm::showMenuHidden() { |
48 | if (b) { | 50 | if (b) { |
49 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 51 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
50 | OtherDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 52 | OtherDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
51 | fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); | 53 | fileMenu->setItemChecked( fileMenu->idAt(0),TRUE); |
52 | } else { | 54 | } else { |
53 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 55 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
54 | OtherDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 56 | OtherDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
55 | fileMenu->setItemChecked( fileMenu->idAt(0),FALSE); | 57 | fileMenu->setItemChecked( fileMenu->idAt(0),FALSE); |
56 | } | 58 | } |
57 | b = !b; | 59 | b = !b; |
58 | populateView(); | 60 | populateView(); |
59 | } | 61 | } |
60 | 62 | ||
61 | void AdvancedFm::showHidden() { | 63 | void AdvancedFm::showHidden() { |
62 | if (b) { | 64 | if (b) { |
63 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 65 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
64 | OtherDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 66 | OtherDir()->setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
65 | } else { | 67 | } else { |
66 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 68 | CurrentDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
67 | OtherDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); | 69 | OtherDir()->setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden*/ | QDir::All); |
68 | } | 70 | } |
69 | populateView(); | 71 | populateView(); |
70 | } | 72 | } |
71 | 73 | ||
72 | QString AdvancedFm::dealWithSymName(const QString &fileName) { | 74 | QString AdvancedFm::dealWithSymName(const QString &fileName) { |
73 | QString strItem = fileName; | 75 | QString strItem = fileName; |
74 | return strItem.right( (strItem.length() - strItem.find("->",0,TRUE)) - 4); | 76 | return strItem.right( (strItem.length() - strItem.find("->",0,TRUE)) - 4); |
75 | } | 77 | } |
76 | 78 | ||
77 | void AdvancedFm::runThis() { | 79 | void AdvancedFm::runThis() { |
78 | if( !CurrentView()->currentItem()) return; | 80 | if( !CurrentView()->currentItem()) return; |
79 | QString fs; | 81 | QString fs; |
80 | QDir *thisDir = CurrentDir(); | 82 | QDir *thisDir = CurrentDir(); |
81 | 83 | ||
82 | QString curFile = CurrentView()->currentItem()->text(0); | 84 | QString curFile = CurrentView()->currentItem()->text(0); |
83 | QString path = thisDir->canonicalPath(); | 85 | QString path = thisDir->canonicalPath(); |
84 | 86 | ||
85 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink | 87 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink |
86 | 88 | ||
87 | curFile = dealWithSymName((const QString&)curFile); | 89 | curFile = dealWithSymName((const QString&)curFile); |
88 | 90 | ||
89 | if(curFile != "../") { | 91 | if(curFile != "../") { |
90 | 92 | ||
91 | fs = getFileSystemType((const QString &) path); | 93 | fs = getFileSystemType((const QString &) path); |
92 | QFileInfo fileInfo( path + "/" + curFile); | 94 | QFileInfo fileInfo( path + "/" + curFile); |
93 | // qDebug( fileInfo.owner()); | 95 | // qDebug( fileInfo.owner()); |
94 | 96 | ||
95 | if( (fileInfo.permission( QFileInfo::ExeUser) | 97 | if( (fileInfo.permission( QFileInfo::ExeUser) |
96 | | fileInfo.permission( QFileInfo::ExeGroup) | 98 | | fileInfo.permission( QFileInfo::ExeGroup) |
97 | | fileInfo.permission( QFileInfo::ExeOther)) // & fs.find("vfat",0,TRUE) == -1) { | 99 | | fileInfo.permission( QFileInfo::ExeOther)) // & fs.find("vfat",0,TRUE) == -1) { |
98 | | fs == "vfat" && fileInfo.filePath().contains("/bin") ) { | 100 | | fs == "vfat" && fileInfo.filePath().contains("/bin") ) { |
99 | QCopEnvelope e("QPE/System", "execute(QString)" ); | 101 | QCopEnvelope e("QPE/System", "execute(QString)" ); |
100 | e << curFile; | 102 | e << curFile; |
101 | } else { | 103 | } else { |
102 | curFile = path + "/" + curFile; | 104 | curFile = path + "/" + curFile; |
103 | DocLnk nf(curFile); | 105 | DocLnk nf(curFile); |
104 | QString execStr = nf.exec(); | 106 | QString execStr = nf.exec(); |
105 | // qDebug( execStr); | 107 | // qDebug( execStr); |
106 | if( execStr.isEmpty() ) { | 108 | if( execStr.isEmpty() ) { |
107 | } else { | 109 | } else { |
108 | nf.execute(); | 110 | nf.execute(); |
109 | } | 111 | } |
110 | } | 112 | } |
111 | } | 113 | } |
112 | } | 114 | } |
113 | 115 | ||
114 | void AdvancedFm::runText() { | 116 | void AdvancedFm::runText() { |
115 | if( !CurrentView()->currentItem()) return; | 117 | if( !CurrentView()->currentItem()) return; |
116 | QString curFile = CurrentView()->currentItem()->text(0); | 118 | QString curFile = CurrentView()->currentItem()->text(0); |
117 | if(curFile != "../") { | 119 | if(curFile != "../") { |
118 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink | 120 | if( curFile.find("@",0,TRUE) !=-1 || curFile.find("->",0,TRUE) !=-1 ) //if symlink |
119 | curFile = dealWithSymName((const QString&)curFile); | 121 | curFile = dealWithSymName((const QString&)curFile); |
120 | curFile = CurrentDir()->canonicalPath()+"/"+curFile; | 122 | curFile = CurrentDir()->canonicalPath()+"/"+curFile; |
121 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); | 123 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); |
122 | e << curFile; | 124 | e << curFile; |
123 | } | 125 | } |
124 | } | 126 | } |
125 | 127 | ||
126 | void AdvancedFm::makeDir() { | 128 | void AdvancedFm::makeDir() { |
127 | InputDialog *fileDlg; | 129 | InputDialog *fileDlg; |
128 | fileDlg = new InputDialog(this,tr("Make Directory"),TRUE, 0); | 130 | fileDlg = new InputDialog(this,tr("Make Directory"),TRUE, 0); |
129 | fileDlg->exec(); | 131 | fileDlg->exec(); |
130 | if( fileDlg->result() == 1 ) { | 132 | if( fileDlg->result() == 1 ) { |
131 | QDir *thisDir = CurrentDir(); | 133 | QDir *thisDir = CurrentDir(); |
132 | QString filename = fileDlg->LineEdit1->text(); | 134 | QString filename = fileDlg->LineEdit1->text(); |
133 | thisDir->mkdir( thisDir->canonicalPath()+"/"+filename); | 135 | thisDir->mkdir( thisDir->canonicalPath()+"/"+filename); |
134 | } | 136 | } |
135 | populateView(); | 137 | populateView(); |
136 | } | 138 | } |
137 | 139 | ||
138 | void AdvancedFm::doDelete() { | 140 | void AdvancedFm::doDelete() { |
139 | QStringList curFileList = getPath(); | 141 | QStringList curFileList = getPath(); |
140 | bool doMsg=true; | 142 | bool doMsg=true; |
141 | int count = curFileList.count(); | 143 | int count = curFileList.count(); |
142 | if( count > 0) { | 144 | if( count > 0) { |
143 | if(count > 1 ) { | 145 | if(count > 1 ) { |
144 | QString msg; | 146 | QString msg; |
145 | msg=tr("Really delete\n%1 files?").arg(count); | 147 | msg=tr("Really delete\n%1 files?").arg(count); |
146 | switch ( QMessageBox::warning(this,tr("Delete"),msg | 148 | switch ( QMessageBox::warning(this,tr("Delete"),msg |
147 | ,tr("Yes"),tr("No"),0,0,1) ) | 149 | ,tr("Yes"),tr("No"),0,0,1) ) |
148 | { | 150 | { |
149 | case 0: | 151 | case 0: |
150 | doMsg=false; | 152 | doMsg=false; |
151 | break; | 153 | break; |
152 | case 1: | 154 | case 1: |
153 | return; | 155 | return; |
154 | break; | 156 | break; |
155 | }; | 157 | }; |
156 | } | 158 | } |
157 | 159 | ||
158 | QString myFile; | 160 | QString myFile; |
159 | 161 | ||
160 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 162 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
161 | myFile = (*it); | 163 | myFile = (*it); |
162 | if( myFile.find(" -> ",0,TRUE) != -1) | 164 | if( myFile.find(" -> ",0,TRUE) != -1) |
163 | myFile = myFile.left( myFile.find(" -> ",0,TRUE)); | 165 | myFile = myFile.left( myFile.find(" -> ",0,TRUE)); |
164 | 166 | ||
165 | QString f = CurrentDir()->canonicalPath(); | 167 | QString f = CurrentDir()->canonicalPath(); |
166 | if(f.right(1).find("/",0,TRUE) == -1) | 168 | if(f.right(1).find("/",0,TRUE) == -1) |
167 | f += "/"; | 169 | f += "/"; |
168 | f += myFile; | 170 | f += myFile; |
169 | if(QDir(f).exists() && !QFileInfo(f).isSymLink() ) { | 171 | if(QDir(f).exists() && !QFileInfo(f).isSymLink() ) { |
170 | //if file is a directory | 172 | //if file is a directory |
171 | 173 | ||
172 | switch ( QMessageBox::warning( this, tr("Delete Directory?"), | 174 | switch ( QMessageBox::warning( this, tr("Delete Directory?"), |
173 | tr("Really delete %1\nand all it's contents ?" ).arg( f ) , | 175 | tr("Really delete %1\nand all it's contents ?" ).arg( f ) , |
174 | tr("Yes"), tr("No"), 0, 0, 1) ) { | 176 | tr("Yes"), tr("No"), 0, 0, 1) ) { |
175 | case 0: | 177 | case 0: |
176 | { | 178 | { |
177 | f=f.left(f.length()-1); | 179 | f=f.left(f.length()-1); |
178 | QString cmd="rm -rf "+f; | 180 | QString cmd="rm -rf "+f; |
179 | startProcess( (const QString)cmd.latin1() ); | 181 | startProcess( (const QString)cmd.latin1() ); |
180 | populateView(); | 182 | populateView(); |
181 | } | 183 | } |
182 | break; | 184 | break; |
183 | case 1: | 185 | case 1: |
184 | // exit | 186 | // exit |
185 | break; | 187 | break; |
186 | }; | 188 | }; |
187 | 189 | ||
188 | } else { | 190 | } else { |
189 | if(doMsg) { | 191 | if(doMsg) { |
190 | switch ( QMessageBox::warning(this,tr("Delete"), | 192 | switch ( QMessageBox::warning(this,tr("Delete"), |
191 | tr("Really delete\n%1?").arg( myFile ), | 193 | tr("Really delete\n%1?").arg( myFile ), |
192 | tr("Yes"), tr("No"), 0, 0, 1) ) { | 194 | tr("Yes"), tr("No"), 0, 0, 1) ) { |
193 | case 1: | 195 | case 1: |
194 | return; | 196 | return; |
195 | break; | 197 | break; |
196 | }; | 198 | }; |
197 | } | 199 | } |
198 | 200 | ||
199 | QString cmd="rm "+f; | 201 | QString cmd="rm "+f; |
200 | QFile file(f); | 202 | QFile file(f); |
201 | QFileInfo fi(myFile); | 203 | QFileInfo fi(myFile); |
202 | if( fi.fileName().find("../",0,TRUE)==-1) { | 204 | if( fi.fileName().find("../",0,TRUE)==-1) { |
203 | // qDebug("remove link files "+myFile); | 205 | // qDebug("remove link files "+myFile); |
204 | 206 | ||
205 | // DocLnk lnk(f); | 207 | // DocLnk lnk(f); |
206 | DocLnk *lnk; | 208 | DocLnk *lnk; |
207 | lnk = new DocLnk(f); | 209 | lnk = new DocLnk(f); |
208 | // qDebug("Deleting doclnk " + lnk->linkFile()); | 210 | // qDebug("Deleting doclnk " + lnk->linkFile()); |
209 | if(lnk->isValid()) | 211 | if(lnk->isValid()) |
210 | lnk->removeLinkFile(); | 212 | lnk->removeLinkFile(); |
211 | // delete lnk; | 213 | // delete lnk; |
212 | file.remove(); | 214 | file.remove(); |
213 | } | 215 | } |
214 | } | 216 | } |
215 | } | 217 | } |
216 | } | 218 | } |
217 | populateView(); | 219 | populateView(); |
218 | } | 220 | } |
219 | 221 | ||
220 | void AdvancedFm::filePerms() { | 222 | void AdvancedFm::filePerms() { |
221 | QStringList curFileList = getPath(); | 223 | QStringList curFileList = getPath(); |
222 | QString filePath; | 224 | QString filePath; |
223 | 225 | ||
224 | filePath = CurrentDir()->canonicalPath()+"/"; | 226 | filePath = CurrentDir()->canonicalPath()+"/"; |
225 | 227 | ||
226 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 228 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
227 | filePermissions *filePerm; | 229 | filePermissions *filePerm; |
228 | filePerm = new filePermissions(this, "Permissions",true,0,(const QString &)(filePath+*it)); | 230 | filePerm = new filePermissions(this, "Permissions",true,0,(const QString &)(filePath+*it)); |
229 | QPEApplication::execDialog( filePerm ); | 231 | QPEApplication::execDialog( filePerm ); |
230 | if( filePerm ) | 232 | if( filePerm ) |
231 | delete filePerm; | 233 | delete filePerm; |
232 | } | 234 | } |
233 | populateView(); | 235 | populateView(); |
234 | } | 236 | } |
235 | 237 | ||
236 | void AdvancedFm::doProperties() { | 238 | void AdvancedFm::doProperties() { |
237 | #if defined(QT_QWS_OPIE) | 239 | #if defined(QT_QWS_OPIE) |
238 | 240 | ||
239 | QStringList curFileList = getPath(); | 241 | QStringList curFileList = getPath(); |
240 | 242 | ||
241 | QString filePath; | 243 | QString filePath; |
242 | filePath = CurrentDir()->canonicalPath()+"/"; | 244 | filePath = CurrentDir()->canonicalPath()+"/"; |
243 | 245 | ||
244 | // qDebug("%d",curFileList.count()); | 246 | // qDebug("%d",curFileList.count()); |
245 | 247 | ||
246 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 248 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
247 | // qDebug((filePath+*it)); | 249 | // qDebug((filePath+*it)); |
248 | DocLnk lnk( (filePath+*it)); | 250 | DocLnk lnk( (filePath+*it)); |
249 | LnkProperties prop( &lnk ); | 251 | LnkProperties prop( &lnk ); |
250 | QPEApplication::execDialog( &prop ); | 252 | QPEApplication::execDialog( &prop ); |
251 | } | 253 | } |
252 | #endif | 254 | #endif |
253 | 255 | ||
254 | } | 256 | } |
255 | 257 | ||
256 | void AdvancedFm::upDir() { | 258 | void AdvancedFm::upDir() { |
257 | QDir *thisDir = CurrentDir(); | 259 | QDir *thisDir = CurrentDir(); |
258 | QString current = thisDir->canonicalPath(); | 260 | QString current = thisDir->canonicalPath(); |
259 | QDir dir(current); | 261 | QDir dir(current); |
260 | dir.cdUp(); | 262 | dir.cdUp(); |
261 | current = dir.canonicalPath(); | 263 | current = dir.canonicalPath(); |
262 | chdir( current.latin1() ); | 264 | chdir( current.latin1() ); |
263 | thisDir->cd( current, TRUE); | 265 | thisDir->cd( current, TRUE); |
264 | 266 | ||
265 | populateView(); | 267 | populateView(); |
266 | update(); | 268 | update(); |
267 | } | 269 | } |
268 | 270 | ||
269 | void AdvancedFm::copy() { | 271 | void AdvancedFm::copy() { |
270 | qApp->processEvents(); | 272 | qApp->processEvents(); |
271 | QStringList curFileList = getPath(); | 273 | QStringList curFileList = getPath(); |
272 | 274 | ||
273 | QDir *thisDir = CurrentDir(); | 275 | QDir *thisDir = CurrentDir(); |
274 | QDir *thatDir = OtherDir(); | 276 | QDir *thatDir = OtherDir(); |
275 | 277 | ||
276 | bool doMsg=true; | 278 | bool doMsg=true; |
277 | int count=curFileList.count(); | 279 | int count=curFileList.count(); |
278 | if( count > 0) { | 280 | if( count > 0) { |
279 | if(count > 1 ){ | 281 | if(count > 1 ){ |
280 | QString msg; | 282 | QString msg; |
281 | msg=tr("Really copy\n%1 files?").arg(count); | 283 | msg=tr("Really copy\n%1 files?").arg(count); |
282 | switch ( QMessageBox::warning(this,tr("Copy"),msg | 284 | switch ( QMessageBox::warning(this,tr("Copy"),msg |
283 | ,tr("Yes"),tr("No"),0,0,1) ) | 285 | ,tr("Yes"),tr("No"),0,0,1) ) |
284 | { | 286 | { |
285 | case 0: | 287 | case 0: |
286 | doMsg=false; | 288 | doMsg=false; |
287 | break; | 289 | break; |
288 | case 1: | 290 | case 1: |
289 | return; | 291 | return; |
290 | break; | 292 | break; |
291 | }; | 293 | }; |
292 | } | 294 | } |
293 | 295 | ||
294 | QString curFile, item, destFile; | 296 | QString curFile, item, destFile; |
295 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 297 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
296 | item=(*it); | 298 | item=(*it); |
297 | if(item.find("->",0,TRUE)) //symlink | 299 | if(item.find("->",0,TRUE)) //symlink |
298 | item = item.left(item.find("->",0,TRUE)); | 300 | item = item.left(item.find("->",0,TRUE)); |
299 | 301 | ||
300 | curFile = thisDir->canonicalPath()+"/"+ item; | 302 | curFile = thisDir->canonicalPath()+"/"+ item; |
301 | destFile = thatDir->canonicalPath()+"/"+ item; | 303 | destFile = thatDir->canonicalPath()+"/"+ item; |
302 | 304 | ||
303 | // qDebug("Destination file is "+destFile); | 305 | // qDebug("Destination file is "+destFile); |
304 | // qDebug("CurrentFile file is " + curFile); | 306 | // qDebug("CurrentFile file is " + curFile); |
305 | 307 | ||
306 | QFile f(destFile); | 308 | QFile f(destFile); |
307 | if( f.exists()) { | 309 | if( f.exists()) { |
308 | if(doMsg) { | 310 | if(doMsg) { |
309 | switch ( QMessageBox::warning(this,tr("File Exists!"), | 311 | switch ( QMessageBox::warning(this,tr("File Exists!"), |
310 | tr("%1 exists. Ok to overwrite?").arg( item ), | 312 | tr("%1 exists. Ok to overwrite?").arg( item ), |
311 | tr("Yes"),tr("No"),0,0,1) ) { | 313 | tr("Yes"),tr("No"),0,0,1) ) { |
312 | case 1: | 314 | case 1: |
313 | return; | 315 | return; |
314 | break; | 316 | break; |
315 | }; | 317 | }; |
316 | } | 318 | } |
317 | f.remove(); | 319 | f.remove(); |
318 | } | 320 | } |
319 | 321 | ||
320 | if( !copyFile( curFile, destFile) ) { | 322 | if( !copyFile( curFile, destFile) ) { |
321 | QMessageBox::message("AdvancedFm", | 323 | QMessageBox::message("AdvancedFm", |
322 | tr( "Could not copy %1 to %2").arg( curFile ).arg( destFile ) ); | 324 | tr( "Could not copy %1 to %2").arg( curFile ).arg( destFile ) ); |
323 | return; | 325 | return; |
324 | } | 326 | } |
325 | } | 327 | } |
326 | setOtherTabCurrent(); | 328 | setOtherTabCurrent(); |
327 | rePopulate(); | 329 | rePopulate(); |
328 | } | 330 | } |
329 | } | 331 | } |
330 | 332 | ||
331 | void AdvancedFm::copyAs() { | 333 | void AdvancedFm::copyAs() { |
332 | qApp->processEvents(); | 334 | qApp->processEvents(); |
333 | 335 | ||
334 | QStringList curFileList = getPath(); | 336 | QStringList curFileList = getPath(); |
335 | QString curFile, item; | 337 | QString curFile, item; |
336 | InputDialog *fileDlg; | 338 | InputDialog *fileDlg; |
337 | 339 | ||
338 | QDir *thisDir = CurrentDir(); | 340 | QDir *thisDir = CurrentDir(); |
339 | QDir *thatDir = OtherDir(); | 341 | QDir *thatDir = OtherDir(); |
340 | 342 | ||
341 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 343 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
342 | QString destFile; | 344 | QString destFile; |
343 | item=(*it); | 345 | item=(*it); |
344 | curFile = thisDir->canonicalPath()+"/"+(*it); | 346 | curFile = thisDir->canonicalPath()+"/"+(*it); |
345 | fileDlg = new InputDialog( this, tr("Copy "+curFile+" As"), TRUE, 0); | 347 | fileDlg = new InputDialog( this, tr("Copy "+curFile+" As"), TRUE, 0); |
346 | 348 | ||
347 | fileDlg->setInputText((const QString &) destFile ); | 349 | fileDlg->setInputText((const QString &) destFile ); |
348 | fileDlg->exec(); | 350 | fileDlg->exec(); |
349 | 351 | ||
350 | if( fileDlg->result() == 1 ) { | 352 | if( fileDlg->result() == 1 ) { |
351 | QString filename = fileDlg->LineEdit1->text(); | 353 | QString filename = fileDlg->LineEdit1->text(); |
352 | destFile = thatDir->canonicalPath()+"/"+filename; | 354 | destFile = thatDir->canonicalPath()+"/"+filename; |
353 | 355 | ||
354 | QFile f( destFile); | 356 | QFile f( destFile); |
355 | if( f.exists()) { | 357 | if( f.exists()) { |
356 | switch (QMessageBox::warning(this,tr("File Exists!"), | 358 | switch (QMessageBox::warning(this,tr("File Exists!"), |
357 | item+tr("\nexists. Ok to overwrite?"), | 359 | item+tr("\nexists. Ok to overwrite?"), |
358 | tr("Yes"),tr("No"),0,0,1) ) { | 360 | tr("Yes"),tr("No"),0,0,1) ) { |
359 | case 0: | 361 | case 0: |
360 | f.remove(); | 362 | f.remove(); |
361 | break; | 363 | break; |
362 | case 1: | 364 | case 1: |
363 | return; | 365 | return; |
364 | break; | 366 | break; |
365 | }; | 367 | }; |
366 | } | 368 | } |
367 | if( !copyFile( curFile, destFile) ) { | 369 | if( !copyFile( curFile, destFile) ) { |
368 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") | 370 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") |
369 | +curFile +tr("to\n")+destFile); | 371 | +curFile +tr("to\n")+destFile); |
370 | return; | 372 | return; |
371 | } | 373 | } |
372 | } | 374 | } |
373 | delete fileDlg; | 375 | delete fileDlg; |
374 | 376 | ||
375 | } | 377 | } |
376 | rePopulate(); | 378 | rePopulate(); |
377 | setOtherTabCurrent(); | 379 | setOtherTabCurrent(); |
378 | } | 380 | } |
379 | 381 | ||
380 | void AdvancedFm::copySameDir() { | 382 | void AdvancedFm::copySameDir() { |
381 | qApp->processEvents(); | 383 | qApp->processEvents(); |
382 | QStringList curFileList = getPath(); | 384 | QStringList curFileList = getPath(); |
383 | QString curFile, item, destFile; | 385 | QString curFile, item, destFile; |
384 | InputDialog *fileDlg; | 386 | InputDialog *fileDlg; |
385 | 387 | ||
386 | QDir *thisDir = CurrentDir(); | 388 | QDir *thisDir = CurrentDir(); |
387 | 389 | ||
388 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 390 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
389 | item=(*it); | 391 | item=(*it); |
390 | curFile = thisDir->canonicalPath()+"/"+ item; | 392 | curFile = thisDir->canonicalPath()+"/"+ item; |
391 | 393 | ||
392 | fileDlg = new InputDialog(this,tr("Copy ")+curFile+tr(" As"),TRUE, 0); | 394 | fileDlg = new InputDialog(this,tr("Copy ")+curFile+tr(" As"),TRUE, 0); |
393 | fileDlg->setInputText((const QString &) destFile ); | 395 | fileDlg->setInputText((const QString &) destFile ); |
394 | fileDlg->exec(); | 396 | fileDlg->exec(); |
395 | 397 | ||
396 | if( fileDlg->result() == 1 ) { | 398 | if( fileDlg->result() == 1 ) { |
397 | 399 | ||
398 | QString filename = fileDlg->LineEdit1->text(); | 400 | QString filename = fileDlg->LineEdit1->text(); |
399 | destFile = thisDir->canonicalPath()+"/"+filename; | 401 | destFile = thisDir->canonicalPath()+"/"+filename; |
400 | 402 | ||
401 | QFile f(destFile); | 403 | QFile f(destFile); |
402 | if( f.exists()) { | 404 | if( f.exists()) { |
403 | switch (QMessageBox::warning(this,tr("Delete"), | 405 | switch (QMessageBox::warning(this,tr("Delete"), |
404 | destFile+tr(" already exists.\nDo you really want to delete it?"), | 406 | destFile+tr(" already exists.\nDo you really want to delete it?"), |
405 | tr("Yes"),tr("No"),0,0,1) ) { | 407 | tr("Yes"),tr("No"),0,0,1) ) { |
406 | case 0: | 408 | case 0: |
407 | 409 | ||
408 | f.remove(); | 410 | f.remove(); |
409 | break; | 411 | break; |
410 | case 1: | 412 | case 1: |
411 | return; | 413 | return; |
412 | break; | 414 | break; |
413 | }; | 415 | }; |
414 | } | 416 | } |
415 | if(!copyFile( curFile,destFile) ) { | 417 | if(!copyFile( curFile,destFile) ) { |
416 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") | 418 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") |
417 | +curFile +tr("to\n")+destFile); | 419 | +curFile +tr("to\n")+destFile); |
418 | return; | 420 | return; |
419 | } | 421 | } |
420 | 422 | ||
421 | // qDebug("copy "+curFile+" as "+destFile); | 423 | // qDebug("copy "+curFile+" as "+destFile); |
422 | } | 424 | } |
423 | delete fileDlg; | 425 | delete fileDlg; |
424 | } | 426 | } |
425 | rePopulate(); | 427 | rePopulate(); |
426 | } | 428 | } |
427 | 429 | ||
428 | void AdvancedFm::move() { | 430 | void AdvancedFm::move() { |
429 | qApp->processEvents(); | 431 | qApp->processEvents(); |
430 | 432 | ||
431 | QStringList curFileList = getPath(); | 433 | QStringList curFileList = getPath(); |
432 | if( curFileList.count() > 0) { | 434 | if( curFileList.count() > 0) { |
433 | QString curFile, destFile, item; | 435 | QString curFile, destFile, item; |
434 | 436 | ||
435 | QDir *thisDir = CurrentDir(); | 437 | QDir *thisDir = CurrentDir(); |
436 | QDir *thatDir = OtherDir(); | 438 | QDir *thatDir = OtherDir(); |
437 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 439 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
438 | item=(*it); | 440 | item=(*it); |
439 | QString destFile = thatDir->canonicalPath(); | 441 | QString destFile = thatDir->canonicalPath(); |
440 | 442 | ||
441 | if(destFile.right(1).find("/",0,TRUE) == -1) | 443 | if(destFile.right(1).find("/",0,TRUE) == -1) |
442 | destFile+="/"; | 444 | destFile+="/"; |
443 | destFile += item; | 445 | destFile += item; |
444 | // qDebug("Destination file is "+destFile); | 446 | // qDebug("Destination file is "+destFile); |
445 | 447 | ||
446 | curFile = thisDir->canonicalPath(); | 448 | curFile = thisDir->canonicalPath(); |
447 | if(curFile.right(1).find("/",0,TRUE) == -1) | 449 | if(curFile.right(1).find("/",0,TRUE) == -1) |
448 | curFile +="/"; | 450 | curFile +="/"; |
449 | curFile+= item; | 451 | curFile+= item; |
450 | // qDebug("CurrentFile file is " + curFile); | 452 | // qDebug("CurrentFile file is " + curFile); |
451 | 453 | ||
452 | if(QFileInfo(curFile).isDir()) { | 454 | if(QFileInfo(curFile).isDir()) { |
453 | moveDirectory( curFile, destFile ); | 455 | moveDirectory( curFile, destFile ); |
454 | rePopulate(); | 456 | rePopulate(); |
455 | return; | 457 | return; |
456 | } | 458 | } |
457 | 459 | ||
458 | QFile f( curFile); | 460 | QFile f( curFile); |
459 | if( f.exists()) { | 461 | if( f.exists()) { |
460 | if( !copyFile( curFile, destFile) ) { | 462 | if( !copyFile( curFile, destFile) ) { |
461 | QMessageBox::message(tr("Note"),tr("Could not move\n")+curFile); | 463 | QMessageBox::message(tr("Note"),tr("Could not move\n")+curFile); |
462 | return; | 464 | return; |
463 | } else | 465 | } else |
464 | QFile::remove(curFile); | 466 | QFile::remove(curFile); |
465 | } | 467 | } |
466 | } | 468 | } |
467 | 469 | ||
468 | } | 470 | } |
469 | rePopulate(); | 471 | rePopulate(); |
470 | setOtherTabCurrent(); | 472 | setOtherTabCurrent(); |
471 | } | 473 | } |
472 | 474 | ||
473 | bool AdvancedFm::moveDirectory( const QString & src, const QString & dest ) { | 475 | bool AdvancedFm::moveDirectory( const QString & src, const QString & dest ) { |
474 | int err = 0; | 476 | int err = 0; |
475 | if( copyDirectory( src, dest ) ) { QString cmd = "rm -rf " + src; | 477 | if( copyDirectory( src, dest ) ) { QString cmd = "rm -rf " + src; |
476 | err = system((const char*)cmd); | 478 | err = system((const char*)cmd); |
477 | } else | 479 | } else |
478 | err = -1; | 480 | err = -1; |
479 | 481 | ||
480 | if(err!=0) { | 482 | if(err!=0) { |
481 | QMessageBox::message(tr("Note"),tr("Could not move\n") + src); | 483 | QMessageBox::message(tr("Note"),tr("Could not move\n") + src); |
482 | return false; | 484 | return false; |
483 | } | 485 | } |
484 | return true; | 486 | return true; |
485 | } | 487 | } |
486 | 488 | ||
487 | bool AdvancedFm::copyDirectory( const QString & src, const QString & dest ) { | 489 | bool AdvancedFm::copyDirectory( const QString & src, const QString & dest ) { |
488 | 490 | ||
489 | QString cmd = "/bin/cp -fpR " + src + " " + dest; | 491 | QString cmd = "/bin/cp -fpR " + src + " " + dest; |
490 | qWarning(cmd); | 492 | qWarning(cmd); |
491 | int err = system( (const char *) cmd ); | 493 | int err = system( (const char *) cmd ); |
492 | if ( err != 0 ) { | 494 | if ( err != 0 ) { |
493 | QMessageBox::message("AdvancedFm", | 495 | QMessageBox::message("AdvancedFm", |
494 | tr( "Could not copy \n%1 \nto \n%2").arg( src ).arg( dest ) ); | 496 | tr( "Could not copy \n%1 \nto \n%2").arg( src ).arg( dest ) ); |
495 | return false; | 497 | return false; |
496 | } | 498 | } |
497 | 499 | ||
498 | return true; | 500 | return true; |
499 | } | 501 | } |
500 | 502 | ||
501 | 503 | ||
502 | bool AdvancedFm::copyFile( const QString & src, const QString & dest ) { | 504 | bool AdvancedFm::copyFile( const QString & src, const QString & dest ) { |
503 | 505 | ||
504 | 506 | ||
505 | if(QFileInfo(src).isDir()) { | 507 | if(QFileInfo(src).isDir()) { |
506 | if( copyDirectory( src, dest )) { | 508 | if( copyDirectory( src, dest )) { |
507 | setOtherTabCurrent(); | 509 | setOtherTabCurrent(); |
508 | populateView(); | 510 | populateView(); |
509 | return true; | 511 | return true; |
510 | } | 512 | } |
511 | else | 513 | else |
512 | return false; | 514 | return false; |
513 | } | 515 | } |
514 | 516 | ||
515 | 517 | ||
516 | bool success = true; | 518 | bool success = true; |
517 | struct stat status; | 519 | struct stat status; |
518 | QFile srcFile(src); | 520 | QFile srcFile(src); |
519 | QFile destFile(dest); | 521 | QFile destFile(dest); |
520 | int err=0; | 522 | int err=0; |
521 | int read_fd=0; | 523 | int read_fd=0; |
522 | int write_fd=0; | 524 | int write_fd=0; |
523 | struct stat stat_buf; | 525 | struct stat stat_buf; |
524 | off_t offset = 0; | 526 | off_t offset = 0; |
525 | if(!srcFile.open( IO_ReadOnly|IO_Raw)) { | 527 | if(!srcFile.open( IO_ReadOnly|IO_Raw)) { |
526 | // qWarning("open failed"); | 528 | // qWarning("open failed"); |
527 | return success = false; | 529 | return success = false; |
528 | } | 530 | } |
529 | read_fd = srcFile.handle(); | 531 | read_fd = srcFile.handle(); |
530 | if(read_fd != -1) { | 532 | if(read_fd != -1) { |
531 | fstat (read_fd, &stat_buf); | 533 | fstat (read_fd, &stat_buf); |
532 | if( !destFile.open( IO_WriteOnly|IO_Raw ) ) { | 534 | if( !destFile.open( IO_WriteOnly|IO_Raw ) ) { |
533 | // qWarning("destfile open failed"); | 535 | // qWarning("destfile open failed"); |
534 | return success = false; | 536 | return success = false; |
535 | } | 537 | } |
536 | write_fd = destFile.handle(); | 538 | write_fd = destFile.handle(); |
537 | if(write_fd != -1) { | 539 | if(write_fd != -1) { |
538 | err = sendfile(write_fd, read_fd, &offset, stat_buf.st_size); | 540 | err = sendfile(write_fd, read_fd, &offset, stat_buf.st_size); |
539 | if( err == -1) { | 541 | if( err == -1) { |
540 | QString msg; | 542 | QString msg; |
541 | switch(err) { | 543 | switch(err) { |
542 | case EBADF : msg = "The input file was not opened for reading or the output file was not opened for writing. "; | 544 | case EBADF : msg = "The input file was not opened for reading or the output file was not opened for writing. "; |
543 | case EINVAL: msg = "Descriptor is not valid or locked. "; | 545 | case EINVAL: msg = "Descriptor is not valid or locked. "; |
544 | case ENOMEM: msg = "Insufficient memory to read from in_fd."; | 546 | case ENOMEM: msg = "Insufficient memory to read from in_fd."; |
545 | case EIO: msg = "Unspecified error while reading from in_fd."; | 547 | case EIO: msg = "Unspecified error while reading from in_fd."; |
546 | }; | 548 | }; |
547 | success = false; | 549 | success = false; |
548 | // qWarning(msg); | 550 | // qWarning(msg); |
549 | } | 551 | } |
550 | } else { | 552 | } else { |
551 | success = false; | 553 | success = false; |
552 | } | 554 | } |
553 | } else { | 555 | } else { |
554 | success = false; | 556 | success = false; |
555 | } | 557 | } |
556 | srcFile.close(); | 558 | srcFile.close(); |
557 | destFile.close(); | 559 | destFile.close(); |
558 | // Set file permissions | 560 | // Set file permissions |
559 | if( stat( (const char *) src, &status ) == 0 ) { | 561 | if( stat( (const char *) src, &status ) == 0 ) { |
560 | chmod( (const char *) dest, status.st_mode ); | 562 | chmod( (const char *) dest, status.st_mode ); |
561 | } | 563 | } |
562 | 564 | ||
563 | return success; | 565 | return success; |
564 | } | 566 | } |
565 | 567 | ||
566 | void AdvancedFm::runCommand() { | 568 | void AdvancedFm::runCommand() { |
567 | if( !CurrentView()->currentItem()) return; | 569 | if( !CurrentView()->currentItem()) return; |
568 | QDir *thisDir = CurrentDir(); | 570 | QDir *thisDir = CurrentDir(); |
569 | 571 | ||
570 | QString curFile; | 572 | QString curFile; |
571 | curFile = thisDir->canonicalPath() +"/"+ CurrentView()->currentItem()->text(0); | 573 | curFile = thisDir->canonicalPath() +"/"+ CurrentView()->currentItem()->text(0); |
572 | 574 | ||
573 | InputDialog *fileDlg; | 575 | InputDialog *fileDlg; |
574 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); | 576 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); |
575 | fileDlg->setInputText(curFile); | 577 | fileDlg->setInputText(curFile); |
576 | fileDlg->exec(); | 578 | fileDlg->exec(); |
577 | //QString command; | 579 | //QString command; |
578 | 580 | ||
579 | if( fileDlg->result() == 1 ) { | 581 | if( fileDlg->result() == 1 ) { |
580 | // qDebug(fileDlg->LineEdit1->text()); | 582 | // qDebug(fileDlg->LineEdit1->text()); |
581 | QStringList command; | 583 | QStringList command; |
582 | 584 | ||
583 | command << "/bin/sh"; | 585 | command << "/bin/sh"; |
584 | command << "-c"; | 586 | command << "-c"; |
585 | command << fileDlg->LineEdit1->text(); | 587 | command << fileDlg->LineEdit1->text(); |
586 | Output *outDlg; | 588 | Output *outDlg; |
587 | outDlg = new Output( command, this, tr("AdvancedFm Output"), true); | 589 | outDlg = new Output( command, this, tr("AdvancedFm Output"), true); |
588 | QPEApplication::execDialog( outDlg ); | 590 | QPEApplication::execDialog( outDlg ); |
589 | qApp->processEvents(); | 591 | qApp->processEvents(); |
590 | 592 | ||
591 | } | 593 | } |
592 | } | 594 | } |
593 | 595 | ||
594 | void AdvancedFm::runCommandStd() { | 596 | void AdvancedFm::runCommandStd() { |
595 | if( !CurrentView()->currentItem()) return; | 597 | if( !CurrentView()->currentItem()) return; |
596 | QString curFile; | 598 | QString curFile; |
597 | QDir *thisDir = CurrentDir(); | 599 | QDir *thisDir = CurrentDir(); |
598 | QListView *thisView = CurrentView(); | 600 | QListView *thisView = CurrentView(); |
599 | if( thisView->currentItem()) | 601 | if( thisView->currentItem()) |
600 | curFile = thisDir->canonicalPath() +"/"+ thisView->currentItem()->text(0); | 602 | curFile = thisDir->canonicalPath() +"/"+ thisView->currentItem()->text(0); |
601 | 603 | ||
602 | InputDialog *fileDlg; | 604 | InputDialog *fileDlg; |
603 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); | 605 | fileDlg = new InputDialog(this,tr("Run Command"),TRUE, 0); |
604 | fileDlg->setInputText(curFile); | 606 | fileDlg->setInputText(curFile); |
605 | fileDlg->exec(); | 607 | fileDlg->exec(); |
606 | 608 | ||
607 | if( fileDlg->result() == 1 ) { | 609 | if( fileDlg->result() == 1 ) { |
608 | qApp->processEvents(); | 610 | qApp->processEvents(); |
609 | startProcess( (const QString)fileDlg->LineEdit1->text().latin1()); | 611 | startProcess( (const QString)fileDlg->LineEdit1->text().latin1()); |
610 | } | 612 | } |
611 | } | 613 | } |
612 | 614 | ||
613 | void AdvancedFm::fileStatus() { | 615 | void AdvancedFm::fileStatus() { |
614 | if( !CurrentView()->currentItem()) return; | 616 | if( !CurrentView()->currentItem()) return; |
615 | QString curFile; | 617 | QString curFile; |
616 | curFile = CurrentView()->currentItem()->text(0); | 618 | curFile = CurrentView()->currentItem()->text(0); |
617 | 619 | ||
618 | QStringList command; | 620 | QStringList command; |
619 | command << "/bin/sh"; | 621 | command << "/bin/sh"; |
620 | command << "-c"; | 622 | command << "-c"; |
621 | command << "stat -l "+ curFile; | 623 | command << "stat -l "+ curFile; |
622 | 624 | ||
623 | Output *outDlg; | 625 | Output *outDlg; |
624 | outDlg = new Output( command, this, tr("AdvancedFm Output"), true); | 626 | outDlg = new Output( command, this, tr("AdvancedFm Output"), true); |
625 | QPEApplication::execDialog( outDlg ); | 627 | QPEApplication::execDialog( outDlg ); |
626 | qApp->processEvents(); | 628 | qApp->processEvents(); |
627 | } | 629 | } |
628 | 630 | ||
629 | 631 | ||
630 | void AdvancedFm::mkDir() { | 632 | void AdvancedFm::mkDir() { |
631 | makeDir(); | 633 | makeDir(); |
632 | } | 634 | } |
633 | 635 | ||
634 | void AdvancedFm::rn() { | 636 | void AdvancedFm::rn() { |
635 | renameIt(); | 637 | renameIt(); |
636 | } | 638 | } |
637 | 639 | ||
638 | void AdvancedFm::del() { | 640 | void AdvancedFm::del() { |
639 | doDelete(); | 641 | doDelete(); |
640 | } | 642 | } |
641 | 643 | ||
642 | void AdvancedFm::mkSym() { | 644 | void AdvancedFm::mkSym() { |
643 | QString cmd; | 645 | QString cmd; |
644 | QStringList curFileList = getPath(); | 646 | QStringList curFileList = getPath(); |
645 | if( curFileList.count() > 0) { | 647 | if( curFileList.count() > 0) { |
646 | QDir *thisDir = CurrentDir(); | 648 | QDir *thisDir = CurrentDir(); |
647 | QDir * thatDir = OtherDir(); | 649 | QDir * thatDir = OtherDir(); |
648 | 650 | ||
649 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 651 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
650 | 652 | ||
651 | QString destName = thatDir->canonicalPath()+"/"+(*it); | 653 | QString destName = thatDir->canonicalPath()+"/"+(*it); |
652 | if(destName.right(1) == "/") { | 654 | if(destName.right(1) == "/") { |
653 | destName = destName.left( destName.length() -1); | 655 | destName = destName.left( destName.length() -1); |
654 | } | 656 | } |
655 | 657 | ||
656 | QString curFile = thisDir->canonicalPath()+"/"+(*it); | 658 | QString curFile = thisDir->canonicalPath()+"/"+(*it); |
657 | 659 | ||
658 | if( curFile.right(1) == "/") { | 660 | if( curFile.right(1) == "/") { |
659 | curFile = curFile.left( curFile.length() -1); | 661 | curFile = curFile.left( curFile.length() -1); |
660 | } | 662 | } |
661 | 663 | ||
662 | cmd = "ln -s "+curFile+" "+destName; | 664 | cmd = "ln -s "+curFile+" "+destName; |
663 | // qDebug(cmd); | 665 | // qDebug(cmd); |
664 | startProcess( (const QString)cmd ); | 666 | startProcess( (const QString)cmd ); |
665 | } | 667 | } |
666 | rePopulate(); | 668 | rePopulate(); |
667 | setOtherTabCurrent(); | 669 | setOtherTabCurrent(); |
668 | } | 670 | } |
669 | } | 671 | } |
670 | 672 | ||
671 | void AdvancedFm::doBeam() { | 673 | void AdvancedFm::doBeam() { |
672 | Ir ir; | 674 | Ir ir; |
673 | if(!ir.supported()) { | 675 | if(!ir.supported()) { |
674 | } else { | 676 | } else { |
675 | QStringList curFileList = getPath(); | 677 | QStringList curFileList = getPath(); |
676 | if( curFileList.count() > 0) { | 678 | if( curFileList.count() > 0) { |
677 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 679 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
678 | QString curFile = (*it); | 680 | QString curFile = (*it); |
679 | QString curFilePath = CurrentDir()->canonicalPath()+"/"+curFile; | 681 | QString curFilePath = CurrentDir()->canonicalPath()+"/"+curFile; |
680 | if( curFilePath.right(1) == "/") { | 682 | if( curFilePath.right(1) == "/") { |
681 | curFilePath = curFilePath.left( curFilePath.length() -1); | 683 | curFilePath = curFilePath.left( curFilePath.length() -1); |
682 | } | 684 | } |
683 | Ir *file = new Ir(this, "IR"); | 685 | Ir *file = new Ir(this, "IR"); |
684 | connect(file, SIGNAL(done(Ir*)), this, SLOT( fileBeamFinished(Ir*))); | 686 | connect(file, SIGNAL(done(Ir*)), this, SLOT( fileBeamFinished(Ir*))); |
685 | file->send( curFilePath, curFile ); | 687 | file->send( curFilePath, curFile ); |
686 | } | 688 | } |
687 | } | 689 | } |
688 | } | 690 | } |
689 | } | 691 | } |
690 | 692 | ||
691 | void AdvancedFm::fileBeamFinished( Ir *) { | 693 | void AdvancedFm::fileBeamFinished( Ir *) { |
692 | QMessageBox::message( tr("Advancedfm Beam out"), tr("Ir sent.") ,tr("Ok") ); | 694 | QMessageBox::message( tr("Advancedfm Beam out"), tr("Ir sent.") ,tr("Ok") ); |
693 | } | 695 | } |
694 | 696 | ||
695 | void AdvancedFm::selectAll() { | 697 | void AdvancedFm::selectAll() { |
696 | QListView *thisView = CurrentView(); | 698 | QListView *thisView = CurrentView(); |
697 | thisView->selectAll(true); | 699 | thisView->selectAll(true); |
698 | thisView->setSelected( thisView->firstChild(),false); | 700 | thisView->setSelected( thisView->firstChild(),false); |
699 | } | 701 | } |
700 | 702 | ||
701 | void AdvancedFm::startProcess(const QString & cmd) { | 703 | void AdvancedFm::startProcess(const QString & cmd) { |
702 | QStringList command; | 704 | QStringList command; |
703 | OProcess *process; | 705 | OProcess *process; |
704 | process = new OProcess(); | 706 | process = new OProcess(); |
705 | connect(process, SIGNAL(processExited(OProcess*)), | 707 | connect(process, SIGNAL(processExited(Opie::Core::OProcess*)), |
706 | this, SLOT( processEnded(OProcess*))); | 708 | this, SLOT( processEnded(OProcess*))); |
707 | 709 | ||
708 | connect(process, SIGNAL( receivedStderr(OProcess*,char*,int)), | 710 | connect(process, SIGNAL( receivedStderr(Opie::Core::OProcess*,char*,int)), |
709 | this, SLOT( oprocessStderr(OProcess*,char*,int))); | 711 | this, SLOT( oprocessStderr(OProcess*,char*,int))); |
710 | 712 | ||
711 | command << "/bin/sh"; | 713 | command << "/bin/sh"; |
712 | command << "-c"; | 714 | command << "-c"; |
713 | command << cmd.latin1(); | 715 | command << cmd.latin1(); |
714 | *process << command; | 716 | *process << command; |
715 | if(!process->start(OProcess::NotifyOnExit, OProcess::All) ) | 717 | if(!process->start(OProcess::NotifyOnExit, OProcess::All) ) |
716 | qDebug("could not start process"); | 718 | qDebug("could not start process"); |
717 | } | 719 | } |
718 | 720 | ||
719 | void AdvancedFm::processEnded(OProcess *) { | 721 | void AdvancedFm::processEnded(OProcess *) { |
720 | rePopulate(); | 722 | rePopulate(); |
721 | } | 723 | } |
722 | 724 | ||
723 | void AdvancedFm::oprocessStderr(OProcess*, char *buffer, int ) { | 725 | void AdvancedFm::oprocessStderr(OProcess*, char *buffer, int ) { |
724 | // qWarning("received stderrt %d bytes", buflen); | 726 | // qWarning("received stderrt %d bytes", buflen); |
725 | 727 | ||
726 | QString lineStr = buffer; | 728 | QString lineStr = buffer; |
727 | QMessageBox::warning( this, tr("Error"), lineStr ,tr("Ok") ); | 729 | QMessageBox::warning( this, tr("Error"), lineStr ,tr("Ok") ); |
728 | } | 730 | } |
729 | 731 | ||
730 | bool AdvancedFm::eventFilter( QObject * o, QEvent * e ) { | 732 | bool AdvancedFm::eventFilter( QObject * o, QEvent * e ) { |
731 | if ( o->inherits( "QLineEdit" ) ) { | 733 | if ( o->inherits( "QLineEdit" ) ) { |
732 | if ( e->type() == QEvent::KeyPress ) { | 734 | if ( e->type() == QEvent::KeyPress ) { |
733 | QKeyEvent *ke = (QKeyEvent*)e; | 735 | QKeyEvent *ke = (QKeyEvent*)e; |
734 | if ( ke->key() == Key_Return || | 736 | if ( ke->key() == Key_Return || |
735 | ke->key() == Key_Enter ) { | 737 | ke->key() == Key_Enter ) { |
736 | okRename(); | 738 | okRename(); |
737 | return true; | 739 | return true; |
738 | } | 740 | } |
739 | else if ( ke->key() == Key_Escape ) { | 741 | else if ( ke->key() == Key_Escape ) { |
740 | cancelRename(); | 742 | cancelRename(); |
741 | return true; | 743 | return true; |
742 | } | 744 | } |
743 | } | 745 | } |
744 | else if ( e->type() == QEvent::FocusOut ) { | 746 | else if ( e->type() == QEvent::FocusOut ) { |
745 | cancelRename(); | 747 | cancelRename(); |
746 | return true; | 748 | return true; |
747 | } | 749 | } |
748 | } | 750 | } |
749 | if ( o->inherits( "QListView" ) ) { | 751 | if ( o->inherits( "QListView" ) ) { |
750 | if ( e->type() == QEvent::FocusIn ) { | 752 | if ( e->type() == QEvent::FocusIn ) { |
751 | if( o == Local_View) { //keep track of which view | 753 | if( o == Local_View) { //keep track of which view |
752 | whichTab=1; | 754 | whichTab=1; |
753 | } | 755 | } |
754 | else { | 756 | else { |
755 | whichTab=2; | 757 | whichTab=2; |
756 | } | 758 | } |
757 | } | 759 | } |
758 | OtherView()->setSelected( OtherView()->currentItem(), FALSE );//make sure there's correct selection | 760 | OtherView()->setSelected( OtherView()->currentItem(), FALSE );//make sure there's correct selection |
759 | } | 761 | } |
760 | 762 | ||
761 | return QWidget::eventFilter( o, e ); | 763 | return QWidget::eventFilter( o, e ); |
762 | } | 764 | } |
763 | 765 | ||
764 | 766 | ||
765 | void AdvancedFm::cancelRename() { | 767 | void AdvancedFm::cancelRename() { |
766 | // qDebug("cancel rename"); | 768 | // qDebug("cancel rename"); |
767 | QListView * view; | 769 | QListView * view; |
768 | view = CurrentView(); | 770 | view = CurrentView(); |
769 | 771 | ||
770 | bool resetFocus = view->viewport()->focusProxy() == renameBox; | 772 | bool resetFocus = view->viewport()->focusProxy() == renameBox; |
771 | delete renameBox; | 773 | delete renameBox; |
772 | renameBox = 0; | 774 | renameBox = 0; |
773 | if ( resetFocus ) { | 775 | if ( resetFocus ) { |
774 | view->viewport()->setFocusProxy( view); | 776 | view->viewport()->setFocusProxy( view); |
775 | view->setFocus(); | 777 | view->setFocus(); |
776 | } | 778 | } |
777 | } | 779 | } |
778 | 780 | ||
779 | void AdvancedFm::doRename(QListView * view) { | 781 | void AdvancedFm::doRename(QListView * view) { |
780 | if( !CurrentView()->currentItem()) return; | 782 | if( !CurrentView()->currentItem()) return; |
781 | 783 | ||
782 | QRect r = view->itemRect( view->currentItem( )); | 784 | QRect r = view->itemRect( view->currentItem( )); |
783 | r = QRect( view->viewportToContents( r.topLeft() ), r.size() ); | 785 | r = QRect( view->viewportToContents( r.topLeft() ), r.size() ); |
784 | r.setX( view->contentsX() ); | 786 | r.setX( view->contentsX() ); |
785 | 787 | ||
786 | if ( r.width() > view->visibleWidth() ) | 788 | if ( r.width() > view->visibleWidth() ) |
787 | r.setWidth( view->visibleWidth() ); | 789 | r.setWidth( view->visibleWidth() ); |
788 | 790 | ||
789 | renameBox = new QLineEdit( view->viewport(), "qt_renamebox" ); | 791 | renameBox = new QLineEdit( view->viewport(), "qt_renamebox" ); |
790 | renameBox->setFrame(true); | 792 | renameBox->setFrame(true); |
791 | 793 | ||
792 | renameBox->setText( view->currentItem()->text(0) ); | 794 | renameBox->setText( view->currentItem()->text(0) ); |
793 | 795 | ||
794 | renameBox->selectAll(); | 796 | renameBox->selectAll(); |
795 | renameBox->installEventFilter( this ); | 797 | renameBox->installEventFilter( this ); |
796 | 798 | ||
797 | view->addChild( renameBox, r.x(), r.y() ); | 799 | view->addChild( renameBox, r.x(), r.y() ); |
798 | 800 | ||
799 | renameBox->resize( r.size() ); | 801 | renameBox->resize( r.size() ); |
800 | 802 | ||
801 | view->viewport()->setFocusProxy( renameBox ); | 803 | view->viewport()->setFocusProxy( renameBox ); |
802 | 804 | ||
803 | renameBox->setFocus(); | 805 | renameBox->setFocus(); |
804 | renameBox->show(); | 806 | renameBox->show(); |
805 | } | 807 | } |
806 | 808 | ||
807 | 809 | ||
808 | void AdvancedFm::renameIt() { | 810 | void AdvancedFm::renameIt() { |
809 | if( !CurrentView()->currentItem()) return; | 811 | if( !CurrentView()->currentItem()) return; |
810 | 812 | ||
811 | QListView *thisView = CurrentView(); | 813 | QListView *thisView = CurrentView(); |
812 | oldName = thisView->currentItem()->text(0); | 814 | oldName = thisView->currentItem()->text(0); |
813 | doRename( thisView ); | 815 | doRename( thisView ); |
814 | } | 816 | } |
815 | 817 | ||
816 | void AdvancedFm::okRename() { | 818 | void AdvancedFm::okRename() { |
817 | if( !CurrentView()->currentItem()) return; | 819 | if( !CurrentView()->currentItem()) return; |
818 | 820 | ||
819 | QString newName = renameBox->text(); | 821 | QString newName = renameBox->text(); |
820 | cancelRename(); | 822 | cancelRename(); |
821 | QListView * view = CurrentView(); | 823 | QListView * view = CurrentView(); |
822 | QString path = CurrentDir()->canonicalPath() + "/"; | 824 | QString path = CurrentDir()->canonicalPath() + "/"; |
823 | oldName = path + oldName; | 825 | oldName = path + oldName; |
824 | newName = path + newName; | 826 | newName = path + newName; |
825 | if( rename( oldName.latin1(), newName.latin1())== -1) | 827 | if( rename( oldName.latin1(), newName.latin1())== -1) |
826 | QMessageBox::message(tr("Note"),tr("Could not rename")); | 828 | QMessageBox::message(tr("Note"),tr("Could not rename")); |
827 | else | 829 | else |
828 | oldName = ""; | 830 | oldName = ""; |
829 | view->takeItem( view->currentItem() ); | 831 | view->takeItem( view->currentItem() ); |
830 | delete view->currentItem(); | 832 | delete view->currentItem(); |
831 | rePopulate(); | 833 | rePopulate(); |
832 | } | 834 | } |
833 | 835 | ||
834 | void AdvancedFm::openSearch() { | 836 | void AdvancedFm::openSearch() { |
835 | QMessageBox::message(tr("Note"),tr("Not Yet Implemented")); | 837 | QMessageBox::message(tr("Note"),tr("Not Yet Implemented")); |
836 | } | 838 | } |
diff --git a/noncore/apps/advancedfm/main.cpp b/noncore/apps/advancedfm/main.cpp index 3c1a164..df0d4af 100644 --- a/noncore/apps/advancedfm/main.cpp +++ b/noncore/apps/advancedfm/main.cpp | |||
@@ -1,33 +1,22 @@ | |||
1 | 1 | ||
2 | /*************************************************************************** | 2 | /*************************************************************************** |
3 | using namespace Opie::Core; | ||
4 | using namespace Opie::Core; | ||
3 | main.cpp - description | 5 | main.cpp - description |
4 | ------------------- | 6 | ------------------- |
5 | begin : March 10, 2002 | 7 | begin : March 10, 2002 |
6 | copyright : (C) 2002 by llornkcor | 8 | copyright : (C) 2002 by llornkcor |
7 | email : ljp@llornkcor.com | 9 | email : ljp@llornkcor.com |
8 | * This program is free software; you can redistribute it and/or modify * | 10 | * This program is free software; you can redistribute it and/or modify * |
9 | * it under the terms of the GNU General Public License as published by * | 11 | * it under the terms of the GNU General Public License as published by * |
10 | * the Free Software Foundation; either version 2 of the License, or * | 12 | * the Free Software Foundation; either version 2 of the License, or * |
11 | * (at your option) any later version. * | 13 | * (at your option) any later version. * |
12 | ***************************************************************************/ | 14 | ***************************************************************************/ |
13 | 15 | ||
14 | #include "advancedfm.h" | 16 | #include "advancedfm.h" |
15 | |||
16 | #ifdef NOQUICKLAUNCH | ||
17 | |||
18 | #include <qpe/qpeapplication.h> | ||
19 | |||
20 | int main(int argc, char *argv[]) | ||
21 | { | ||
22 | QPEApplication a(argc, argv); | ||
23 | |||
24 | AdvancedFm advencedFm; | ||
25 | a.showMainWidget( &advencedFm); | ||
26 | return a.exec(); | ||
27 | } | ||
28 | #else | ||
29 | #include <opie2/oapplicationfactory.h> | 17 | #include <opie2/oapplicationfactory.h> |
30 | 18 | ||
19 | using namespace Opie::Core; | ||
20 | |||
31 | OPIE_EXPORT_APP( OApplicationFactory<AdvancedFm> ) | 21 | OPIE_EXPORT_APP( OApplicationFactory<AdvancedFm> ) |
32 | 22 | ||
33 | #endif | ||
diff --git a/noncore/apps/advancedfm/output.cpp b/noncore/apps/advancedfm/output.cpp index 0bba1d8..16a0992 100644 --- a/noncore/apps/advancedfm/output.cpp +++ b/noncore/apps/advancedfm/output.cpp | |||
@@ -1,276 +1,278 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** outputEdit.cpp | 2 | ** outputEdit.cpp |
3 | ** | 3 | ** |
4 | ** Copyright: Fri Apr 12 15:12:58 2002 L.J. Potter <ljp@llornkcor.com> | 4 | ** Copyright: Fri Apr 12 15:12:58 2002 L.J. Potter <ljp@llornkcor.com> |
5 | ****************************************************************************/ | 5 | ****************************************************************************/ |
6 | #include "output.h" | 6 | #include "output.h" |
7 | 7 | ||
8 | #include <qpe/qpeapplication.h> | 8 | #include <qpe/qpeapplication.h> |
9 | #include <qpe/applnk.h> | 9 | #include <qpe/applnk.h> |
10 | 10 | ||
11 | #include <qfile.h> | 11 | #include <qfile.h> |
12 | #include <qmultilineedit.h> | 12 | #include <qmultilineedit.h> |
13 | #include <qpushbutton.h> | 13 | #include <qpushbutton.h> |
14 | #include <qlayout.h> | 14 | #include <qlayout.h> |
15 | 15 | ||
16 | #include <errno.h> | 16 | #include <errno.h> |
17 | 17 | ||
18 | /* XPM */ | 18 | /* XPM */ |
19 | using namespace Opie::Core; | ||
20 | using namespace Opie::Core; | ||
19 | static char * filesave_xpm[] = { | 21 | static char * filesave_xpm[] = { |
20 | "16 16 78 1", | 22 | "16 16 78 1", |
21 | " c None", | 23 | " c None", |
22 | ". c #343434", | 24 | ". c #343434", |
23 | "+ c #A0A0A0", | 25 | "+ c #A0A0A0", |
24 | "@ c #565656", | 26 | "@ c #565656", |
25 | "# c #9E9E9E", | 27 | "# c #9E9E9E", |
26 | "$ c #525252", | 28 | "$ c #525252", |
27 | "% c #929292", | 29 | "% c #929292", |
28 | "& c #676767", | 30 | "& c #676767", |
29 | "* c #848484", | 31 | "* c #848484", |
30 | "= c #666666", | 32 | "= c #666666", |
31 | "- c #D8D8D8", | 33 | "- c #D8D8D8", |
32 | "; c #FFFFFF", | 34 | "; c #FFFFFF", |
33 | "> c #DBDBDB", | 35 | "> c #DBDBDB", |
34 | ", c #636363", | 36 | ", c #636363", |
35 | "' c #989898", | 37 | "' c #989898", |
36 | ") c #2D2D2D", | 38 | ") c #2D2D2D", |
37 | "! c #909090", | 39 | "! c #909090", |
38 | "~ c #AEAEAE", | 40 | "~ c #AEAEAE", |
39 | "{ c #EAEAEA", | 41 | "{ c #EAEAEA", |
40 | "] c #575757", | 42 | "] c #575757", |
41 | "^ c #585858", | 43 | "^ c #585858", |
42 | "/ c #8A8A8A", | 44 | "/ c #8A8A8A", |
43 | "( c #828282", | 45 | "( c #828282", |
44 | "_ c #6F6F6F", | 46 | "_ c #6F6F6F", |
45 | ": c #C9C9C9", | 47 | ": c #C9C9C9", |
46 | "< c #050505", | 48 | "< c #050505", |
47 | "[ c #292929", | 49 | "[ c #292929", |
48 | "} c #777777", | 50 | "} c #777777", |
49 | "| c #616161", | 51 | "| c #616161", |
50 | "1 c #3A3A3A", | 52 | "1 c #3A3A3A", |
51 | "2 c #BEBEBE", | 53 | "2 c #BEBEBE", |
52 | "3 c #2C2C2C", | 54 | "3 c #2C2C2C", |
53 | "4 c #7C7C7C", | 55 | "4 c #7C7C7C", |
54 | "5 c #F6F6F6", | 56 | "5 c #F6F6F6", |
55 | "6 c #FCFCFC", | 57 | "6 c #FCFCFC", |
56 | "7 c #6B6B6B", | 58 | "7 c #6B6B6B", |
57 | "8 c #959595", | 59 | "8 c #959595", |
58 | "9 c #4F4F4F", | 60 | "9 c #4F4F4F", |
59 | "0 c #808080", | 61 | "0 c #808080", |
60 | "a c #767676", | 62 | "a c #767676", |
61 | "b c #818181", | 63 | "b c #818181", |
62 | "c c #B8B8B8", | 64 | "c c #B8B8B8", |
63 | "d c #FBFBFB", | 65 | "d c #FBFBFB", |
64 | "e c #F9F9F9", | 66 | "e c #F9F9F9", |
65 | "f c #CCCCCC", | 67 | "f c #CCCCCC", |
66 | "g c #030303", | 68 | "g c #030303", |
67 | "h c #737373", | 69 | "h c #737373", |
68 | "i c #7A7A7A", | 70 | "i c #7A7A7A", |
69 | "j c #7E7E7E", | 71 | "j c #7E7E7E", |
70 | "k c #6A6A6A", | 72 | "k c #6A6A6A", |
71 | "l c #FAFAFA", | 73 | "l c #FAFAFA", |
72 | "m c #505050", | 74 | "m c #505050", |
73 | "n c #9D9D9D", | 75 | "n c #9D9D9D", |
74 | "o c #333333", | 76 | "o c #333333", |
75 | "p c #7B7B7B", | 77 | "p c #7B7B7B", |
76 | "q c #787878", | 78 | "q c #787878", |
77 | "r c #696969", | 79 | "r c #696969", |
78 | "s c #494949", | 80 | "s c #494949", |
79 | "t c #555555", | 81 | "t c #555555", |
80 | "u c #949494", | 82 | "u c #949494", |
81 | "v c #E6E6E6", | 83 | "v c #E6E6E6", |
82 | "w c #424242", | 84 | "w c #424242", |
83 | "x c #515151", | 85 | "x c #515151", |
84 | "y c #535353", | 86 | "y c #535353", |
85 | "z c #3E3E3E", | 87 | "z c #3E3E3E", |
86 | "A c #D4D4D4", | 88 | "A c #D4D4D4", |
87 | "B c #0C0C0C", | 89 | "B c #0C0C0C", |
88 | "C c #353535", | 90 | "C c #353535", |
89 | "D c #474747", | 91 | "D c #474747", |
90 | "E c #ECECEC", | 92 | "E c #ECECEC", |
91 | "F c #919191", | 93 | "F c #919191", |
92 | "G c #7D7D7D", | 94 | "G c #7D7D7D", |
93 | "H c #000000", | 95 | "H c #000000", |
94 | "I c #404040", | 96 | "I c #404040", |
95 | "J c #858585", | 97 | "J c #858585", |
96 | "K c #323232", | 98 | "K c #323232", |
97 | "L c #D0D0D0", | 99 | "L c #D0D0D0", |
98 | "M c #1C1C1C", | 100 | "M c #1C1C1C", |
99 | " ...+ ", | 101 | " ...+ ", |
100 | " @#$%&..+ ", | 102 | " @#$%&..+ ", |
101 | " .*=-;;>,..+ ", | 103 | " .*=-;;>,..+ ", |
102 | " ')!~;;;;;;{]..", | 104 | " ')!~;;;;;;{]..", |
103 | " ^/(-;;;;;;;_:<", | 105 | " ^/(-;;;;;;;_:<", |
104 | " [}|;;;;;;;{12$", | 106 | " [}|;;;;;;;{12$", |
105 | " #34-55;;;;678$+", | 107 | " #34-55;;;;678$+", |
106 | " 90ab=c;dd;e1fg ", | 108 | " 90ab=c;dd;e1fg ", |
107 | " [ahij((kbl0mn$ ", | 109 | " [ahij((kbl0mn$ ", |
108 | " op^q^^7r&]s/$+ ", | 110 | " op^q^^7r&]s/$+ ", |
109 | "@btu;vbwxy]zAB ", | 111 | "@btu;vbwxy]zAB ", |
110 | "CzDEvEv;;DssF$ ", | 112 | "CzDEvEv;;DssF$ ", |
111 | "G.H{E{E{IxsJ$+ ", | 113 | "G.H{E{E{IxsJ$+ ", |
112 | " +...vEKxzLM ", | 114 | " +...vEKxzLM ", |
113 | " +...z]n$ ", | 115 | " +...z]n$ ", |
114 | " +... "}; | 116 | " +... "}; |
115 | 117 | ||
116 | Output::Output( const QStringList commands, QWidget* parent, const char* name, bool modal, WFlags fl) | 118 | Output::Output( const QStringList commands, QWidget* parent, const char* name, bool modal, WFlags fl) |
117 | : QDialog( parent, name, modal, fl ) | 119 | : QDialog( parent, name, modal, fl ) |
118 | { | 120 | { |
119 | QStringList cmmds; | 121 | QStringList cmmds; |
120 | // cmmds=QStringList::split( " ", commands, false); | 122 | // cmmds=QStringList::split( " ", commands, false); |
121 | cmmds=commands; | 123 | cmmds=commands; |
122 | // qDebug("count %d", cmmds.count()); | 124 | // qDebug("count %d", cmmds.count()); |
123 | if ( !name ) | 125 | if ( !name ) |
124 | setName( tr("Output")); | 126 | setName( tr("Output")); |
125 | resize( 196, 269 ); | 127 | resize( 196, 269 ); |
126 | setCaption( name ); | 128 | setCaption( name ); |
127 | 129 | ||
128 | OutputLayout = new QGridLayout( this ); | 130 | OutputLayout = new QGridLayout( this ); |
129 | OutputLayout->setSpacing( 2); | 131 | OutputLayout->setSpacing( 2); |
130 | OutputLayout->setMargin( 2); | 132 | OutputLayout->setMargin( 2); |
131 | 133 | ||
132 | QPushButton *docButton; | 134 | QPushButton *docButton; |
133 | docButton = new QPushButton( QPixmap(( const char** ) filesave_xpm ) ,"",this,"saveButton"); | 135 | docButton = new QPushButton( QPixmap(( const char** ) filesave_xpm ) ,"",this,"saveButton"); |
134 | docButton->setFixedSize( QSize( 20, 20 ) ); | 136 | docButton->setFixedSize( QSize( 20, 20 ) ); |
135 | connect( docButton,SIGNAL(released()),this,SLOT( saveOutput() )); | 137 | connect( docButton,SIGNAL(released()),this,SLOT( saveOutput() )); |
136 | // docButton->setFlat(TRUE); | 138 | // docButton->setFlat(TRUE); |
137 | OutputLayout->addMultiCellWidget( docButton, 0,0,3,3 ); | 139 | OutputLayout->addMultiCellWidget( docButton, 0,0,3,3 ); |
138 | 140 | ||
139 | OutputEdit = new QMultiLineEdit( this, "OutputEdit" ); | 141 | OutputEdit = new QMultiLineEdit( this, "OutputEdit" ); |
140 | OutputLayout->addMultiCellWidget( OutputEdit, 1,1,0,3 ); | 142 | OutputLayout->addMultiCellWidget( OutputEdit, 1,1,0,3 ); |
141 | 143 | ||
142 | proc = new OProcess(); | 144 | proc = new OProcess(); |
143 | 145 | ||
144 | connect(proc, SIGNAL(processExited(OProcess*)), | 146 | connect(proc, SIGNAL(processExited(Opie::Core::OProcess*)), |
145 | this, SLOT( processFinished())); | 147 | this, SLOT( processFinished())); |
146 | 148 | ||
147 | connect(proc, SIGNAL(receivedStdout(OProcess*,char*,int)), | 149 | connect(proc, SIGNAL(receivedStdout(Opie::Core::OProcess*,char*,int)), |
148 | this, SLOT(commandStdout(OProcess*,char*,int))); | 150 | this, SLOT(commandStdout(OProcess*,char*,int))); |
149 | 151 | ||
150 | connect(proc, SIGNAL(receivedStderr(OProcess*,char*,int)), | 152 | connect(proc, SIGNAL(receivedStderr(Opie::Core::OProcess*,char*,int)), |
151 | this, SLOT(commandStderr(OProcess*,char*,int))); | 153 | this, SLOT(commandStderr(OProcess*,char*,int))); |
152 | 154 | ||
153 | // connect( , SIGNAL(received(const QByteArray&)), | 155 | // connect( , SIGNAL(received(const QByteArray&)), |
154 | // this, SLOT(commandStdin(const QByteArray&))); | 156 | // this, SLOT(commandStdin(const QByteArray&))); |
155 | 157 | ||
156 | // * proc << commands.latin1(); | 158 | // * proc << commands.latin1(); |
157 | for ( QStringList::Iterator it = cmmds.begin(); it != cmmds.end(); ++it ) { | 159 | for ( QStringList::Iterator it = cmmds.begin(); it != cmmds.end(); ++it ) { |
158 | qDebug( "%s", (*it).latin1() ); | 160 | qDebug( "%s", (*it).latin1() ); |
159 | * proc << (*it).latin1(); | 161 | * proc << (*it).latin1(); |
160 | } | 162 | } |
161 | 163 | ||
162 | if(!proc->start(OProcess::NotifyOnExit, OProcess::All)) { | 164 | if(!proc->start(OProcess::NotifyOnExit, OProcess::All)) { |
163 | 165 | ||
164 | OutputEdit->append(tr("Process could not start") ); | 166 | OutputEdit->append(tr("Process could not start") ); |
165 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); | 167 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); |
166 | perror("Error: "); | 168 | perror("Error: "); |
167 | QString errorMsg=tr("Error\n")+(QString)strerror(errno); | 169 | QString errorMsg=tr("Error\n")+(QString)strerror(errno); |
168 | OutputEdit->append( errorMsg); | 170 | OutputEdit->append( errorMsg); |
169 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); | 171 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); |
170 | } | 172 | } |
171 | } | 173 | } |
172 | 174 | ||
173 | Output::~Output() { | 175 | Output::~Output() { |
174 | } | 176 | } |
175 | 177 | ||
176 | void Output::saveOutput() { | 178 | void Output::saveOutput() { |
177 | 179 | ||
178 | InputDialog *fileDlg; | 180 | InputDialog *fileDlg; |
179 | fileDlg = new InputDialog(this,tr("Save output to file (name only)"),TRUE, 0); | 181 | fileDlg = new InputDialog(this,tr("Save output to file (name only)"),TRUE, 0); |
180 | fileDlg->exec(); | 182 | fileDlg->exec(); |
181 | if( fileDlg->result() == 1 ) { | 183 | if( fileDlg->result() == 1 ) { |
182 | QString filename = QPEApplication::documentDir(); | 184 | QString filename = QPEApplication::documentDir(); |
183 | if(filename.right(1).find('/') == -1) | 185 | if(filename.right(1).find('/') == -1) |
184 | filename+="/"; | 186 | filename+="/"; |
185 | QString name = fileDlg->LineEdit1->text(); | 187 | QString name = fileDlg->LineEdit1->text(); |
186 | filename+="text/plain/"+name; | 188 | filename+="text/plain/"+name; |
187 | qDebug(filename); | 189 | qDebug(filename); |
188 | 190 | ||
189 | QFile f(filename); | 191 | QFile f(filename); |
190 | f.open( IO_WriteOnly); | 192 | f.open( IO_WriteOnly); |
191 | if( f.writeBlock( OutputEdit->text(), qstrlen( OutputEdit->text()) ) != -1) { | 193 | if( f.writeBlock( OutputEdit->text(), qstrlen( OutputEdit->text()) ) != -1) { |
192 | DocLnk lnk; | 194 | DocLnk lnk; |
193 | lnk.setName(name); //sets file name | 195 | lnk.setName(name); //sets file name |
194 | lnk.setFile(filename); //sets File property | 196 | lnk.setFile(filename); //sets File property |
195 | lnk.setType("text/plain"); | 197 | lnk.setType("text/plain"); |
196 | if(!lnk.writeLink()) { | 198 | if(!lnk.writeLink()) { |
197 | qDebug("Writing doclink did not work"); | 199 | qDebug("Writing doclink did not work"); |
198 | } | 200 | } |
199 | } else | 201 | } else |
200 | qWarning("Could not write file"); | 202 | qWarning("Could not write file"); |
201 | f.close(); | 203 | f.close(); |
202 | } | 204 | } |
203 | } | 205 | } |
204 | 206 | ||
205 | void Output::commandStdout(OProcess*, char *buffer, int buflen) { | 207 | void Output::commandStdout(OProcess*, char *buffer, int buflen) { |
206 | qWarning("received stdout %d bytes", buflen); | 208 | qWarning("received stdout %d bytes", buflen); |
207 | 209 | ||
208 | // QByteArray data(buflen); | 210 | // QByteArray data(buflen); |
209 | // data.fill(*buffer, buflen); | 211 | // data.fill(*buffer, buflen); |
210 | // for (uint i = 0; i < data.count(); i++ ) { | 212 | // for (uint i = 0; i < data.count(); i++ ) { |
211 | // printf("%c", buffer[i] ); | 213 | // printf("%c", buffer[i] ); |
212 | // } | 214 | // } |
213 | // printf("\n"); | 215 | // printf("\n"); |
214 | 216 | ||
215 | QString lineStr = buffer; | 217 | QString lineStr = buffer; |
216 | lineStr=lineStr.left(lineStr.length()-1); | 218 | lineStr=lineStr.left(lineStr.length()-1); |
217 | OutputEdit->append(lineStr); | 219 | OutputEdit->append(lineStr); |
218 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); | 220 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); |
219 | } | 221 | } |
220 | 222 | ||
221 | 223 | ||
222 | void Output::commandStdin( const QByteArray &data) { | 224 | void Output::commandStdin( const QByteArray &data) { |
223 | qWarning("received stdin %d bytes", data.size()); | 225 | qWarning("received stdin %d bytes", data.size()); |
224 | // recieved data from the io layer goes to sz | 226 | // recieved data from the io layer goes to sz |
225 | proc->writeStdin(data.data(), data.size()); | 227 | proc->writeStdin(data.data(), data.size()); |
226 | } | 228 | } |
227 | 229 | ||
228 | void Output::commandStderr(OProcess*, char *buffer, int buflen) { | 230 | void Output::commandStderr(OProcess*, char *buffer, int buflen) { |
229 | qWarning("received stderrt %d bytes", buflen); | 231 | qWarning("received stderrt %d bytes", buflen); |
230 | 232 | ||
231 | QString lineStr = buffer; | 233 | QString lineStr = buffer; |
232 | // lineStr=lineStr.left(lineStr.length()-1); | 234 | // lineStr=lineStr.left(lineStr.length()-1); |
233 | OutputEdit->append(lineStr); | 235 | OutputEdit->append(lineStr); |
234 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); | 236 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); |
235 | } | 237 | } |
236 | 238 | ||
237 | void Output::processFinished() { | 239 | void Output::processFinished() { |
238 | 240 | ||
239 | delete proc; | 241 | delete proc; |
240 | OutputEdit->append( tr("\nFinished\n") ); | 242 | OutputEdit->append( tr("\nFinished\n") ); |
241 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); | 243 | OutputEdit->setCursorPosition( OutputEdit->numLines() + 1,0,FALSE); |
242 | // close(); | 244 | // close(); |
243 | // disconnect( layer(), SIGNAL(received(const QByteArray&)), | 245 | // disconnect( layer(), SIGNAL(received(const QByteArray&)), |
244 | // this, SLOT(commandStdin(const QByteArray&))); | 246 | // this, SLOT(commandStdin(const QByteArray&))); |
245 | } | 247 | } |
246 | 248 | ||
247 | //============================== | 249 | //============================== |
248 | 250 | ||
249 | InputDialog::InputDialog( QWidget* parent, const char* name, bool modal, WFlags fl ) | 251 | InputDialog::InputDialog( QWidget* parent, const char* name, bool modal, WFlags fl ) |
250 | : QDialog( parent, name, modal, fl ) | 252 | : QDialog( parent, name, modal, fl ) |
251 | { | 253 | { |
252 | if ( !name ) | 254 | if ( !name ) |
253 | setName( "InputDialog" ); | 255 | setName( "InputDialog" ); |
254 | resize( 234, 50 ); | 256 | resize( 234, 50 ); |
255 | setMaximumSize( QSize( 240, 50 ) ); | 257 | setMaximumSize( QSize( 240, 50 ) ); |
256 | setCaption( tr(name ) ); | 258 | setCaption( tr(name ) ); |
257 | 259 | ||
258 | LineEdit1 = new QLineEdit( this, "LineEdit1" ); | 260 | LineEdit1 = new QLineEdit( this, "LineEdit1" ); |
259 | LineEdit1->setGeometry( QRect( 10, 10, 216, 22 ) ); | 261 | LineEdit1->setGeometry( QRect( 10, 10, 216, 22 ) ); |
260 | LineEdit1->setFocus(); | 262 | LineEdit1->setFocus(); |
261 | LineEdit1->setFocus(); | 263 | LineEdit1->setFocus(); |
262 | connect(LineEdit1,SIGNAL(returnPressed()),this,SLOT(returned() )); | 264 | connect(LineEdit1,SIGNAL(returnPressed()),this,SLOT(returned() )); |
263 | } | 265 | } |
264 | 266 | ||
265 | InputDialog::~InputDialog() { | 267 | InputDialog::~InputDialog() { |
266 | inputText = LineEdit1->text(); | 268 | inputText = LineEdit1->text(); |
267 | } | 269 | } |
268 | 270 | ||
269 | void InputDialog::setInputText(const QString &string) { | 271 | void InputDialog::setInputText(const QString &string) { |
270 | LineEdit1->setText( string); | 272 | LineEdit1->setText( string); |
271 | } | 273 | } |
272 | 274 | ||
273 | void InputDialog::returned() { | 275 | void InputDialog::returned() { |
274 | inputText = LineEdit1->text(); | 276 | inputText = LineEdit1->text(); |
275 | this->accept(); | 277 | this->accept(); |
276 | } | 278 | } |
diff --git a/noncore/apps/advancedfm/output.h b/noncore/apps/advancedfm/output.h index 26c0fa0..37ba57d 100644 --- a/noncore/apps/advancedfm/output.h +++ b/noncore/apps/advancedfm/output.h | |||
@@ -1,65 +1,65 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** Form interface generated from reading ui file 'outputEdit.ui' | 2 | ** Form interface generated from reading ui file 'outputEdit.ui' |
3 | ** | 3 | ** |
4 | ** Created: Fri Apr 12 15:12:44 2002 | 4 | ** Created: Fri Apr 12 15:12:44 2002 |
5 | ** by: The User Interface Compiler (uic) | 5 | ** by: The User Interface Compiler (uic) |
6 | ** | 6 | ** |
7 | ** WARNING! All changes made in this file will be lost! | 7 | ** WARNING! All changes made in this file will be lost! |
8 | ****************************************************************************/ | 8 | ****************************************************************************/ |
9 | #ifndef OUTPUT_H | 9 | #ifndef OUTPUT_H |
10 | #define OUTPUT_H | 10 | #define OUTPUT_H |
11 | 11 | ||
12 | #include <qvariant.h> | 12 | #include <qvariant.h> |
13 | #include <qdialog.h> | 13 | #include <qdialog.h> |
14 | #include <qcstring.h> | 14 | #include <qcstring.h> |
15 | #include <qstringlist.h> | 15 | #include <qstringlist.h> |
16 | #include <qlineedit.h> | 16 | #include <qlineedit.h> |
17 | #include <qwhatsthis.h> | 17 | #include <qwhatsthis.h> |
18 | 18 | ||
19 | #include <opie2/oprocess.h> | 19 | #include <opie2/oprocess.h> |
20 | 20 | ||
21 | class QVBoxLayout; | 21 | class QVBoxLayout; |
22 | class QHBoxLayout; | 22 | class QHBoxLayout; |
23 | class QGridLayout; | 23 | class QGridLayout; |
24 | class QMultiLineEdit; | 24 | class QMultiLineEdit; |
25 | 25 | ||
26 | class Output : public QDialog | 26 | class Output : public QDialog |
27 | { | 27 | { |
28 | Q_OBJECT | 28 | Q_OBJECT |
29 | 29 | ||
30 | public: | 30 | public: |
31 | Output(const QStringList commands=0, QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); | 31 | Output(const QStringList commands=0, QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); |
32 | ~Output(); | 32 | ~Output(); |
33 | 33 | ||
34 | QMultiLineEdit* OutputEdit; | 34 | QMultiLineEdit* OutputEdit; |
35 | 35 | ||
36 | protected: | 36 | protected: |
37 | QGridLayout* OutputLayout; | 37 | QGridLayout* OutputLayout; |
38 | OProcess *proc; | 38 | Opie::Core::OProcess *proc; |
39 | protected slots: | 39 | protected slots: |
40 | void saveOutput(); | 40 | void saveOutput(); |
41 | void commandStdout(OProcess*, char *, int); | 41 | void commandStdout(Opie::Core::OProcess*, char *, int); |
42 | void commandStdin(const QByteArray &); | 42 | void commandStdin(const QByteArray &); |
43 | void commandStderr(OProcess*, char *, int); | 43 | void commandStderr(Opie::Core::OProcess*, char *, int); |
44 | void processFinished(); | 44 | void processFinished(); |
45 | private: | 45 | private: |
46 | QString cmmd; | 46 | QString cmmd; |
47 | 47 | ||
48 | }; | 48 | }; |
49 | 49 | ||
50 | class InputDialog : public QDialog | 50 | class InputDialog : public QDialog |
51 | { | 51 | { |
52 | Q_OBJECT | 52 | Q_OBJECT |
53 | 53 | ||
54 | public: | 54 | public: |
55 | InputDialog( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); | 55 | InputDialog( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); |
56 | ~InputDialog(); | 56 | ~InputDialog(); |
57 | QString inputText; | 57 | QString inputText; |
58 | QLineEdit* LineEdit1; | 58 | QLineEdit* LineEdit1; |
59 | void setInputText(const QString &); | 59 | void setInputText(const QString &); |
60 | private slots: | 60 | private slots: |
61 | void returned(); | 61 | void returned(); |
62 | 62 | ||
63 | }; | 63 | }; |
64 | 64 | ||
65 | #endif // OUTPUT_H | 65 | #endif // OUTPUT_H |
diff --git a/noncore/apps/checkbook/checkbook.cpp b/noncore/apps/checkbook/checkbook.cpp index 1b933f2..706d970 100644 --- a/noncore/apps/checkbook/checkbook.cpp +++ b/noncore/apps/checkbook/checkbook.cpp | |||
@@ -1,572 +1,573 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. | 3 | =. |
4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> | 4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include "checkbook.h" | 29 | #include "checkbook.h" |
30 | #include "cbinfo.h" | 30 | #include "cbinfo.h" |
31 | #include "transaction.h" | 31 | #include "transaction.h" |
32 | #include "traninfo.h" | 32 | #include "traninfo.h" |
33 | #include "graph.h" | 33 | #include "graph.h" |
34 | #include "graphinfo.h" | 34 | #include "graphinfo.h" |
35 | #include "password.h" | 35 | #include "password.h" |
36 | #include "cfg.h" | 36 | #include "cfg.h" |
37 | 37 | ||
38 | #include <qpe/qpeapplication.h> | 38 | #include <qpe/qpeapplication.h> |
39 | #include <qpe/qpemessagebox.h> | 39 | #include <qpe/qpemessagebox.h> |
40 | #include <qpe/resource.h> | 40 | #include <qpe/resource.h> |
41 | 41 | ||
42 | #include <qcheckbox.h> | 42 | #include <qcheckbox.h> |
43 | #include <qcombobox.h> | 43 | #include <qcombobox.h> |
44 | #include <qlabel.h> | 44 | #include <qlabel.h> |
45 | #include <qlayout.h> | 45 | #include <qlayout.h> |
46 | #include <qlineedit.h> | 46 | #include <qlineedit.h> |
47 | #include <qmultilineedit.h> | 47 | #include <qmultilineedit.h> |
48 | #include <qpushbutton.h> | 48 | #include <qpushbutton.h> |
49 | #include <qwhatsthis.h> | 49 | #include <qwhatsthis.h> |
50 | #include <qpopupmenu.h> | 50 | #include <qpopupmenu.h> |
51 | 51 | ||
52 | #define COL_ID 0 | 52 | #define COL_ID 0 |
53 | #define COL_SORTDATE 1 | 53 | #define COL_SORTDATE 1 |
54 | #define COL_NUM 2 | 54 | #define COL_NUM 2 |
55 | #define COL_DATE 3 | 55 | #define COL_DATE 3 |
56 | #define COL_DESC 4 | 56 | #define COL_DESC 4 |
57 | #define COL_AMOUNT 5 | 57 | #define COL_AMOUNT 5 |
58 | #define COL_BAL 6 | 58 | #define COL_BAL 6 |
59 | 59 | ||
60 | // --- Checkbook -------------------------------------------------------------- | 60 | // --- Checkbook -------------------------------------------------------------- |
61 | using namespace Opie::Ui; | ||
61 | Checkbook::Checkbook( QWidget *parent, CBInfo *i, Cfg *cfg ) | 62 | Checkbook::Checkbook( QWidget *parent, CBInfo *i, Cfg *cfg ) |
62 | : QDialog( parent, 0, TRUE, WStyle_ContextHelp ) | 63 | : QDialog( parent, 0, TRUE, WStyle_ContextHelp ) |
63 | { | 64 | { |
64 | info = i; | 65 | info = i; |
65 | _pCfg=cfg; | 66 | _pCfg=cfg; |
66 | 67 | ||
67 | // Title bar | 68 | // Title bar |
68 | if ( info->name() != "" ) | 69 | if ( info->name() != "" ) |
69 | { | 70 | { |
70 | QString tempstr = info->name(); | 71 | QString tempstr = info->name(); |
71 | tempstr.append( " - " ); | 72 | tempstr.append( " - " ); |
72 | tempstr.append( tr( "Checkbook" ) ); | 73 | tempstr.append( tr( "Checkbook" ) ); |
73 | setCaption( tempstr ); | 74 | setCaption( tempstr ); |
74 | } | 75 | } |
75 | else | 76 | else |
76 | { | 77 | { |
77 | setCaption( tr( "New checkbook" ) ); | 78 | setCaption( tr( "New checkbook" ) ); |
78 | } | 79 | } |
79 | 80 | ||
80 | 81 | ||
81 | // Setup layout to make everything pretty | 82 | // Setup layout to make everything pretty |
82 | QVBoxLayout *layout = new QVBoxLayout( this ); | 83 | QVBoxLayout *layout = new QVBoxLayout( this ); |
83 | layout->setMargin( 2 ); | 84 | layout->setMargin( 2 ); |
84 | layout->setSpacing( 4 ); | 85 | layout->setSpacing( 4 ); |
85 | 86 | ||
86 | // Setup tabs for all info | 87 | // Setup tabs for all info |
87 | mainWidget = new OTabWidget( this ); | 88 | mainWidget = new OTabWidget( this ); |
88 | layout->addWidget( mainWidget ); | 89 | layout->addWidget( mainWidget ); |
89 | mainWidget->addTab( initInfo(), "checkbook/infotab", tr( "Info" ) ); | 90 | mainWidget->addTab( initInfo(), "checkbook/infotab", tr( "Info" ) ); |
90 | mainWidget->addTab( initTransactions(), "checkbook/trantab", tr( "Transactions" ) ); | 91 | mainWidget->addTab( initTransactions(), "checkbook/trantab", tr( "Transactions" ) ); |
91 | mainWidget->addTab( initCharts(), "checkbook/charttab", tr( "Charts" ) ); | 92 | mainWidget->addTab( initCharts(), "checkbook/charttab", tr( "Charts" ) ); |
92 | if( _pCfg->isShowLastTab() ) | 93 | if( _pCfg->isShowLastTab() ) |
93 | mainWidget->setCurrentTab( info->getLastTab() ); | 94 | mainWidget->setCurrentTab( info->getLastTab() ); |
94 | else | 95 | else |
95 | mainWidget->setCurrentTab( tr( "Info" ) ); | 96 | mainWidget->setCurrentTab( tr( "Info" ) ); |
96 | connect( mainWidget, SIGNAL( currentChanged(QWidget*) ), this, SLOT( slotTab(QWidget*) ) ); | 97 | connect( mainWidget, SIGNAL( currentChanged(QWidget*) ), this, SLOT( slotTab(QWidget*) ) ); |
97 | 98 | ||
98 | // Load checkbook information | 99 | // Load checkbook information |
99 | loadCheckbook(); | 100 | loadCheckbook(); |
100 | } | 101 | } |
101 | 102 | ||
102 | Checkbook::~Checkbook() | 103 | Checkbook::~Checkbook() |
103 | { | 104 | { |
104 | } | 105 | } |
105 | 106 | ||
106 | // --- initInfo --------------------------------------------------------------- | 107 | // --- initInfo --------------------------------------------------------------- |
107 | QWidget *Checkbook::initInfo() | 108 | QWidget *Checkbook::initInfo() |
108 | { | 109 | { |
109 | QWidget *control = new QWidget( mainWidget, tr("Info") ); | 110 | QWidget *control = new QWidget( mainWidget, tr("Info") ); |
110 | 111 | ||
111 | QVBoxLayout *vb = new QVBoxLayout( control ); | 112 | QVBoxLayout *vb = new QVBoxLayout( control ); |
112 | 113 | ||
113 | QScrollView *sv = new QScrollView( control ); | 114 | QScrollView *sv = new QScrollView( control ); |
114 | vb->addWidget( sv, 0, 0 ); | 115 | vb->addWidget( sv, 0, 0 ); |
115 | sv->setResizePolicy( QScrollView::AutoOneFit ); | 116 | sv->setResizePolicy( QScrollView::AutoOneFit ); |
116 | sv->setFrameStyle( QFrame::NoFrame ); | 117 | sv->setFrameStyle( QFrame::NoFrame ); |
117 | 118 | ||
118 | QWidget *container = new QWidget( sv->viewport() ); | 119 | QWidget *container = new QWidget( sv->viewport() ); |
119 | sv->addChild( container ); | 120 | sv->addChild( container ); |
120 | 121 | ||
121 | QGridLayout *layout = new QGridLayout( container ); | 122 | QGridLayout *layout = new QGridLayout( container ); |
122 | layout->setSpacing( 2 ); | 123 | layout->setSpacing( 2 ); |
123 | layout->setMargin( 4 ); | 124 | layout->setMargin( 4 ); |
124 | 125 | ||
125 | // Password protection | 126 | // Password protection |
126 | passwordCB = new QCheckBox( tr( "Password protect" ), container ); | 127 | passwordCB = new QCheckBox( tr( "Password protect" ), container ); |
127 | QWhatsThis::add( passwordCB, tr( "Click here to enable/disable password protection of this checkbook." ) ); | 128 | QWhatsThis::add( passwordCB, tr( "Click here to enable/disable password protection of this checkbook." ) ); |
128 | connect( passwordCB, SIGNAL( clicked() ), this, SLOT( slotPasswordClicked() ) ); | 129 | connect( passwordCB, SIGNAL( clicked() ), this, SLOT( slotPasswordClicked() ) ); |
129 | layout->addMultiCellWidget( passwordCB, 0, 0, 0, 1 ); | 130 | layout->addMultiCellWidget( passwordCB, 0, 0, 0, 1 ); |
130 | 131 | ||
131 | // Account name | 132 | // Account name |
132 | QLabel *label = new QLabel( tr( "Name:" ), container ); | 133 | QLabel *label = new QLabel( tr( "Name:" ), container ); |
133 | QWhatsThis::add( label, tr( "Enter name of checkbook here." ) ); | 134 | QWhatsThis::add( label, tr( "Enter name of checkbook here." ) ); |
134 | layout->addWidget( label, 1, 0 ); | 135 | layout->addWidget( label, 1, 0 ); |
135 | nameEdit = new QLineEdit( container ); | 136 | nameEdit = new QLineEdit( container ); |
136 | QWhatsThis::add( nameEdit, tr( "Enter name of checkbook here." ) ); | 137 | QWhatsThis::add( nameEdit, tr( "Enter name of checkbook here." ) ); |
137 | connect( nameEdit, SIGNAL( textChanged(const QString&) ), | 138 | connect( nameEdit, SIGNAL( textChanged(const QString&) ), |
138 | this, SLOT( slotNameChanged(const QString&) ) ); | 139 | this, SLOT( slotNameChanged(const QString&) ) ); |
139 | layout->addWidget( nameEdit, 1, 1 ); | 140 | layout->addWidget( nameEdit, 1, 1 ); |
140 | 141 | ||
141 | // Type of account | 142 | // Type of account |
142 | label = new QLabel( tr( "Type:" ), container ); | 143 | label = new QLabel( tr( "Type:" ), container ); |
143 | QWhatsThis::add( label, tr( "Select type of checkbook here." ) ); | 144 | QWhatsThis::add( label, tr( "Select type of checkbook here." ) ); |
144 | layout->addWidget( label, 2, 0 ); | 145 | layout->addWidget( label, 2, 0 ); |
145 | typeList = new QComboBox( container ); | 146 | typeList = new QComboBox( container ); |
146 | QWhatsThis::add( typeList, tr( "Select type of checkbook here." ) ); | 147 | QWhatsThis::add( typeList, tr( "Select type of checkbook here." ) ); |
147 | typeList->insertStringList( _pCfg->getAccountTypes() ); | 148 | typeList->insertStringList( _pCfg->getAccountTypes() ); |
148 | layout->addWidget( typeList, 2, 1 ); | 149 | layout->addWidget( typeList, 2, 1 ); |
149 | 150 | ||
150 | // Bank/institution name | 151 | // Bank/institution name |
151 | label = new QLabel( tr( "Bank:" ), container ); | 152 | label = new QLabel( tr( "Bank:" ), container ); |
152 | QWhatsThis::add( label, tr( "Enter name of the bank for this checkbook here." ) ); | 153 | QWhatsThis::add( label, tr( "Enter name of the bank for this checkbook here." ) ); |
153 | layout->addWidget( label, 3, 0 ); | 154 | layout->addWidget( label, 3, 0 ); |
154 | bankEdit = new QLineEdit( container ); | 155 | bankEdit = new QLineEdit( container ); |
155 | QWhatsThis::add( bankEdit, tr( "Enter name of the bank for this checkbook here." ) ); | 156 | QWhatsThis::add( bankEdit, tr( "Enter name of the bank for this checkbook here." ) ); |
156 | layout->addWidget( bankEdit, 3, 1 ); | 157 | layout->addWidget( bankEdit, 3, 1 ); |
157 | 158 | ||
158 | // Account number | 159 | // Account number |
159 | label = new QLabel( tr( "Account number:" ), container ); | 160 | label = new QLabel( tr( "Account number:" ), container ); |
160 | QWhatsThis::add( label, tr( "Enter account number for this checkbook here." ) ); | 161 | QWhatsThis::add( label, tr( "Enter account number for this checkbook here." ) ); |
161 | layout->addWidget( label, 4, 0 ); | 162 | layout->addWidget( label, 4, 0 ); |
162 | acctNumEdit = new QLineEdit( container ); | 163 | acctNumEdit = new QLineEdit( container ); |
163 | QWhatsThis::add( acctNumEdit, tr( "Enter account number for this checkbook here." ) ); | 164 | QWhatsThis::add( acctNumEdit, tr( "Enter account number for this checkbook here." ) ); |
164 | layout->addWidget( acctNumEdit, 4, 1 ); | 165 | layout->addWidget( acctNumEdit, 4, 1 ); |
165 | 166 | ||
166 | // PIN number | 167 | // PIN number |
167 | label = new QLabel( tr( "PIN number:" ), container ); | 168 | label = new QLabel( tr( "PIN number:" ), container ); |
168 | QWhatsThis::add( label, tr( "Enter PIN number for this checkbook here." ) ); | 169 | QWhatsThis::add( label, tr( "Enter PIN number for this checkbook here." ) ); |
169 | layout->addWidget( label, 5, 0 ); | 170 | layout->addWidget( label, 5, 0 ); |
170 | pinNumEdit = new QLineEdit( container ); | 171 | pinNumEdit = new QLineEdit( container ); |
171 | QWhatsThis::add( pinNumEdit, tr( "Enter PIN number for this checkbook here." ) ); | 172 | QWhatsThis::add( pinNumEdit, tr( "Enter PIN number for this checkbook here." ) ); |
172 | layout->addWidget( pinNumEdit, 5, 1 ); | 173 | layout->addWidget( pinNumEdit, 5, 1 ); |
173 | 174 | ||
174 | // Starting balance | 175 | // Starting balance |
175 | label = new QLabel( tr( "Starting balance:" ), container ); | 176 | label = new QLabel( tr( "Starting balance:" ), container ); |
176 | QWhatsThis::add( label, tr( "Enter the initial balance for this checkbook here." ) ); | 177 | QWhatsThis::add( label, tr( "Enter the initial balance for this checkbook here." ) ); |
177 | layout->addWidget( label, 6, 0 ); | 178 | layout->addWidget( label, 6, 0 ); |
178 | balanceEdit = new QLineEdit( container ); | 179 | balanceEdit = new QLineEdit( container ); |
179 | QWhatsThis::add( balanceEdit, tr( "Enter the initial balance for this checkbook here." ) ); | 180 | QWhatsThis::add( balanceEdit, tr( "Enter the initial balance for this checkbook here." ) ); |
180 | connect( balanceEdit, SIGNAL( textChanged(const QString&) ), | 181 | connect( balanceEdit, SIGNAL( textChanged(const QString&) ), |
181 | this, SLOT( slotStartingBalanceChanged(const QString&) ) ); | 182 | this, SLOT( slotStartingBalanceChanged(const QString&) ) ); |
182 | layout->addWidget( balanceEdit, 6, 1 ); | 183 | layout->addWidget( balanceEdit, 6, 1 ); |
183 | 184 | ||
184 | // Notes | 185 | // Notes |
185 | label = new QLabel( tr( "Notes:" ), container ); | 186 | label = new QLabel( tr( "Notes:" ), container ); |
186 | QWhatsThis::add( label, tr( "Enter any additional information for this checkbook here." ) ); | 187 | QWhatsThis::add( label, tr( "Enter any additional information for this checkbook here." ) ); |
187 | layout->addWidget( label, 7, 0 ); | 188 | layout->addWidget( label, 7, 0 ); |
188 | notesEdit = new QMultiLineEdit( container ); | 189 | notesEdit = new QMultiLineEdit( container ); |
189 | QWhatsThis::add( notesEdit, tr( "Enter any additional information for this checkbook here." ) ); | 190 | QWhatsThis::add( notesEdit, tr( "Enter any additional information for this checkbook here." ) ); |
190 | notesEdit->setMinimumHeight( 25 ); | 191 | notesEdit->setMinimumHeight( 25 ); |
191 | notesEdit->setMaximumHeight( 65 ); | 192 | notesEdit->setMaximumHeight( 65 ); |
192 | layout->addMultiCellWidget( notesEdit, 8, 8, 0, 1 ); | 193 | layout->addMultiCellWidget( notesEdit, 8, 8, 0, 1 ); |
193 | 194 | ||
194 | return control; | 195 | return control; |
195 | } | 196 | } |
196 | 197 | ||
197 | 198 | ||
198 | // --- initTransactions ------------------------------------------------------- | 199 | // --- initTransactions ------------------------------------------------------- |
199 | QWidget *Checkbook::initTransactions() | 200 | QWidget *Checkbook::initTransactions() |
200 | { | 201 | { |
201 | QWidget *control = new QWidget( mainWidget, tr("Transactions") ); | 202 | QWidget *control = new QWidget( mainWidget, tr("Transactions") ); |
202 | 203 | ||
203 | QGridLayout *layout = new QGridLayout( control ); | 204 | QGridLayout *layout = new QGridLayout( control ); |
204 | layout->setSpacing( 2 ); | 205 | layout->setSpacing( 2 ); |
205 | layout->setMargin( 4 ); | 206 | layout->setMargin( 4 ); |
206 | 207 | ||
207 | // Sort selector | 208 | // Sort selector |
208 | QLabel *label = new QLabel( tr( "Sort by:" ), control ); | 209 | QLabel *label = new QLabel( tr( "Sort by:" ), control ); |
209 | QWhatsThis::add( label, tr( "Select checkbook sorting here." ) ); | 210 | QWhatsThis::add( label, tr( "Select checkbook sorting here." ) ); |
210 | layout->addMultiCellWidget( label, 0, 0, 0, 1 ); | 211 | layout->addMultiCellWidget( label, 0, 0, 0, 1 ); |
211 | _cbSortType=new QComboBox( control ); | 212 | _cbSortType=new QComboBox( control ); |
212 | _cbSortType->insertItem( tr("Entry Order") ); | 213 | _cbSortType->insertItem( tr("Entry Order") ); |
213 | _cbSortType->insertItem( tr("Date") ); | 214 | _cbSortType->insertItem( tr("Date") ); |
214 | _cbSortType->insertItem( tr("Number") ); | 215 | _cbSortType->insertItem( tr("Number") ); |
215 | layout->addMultiCellWidget( _cbSortType, 0, 0, 1, 2 ); | 216 | layout->addMultiCellWidget( _cbSortType, 0, 0, 1, 2 ); |
216 | connect( _cbSortType, SIGNAL( activated(const QString&) ), this, SLOT( slotSortChanged(const QString&) ) ); | 217 | connect( _cbSortType, SIGNAL( activated(const QString&) ), this, SLOT( slotSortChanged(const QString&) ) ); |
217 | 218 | ||
218 | // Table | 219 | // Table |
219 | tranTable = new QListView( control ); | 220 | tranTable = new QListView( control ); |
220 | QFont fnt(QPEApplication::font()); | 221 | QFont fnt(QPEApplication::font()); |
221 | fnt.setPointSize( fnt.pointSize()-1 ); | 222 | fnt.setPointSize( fnt.pointSize()-1 ); |
222 | tranTable->setFont( fnt ); | 223 | tranTable->setFont( fnt ); |
223 | QWhatsThis::add( tranTable, tr( "This is a listing of all transactions entered for this checkbook.\n\nTo sort entries by a specific field, click on the column name." ) ); | 224 | QWhatsThis::add( tranTable, tr( "This is a listing of all transactions entered for this checkbook.\n\nTo sort entries by a specific field, click on the column name." ) ); |
224 | tranTable->addColumn( tr( "Id" ) ); | 225 | tranTable->addColumn( tr( "Id" ) ); |
225 | tranTable->setColumnWidthMode( COL_ID, QListView::Manual ); | 226 | tranTable->setColumnWidthMode( COL_ID, QListView::Manual ); |
226 | tranTable->setColumnWidth( COL_ID, 0); | 227 | tranTable->setColumnWidth( COL_ID, 0); |
227 | tranTable->addColumn( tr( "SortDate" ) ); | 228 | tranTable->addColumn( tr( "SortDate" ) ); |
228 | tranTable->setColumnWidthMode( COL_SORTDATE, QListView::Manual ); | 229 | tranTable->setColumnWidthMode( COL_SORTDATE, QListView::Manual ); |
229 | tranTable->setColumnWidth( COL_SORTDATE, 0); | 230 | tranTable->setColumnWidth( COL_SORTDATE, 0); |
230 | tranTable->addColumn( tr( "Num" ) ); | 231 | tranTable->addColumn( tr( "Num" ) ); |
231 | tranTable->addColumn( tr( "Date" ) ); | 232 | tranTable->addColumn( tr( "Date" ) ); |
232 | //tranTable->addColumn( tr( "Cleared" ) ); | 233 | //tranTable->addColumn( tr( "Cleared" ) ); |
233 | tranTable->addColumn( tr( "Description" ) ); | 234 | tranTable->addColumn( tr( "Description" ) ); |
234 | int column = tranTable->addColumn( tr( "Amount" ) ); | 235 | int column = tranTable->addColumn( tr( "Amount" ) ); |
235 | tranTable->setColumnAlignment( column, Qt::AlignRight ); | 236 | tranTable->setColumnAlignment( column, Qt::AlignRight ); |
236 | column=tranTable->addColumn( tr("Balance") ); | 237 | column=tranTable->addColumn( tr("Balance") ); |
237 | tranTable->setColumnAlignment( column, Qt::AlignRight ); | 238 | tranTable->setColumnAlignment( column, Qt::AlignRight ); |
238 | tranTable->setAllColumnsShowFocus( TRUE ); | 239 | tranTable->setAllColumnsShowFocus( TRUE ); |
239 | tranTable->setSorting( -1 ); | 240 | tranTable->setSorting( -1 ); |
240 | layout->addMultiCellWidget( tranTable, 1, 1, 0, 2 ); | 241 | layout->addMultiCellWidget( tranTable, 1, 1, 0, 2 ); |
241 | QPEApplication::setStylusOperation( tranTable->viewport(), QPEApplication::RightOnHold ); | 242 | QPEApplication::setStylusOperation( tranTable->viewport(), QPEApplication::RightOnHold ); |
242 | connect( tranTable, SIGNAL( rightButtonPressed(QListViewItem*,const QPoint&,int) ), | 243 | connect( tranTable, SIGNAL( rightButtonPressed(QListViewItem*,const QPoint&,int) ), |
243 | this, SLOT( slotMenuTran(QListViewItem*,const QPoint&) ) ); | 244 | this, SLOT( slotMenuTran(QListViewItem*,const QPoint&) ) ); |
244 | connect( tranTable, SIGNAL( doubleClicked(QListViewItem*) ), | 245 | connect( tranTable, SIGNAL( doubleClicked(QListViewItem*) ), |
245 | this, SLOT( slotEditTran() ) ); | 246 | this, SLOT( slotEditTran() ) ); |
246 | _sortCol=COL_ID; | 247 | _sortCol=COL_ID; |
247 | 248 | ||
248 | // Buttons | 249 | // Buttons |
249 | QPushButton *btn = new QPushButton( Resource::loadPixmap( "new" ), tr( "New" ), control ); | 250 | QPushButton *btn = new QPushButton( Resource::loadPixmap( "new" ), tr( "New" ), control ); |
250 | QWhatsThis::add( btn, tr( "Click here to add a new transaction." ) ); | 251 | QWhatsThis::add( btn, tr( "Click here to add a new transaction." ) ); |
251 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotNewTran() ) ); | 252 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotNewTran() ) ); |
252 | layout->addWidget( btn, 2, 0 ); | 253 | layout->addWidget( btn, 2, 0 ); |
253 | 254 | ||
254 | btn = new QPushButton( Resource::loadPixmap( "edit" ), tr( "Edit" ), control ); | 255 | btn = new QPushButton( Resource::loadPixmap( "edit" ), tr( "Edit" ), control ); |
255 | QWhatsThis::add( btn, tr( "Select a transaction and then click here to edit it." ) ); | 256 | QWhatsThis::add( btn, tr( "Select a transaction and then click here to edit it." ) ); |
256 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotEditTran() ) ); | 257 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotEditTran() ) ); |
257 | layout->addWidget( btn, 2, 1 ); | 258 | layout->addWidget( btn, 2, 1 ); |
258 | 259 | ||
259 | btn = new QPushButton( Resource::loadPixmap( "trash" ), tr( "Delete" ), control ); | 260 | btn = new QPushButton( Resource::loadPixmap( "trash" ), tr( "Delete" ), control ); |
260 | QWhatsThis::add( btn, tr( "Select a checkbook and then click here to delete it." ) ); | 261 | QWhatsThis::add( btn, tr( "Select a checkbook and then click here to delete it." ) ); |
261 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotDeleteTran() ) ); | 262 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotDeleteTran() ) ); |
262 | layout->addWidget( btn, 2, 2 ); | 263 | layout->addWidget( btn, 2, 2 ); |
263 | 264 | ||
264 | return( control ); | 265 | return( control ); |
265 | } | 266 | } |
266 | 267 | ||
267 | 268 | ||
268 | // --- initCharts ------------------------------------------------------------- | 269 | // --- initCharts ------------------------------------------------------------- |
269 | QWidget *Checkbook::initCharts() | 270 | QWidget *Checkbook::initCharts() |
270 | { | 271 | { |
271 | graphInfo = 0x0; | 272 | graphInfo = 0x0; |
272 | 273 | ||
273 | QWidget *control = new QWidget( mainWidget, tr("Charts") ); | 274 | QWidget *control = new QWidget( mainWidget, tr("Charts") ); |
274 | 275 | ||
275 | QGridLayout *layout = new QGridLayout( control ); | 276 | QGridLayout *layout = new QGridLayout( control ); |
276 | layout->setSpacing( 2 ); | 277 | layout->setSpacing( 2 ); |
277 | layout->setMargin( 4 ); | 278 | layout->setMargin( 4 ); |
278 | 279 | ||
279 | graphWidget = new Graph( control ); | 280 | graphWidget = new Graph( control ); |
280 | QWhatsThis::add( graphWidget, tr( "Select the desired chart below and then click on the Draw button." ) ); | 281 | QWhatsThis::add( graphWidget, tr( "Select the desired chart below and then click on the Draw button." ) ); |
281 | layout->addMultiCellWidget( graphWidget, 0, 0, 0, 2 ); | 282 | layout->addMultiCellWidget( graphWidget, 0, 0, 0, 2 ); |
282 | 283 | ||
283 | graphList = new QComboBox( control ); | 284 | graphList = new QComboBox( control ); |
284 | QWhatsThis::add( graphList, tr( "Click here to select the desired chart type." ) ); | 285 | QWhatsThis::add( graphList, tr( "Click here to select the desired chart type." ) ); |
285 | graphList->insertItem( tr( "Account balance" ) ); | 286 | graphList->insertItem( tr( "Account balance" ) ); |
286 | graphList->insertItem( tr( "Withdrawals by category" ) ); | 287 | graphList->insertItem( tr( "Withdrawals by category" ) ); |
287 | graphList->insertItem( tr( "Deposits by category" ) ); | 288 | graphList->insertItem( tr( "Deposits by category" ) ); |
288 | 289 | ||
289 | layout->addMultiCellWidget( graphList, 1, 1, 0, 1 ); | 290 | layout->addMultiCellWidget( graphList, 1, 1, 0, 1 ); |
290 | 291 | ||
291 | QPushButton *btn = new QPushButton( Resource::loadPixmap( "checkbook/drawbtn" ), tr( "Draw" ), control ); | 292 | QPushButton *btn = new QPushButton( Resource::loadPixmap( "checkbook/drawbtn" ), tr( "Draw" ), control ); |
292 | QWhatsThis::add( btn, tr( "Click here to draw the selected chart." ) ); | 293 | QWhatsThis::add( btn, tr( "Click here to draw the selected chart." ) ); |
293 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotDrawGraph() ) ); | 294 | connect( btn, SIGNAL( clicked() ), this, SLOT( slotDrawGraph() ) ); |
294 | layout->addWidget( btn, 1, 2 ); | 295 | layout->addWidget( btn, 1, 2 ); |
295 | 296 | ||
296 | return control; | 297 | return control; |
297 | } | 298 | } |
298 | 299 | ||
299 | // --- loadCheckbook ---------------------------------------------------------- | 300 | // --- loadCheckbook ---------------------------------------------------------- |
300 | void Checkbook::loadCheckbook() | 301 | void Checkbook::loadCheckbook() |
301 | { | 302 | { |
302 | if ( !info ) | 303 | if ( !info ) |
303 | { | 304 | { |
304 | return; | 305 | return; |
305 | } | 306 | } |
306 | 307 | ||
307 | tranList = info->transactions(); | 308 | tranList = info->transactions(); |
308 | 309 | ||
309 | passwordCB->setChecked( !info->password().isNull() ); | 310 | passwordCB->setChecked( !info->password().isNull() ); |
310 | nameEdit->setText( info->name() ); | 311 | nameEdit->setText( info->name() ); |
311 | QString temptext = info->type(); | 312 | QString temptext = info->type(); |
312 | int i = typeList->count(); | 313 | int i = typeList->count(); |
313 | while ( i > 0 ) | 314 | while ( i > 0 ) |
314 | { | 315 | { |
315 | i--; | 316 | i--; |
316 | typeList->setCurrentItem( i ); | 317 | typeList->setCurrentItem( i ); |
317 | if ( typeList->currentText() == temptext ) | 318 | if ( typeList->currentText() == temptext ) |
318 | { | 319 | { |
319 | break; | 320 | break; |
320 | } | 321 | } |
321 | } | 322 | } |
322 | if( i<=0 ) { | 323 | if( i<=0 ) { |
323 | typeList->insertItem( temptext, 0 ); | 324 | typeList->insertItem( temptext, 0 ); |
324 | typeList->setCurrentItem(0); | 325 | typeList->setCurrentItem(0); |
325 | } | 326 | } |
326 | bankEdit->setText( info->bank() ); | 327 | bankEdit->setText( info->bank() ); |
327 | acctNumEdit->setText( info->account() ); | 328 | acctNumEdit->setText( info->account() ); |
328 | pinNumEdit->setText( info->pin() ); | 329 | pinNumEdit->setText( info->pin() ); |
329 | temptext.setNum( info->startingBalance(), 'f', 2 ); | 330 | temptext.setNum( info->startingBalance(), 'f', 2 ); |
330 | balanceEdit->setText( temptext ); | 331 | balanceEdit->setText( temptext ); |
331 | notesEdit->setText( info->notes() ); | 332 | notesEdit->setText( info->notes() ); |
332 | 333 | ||
333 | // Load transactions | 334 | // Load transactions |
334 | float amount; | 335 | float amount; |
335 | QString stramount; | 336 | QString stramount; |
336 | for ( TranInfo *tran = tranList->first(); tran; tran = tranList->next() ) | 337 | for ( TranInfo *tran = tranList->first(); tran; tran = tranList->next() ) |
337 | { | 338 | { |
338 | amount = tran->amount(); | 339 | amount = tran->amount(); |
339 | if ( tran->withdrawal() ) | 340 | if ( tran->withdrawal() ) |
340 | { | 341 | { |
341 | amount *= -1; | 342 | amount *= -1; |
342 | } | 343 | } |
343 | stramount.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), amount ); | 344 | stramount.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), amount ); |
344 | ( void ) new CBListItem( tran, tranTable, tran->getIdStr(), tran->datestr(false), tran->number(), tran->datestr(true), tran->desc(), stramount ); | 345 | ( void ) new CBListItem( tran, tranTable, tran->getIdStr(), tran->datestr(false), tran->number(), tran->datestr(true), tran->desc(), stramount ); |
345 | } | 346 | } |
346 | 347 | ||
347 | // set sort order | 348 | // set sort order |
348 | bool bOk=false; | 349 | bool bOk=false; |
349 | for(int i=0; i<_cbSortType->count(); i++) { | 350 | for(int i=0; i<_cbSortType->count(); i++) { |
350 | if( _cbSortType->text(i)==info->getSortOrder() ) { | 351 | if( _cbSortType->text(i)==info->getSortOrder() ) { |
351 | _cbSortType->setCurrentItem(i); | 352 | _cbSortType->setCurrentItem(i); |
352 | slotSortChanged( info->getSortOrder() ); | 353 | slotSortChanged( info->getSortOrder() ); |
353 | bOk=true; | 354 | bOk=true; |
354 | break; | 355 | break; |
355 | } | 356 | } |
356 | } | 357 | } |
357 | if( !bOk ) { | 358 | if( !bOk ) { |
358 | _cbSortType->setCurrentItem(0); | 359 | _cbSortType->setCurrentItem(0); |
359 | slotSortChanged( _cbSortType->currentText() ); | 360 | slotSortChanged( _cbSortType->currentText() ); |
360 | } | 361 | } |
361 | 362 | ||
362 | // calc running balance | 363 | // calc running balance |
363 | adjustBalance(); | 364 | adjustBalance(); |
364 | } | 365 | } |
365 | 366 | ||
366 | 367 | ||
367 | // --- adjustBalance ---------------------------------------------------------- | 368 | // --- adjustBalance ---------------------------------------------------------- |
368 | void Checkbook::adjustBalance() | 369 | void Checkbook::adjustBalance() |
369 | { | 370 | { |
370 | // update running balance in register | 371 | // update running balance in register |
371 | QString sRunning; | 372 | QString sRunning; |
372 | float bal=info->startingBalance(); | 373 | float bal=info->startingBalance(); |
373 | for(CBListItem *item=(CBListItem *)tranTable->firstChild(); item; item=(CBListItem *)item->nextSibling() ) { | 374 | for(CBListItem *item=(CBListItem *)tranTable->firstChild(); item; item=(CBListItem *)item->nextSibling() ) { |
374 | TranInfo *tran=item->getTranInfo(); | 375 | TranInfo *tran=item->getTranInfo(); |
375 | bal=bal + (tran->withdrawal() ? -1 : 1)*tran->amount() - tran->fee(); | 376 | bal=bal + (tran->withdrawal() ? -1 : 1)*tran->amount() - tran->fee(); |
376 | sRunning.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), bal ); | 377 | sRunning.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), bal ); |
377 | item->setText( COL_BAL, sRunning); | 378 | item->setText( COL_BAL, sRunning); |
378 | } | 379 | } |
379 | } | 380 | } |
380 | 381 | ||
381 | // --- resort ----------------------------------------------------------------- | 382 | // --- resort ----------------------------------------------------------------- |
382 | void Checkbook::resort() | 383 | void Checkbook::resort() |
383 | { | 384 | { |
384 | tranTable->setSorting(_sortCol); | 385 | tranTable->setSorting(_sortCol); |
385 | tranTable->sort(); | 386 | tranTable->sort(); |
386 | tranTable->setSorting(-1); | 387 | tranTable->setSorting(-1); |
387 | } | 388 | } |
388 | 389 | ||
389 | 390 | ||
390 | // --- accept ----------------------------------------------------------------- | 391 | // --- accept ----------------------------------------------------------------- |
391 | void Checkbook::accept() | 392 | void Checkbook::accept() |
392 | { | 393 | { |
393 | info->setName( nameEdit->text() ); | 394 | info->setName( nameEdit->text() ); |
394 | info->setType( typeList->currentText() ); | 395 | info->setType( typeList->currentText() ); |
395 | info->setBank( bankEdit->text() ); | 396 | info->setBank( bankEdit->text() ); |
396 | info->setAccount( acctNumEdit->text() ); | 397 | info->setAccount( acctNumEdit->text() ); |
397 | info->setPin( pinNumEdit->text() ); | 398 | info->setPin( pinNumEdit->text() ); |
398 | bool ok; | 399 | bool ok; |
399 | info->setStartingBalance( balanceEdit->text().toFloat( &ok ) ); | 400 | info->setStartingBalance( balanceEdit->text().toFloat( &ok ) ); |
400 | info->setNotes( notesEdit->text() ); | 401 | info->setNotes( notesEdit->text() ); |
401 | 402 | ||
402 | QDialog::accept(); | 403 | QDialog::accept(); |
403 | } | 404 | } |
404 | 405 | ||
405 | // --- slotPasswordClicked ---------------------------------------------------- | 406 | // --- slotPasswordClicked ---------------------------------------------------- |
406 | void Checkbook::slotPasswordClicked() | 407 | void Checkbook::slotPasswordClicked() |
407 | { | 408 | { |
408 | if ( info->password().isNull() && passwordCB->isChecked() ) | 409 | if ( info->password().isNull() && passwordCB->isChecked() ) |
409 | { | 410 | { |
410 | Password *pw = new Password( this, tr( "Enter password" ), tr( "Please enter your password:" ) ); | 411 | Password *pw = new Password( this, tr( "Enter password" ), tr( "Please enter your password:" ) ); |
411 | if ( pw->exec() != QDialog::Accepted ) | 412 | if ( pw->exec() != QDialog::Accepted ) |
412 | { | 413 | { |
413 | passwordCB->setChecked( FALSE ); | 414 | passwordCB->setChecked( FALSE ); |
414 | delete pw; | 415 | delete pw; |
415 | return; | 416 | return; |
416 | } | 417 | } |
417 | info->setPassword( pw->password ); | 418 | info->setPassword( pw->password ); |
418 | delete pw; | 419 | delete pw; |
419 | 420 | ||
420 | pw = new Password( this, tr( "Confirm password" ), tr( "Please confirm your password:" ) ); | 421 | pw = new Password( this, tr( "Confirm password" ), tr( "Please confirm your password:" ) ); |
421 | if ( pw->exec() != QDialog::Accepted || pw->password != info->password() ) | 422 | if ( pw->exec() != QDialog::Accepted || pw->password != info->password() ) |
422 | { | 423 | { |
423 | passwordCB->setChecked( FALSE ); | 424 | passwordCB->setChecked( FALSE ); |
424 | info->setPassword( QString::null ); | 425 | info->setPassword( QString::null ); |
425 | } | 426 | } |
426 | 427 | ||
427 | delete pw; | 428 | delete pw; |
428 | } | 429 | } |
429 | else if ( !info->password().isNull() && !passwordCB->isChecked() ) | 430 | else if ( !info->password().isNull() && !passwordCB->isChecked() ) |
430 | { | 431 | { |
431 | Password *pw = new Password( this, tr( "Enter password" ), | 432 | Password *pw = new Password( this, tr( "Enter password" ), |
432 | tr( "Please enter your password to confirm removal of password protection:" ) ); | 433 | tr( "Please enter your password to confirm removal of password protection:" ) ); |
433 | if ( pw->exec() == QDialog::Accepted && pw->password == info->password() ) | 434 | if ( pw->exec() == QDialog::Accepted && pw->password == info->password() ) |
434 | { | 435 | { |
435 | info->setPassword( QString::null ); | 436 | info->setPassword( QString::null ); |
436 | delete pw; | 437 | delete pw; |
437 | return; | 438 | return; |
438 | } | 439 | } |
439 | else | 440 | else |
440 | { | 441 | { |
441 | passwordCB->setChecked( TRUE ); | 442 | passwordCB->setChecked( TRUE ); |
442 | } | 443 | } |
443 | 444 | ||
444 | delete pw; | 445 | delete pw; |
445 | } | 446 | } |
446 | } | 447 | } |
447 | 448 | ||
448 | void Checkbook::slotNameChanged( const QString &newname ) | 449 | void Checkbook::slotNameChanged( const QString &newname ) |
449 | { | 450 | { |
450 | info->setName( newname ); | 451 | info->setName( newname ); |
451 | 452 | ||
452 | // TODO - need filedir | 453 | // TODO - need filedir |
453 | // QString namestr = filedir; | 454 | // QString namestr = filedir; |
454 | // namestr.append( newname ); | 455 | // namestr.append( newname ); |
455 | // namestr.append( ".qcb" ); | 456 | // namestr.append( ".qcb" ); |
456 | // info->setFilename( namestr ); | 457 | // info->setFilename( namestr ); |
457 | 458 | ||
458 | QString namestr = newname; | 459 | QString namestr = newname; |
459 | namestr.append( " - " ); | 460 | namestr.append( " - " ); |
460 | namestr.append( tr( "Checkbook" ) ); | 461 | namestr.append( tr( "Checkbook" ) ); |
461 | setCaption( namestr ); | 462 | setCaption( namestr ); |
462 | } | 463 | } |
463 | 464 | ||
464 | 465 | ||
465 | // ---slotStartingBalanceChanged ---------------------------------------------- | 466 | // ---slotStartingBalanceChanged ---------------------------------------------- |
466 | void Checkbook::slotStartingBalanceChanged( const QString &newbalance ) | 467 | void Checkbook::slotStartingBalanceChanged( const QString &newbalance ) |
467 | { | 468 | { |
468 | bool ok; | 469 | bool ok; |
469 | info->setStartingBalance( newbalance.toFloat( &ok ) ); | 470 | info->setStartingBalance( newbalance.toFloat( &ok ) ); |
470 | adjustBalance(); | 471 | adjustBalance(); |
471 | } | 472 | } |
472 | 473 | ||
473 | 474 | ||
474 | // --- slotNewTran ------------------------------------------------------------ | 475 | // --- slotNewTran ------------------------------------------------------------ |
475 | void Checkbook::slotNewTran() | 476 | void Checkbook::slotNewTran() |
476 | { | 477 | { |
477 | TranInfo *traninfo = new TranInfo( info->getNextNumber() ); | 478 | TranInfo *traninfo = new TranInfo( info->getNextNumber() ); |
478 | if( !_dLastNew.isNull() ) | 479 | if( !_dLastNew.isNull() ) |
479 | traninfo->setDate(_dLastNew); | 480 | traninfo->setDate(_dLastNew); |
480 | 481 | ||
481 | Transaction *currtran = new Transaction( this, true, info->name(), | 482 | Transaction *currtran = new Transaction( this, true, info->name(), |
482 | traninfo, | 483 | traninfo, |
483 | _pCfg ); | 484 | _pCfg ); |
484 | if ( QPEApplication::execDialog( currtran ) == QDialog::Accepted ) | 485 | if ( QPEApplication::execDialog( currtran ) == QDialog::Accepted ) |
485 | { | 486 | { |
486 | // Add to transaction list | 487 | // Add to transaction list |
487 | info->addTransaction( traninfo ); | 488 | info->addTransaction( traninfo ); |
488 | 489 | ||
489 | // Add to transaction table | 490 | // Add to transaction table |
490 | float amount; | 491 | float amount; |
491 | QString stramount; | 492 | QString stramount; |
492 | amount = (traninfo->withdrawal() ? -1 : 1)*traninfo->amount(); | 493 | amount = (traninfo->withdrawal() ? -1 : 1)*traninfo->amount(); |
493 | stramount.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), amount ); | 494 | stramount.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), amount ); |
494 | ( void ) new CBListItem( traninfo, tranTable, traninfo->getIdStr(), traninfo->datestr(false), | 495 | ( void ) new CBListItem( traninfo, tranTable, traninfo->getIdStr(), traninfo->datestr(false), |
495 | traninfo->number(), traninfo->datestr(true), traninfo->desc(), | 496 | traninfo->number(), traninfo->datestr(true), traninfo->desc(), |
496 | stramount ); | 497 | stramount ); |
497 | resort(); | 498 | resort(); |
498 | adjustBalance(); | 499 | adjustBalance(); |
499 | 500 | ||
500 | // save last date | 501 | // save last date |
501 | _dLastNew = traninfo->date(); | 502 | _dLastNew = traninfo->date(); |
502 | 503 | ||
503 | // save description in list of payees, if not in there | 504 | // save description in list of payees, if not in there |
504 | QStringList *pLst=&_pCfg->getPayees(); | 505 | QStringList *pLst=&_pCfg->getPayees(); |
505 | if( _pCfg->getSavePayees() && pLst->contains(traninfo->desc())==0 ) { | 506 | if( _pCfg->getSavePayees() && pLst->contains(traninfo->desc())==0 ) { |
506 | pLst->append( traninfo->desc() ); | 507 | pLst->append( traninfo->desc() ); |
507 | pLst->sort(); | 508 | pLst->sort(); |
508 | _pCfg->setDirty(true); | 509 | _pCfg->setDirty(true); |
509 | } | 510 | } |
510 | } | 511 | } |
511 | else | 512 | else |
512 | { | 513 | { |
513 | delete traninfo; | 514 | delete traninfo; |
514 | } | 515 | } |
515 | } | 516 | } |
516 | 517 | ||
517 | 518 | ||
518 | // --- slotEditTran ----------------------------------------------------------- | 519 | // --- slotEditTran ----------------------------------------------------------- |
519 | void Checkbook::slotEditTran() | 520 | void Checkbook::slotEditTran() |
520 | { | 521 | { |
521 | QListViewItem *curritem = tranTable->currentItem(); | 522 | QListViewItem *curritem = tranTable->currentItem(); |
522 | if ( !curritem ) | 523 | if ( !curritem ) |
523 | return; | 524 | return; |
524 | 525 | ||
525 | TranInfo *traninfo=info->findTransaction( curritem->text(COL_ID) ); | 526 | TranInfo *traninfo=info->findTransaction( curritem->text(COL_ID) ); |
526 | 527 | ||
527 | Transaction *currtran = new Transaction( this, false, info->name(), | 528 | Transaction *currtran = new Transaction( this, false, info->name(), |
528 | traninfo, | 529 | traninfo, |
529 | _pCfg ); | 530 | _pCfg ); |
530 | if ( QPEApplication::execDialog( currtran ) == QDialog::Accepted ) | 531 | if ( QPEApplication::execDialog( currtran ) == QDialog::Accepted ) |
531 | { | 532 | { |
532 | curritem->setText( COL_NUM, traninfo->number() ); | 533 | curritem->setText( COL_NUM, traninfo->number() ); |
533 | curritem->setText( COL_SORTDATE, traninfo->datestr(false) ); | 534 | curritem->setText( COL_SORTDATE, traninfo->datestr(false) ); |
534 | curritem->setText( COL_DATE, traninfo->datestr(true) ); | 535 | curritem->setText( COL_DATE, traninfo->datestr(true) ); |
535 | curritem->setText( COL_DESC, traninfo->desc() ); | 536 | curritem->setText( COL_DESC, traninfo->desc() ); |
536 | 537 | ||
537 | float amount = traninfo->amount(); | 538 | float amount = traninfo->amount(); |
538 | if ( traninfo->withdrawal() ) | 539 | if ( traninfo->withdrawal() ) |
539 | { | 540 | { |
540 | amount *= -1; | 541 | amount *= -1; |
541 | } | 542 | } |
542 | QString stramount; | 543 | QString stramount; |
543 | stramount.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), amount ); | 544 | stramount.sprintf( "%s%.2f", _pCfg->getCurrencySymbol().latin1(), amount ); |
544 | curritem->setText( COL_AMOUNT, stramount ); | 545 | curritem->setText( COL_AMOUNT, stramount ); |
545 | resort(); | 546 | resort(); |
546 | adjustBalance(); | 547 | adjustBalance(); |
547 | 548 | ||
548 | // save description in list of payees, if not in there | 549 | // save description in list of payees, if not in there |
549 | QStringList *pLst=&_pCfg->getPayees(); | 550 | QStringList *pLst=&_pCfg->getPayees(); |
550 | if( _pCfg->getSavePayees() && pLst->contains(traninfo->desc())==0 ) { | 551 | if( _pCfg->getSavePayees() && pLst->contains(traninfo->desc())==0 ) { |
551 | pLst->append( traninfo->desc() ); | 552 | pLst->append( traninfo->desc() ); |
552 | pLst->sort(); | 553 | pLst->sort(); |
553 | _pCfg->setDirty(true); | 554 | _pCfg->setDirty(true); |
554 | } | 555 | } |
555 | } | 556 | } |
556 | 557 | ||
557 | delete currtran; | 558 | delete currtran; |
558 | } | 559 | } |
559 | 560 | ||
560 | // --- slotMenuTran ----------------------------------------------------------- | 561 | // --- slotMenuTran ----------------------------------------------------------- |
561 | void Checkbook::slotMenuTran(QListViewItem *item, const QPoint &pnt) | 562 | void Checkbook::slotMenuTran(QListViewItem *item, const QPoint &pnt) |
562 | { | 563 | { |
563 | // active item? | 564 | // active item? |
564 | if( !item ) | 565 | if( !item ) |
565 | return; | 566 | return; |
566 | 567 | ||
567 | // Display menu | 568 | // Display menu |
568 | QPopupMenu m; | 569 | QPopupMenu m; |
569 | m.insertItem( QWidget::tr( "Edit" ), 1 ); | 570 | m.insertItem( QWidget::tr( "Edit" ), 1 ); |
570 | m.insertItem( QWidget::tr( "New" ), 2 ); | 571 | m.insertItem( QWidget::tr( "New" ), 2 ); |
571 | m.insertItem( QWidget::tr( "Delete" ), 3 ); | 572 | m.insertItem( QWidget::tr( "Delete" ), 3 ); |
572 | int r = m.exec( pnt ); | 573 | int r = m.exec( pnt ); |
diff --git a/noncore/apps/checkbook/checkbook.h b/noncore/apps/checkbook/checkbook.h index e2f0e56..80bc106 100644 --- a/noncore/apps/checkbook/checkbook.h +++ b/noncore/apps/checkbook/checkbook.h | |||
@@ -1,150 +1,149 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. | 3 | =. |
4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> | 4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #ifndef CHECKBOOK_H | 29 | #ifndef CHECKBOOK_H |
30 | #define CHECKBOOK_H | 30 | #define CHECKBOOK_H |
31 | 31 | ||
32 | #include <opie2/otabwidget.h> | 32 | #include <opie2/otabwidget.h> |
33 | 33 | ||
34 | #include <qdatetime.h> | 34 | #include <qdatetime.h> |
35 | #include <qdialog.h> | 35 | #include <qdialog.h> |
36 | #include <qlistview.h> | 36 | #include <qlistview.h> |
37 | 37 | ||
38 | using Opie::OTabWidget; | ||
39 | 38 | ||
40 | class CBInfo; | 39 | class CBInfo; |
41 | class Graph; | 40 | class Graph; |
42 | class GraphInfo; | 41 | class GraphInfo; |
43 | class QCheckBox; | 42 | class QCheckBox; |
44 | class QComboBox; | 43 | class QComboBox; |
45 | class QLabel; | 44 | class QLabel; |
46 | class QLineEdit; | 45 | class QLineEdit; |
47 | class QListView; | 46 | class QListView; |
48 | class QMultiLineEdit; | 47 | class QMultiLineEdit; |
49 | class QString; | 48 | class QString; |
50 | class TranInfo; | 49 | class TranInfo; |
51 | class TranInfoList; | 50 | class TranInfoList; |
52 | class Cfg; | 51 | class Cfg; |
53 | class QMouseEvent; | 52 | class QMouseEvent; |
54 | 53 | ||
55 | 54 | ||
56 | // --- Checkbook -------------------------------------------------------------- | 55 | // --- Checkbook -------------------------------------------------------------- |
57 | class Checkbook : public QDialog | 56 | class Checkbook : public QDialog |
58 | { | 57 | { |
59 | Q_OBJECT | 58 | Q_OBJECT |
60 | 59 | ||
61 | public: | 60 | public: |
62 | Checkbook( QWidget *, CBInfo *, Cfg *cfg ); | 61 | Checkbook( QWidget *, CBInfo *, Cfg *cfg ); |
63 | ~Checkbook(); | 62 | ~Checkbook(); |
64 | 63 | ||
65 | // resort | 64 | // resort |
66 | void resort(); | 65 | void resort(); |
67 | 66 | ||
68 | // members | 67 | // members |
69 | TranInfoList *getTranList() { return(tranList); } | 68 | TranInfoList *getTranList() { return(tranList); } |
70 | 69 | ||
71 | private: | 70 | private: |
72 | CBInfo *info; | 71 | CBInfo *info; |
73 | TranInfoList *tranList; | 72 | TranInfoList *tranList; |
74 | Cfg *_pCfg; | 73 | Cfg *_pCfg; |
75 | 74 | ||
76 | OTabWidget *mainWidget; | 75 | Opie::Ui::OTabWidget *mainWidget; |
77 | void loadCheckbook(); | 76 | void loadCheckbook(); |
78 | void adjustBalance(); | 77 | void adjustBalance(); |
79 | 78 | ||
80 | // Info tab | 79 | // Info tab |
81 | QWidget *initInfo(); | 80 | QWidget *initInfo(); |
82 | QCheckBox *passwordCB; | 81 | QCheckBox *passwordCB; |
83 | QLineEdit *nameEdit; | 82 | QLineEdit *nameEdit; |
84 | QComboBox *typeList; | 83 | QComboBox *typeList; |
85 | QLineEdit *bankEdit; | 84 | QLineEdit *bankEdit; |
86 | QLineEdit *acctNumEdit; | 85 | QLineEdit *acctNumEdit; |
87 | QLineEdit *pinNumEdit; | 86 | QLineEdit *pinNumEdit; |
88 | QLineEdit *balanceEdit; | 87 | QLineEdit *balanceEdit; |
89 | QMultiLineEdit *notesEdit; | 88 | QMultiLineEdit *notesEdit; |
90 | int _sortCol; | 89 | int _sortCol; |
91 | 90 | ||
92 | // Transactions tab | 91 | // Transactions tab |
93 | QWidget *initTransactions(); | 92 | QWidget *initTransactions(); |
94 | QListView *tranTable; | 93 | QListView *tranTable; |
95 | QComboBox *_cbSortType; | 94 | QComboBox *_cbSortType; |
96 | QDate _dLastNew; | 95 | QDate _dLastNew; |
97 | 96 | ||
98 | // Charts tab | 97 | // Charts tab |
99 | QWidget *initCharts(); | 98 | QWidget *initCharts(); |
100 | GraphInfo *graphInfo; | 99 | GraphInfo *graphInfo; |
101 | QComboBox *graphList; | 100 | QComboBox *graphList; |
102 | Graph *graphWidget; | 101 | Graph *graphWidget; |
103 | 102 | ||
104 | void drawBalanceChart(); | 103 | void drawBalanceChart(); |
105 | void drawCategoryChart( bool = TRUE ); | 104 | void drawCategoryChart( bool = TRUE ); |
106 | 105 | ||
107 | 106 | ||
108 | protected slots: | 107 | protected slots: |
109 | void accept(); | 108 | void accept(); |
110 | void slotTab(QWidget *tab); | 109 | void slotTab(QWidget *tab); |
111 | 110 | ||
112 | private slots: | 111 | private slots: |
113 | void slotPasswordClicked(); | 112 | void slotPasswordClicked(); |
114 | void slotNameChanged( const QString & ); | 113 | void slotNameChanged( const QString & ); |
115 | void slotStartingBalanceChanged( const QString & ); | 114 | void slotStartingBalanceChanged( const QString & ); |
116 | void slotNewTran(); | 115 | void slotNewTran(); |
117 | void slotEditTran(); | 116 | void slotEditTran(); |
118 | void slotMenuTran(QListViewItem *, const QPoint &); | 117 | void slotMenuTran(QListViewItem *, const QPoint &); |
119 | void slotDeleteTran(); | 118 | void slotDeleteTran(); |
120 | void slotDrawGraph(); | 119 | void slotDrawGraph(); |
121 | void slotSortChanged( const QString & ); | 120 | void slotSortChanged( const QString & ); |
122 | }; | 121 | }; |
123 | 122 | ||
124 | 123 | ||
125 | // --- CBListItem ------------------------------------------------------------- | 124 | // --- CBListItem ------------------------------------------------------------- |
126 | class CBListItem : public QListViewItem | 125 | class CBListItem : public QListViewItem |
127 | { | 126 | { |
128 | //Q_OBJECT | 127 | //Q_OBJECT |
129 | 128 | ||
130 | public: | 129 | public: |
131 | CBListItem( TranInfo *, QListView *, QString = QString::null, QString = QString::null, | 130 | CBListItem( TranInfo *, QListView *, QString = QString::null, QString = QString::null, |
132 | QString = QString::null, QString = QString::null, QString = QString::null, | 131 | QString = QString::null, QString = QString::null, QString = QString::null, |
133 | QString = QString::null, QString = QString::null, QString = QString::null ); | 132 | QString = QString::null, QString = QString::null, QString = QString::null ); |
134 | 133 | ||
135 | void paintCell( QPainter *, const QColorGroup &, int, int, int ); | 134 | void paintCell( QPainter *, const QColorGroup &, int, int, int ); |
136 | 135 | ||
137 | // --- members | 136 | // --- members |
138 | TranInfo *getTranInfo() { return(_pTran); } | 137 | TranInfo *getTranInfo() { return(_pTran); } |
139 | 138 | ||
140 | private: | 139 | private: |
141 | TranInfo *_pTran; | 140 | TranInfo *_pTran; |
142 | QListView *owner; | 141 | QListView *owner; |
143 | bool m_known; | 142 | bool m_known; |
144 | bool m_odd; | 143 | bool m_odd; |
145 | 144 | ||
146 | bool isAltBackground(); | 145 | bool isAltBackground(); |
147 | }; | 146 | }; |
148 | 147 | ||
149 | 148 | ||
150 | #endif | 149 | #endif |
diff --git a/noncore/apps/checkbook/main.cpp b/noncore/apps/checkbook/main.cpp index 0384620..1135bee 100644 --- a/noncore/apps/checkbook/main.cpp +++ b/noncore/apps/checkbook/main.cpp | |||
@@ -1,33 +1,35 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. | 3 | =. |
4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> | 4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include <opie2/oapplicationfactory.h> | 29 | #include <opie2/oapplicationfactory.h> |
30 | 30 | ||
31 | using namespace Opie::Core; | ||
32 | using namespace Opie::Core; | ||
31 | #include "mainwindow.h" | 33 | #include "mainwindow.h" |
32 | 34 | ||
33 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) | 35 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) |
diff --git a/noncore/apps/checkbook/mainwindow.cpp b/noncore/apps/checkbook/mainwindow.cpp index 254ce6a..ce15e3e 100644 --- a/noncore/apps/checkbook/mainwindow.cpp +++ b/noncore/apps/checkbook/mainwindow.cpp | |||
@@ -1,358 +1,358 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the OPIE Project | 2 | This file is part of the OPIE Project |
3 | =. | 3 | =. |
4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> | 4 | .=l. Copyright (c) 2002 Dan Williams <drw@handhelds.org> |
5 | .>+-= | 5 | .>+-= |
6 | _;:, .> :=|. This file is free software; you can | 6 | _;:, .> :=|. This file is free software; you can |
7 | .> <`_, > . <= redistribute it and/or modify it under | 7 | .> <`_, > . <= redistribute it and/or modify it under |
8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public | 8 | :`=1 )Y*s>-.-- : the terms of the GNU General Public |
9 | .="- .-=="i, .._ License as published by the Free Software | 9 | .="- .-=="i, .._ License as published by the Free Software |
10 | - . .-<_> .<> Foundation; either version 2 of the License, | 10 | - . .-<_> .<> Foundation; either version 2 of the License, |
11 | ._= =} : or (at your option) any later version. | 11 | ._= =} : or (at your option) any later version. |
12 | .%`+i> _;_. | 12 | .%`+i> _;_. |
13 | .i_,=:_. -<s. This file is distributed in the hope that | 13 | .i_,=:_. -<s. This file is distributed in the hope that |
14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 14 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
15 | : .. .:, . . . without even the implied warranty of | 15 | : .. .:, . . . without even the implied warranty of |
16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 16 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General | 17 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU General |
18 | ..}^=.= = ; Public License for more details. | 18 | ..}^=.= = ; Public License for more details. |
19 | ++= -. .` .: | 19 | ++= -. .` .: |
20 | : = ...= . :.=- You should have received a copy of the GNU | 20 | : = ...= . :.=- You should have received a copy of the GNU |
21 | -. .:....=;==+<; General Public License along with this file; | 21 | -. .:....=;==+<; General Public License along with this file; |
22 | -_. . . )=. = see the file COPYING. If not, write to the | 22 | -_. . . )=. = see the file COPYING. If not, write to the |
23 | -- :-=` Free Software Foundation, Inc., | 23 | -- :-=` Free Software Foundation, Inc., |
24 | 59 Temple Place - Suite 330, | 24 | 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include "mainwindow.h" | 29 | #include "mainwindow.h" |
30 | #include "cbinfo.h" | 30 | #include "cbinfo.h" |
31 | #include "configuration.h" | 31 | #include "configuration.h" |
32 | #include "password.h" | 32 | #include "password.h" |
33 | #include "checkbook.h" | 33 | #include "checkbook.h" |
34 | 34 | ||
35 | #include <qpe/config.h> | 35 | #include <qpe/config.h> |
36 | #include <qpe/qpeapplication.h> | 36 | #include <qpe/qpeapplication.h> |
37 | #include <qpe/qpemessagebox.h> | 37 | #include <qpe/qpemessagebox.h> |
38 | #include <qpe/qpetoolbar.h> | 38 | #include <qtoolbar.h> |
39 | #include <qpe/resource.h> | 39 | #include <qpe/resource.h> |
40 | 40 | ||
41 | #include <qmenubar.h> | 41 | #include <qmenubar.h> |
42 | #include <qaction.h> | 42 | #include <qaction.h> |
43 | #include <qdir.h> | 43 | #include <qdir.h> |
44 | #include <qwhatsthis.h> | 44 | #include <qwhatsthis.h> |
45 | 45 | ||
46 | 46 | ||
47 | MainWindow::MainWindow( QWidget* parent, const char* name, WFlags /*fl*/ ) | 47 | MainWindow::MainWindow( QWidget* parent, const char* name, WFlags /*fl*/ ) |
48 | : QMainWindow( parent, name, WStyle_ContextHelp ) | 48 | : QMainWindow( parent, name, WStyle_ContextHelp ) |
49 | { | 49 | { |
50 | setCaption( tr( "Checkbook" ) ); | 50 | setCaption( tr( "Checkbook" ) ); |
51 | 51 | ||
52 | cbDir = Global::applicationFileName( "checkbook", "" ); | 52 | cbDir = Global::applicationFileName( "checkbook", "" ); |
53 | lockIcon = Resource::loadPixmap( "locked" ); | 53 | lockIcon = Resource::loadPixmap( "locked" ); |
54 | 54 | ||
55 | // Load configuration options | 55 | // Load configuration options |
56 | Config config( "checkbook" ); | 56 | Config config( "checkbook" ); |
57 | _cfg.readConfig( config ); | 57 | _cfg.readConfig( config ); |
58 | 58 | ||
59 | 59 | ||
60 | // Build menu and tool bars | 60 | // Build menu and tool bars |
61 | setToolBarsMovable( FALSE ); | 61 | setToolBarsMovable( FALSE ); |
62 | 62 | ||
63 | QToolBar *bar = new QToolBar( this ); | 63 | QToolBar *bar = new QToolBar( this ); |
64 | bar->setHorizontalStretchable( TRUE ); | 64 | bar->setHorizontalStretchable( TRUE ); |
65 | QMenuBar *mb = new QMenuBar( bar ); | 65 | QMenuBar *mb = new QMenuBar( bar ); |
66 | mb->setMargin( 0 ); | 66 | mb->setMargin( 0 ); |
67 | QPopupMenu *popup = new QPopupMenu( this ); | 67 | QPopupMenu *popup = new QPopupMenu( this ); |
68 | 68 | ||
69 | bar = new QToolBar( this ); | 69 | bar = new QToolBar( this ); |
70 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); | 70 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); |
71 | a->setWhatsThis( tr( "Click here to create a new checkbook.\n\nYou also can select New from the Checkbook menu." ) ); | 71 | a->setWhatsThis( tr( "Click here to create a new checkbook.\n\nYou also can select New from the Checkbook menu." ) ); |
72 | connect( a, SIGNAL( activated() ), this, SLOT( slotNew() ) ); | 72 | connect( a, SIGNAL( activated() ), this, SLOT( slotNew() ) ); |
73 | a->addTo( popup ); | 73 | a->addTo( popup ); |
74 | a->addTo( bar ); | 74 | a->addTo( bar ); |
75 | 75 | ||
76 | actionOpen = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ), QString::null, | 76 | actionOpen = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ), QString::null, |
77 | 0, this, 0 ); | 77 | 0, this, 0 ); |
78 | actionOpen->setWhatsThis( tr( "Select a checkbook and then click here to edit it.\n\nYou also can select Edit from the Checkbook menu, or click and hold on a checkbook name." ) ); | 78 | actionOpen->setWhatsThis( tr( "Select a checkbook and then click here to edit it.\n\nYou also can select Edit from the Checkbook menu, or click and hold on a checkbook name." ) ); |
79 | connect( actionOpen, SIGNAL( activated() ), this, SLOT( slotEdit() ) ); | 79 | connect( actionOpen, SIGNAL( activated() ), this, SLOT( slotEdit() ) ); |
80 | actionOpen->addTo( popup ); | 80 | actionOpen->addTo( popup ); |
81 | actionOpen->addTo( bar ); | 81 | actionOpen->addTo( bar ); |
82 | 82 | ||
83 | actionDelete = new QAction( tr( "Delete" ), Resource::loadPixmap( "trash" ), QString::null, | 83 | actionDelete = new QAction( tr( "Delete" ), Resource::loadPixmap( "trash" ), QString::null, |
84 | 0, this, 0 ); | 84 | 0, this, 0 ); |
85 | actionDelete->setWhatsThis( tr( "Select a checkbook and then click here delete it.\n\nYou also can select Delete from the Checkbook menu." ) ); | 85 | actionDelete->setWhatsThis( tr( "Select a checkbook and then click here delete it.\n\nYou also can select Delete from the Checkbook menu." ) ); |
86 | connect( actionDelete, SIGNAL( activated() ), this, SLOT( slotDelete() ) ); | 86 | connect( actionDelete, SIGNAL( activated() ), this, SLOT( slotDelete() ) ); |
87 | actionDelete->addTo( popup ); | 87 | actionDelete->addTo( popup ); |
88 | actionDelete->addTo( bar ); | 88 | actionDelete->addTo( bar ); |
89 | 89 | ||
90 | popup->insertSeparator(); | 90 | popup->insertSeparator(); |
91 | 91 | ||
92 | a = new QAction( tr( "Configure" ), Resource::loadPixmap( "SettingsIcon" ), QString::null, 0, this, 0 ); | 92 | a = new QAction( tr( "Configure" ), Resource::loadPixmap( "SettingsIcon" ), QString::null, 0, this, 0 ); |
93 | a->setWhatsThis( tr( "Click here to configure this app." ) ); | 93 | a->setWhatsThis( tr( "Click here to configure this app." ) ); |
94 | connect( a, SIGNAL( activated() ), this, SLOT( slotConfigure() ) ); | 94 | connect( a, SIGNAL( activated() ), this, SLOT( slotConfigure() ) ); |
95 | a->addTo( popup ); | 95 | a->addTo( popup ); |
96 | a->addTo( bar ); | 96 | a->addTo( bar ); |
97 | 97 | ||
98 | mb->insertItem( tr( "Checkbook" ), popup ); | 98 | mb->insertItem( tr( "Checkbook" ), popup ); |
99 | 99 | ||
100 | // Load Checkbook selection list | 100 | // Load Checkbook selection list |
101 | checkbooks = new CBInfoList(); | 101 | checkbooks = new CBInfoList(); |
102 | 102 | ||
103 | QDir checkdir( cbDir ); | 103 | QDir checkdir( cbDir ); |
104 | if (checkdir.exists() == true) | 104 | if (checkdir.exists() == true) |
105 | { | 105 | { |
106 | QStringList cblist = checkdir.entryList( "*.qcb", QDir::Files|QDir::Readable|QDir::Writable, | 106 | QStringList cblist = checkdir.entryList( "*.qcb", QDir::Files|QDir::Readable|QDir::Writable, |
107 | QDir::Time ); | 107 | QDir::Time ); |
108 | CBInfo *cb = 0x0; | 108 | CBInfo *cb = 0x0; |
109 | QString filename; | 109 | QString filename; |
110 | 110 | ||
111 | for ( QStringList::Iterator it = cblist.begin(); it != cblist.end(); it++ ) | 111 | for ( QStringList::Iterator it = cblist.begin(); it != cblist.end(); it++ ) |
112 | { | 112 | { |
113 | filename = cbDir; | 113 | filename = cbDir; |
114 | filename.append( (*it) ); | 114 | filename.append( (*it) ); |
115 | 115 | ||
116 | cb = new CBInfo( (*it).remove( (*it).find('.'), (*it).length() ), filename ); | 116 | cb = new CBInfo( (*it).remove( (*it).find('.'), (*it).length() ), filename ); |
117 | checkbooks->inSort( cb ); | 117 | checkbooks->inSort( cb ); |
118 | } | 118 | } |
119 | } | 119 | } |
120 | 120 | ||
121 | // Build Checkbook selection list control | 121 | // Build Checkbook selection list control |
122 | cbList = 0x0; | 122 | cbList = 0x0; |
123 | buildList(); | 123 | buildList(); |
124 | 124 | ||
125 | // open last book? | 125 | // open last book? |
126 | if( _cfg.isOpenLastBook() ) { | 126 | if( _cfg.isOpenLastBook() ) { |
127 | this->show(); | 127 | this->show(); |
128 | this->showMaximized(); | 128 | this->showMaximized(); |
129 | QListViewItem *itm=cbList->firstChild(); | 129 | QListViewItem *itm=cbList->firstChild(); |
130 | while( itm ) { | 130 | while( itm ) { |
131 | if( itm->text(posName)==_cfg.getLastBook() ) { | 131 | if( itm->text(posName)==_cfg.getLastBook() ) { |
132 | openBook( itm ); | 132 | openBook( itm ); |
133 | break; | 133 | break; |
134 | } | 134 | } |
135 | itm=itm->nextSibling(); | 135 | itm=itm->nextSibling(); |
136 | } | 136 | } |
137 | } | 137 | } |
138 | } | 138 | } |
139 | 139 | ||
140 | 140 | ||
141 | // --- ~MainWindow ------------------------------------------------------------ | 141 | // --- ~MainWindow ------------------------------------------------------------ |
142 | MainWindow::~MainWindow() | 142 | MainWindow::~MainWindow() |
143 | { | 143 | { |
144 | writeConfig(); | 144 | writeConfig(); |
145 | } | 145 | } |
146 | 146 | ||
147 | 147 | ||
148 | // --- buildList -------------------------------------------------------------- | 148 | // --- buildList -------------------------------------------------------------- |
149 | void MainWindow::buildList() | 149 | void MainWindow::buildList() |
150 | { | 150 | { |
151 | if ( cbList ) | 151 | if ( cbList ) |
152 | delete cbList; | 152 | delete cbList; |
153 | 153 | ||
154 | cbList = new QListView( this ); | 154 | cbList = new QListView( this ); |
155 | QWhatsThis::add( cbList, tr( "This is a listing of all checkbooks currently available." ) ); | 155 | QWhatsThis::add( cbList, tr( "This is a listing of all checkbooks currently available." ) ); |
156 | 156 | ||
157 | if ( _cfg.getShowLocks() ) | 157 | if ( _cfg.getShowLocks() ) |
158 | { | 158 | { |
159 | cbList->addColumn( Resource::loadIconSet( "locked" ), "", 24 ); | 159 | cbList->addColumn( Resource::loadIconSet( "locked" ), "", 24 ); |
160 | posName = 1; | 160 | posName = 1; |
161 | } | 161 | } |
162 | else | 162 | else |
163 | { | 163 | { |
164 | posName = 0; | 164 | posName = 0; |
165 | } | 165 | } |
166 | cbList->addColumn( tr( "Checkbook Name" ) ); | 166 | cbList->addColumn( tr( "Checkbook Name" ) ); |
167 | if ( _cfg.getShowBalances() ) | 167 | if ( _cfg.getShowBalances() ) |
168 | { | 168 | { |
169 | int colnum = cbList->addColumn( tr( "Balance" ) ); | 169 | int colnum = cbList->addColumn( tr( "Balance" ) ); |
170 | cbList->setColumnAlignment( colnum, Qt::AlignRight ); | 170 | cbList->setColumnAlignment( colnum, Qt::AlignRight ); |
171 | } | 171 | } |
172 | cbList->setAllColumnsShowFocus( TRUE ); | 172 | cbList->setAllColumnsShowFocus( TRUE ); |
173 | cbList->setSorting( posName ); | 173 | cbList->setSorting( posName ); |
174 | QPEApplication::setStylusOperation( cbList->viewport(), QPEApplication::RightOnHold ); | 174 | QPEApplication::setStylusOperation( cbList->viewport(), QPEApplication::RightOnHold ); |
175 | connect( cbList, SIGNAL( rightButtonPressed(QListViewItem*,const QPoint&,int) ), | 175 | connect( cbList, SIGNAL( rightButtonPressed(QListViewItem*,const QPoint&,int) ), |
176 | this, SLOT( slotEdit() ) ); | 176 | this, SLOT( slotEdit() ) ); |
177 | setCentralWidget( cbList ); | 177 | setCentralWidget( cbList ); |
178 | 178 | ||
179 | for ( CBInfo *cb = checkbooks->first(); cb; cb = checkbooks->next() ) | 179 | for ( CBInfo *cb = checkbooks->first(); cb; cb = checkbooks->next() ) |
180 | { | 180 | { |
181 | addCheckbook( cb ); | 181 | addCheckbook( cb ); |
182 | } | 182 | } |
183 | } | 183 | } |
184 | 184 | ||
185 | void MainWindow::addCheckbook( CBInfo *cb ) | 185 | void MainWindow::addCheckbook( CBInfo *cb ) |
186 | { | 186 | { |
187 | QListViewItem *lvi = new QListViewItem( cbList ); | 187 | QListViewItem *lvi = new QListViewItem( cbList ); |
188 | if ( _cfg.getShowLocks() && !cb->password().isNull() ) | 188 | if ( _cfg.getShowLocks() && !cb->password().isNull() ) |
189 | { | 189 | { |
190 | lvi->setPixmap( 0, lockIcon ); | 190 | lvi->setPixmap( 0, lockIcon ); |
191 | } | 191 | } |
192 | lvi->setText( posName, cb->name() ); | 192 | lvi->setText( posName, cb->name() ); |
193 | if ( _cfg.getShowBalances() ) | 193 | if ( _cfg.getShowBalances() ) |
194 | { | 194 | { |
195 | QString balance; | 195 | QString balance; |
196 | balance.sprintf( "%s%.2f", _cfg.getCurrencySymbol().latin1(), cb->balance() ); | 196 | balance.sprintf( "%s%.2f", _cfg.getCurrencySymbol().latin1(), cb->balance() ); |
197 | lvi->setText( posName + 1, balance ); | 197 | lvi->setText( posName + 1, balance ); |
198 | } | 198 | } |
199 | } | 199 | } |
200 | 200 | ||
201 | void MainWindow::buildFilename( const QString &name ) | 201 | void MainWindow::buildFilename( const QString &name ) |
202 | { | 202 | { |
203 | tempFilename = cbDir; | 203 | tempFilename = cbDir; |
204 | tempFilename.append( name ); | 204 | tempFilename.append( name ); |
205 | tempFilename.append( ".qcb" ); | 205 | tempFilename.append( ".qcb" ); |
206 | } | 206 | } |
207 | 207 | ||
208 | void MainWindow::slotNew() | 208 | void MainWindow::slotNew() |
209 | { | 209 | { |
210 | CBInfo *cb = new CBInfo(); | 210 | CBInfo *cb = new CBInfo(); |
211 | 211 | ||
212 | Checkbook *currcb = new Checkbook( this, cb, &_cfg ); | 212 | Checkbook *currcb = new Checkbook( this, cb, &_cfg ); |
213 | if ( QPEApplication::execDialog( currcb ) == QDialog::Accepted ) | 213 | if ( QPEApplication::execDialog( currcb ) == QDialog::Accepted ) |
214 | { | 214 | { |
215 | // Save new checkbook | 215 | // Save new checkbook |
216 | buildFilename( cb->name() ); | 216 | buildFilename( cb->name() ); |
217 | _cfg.setLastBook( cb->name() ); | 217 | _cfg.setLastBook( cb->name() ); |
218 | cb->setFilename( tempFilename ); | 218 | cb->setFilename( tempFilename ); |
219 | cb->write(); | 219 | cb->write(); |
220 | 220 | ||
221 | // Add to listbox | 221 | // Add to listbox |
222 | checkbooks->inSort( cb ); | 222 | checkbooks->inSort( cb ); |
223 | addCheckbook( cb ); | 223 | addCheckbook( cb ); |
224 | } | 224 | } |
225 | delete currcb; | 225 | delete currcb; |
226 | } | 226 | } |
227 | 227 | ||
228 | // --- slotEdit --------------------------------------------------------------- | 228 | // --- slotEdit --------------------------------------------------------------- |
229 | void MainWindow::slotEdit() | 229 | void MainWindow::slotEdit() |
230 | { | 230 | { |
231 | // get name and open it | 231 | // get name and open it |
232 | QListViewItem *curritem = cbList->currentItem(); | 232 | QListViewItem *curritem = cbList->currentItem(); |
233 | if ( !curritem ) | 233 | if ( !curritem ) |
234 | return; | 234 | return; |
235 | openBook( curritem ); | 235 | openBook( curritem ); |
236 | } | 236 | } |
237 | 237 | ||
238 | 238 | ||
239 | // --- openBook --------------------------------------------------------------- | 239 | // --- openBook --------------------------------------------------------------- |
240 | void MainWindow::openBook(QListViewItem *curritem) | 240 | void MainWindow::openBook(QListViewItem *curritem) |
241 | { | 241 | { |
242 | // find book in List | 242 | // find book in List |
243 | QString currname=curritem->text(posName); | 243 | QString currname=curritem->text(posName); |
244 | CBInfo *cb = checkbooks->first(); | 244 | CBInfo *cb = checkbooks->first(); |
245 | while ( cb ) { | 245 | while ( cb ) { |
246 | if ( cb->name() == currname ) | 246 | if ( cb->name() == currname ) |
247 | break; | 247 | break; |
248 | cb = checkbooks->next(); | 248 | cb = checkbooks->next(); |
249 | } | 249 | } |
250 | if ( !cb ) return; | 250 | if ( !cb ) return; |
251 | 251 | ||
252 | // | 252 | // |
253 | buildFilename( currname ); | 253 | buildFilename( currname ); |
254 | float currbalance = cb->balance(); | 254 | float currbalance = cb->balance(); |
255 | bool currlock = !cb->password().isNull(); | 255 | bool currlock = !cb->password().isNull(); |
256 | 256 | ||
257 | if ( currlock ) | 257 | if ( currlock ) |
258 | { | 258 | { |
259 | Password *pw = new Password( this, tr( "Enter password" ), tr( "Please enter your password:" ) ); | 259 | Password *pw = new Password( this, tr( "Enter password" ), tr( "Please enter your password:" ) ); |
260 | if ( pw->exec() != QDialog::Accepted || pw->password != cb->password() ) | 260 | if ( pw->exec() != QDialog::Accepted || pw->password != cb->password() ) |
261 | { | 261 | { |
262 | delete pw; | 262 | delete pw; |
263 | return; | 263 | return; |
264 | } | 264 | } |
265 | delete pw; | 265 | delete pw; |
266 | } | 266 | } |
267 | 267 | ||
268 | _cfg.setLastBook( currname ); | 268 | _cfg.setLastBook( currname ); |
269 | Checkbook *currcb = new Checkbook( this, cb, &_cfg ); | 269 | Checkbook *currcb = new Checkbook( this, cb, &_cfg ); |
270 | if ( QPEApplication::execDialog( currcb ) == QDialog::Accepted ) | 270 | if ( QPEApplication::execDialog( currcb ) == QDialog::Accepted ) |
271 | { | 271 | { |
272 | QString newname = cb->name(); | 272 | QString newname = cb->name(); |
273 | if ( currname != newname ) | 273 | if ( currname != newname ) |
274 | { | 274 | { |
275 | // Update name if changed | 275 | // Update name if changed |
276 | if( curritem ) { | 276 | if( curritem ) { |
277 | curritem->setText( posName, newname ); | 277 | curritem->setText( posName, newname ); |
278 | cbList->sort(); | 278 | cbList->sort(); |
279 | } | 279 | } |
280 | _cfg.setLastBook( newname ); | 280 | _cfg.setLastBook( newname ); |
281 | 281 | ||
282 | // Remove old file | 282 | // Remove old file |
283 | QFile f( tempFilename ); | 283 | QFile f( tempFilename ); |
284 | if ( f.exists() ) | 284 | if ( f.exists() ) |
285 | f.remove(); | 285 | f.remove(); |
286 | 286 | ||
287 | // Get new filename | 287 | // Get new filename |
288 | buildFilename( newname ); | 288 | buildFilename( newname ); |
289 | cb->setFilename( tempFilename ); | 289 | cb->setFilename( tempFilename ); |
290 | } | 290 | } |
291 | 291 | ||
292 | cb->write(); | 292 | cb->write(); |
293 | 293 | ||
294 | // Update lock if changed | 294 | // Update lock if changed |
295 | if ( _cfg.getShowLocks() && !cb->password().isNull() != currlock ) | 295 | if ( _cfg.getShowLocks() && !cb->password().isNull() != currlock ) |
296 | { | 296 | { |
297 | if ( !cb->password().isNull() ) | 297 | if ( !cb->password().isNull() ) |
298 | curritem->setPixmap( 0, lockIcon ); | 298 | curritem->setPixmap( 0, lockIcon ); |
299 | else | 299 | else |
300 | curritem->setPixmap( 0, nullIcon ); | 300 | curritem->setPixmap( 0, nullIcon ); |
301 | } | 301 | } |
302 | 302 | ||
303 | // Update balance if changed | 303 | // Update balance if changed |
304 | if ( _cfg.getShowBalances() && cb->balance() != currbalance ) | 304 | if ( _cfg.getShowBalances() && cb->balance() != currbalance ) |
305 | { | 305 | { |
306 | QString tempstr; | 306 | QString tempstr; |
307 | tempstr.sprintf( "%s%.2f", _cfg.getCurrencySymbol().latin1(), cb->balance() ); | 307 | tempstr.sprintf( "%s%.2f", _cfg.getCurrencySymbol().latin1(), cb->balance() ); |
308 | curritem->setText( posName + 1, tempstr ); | 308 | curritem->setText( posName + 1, tempstr ); |
309 | } | 309 | } |
310 | 310 | ||
311 | // write config, if needed | 311 | // write config, if needed |
312 | if( _cfg.isDirty() ) { | 312 | if( _cfg.isDirty() ) { |
313 | Config config("checkbook"); | 313 | Config config("checkbook"); |
314 | _cfg.writeConfig( config ); | 314 | _cfg.writeConfig( config ); |
315 | } | 315 | } |
316 | } | 316 | } |
317 | delete currcb; | 317 | delete currcb; |
318 | } | 318 | } |
319 | 319 | ||
320 | // --- slotDelete ------------------------------------------------------------- | 320 | // --- slotDelete ------------------------------------------------------------- |
321 | void MainWindow::slotDelete() | 321 | void MainWindow::slotDelete() |
322 | { | 322 | { |
323 | QString currname = cbList->currentItem()->text( posName ); | 323 | QString currname = cbList->currentItem()->text( posName ); |
324 | 324 | ||
325 | if ( QPEMessageBox::confirmDelete ( this, tr( "Delete checkbook" ), currname ) ) | 325 | if ( QPEMessageBox::confirmDelete ( this, tr( "Delete checkbook" ), currname ) ) |
326 | { | 326 | { |
327 | buildFilename( currname ); | 327 | buildFilename( currname ); |
328 | QFile f( tempFilename ); | 328 | QFile f( tempFilename ); |
329 | if ( f.exists() ) | 329 | if ( f.exists() ) |
330 | { | 330 | { |
331 | f.remove(); | 331 | f.remove(); |
332 | } | 332 | } |
333 | 333 | ||
334 | delete cbList->currentItem(); | 334 | delete cbList->currentItem(); |
335 | } | 335 | } |
336 | } | 336 | } |
337 | 337 | ||
338 | // --- slotConfigure ---------------------------------------------------------- | 338 | // --- slotConfigure ---------------------------------------------------------- |
339 | void MainWindow::slotConfigure() | 339 | void MainWindow::slotConfigure() |
340 | { | 340 | { |
341 | Configuration *cfgdlg = new Configuration( this, _cfg ); | 341 | Configuration *cfgdlg = new Configuration( this, _cfg ); |
342 | if ( QPEApplication::execDialog( cfgdlg ) == QDialog::Accepted ) | 342 | if ( QPEApplication::execDialog( cfgdlg ) == QDialog::Accepted ) |
343 | { | 343 | { |
344 | // read data from config dialog & save it | 344 | // read data from config dialog & save it |
345 | cfgdlg->saveConfig( _cfg ); | 345 | cfgdlg->saveConfig( _cfg ); |
346 | writeConfig(); | 346 | writeConfig(); |
347 | buildList(); | 347 | buildList(); |
348 | } | 348 | } |
349 | delete cfgdlg; | 349 | delete cfgdlg; |
350 | } | 350 | } |
351 | 351 | ||
352 | 352 | ||
353 | // --- writeConfig -------------------------------------------------------------- | 353 | // --- writeConfig -------------------------------------------------------------- |
354 | void MainWindow::writeConfig() | 354 | void MainWindow::writeConfig() |
355 | { | 355 | { |
356 | Config config("checkbook"); | 356 | Config config("checkbook"); |
357 | _cfg.writeConfig( config ); | 357 | _cfg.writeConfig( config ); |
358 | } | 358 | } |
diff --git a/noncore/apps/confedit/main.cpp b/noncore/apps/confedit/main.cpp index 584e6b2..3a010dd 100644 --- a/noncore/apps/confedit/main.cpp +++ b/noncore/apps/confedit/main.cpp | |||
@@ -1,5 +1,6 @@ | |||
1 | |||
2 | #include "mainwindow.h" | 1 | #include "mainwindow.h" |
3 | #include <opie2/oapplicationfactory.h> | 2 | #include <opie2/oapplicationfactory.h> |
4 | 3 | ||
4 | using namespace Opie::Core; | ||
5 | |||
5 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) | 6 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) |
diff --git a/noncore/apps/odict/main.cpp b/noncore/apps/odict/main.cpp index d5b08d3..7729d5f 100644 --- a/noncore/apps/odict/main.cpp +++ b/noncore/apps/odict/main.cpp | |||
@@ -1,24 +1,26 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | application: : ODict | 2 | application: : ODict |
3 | 3 | ||
4 | begin : December 2002 | 4 | begin : December 2002 |
5 | copyright : ( C ) 2002, 2003 by Carsten Niehaus | 5 | copyright : ( C ) 2002, 2003 by Carsten Niehaus |
6 | email : cniehaus@handhelds.org | 6 | email : cniehaus@handhelds.org |
7 | **************************************************************************/ | 7 | **************************************************************************/ |
8 | 8 | ||
9 | /*************************************************************************** | 9 | /*************************************************************************** |
10 | * * | 10 | * * |
11 | * This program is free software; you can redistribute it and/or modify * | 11 | * This program is free software; you can redistribute it and/or modify * |
12 | * it under the terms of the GNU General Public License as published by * | 12 | * it under the terms of the GNU General Public License as published by * |
13 | * the Free Software Foundation; either version 2 of the License, or * | 13 | * the Free Software Foundation; either version 2 of the License, or * |
14 | * ( at your option ) any later version. * | 14 | * ( at your option ) any later version. * |
15 | * * | 15 | * * |
16 | **************************************************************************/ | 16 | **************************************************************************/ |
17 | 17 | ||
18 | 18 | ||
19 | #include <opie2/oapplicationfactory.h> | 19 | #include <opie2/oapplicationfactory.h> |
20 | 20 | ||
21 | #include "odict.h" | 21 | #include "odict.h" |
22 | 22 | ||
23 | 23 | ||
24 | using namespace Opie::Core; | ||
25 | using namespace Opie::Core; | ||
24 | OPIE_EXPORT_APP( OApplicationFactory<ODict> ) | 26 | OPIE_EXPORT_APP( OApplicationFactory<ODict> ) |
diff --git a/noncore/apps/odict/searchmethoddlg.cpp b/noncore/apps/odict/searchmethoddlg.cpp index f71cfd8..34e8b16 100644 --- a/noncore/apps/odict/searchmethoddlg.cpp +++ b/noncore/apps/odict/searchmethoddlg.cpp | |||
@@ -1,109 +1,108 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | application: : ODict | 2 | application: : ODict |
3 | 3 | ||
4 | begin : December 2002 | 4 | begin : December 2002 |
5 | copyright : ( C ) 2002, 2003 by Carsten Niehaus | 5 | copyright : ( C ) 2002, 2003 by Carsten Niehaus |
6 | email : cniehaus@handhelds.org | 6 | email : cniehaus@handhelds.org |
7 | **************************************************************************/ | 7 | **************************************************************************/ |
8 | 8 | ||
9 | /*************************************************************************** | 9 | /*************************************************************************** |
10 | * * | 10 | * * |
11 | * This program is free software; you can redistribute it and/or modify * | 11 | * This program is free software; you can redistribute it and/or modify * |
12 | * it under the terms of the GNU General Public License as published by * | 12 | * it under the terms of the GNU General Public License as published by * |
13 | * the Free Software Foundation; either version 2 of the License, or * | 13 | * the Free Software Foundation; either version 2 of the License, or * |
14 | * ( at your option ) any later version. * | 14 | * ( at your option ) any later version. * |
15 | * * | 15 | * * |
16 | **************************************************************************/ | 16 | **************************************************************************/ |
17 | #include "searchmethoddlg.h" | 17 | #include "searchmethoddlg.h" |
18 | 18 | ||
19 | #include <opie2/ofileselector.h> | 19 | #include <opie2/ofileselector.h> |
20 | #include <opie2/ofiledialog.h> | 20 | #include <opie2/ofiledialog.h> |
21 | 21 | ||
22 | #include <qpe/config.h> | 22 | #include <qpe/config.h> |
23 | #include <qpe/qpeapplication.h> | 23 | #include <qpe/qpeapplication.h> |
24 | 24 | ||
25 | #include <qlayout.h> | 25 | #include <qlayout.h> |
26 | #include <qvbox.h> | 26 | #include <qvbox.h> |
27 | #include <qlabel.h> | 27 | #include <qlabel.h> |
28 | #include <qpushbutton.h> | 28 | #include <qpushbutton.h> |
29 | #include <qlineedit.h> | 29 | #include <qlineedit.h> |
30 | #include <qdir.h> | 30 | #include <qdir.h> |
31 | 31 | ||
32 | using Opie::OFileDialog; | 32 | using namespace Opie::Ui; |
33 | using Opie::OFileSelector; | ||
34 | 33 | ||
35 | SearchMethodDlg::SearchMethodDlg(QWidget *parent, const char *name, bool modal, QString itemname) : QDialog(parent, name, modal) | 34 | SearchMethodDlg::SearchMethodDlg(QWidget *parent, const char *name, bool modal, QString itemname) : QDialog(parent, name, modal) |
36 | { | 35 | { |
37 | 36 | ||
38 | QVBoxLayout *vbox_layout = new QVBoxLayout( this, 4,4,"vbox_layout" ); | 37 | QVBoxLayout *vbox_layout = new QVBoxLayout( this, 4,4,"vbox_layout" ); |
39 | QVBox *vbox = new QVBox( this ); | 38 | QVBox *vbox = new QVBox( this ); |
40 | 39 | ||
41 | QHBox *hbox1 = new QHBox( vbox ); | 40 | QHBox *hbox1 = new QHBox( vbox ); |
42 | QLabel *nameLabel = new QLabel( tr( "Name:" ) , hbox1 ); | 41 | QLabel *nameLabel = new QLabel( tr( "Name:" ) , hbox1 ); |
43 | nameLE = new QLineEdit( hbox1 ); | 42 | nameLE = new QLineEdit( hbox1 ); |
44 | 43 | ||
45 | QLabel *dictLabel = new QLabel( tr( "Dictionary file" ), vbox ); | 44 | QLabel *dictLabel = new QLabel( tr( "Dictionary file" ), vbox ); |
46 | QHBox *hbox2 = new QHBox( vbox ); | 45 | QHBox *hbox2 = new QHBox( vbox ); |
47 | dictFileLE = new QLineEdit( hbox2 ); | 46 | dictFileLE = new QLineEdit( hbox2 ); |
48 | QPushButton *browseButton = new QPushButton( tr( "Browse" ) , hbox2 ); | 47 | QPushButton *browseButton = new QPushButton( tr( "Browse" ) , hbox2 ); |
49 | connect( browseButton, SIGNAL( clicked() ), this, SLOT( slotBrowse() ) ); | 48 | connect( browseButton, SIGNAL( clicked() ), this, SLOT( slotBrowse() ) ); |
50 | 49 | ||
51 | QWidget *dummywidget = new QWidget( vbox ); | 50 | QWidget *dummywidget = new QWidget( vbox ); |
52 | QLabel *lag1 = new QLabel( tr( "Language 1" ),dummywidget); | 51 | QLabel *lag1 = new QLabel( tr( "Language 1" ),dummywidget); |
53 | QLabel *devider = new QLabel( tr( "Decollator" ),dummywidget); | 52 | QLabel *devider = new QLabel( tr( "Decollator" ),dummywidget); |
54 | QLabel *lag2 = new QLabel( tr( "Language 2" ),dummywidget); | 53 | QLabel *lag2 = new QLabel( tr( "Language 2" ),dummywidget); |
55 | lang1 = new QLineEdit( dummywidget ); | 54 | lang1 = new QLineEdit( dummywidget ); |
56 | lang2 = new QLineEdit( dummywidget ); | 55 | lang2 = new QLineEdit( dummywidget ); |
57 | trenner = new QLineEdit( dummywidget ); | 56 | trenner = new QLineEdit( dummywidget ); |
58 | trenner->setText( "::" ); | 57 | trenner->setText( "::" ); |
59 | 58 | ||
60 | QGridLayout *grid = new QGridLayout( dummywidget, 2,3 ); | 59 | QGridLayout *grid = new QGridLayout( dummywidget, 2,3 ); |
61 | grid->addWidget( lag1, 0,0 ); | 60 | grid->addWidget( lag1, 0,0 ); |
62 | grid->addWidget( devider, 0,1 ); | 61 | grid->addWidget( devider, 0,1 ); |
63 | grid->addWidget( lag2, 0,2 ); | 62 | grid->addWidget( lag2, 0,2 ); |
64 | grid->addWidget( lang1, 1,0 ); | 63 | grid->addWidget( lang1, 1,0 ); |
65 | grid->addWidget( trenner, 1,1 ); | 64 | grid->addWidget( trenner, 1,1 ); |
66 | grid->addWidget( lang2, 1,2 ); | 65 | grid->addWidget( lang2, 1,2 ); |
67 | 66 | ||
68 | vbox_layout->addWidget( vbox ); | 67 | vbox_layout->addWidget( vbox ); |
69 | 68 | ||
70 | QPEApplication::execDialog ( this ); | 69 | QPEApplication::execDialog ( this ); |
71 | 70 | ||
72 | if( !itemname ) | 71 | if( !itemname ) |
73 | setCaption( tr( "New Searchmethod" ) ); | 72 | setCaption( tr( "New Searchmethod" ) ); |
74 | else | 73 | else |
75 | { | 74 | { |
76 | setCaption( tr( "Change Searchmethod" ) ); | 75 | setCaption( tr( "Change Searchmethod" ) ); |
77 | itemName = itemname; | 76 | itemName = itemname; |
78 | setupEntries(itemname); | 77 | setupEntries(itemname); |
79 | } | 78 | } |
80 | } | 79 | } |
81 | 80 | ||
82 | void SearchMethodDlg::setupEntries( QString item ) | 81 | void SearchMethodDlg::setupEntries( QString item ) |
83 | { | 82 | { |
84 | Config cfg( "odict" ); | 83 | Config cfg( "odict" ); |
85 | cfg.setGroup( "Method_"+itemName ); | 84 | cfg.setGroup( "Method_"+itemName ); |
86 | trenner->setText( cfg.readEntry( "Seperator" ) ); | 85 | trenner->setText( cfg.readEntry( "Seperator" ) ); |
87 | lang1->setText( cfg.readEntry( "Lang1" ) ); | 86 | lang1->setText( cfg.readEntry( "Lang1" ) ); |
88 | lang2->setText( cfg.readEntry( "Lang2" ) ); | 87 | lang2->setText( cfg.readEntry( "Lang2" ) ); |
89 | nameLE->setText( itemName ); | 88 | nameLE->setText( itemName ); |
90 | dictFileLE->setText( cfg.readEntry( "file" ) ); | 89 | dictFileLE->setText( cfg.readEntry( "file" ) ); |
91 | } | 90 | } |
92 | 91 | ||
93 | void SearchMethodDlg::slotBrowse() | 92 | void SearchMethodDlg::slotBrowse() |
94 | { | 93 | { |
95 | itemName=OFileDialog::getOpenFileName( OFileSelector::EXTENDED,QDir::homeDirPath()); | 94 | itemName=OFileDialog::getOpenFileName( OFileSelector::EXTENDED,QDir::homeDirPath()); |
96 | dictFileLE->setText( itemName ); | 95 | dictFileLE->setText( itemName ); |
97 | } | 96 | } |
98 | 97 | ||
99 | void SearchMethodDlg::saveItem() | 98 | void SearchMethodDlg::saveItem() |
100 | { | 99 | { |
101 | QString name = nameLE->text(); | 100 | QString name = nameLE->text(); |
102 | Config cfg( "odict" ); | 101 | Config cfg( "odict" ); |
103 | cfg.setGroup( "Method_"+name ); | 102 | cfg.setGroup( "Method_"+name ); |
104 | cfg.writeEntry( "Name", name ); | 103 | cfg.writeEntry( "Name", name ); |
105 | cfg.writeEntry( "Seperator", trenner->text() ); | 104 | cfg.writeEntry( "Seperator", trenner->text() ); |
106 | cfg.writeEntry( "Lang1", lang1->text() ); | 105 | cfg.writeEntry( "Lang1", lang1->text() ); |
107 | cfg.writeEntry( "Lang2", lang2->text() ); | 106 | cfg.writeEntry( "Lang2", lang2->text() ); |
108 | cfg.writeEntry( "file", dictFileLE->text() ); | 107 | cfg.writeEntry( "file", dictFileLE->text() ); |
109 | } | 108 | } |
diff --git a/noncore/apps/opie-bartender/bartender.cpp b/noncore/apps/opie-bartender/bartender.cpp index b6401ed..e6cb515 100644 --- a/noncore/apps/opie-bartender/bartender.cpp +++ b/noncore/apps/opie-bartender/bartender.cpp | |||
@@ -1,432 +1,432 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** | 2 | ** |
3 | ** Created: Sat Jul 20 08:10:53 2002 | 3 | ** Created: Sat Jul 20 08:10:53 2002 |
4 | ** by: L.J. Potter <ljp@llornkcor.com> | 4 | ** by: L.J. Potter <ljp@llornkcor.com> |
5 | ** copyright : (C) 2002 by ljp | 5 | ** copyright : (C) 2002 by ljp |
6 | email : ljp@llornkcor.com | 6 | email : ljp@llornkcor.com |
7 | * This program is free software; you can redistribute it and/or modify * | 7 | * This program is free software; you can redistribute it and/or modify * |
8 | * it under the terms of the GNU General Public License as published by * | 8 | * it under the terms of the GNU General Public License as published by * |
9 | * the Free Software Foundation; either version 2 of the License, or * | 9 | * the Free Software Foundation; either version 2 of the License, or * |
10 | * (at your option) any later version. * | 10 | * (at your option) any later version. * |
11 | ***************************************************************************/ | 11 | ***************************************************************************/ |
12 | 12 | ||
13 | #include "bartender.h" | 13 | #include "bartender.h" |
14 | #include "showdrinks.h" | 14 | #include "showdrinks.h" |
15 | #include "inputDialog.h" | 15 | #include "inputDialog.h" |
16 | #include "searchresults.h" | 16 | #include "searchresults.h" |
17 | #include "bac.h" | 17 | #include "bac.h" |
18 | 18 | ||
19 | #include <qpe/qpetoolbar.h> | 19 | #include <qtoolbar.h> |
20 | #include <qmenubar.h> | 20 | #include <qmenubar.h> |
21 | //#include <opie2/colorpopupmenu.h> | 21 | //#include <opie2/colorpopupmenu.h> |
22 | #include <qpe/qpeapplication.h> | 22 | #include <qpe/qpeapplication.h> |
23 | #include <qpe/resource.h> | 23 | #include <qpe/resource.h> |
24 | 24 | ||
25 | #include <qlineedit.h> | 25 | #include <qlineedit.h> |
26 | #include <qdir.h> | 26 | #include <qdir.h> |
27 | #include <qpushbutton.h> | 27 | #include <qpushbutton.h> |
28 | #include <qlistbox.h> | 28 | #include <qlistbox.h> |
29 | #include <qmultilineedit.h> | 29 | #include <qmultilineedit.h> |
30 | #include <qmessagebox.h> | 30 | #include <qmessagebox.h> |
31 | #include <qtextstream.h> | 31 | #include <qtextstream.h> |
32 | #include <qaction.h> | 32 | #include <qaction.h> |
33 | #include <qheader.h> | 33 | #include <qheader.h> |
34 | #include <qlistview.h> | 34 | #include <qlistview.h> |
35 | #include <qlayout.h> | 35 | #include <qlayout.h> |
36 | 36 | ||
37 | #include <fcntl.h> | 37 | #include <fcntl.h> |
38 | #include <unistd.h> | 38 | #include <unistd.h> |
39 | #include <stdlib.h> | 39 | #include <stdlib.h> |
40 | #include <stdio.h> | 40 | #include <stdio.h> |
41 | #include <errno.h> | 41 | #include <errno.h> |
42 | 42 | ||
43 | 43 | ||
44 | Bartender::Bartender( QWidget* parent, const char* name, WFlags fl ) | 44 | Bartender::Bartender( QWidget* parent, const char* name, WFlags fl ) |
45 | : QMainWindow( parent, name, fl ) { | 45 | : QMainWindow( parent, name, fl ) { |
46 | if ( !name ) | 46 | if ( !name ) |
47 | setName( "Bartender" ); | 47 | setName( "Bartender" ); |
48 | QGridLayout *layout = new QGridLayout( this ); | 48 | QGridLayout *layout = new QGridLayout( this ); |
49 | layout->setSpacing( 2); | 49 | layout->setSpacing( 2); |
50 | layout->setMargin( 2); | 50 | layout->setMargin( 2); |
51 | connect( qApp,SIGNAL( aboutToQuit()),SLOT( cleanUp()) ); | 51 | connect( qApp,SIGNAL( aboutToQuit()),SLOT( cleanUp()) ); |
52 | 52 | ||
53 | setCaption( tr( "Bartender" ) ); | 53 | setCaption( tr( "Bartender" ) ); |
54 | 54 | ||
55 | ToolBar1 = new QToolBar( this, "ToolBar1" ); | 55 | ToolBar1 = new QToolBar( this, "ToolBar1" ); |
56 | ToolBar1->setFixedHeight(22); | 56 | ToolBar1->setFixedHeight(22); |
57 | layout->addMultiCellWidget( ToolBar1, 0, 0, 0, 4 ); | 57 | layout->addMultiCellWidget( ToolBar1, 0, 0, 0, 4 ); |
58 | 58 | ||
59 | QMenuBar *menuBar = new QMenuBar( ToolBar1 ); | 59 | QMenuBar *menuBar = new QMenuBar( ToolBar1 ); |
60 | QPopupMenu *fileMenu; | 60 | QPopupMenu *fileMenu; |
61 | fileMenu = new QPopupMenu( this); | 61 | fileMenu = new QPopupMenu( this); |
62 | menuBar->insertItem( tr("File"), fileMenu ); | 62 | menuBar->insertItem( tr("File"), fileMenu ); |
63 | 63 | ||
64 | fileMenu->insertItem(tr("New Drink")); | 64 | fileMenu->insertItem(tr("New Drink")); |
65 | fileMenu->insertItem(tr("Open Drink")); | 65 | fileMenu->insertItem(tr("Open Drink")); |
66 | fileMenu->insertItem(tr("Find by Drink Name")); | 66 | fileMenu->insertItem(tr("Find by Drink Name")); |
67 | fileMenu->insertItem(tr("Find by Alcohol")); | 67 | fileMenu->insertItem(tr("Find by Alcohol")); |
68 | 68 | ||
69 | QPopupMenu *editMenu; | 69 | QPopupMenu *editMenu; |
70 | editMenu = new QPopupMenu( this); | 70 | editMenu = new QPopupMenu( this); |
71 | menuBar->insertItem( tr("Edit"), editMenu ); | 71 | menuBar->insertItem( tr("Edit"), editMenu ); |
72 | editMenu->insertItem(tr("edit")); | 72 | editMenu->insertItem(tr("edit")); |
73 | 73 | ||
74 | connect( fileMenu, SIGNAL( activated(int) ), this, SLOT( fileMenuActivated(int) )); | 74 | connect( fileMenu, SIGNAL( activated(int) ), this, SLOT( fileMenuActivated(int) )); |
75 | connect( editMenu, SIGNAL( activated(int) ), this, SLOT( editMenuActivated(int) )); | 75 | connect( editMenu, SIGNAL( activated(int) ), this, SLOT( editMenuActivated(int) )); |
76 | 76 | ||
77 | 77 | ||
78 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), "New", 0, this, 0 ); | 78 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), "New", 0, this, 0 ); |
79 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); | 79 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); |
80 | a->addTo( ToolBar1 ); | 80 | a->addTo( ToolBar1 ); |
81 | 81 | ||
82 | a = new QAction( tr( "Open" ), Resource::loadPixmap( "bartender/bartender_sm" ), "open", 0, this, 0 ); | 82 | a = new QAction( tr( "Open" ), Resource::loadPixmap( "bartender/bartender_sm" ), "open", 0, this, 0 ); |
83 | connect( a, SIGNAL( activated() ), this, SLOT( openCurrentDrink() ) ); | 83 | connect( a, SIGNAL( activated() ), this, SLOT( openCurrentDrink() ) ); |
84 | a->addTo( ToolBar1 ); | 84 | a->addTo( ToolBar1 ); |
85 | 85 | ||
86 | a = new QAction( tr( "Find" ), Resource::loadPixmap( "find" ), "Find", 0, this, 0 ); | 86 | a = new QAction( tr( "Find" ), Resource::loadPixmap( "find" ), "Find", 0, this, 0 ); |
87 | connect( a, SIGNAL( activated() ), this, SLOT( askSearch() ) ); | 87 | connect( a, SIGNAL( activated() ), this, SLOT( askSearch() ) ); |
88 | a->addTo( ToolBar1 ); | 88 | a->addTo( ToolBar1 ); |
89 | 89 | ||
90 | a = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ),"Edit", 0, this, 0 ); | 90 | a = new QAction( tr( "Edit" ), Resource::loadPixmap( "edit" ),"Edit", 0, this, 0 ); |
91 | connect( a, SIGNAL( activated() ), this, SLOT( doEdit() ) ); | 91 | connect( a, SIGNAL( activated() ), this, SLOT( doEdit() ) ); |
92 | a->addTo( ToolBar1 ); | 92 | a->addTo( ToolBar1 ); |
93 | 93 | ||
94 | QPushButton *t; | 94 | QPushButton *t; |
95 | t= new QPushButton( "BAC", ToolBar1, "bacButtin"); | 95 | t= new QPushButton( "BAC", ToolBar1, "bacButtin"); |
96 | connect( t, SIGNAL( clicked() ), this, SLOT( doBac() ) ); | 96 | connect( t, SIGNAL( clicked() ), this, SLOT( doBac() ) ); |
97 | 97 | ||
98 | DrinkView = new QListView( this, "DrinkView" ); | 98 | DrinkView = new QListView( this, "DrinkView" ); |
99 | DrinkView->addColumn( tr( "Name of Drink" ) ); | 99 | DrinkView->addColumn( tr( "Name of Drink" ) ); |
100 | // DrinkView->setRootIsDecorated( TRUE ); | 100 | // DrinkView->setRootIsDecorated( TRUE ); |
101 | DrinkView->header()->hide(); | 101 | DrinkView->header()->hide(); |
102 | 102 | ||
103 | QPEApplication::setStylusOperation( DrinkView->viewport(),QPEApplication::RightOnHold); | 103 | QPEApplication::setStylusOperation( DrinkView->viewport(),QPEApplication::RightOnHold); |
104 | 104 | ||
105 | connect(DrinkView, SIGNAL( doubleClicked(QListViewItem*)),this,SLOT(showDrink(QListViewItem*))); | 105 | connect(DrinkView, SIGNAL( doubleClicked(QListViewItem*)),this,SLOT(showDrink(QListViewItem*))); |
106 | connect(DrinkView, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int)), | 106 | connect(DrinkView, SIGNAL( mouseButtonPressed(int,QListViewItem*,const QPoint&,int)), |
107 | this,SLOT( showDrink(int,QListViewItem*,const QPoint&,int))); | 107 | this,SLOT( showDrink(int,QListViewItem*,const QPoint&,int))); |
108 | 108 | ||
109 | layout->addMultiCellWidget( DrinkView, 1, 2, 0, 4 ); | 109 | layout->addMultiCellWidget( DrinkView, 1, 2, 0, 4 ); |
110 | if(QDir("db").exists()) { | 110 | if(QDir("db").exists()) { |
111 | dbFile.setName( "db/drinkdb.txt"); | 111 | dbFile.setName( "db/drinkdb.txt"); |
112 | } else | 112 | } else |
113 | dbFile.setName( QPEApplication::qpeDir()+"/etc/bartender/drinkdb.txt"); | 113 | dbFile.setName( QPEApplication::qpeDir()+"/etc/bartender/drinkdb.txt"); |
114 | initDrinkDb(); | 114 | initDrinkDb(); |
115 | } | 115 | } |
116 | 116 | ||
117 | Bartender::~Bartender() { | 117 | Bartender::~Bartender() { |
118 | } | 118 | } |
119 | 119 | ||
120 | /* | 120 | /* |
121 | this happens right before exit */ | 121 | this happens right before exit */ |
122 | void Bartender::cleanUp() { | 122 | void Bartender::cleanUp() { |
123 | dbFile.close(); | 123 | dbFile.close(); |
124 | 124 | ||
125 | } | 125 | } |
126 | 126 | ||
127 | void Bartender::initDrinkDb() { | 127 | void Bartender::initDrinkDb() { |
128 | 128 | ||
129 | if(!dbFile.isOpen()) | 129 | if(!dbFile.isOpen()) |
130 | if ( !dbFile.open( IO_ReadOnly)) { | 130 | if ( !dbFile.open( IO_ReadOnly)) { |
131 | QMessageBox::message( (tr("Note")), (tr("Drink database not opened sucessfully.\n")) ); | 131 | QMessageBox::message( (tr("Note")), (tr("Drink database not opened sucessfully.\n")) ); |
132 | return; | 132 | return; |
133 | } | 133 | } |
134 | fillList(); | 134 | fillList(); |
135 | } | 135 | } |
136 | 136 | ||
137 | void Bartender::fillList() { | 137 | void Bartender::fillList() { |
138 | dbFile.at(1); | 138 | dbFile.at(1); |
139 | DrinkView->clear(); | 139 | DrinkView->clear(); |
140 | int i=0; | 140 | int i=0; |
141 | QListViewItem * item ; | 141 | QListViewItem * item ; |
142 | QTextStream t( &dbFile); | 142 | QTextStream t( &dbFile); |
143 | QString s; | 143 | QString s; |
144 | while ( !t.eof()) { | 144 | while ( !t.eof()) { |
145 | s = t.readLine(); | 145 | s = t.readLine(); |
146 | if(s.find("#",0,TRUE) != -1) { | 146 | if(s.find("#",0,TRUE) != -1) { |
147 | // qDebug(s.right(s.length()-2)); | 147 | // qDebug(s.right(s.length()-2)); |
148 | item= new QListViewItem( DrinkView, 0 ); | 148 | item= new QListViewItem( DrinkView, 0 ); |
149 | item->setText( 0, s.right(s.length()-2)); | 149 | item->setText( 0, s.right(s.length()-2)); |
150 | i++; | 150 | i++; |
151 | } | 151 | } |
152 | } | 152 | } |
153 | qDebug("there are currently %d of drinks", i); | 153 | qDebug("there are currently %d of drinks", i); |
154 | } | 154 | } |
155 | 155 | ||
156 | void Bartender::fileNew() { | 156 | void Bartender::fileNew() { |
157 | 157 | ||
158 | New_Drink *newDrinks; | 158 | New_Drink *newDrinks; |
159 | newDrinks = new New_Drink(this,"New Drink....", TRUE); | 159 | newDrinks = new New_Drink(this,"New Drink....", TRUE); |
160 | QString newName, newIng; | 160 | QString newName, newIng; |
161 | QPEApplication::execDialog( newDrinks ); | 161 | QPEApplication::execDialog( newDrinks ); |
162 | newName = newDrinks->LineEdit1->text(); | 162 | newName = newDrinks->LineEdit1->text(); |
163 | newIng= newDrinks->MultiLineEdit1->text(); | 163 | newIng= newDrinks->MultiLineEdit1->text(); |
164 | 164 | ||
165 | if(dbFile.isOpen()) | 165 | if(dbFile.isOpen()) |
166 | dbFile.close(); | 166 | dbFile.close(); |
167 | if ( !dbFile.open( IO_WriteOnly| IO_Append)) { | 167 | if ( !dbFile.open( IO_WriteOnly| IO_Append)) { |
168 | QMessageBox::message( (tr("Note")), (tr("Drink database not opened sucessfully.\n")) ); | 168 | QMessageBox::message( (tr("Note")), (tr("Drink database not opened sucessfully.\n")) ); |
169 | return; | 169 | return; |
170 | } | 170 | } |
171 | if(newDrinks ->result() == 1 ) { | 171 | if(newDrinks ->result() == 1 ) { |
172 | QString newDrink="\n# "+newName+"\n"; | 172 | QString newDrink="\n# "+newName+"\n"; |
173 | newDrink.append(newIng+"\n"); | 173 | newDrink.append(newIng+"\n"); |
174 | qDebug("writing "+newDrink); | 174 | qDebug("writing "+newDrink); |
175 | dbFile.writeBlock( newDrink.latin1(), newDrink.length()); | 175 | dbFile.writeBlock( newDrink.latin1(), newDrink.length()); |
176 | clearList(); | 176 | clearList(); |
177 | dbFile.close(); | 177 | dbFile.close(); |
178 | 178 | ||
179 | initDrinkDb(); | 179 | initDrinkDb(); |
180 | } | 180 | } |
181 | delete newDrinks; | 181 | delete newDrinks; |
182 | } | 182 | } |
183 | 183 | ||
184 | void Bartender::showDrink(int mouse, QListViewItem * item, const QPoint&, int) { | 184 | void Bartender::showDrink(int mouse, QListViewItem * item, const QPoint&, int) { |
185 | switch (mouse) { | 185 | switch (mouse) { |
186 | case 1: | 186 | case 1: |
187 | // showDrink(item); | 187 | // showDrink(item); |
188 | break; | 188 | break; |
189 | case 2: | 189 | case 2: |
190 | showDrink(item); | 190 | showDrink(item); |
191 | break; | 191 | break; |
192 | } | 192 | } |
193 | } | 193 | } |
194 | 194 | ||
195 | void Bartender::showDrink( QListViewItem *item) { | 195 | void Bartender::showDrink( QListViewItem *item) { |
196 | if(item==NULL) return; | 196 | if(item==NULL) return; |
197 | dbFile.at(0); | 197 | dbFile.at(0); |
198 | Show_Drink *showDrinks; | 198 | Show_Drink *showDrinks; |
199 | QString myDrink=item->text(0); | 199 | QString myDrink=item->text(0); |
200 | showDrinks = new Show_Drink(this, myDrink, TRUE); | 200 | showDrinks = new Show_Drink(this, myDrink, TRUE); |
201 | QTextStream t( &dbFile); | 201 | QTextStream t( &dbFile); |
202 | 202 | ||
203 | QString s, s2; | 203 | QString s, s2; |
204 | while ( !t.eof()) { | 204 | while ( !t.eof()) { |
205 | s = t.readLine(); | 205 | s = t.readLine(); |
206 | if(s.find( myDrink, 0, TRUE) != -1) { | 206 | if(s.find( myDrink, 0, TRUE) != -1) { |
207 | for(int i=0;s2.find( "#", 0, TRUE) == -1;i++) { | 207 | for(int i=0;s2.find( "#", 0, TRUE) == -1;i++) { |
208 | s2 = t.readLine(); | 208 | s2 = t.readLine(); |
209 | if(s2.find("#",0,TRUE) == -1 || dbFile.atEnd() ) { | 209 | if(s2.find("#",0,TRUE) == -1 || dbFile.atEnd() ) { |
210 | // qDebug(s2); | 210 | // qDebug(s2); |
211 | showDrinks->MultiLineEdit1->append(s2); | 211 | showDrinks->MultiLineEdit1->append(s2); |
212 | } | 212 | } |
213 | if( dbFile.atEnd() ) break; | 213 | if( dbFile.atEnd() ) break; |
214 | } | 214 | } |
215 | } | 215 | } |
216 | } | 216 | } |
217 | QPEApplication::execDialog( showDrinks ); | 217 | QPEApplication::execDialog( showDrinks ); |
218 | 218 | ||
219 | if(showDrinks ->result() ==0) { | 219 | if(showDrinks ->result() ==0) { |
220 | doEdit(); | 220 | doEdit(); |
221 | } | 221 | } |
222 | delete showDrinks; | 222 | delete showDrinks; |
223 | } | 223 | } |
224 | 224 | ||
225 | void Bartender::askSearch() { | 225 | void Bartender::askSearch() { |
226 | switch ( QMessageBox::warning(this,tr("Find"),tr("Search by drink name\n")+ | 226 | switch ( QMessageBox::warning(this,tr("Find"),tr("Search by drink name\n")+ |
227 | "\nor alcohol ?" | 227 | "\nor alcohol ?" |
228 | ,tr("Drink Name"),tr("Alcohol"),0,0,1) ) { | 228 | ,tr("Drink Name"),tr("Alcohol"),0,0,1) ) { |
229 | case 0: | 229 | case 0: |
230 | doSearchByName(); | 230 | doSearchByName(); |
231 | break; | 231 | break; |
232 | case 1: | 232 | case 1: |
233 | doSearchByDrink(); | 233 | doSearchByDrink(); |
234 | break; | 234 | break; |
235 | }; | 235 | }; |
236 | } | 236 | } |
237 | 237 | ||
238 | /* search by name */ | 238 | /* search by name */ |
239 | void Bartender::doSearchByName() { | 239 | void Bartender::doSearchByName() { |
240 | // if( DrinkView->currentItem() == NULL) return; | 240 | // if( DrinkView->currentItem() == NULL) return; |
241 | QStringList searchList; | 241 | QStringList searchList; |
242 | QString searchForDrinkName; | 242 | QString searchForDrinkName; |
243 | InputDialog *fileDlg; | 243 | InputDialog *fileDlg; |
244 | fileDlg = new InputDialog(this,tr("Find by Drink Name"),TRUE, 0); | 244 | fileDlg = new InputDialog(this,tr("Find by Drink Name"),TRUE, 0); |
245 | fileDlg->exec(); | 245 | fileDlg->exec(); |
246 | if( fileDlg->result() == 1 ) { | 246 | if( fileDlg->result() == 1 ) { |
247 | searchForDrinkName = fileDlg->LineEdit1->text(); | 247 | searchForDrinkName = fileDlg->LineEdit1->text(); |
248 | QListViewItemIterator it( DrinkView ); | 248 | QListViewItemIterator it( DrinkView ); |
249 | for ( ; it.current(); ++it ) { | 249 | for ( ; it.current(); ++it ) { |
250 | if ( it.current()->text(0).find( searchForDrinkName, 0, TRUE) != -1 ) { | 250 | if ( it.current()->text(0).find( searchForDrinkName, 0, TRUE) != -1 ) { |
251 | // qDebug( it.current()->text(0)); | 251 | // qDebug( it.current()->text(0)); |
252 | searchList.append(it.current()->text(0)); | 252 | searchList.append(it.current()->text(0)); |
253 | } | 253 | } |
254 | } | 254 | } |
255 | if(searchList.count() >0) | 255 | if(searchList.count() >0) |
256 | showSearchResult(searchList); | 256 | showSearchResult(searchList); |
257 | else | 257 | else |
258 | QMessageBox::message(tr("Search"),tr("Sorry no results for\n")+searchForDrinkName); | 258 | QMessageBox::message(tr("Search"),tr("Sorry no results for\n")+searchForDrinkName); |
259 | }//end Inputdialog | 259 | }//end Inputdialog |
260 | delete fileDlg; | 260 | delete fileDlg; |
261 | } | 261 | } |
262 | 262 | ||
263 | void Bartender::doSearchByDrink() { | 263 | void Bartender::doSearchByDrink() { |
264 | // if( DrinkView->currentItem() == NULL) return; | 264 | // if( DrinkView->currentItem() == NULL) return; |
265 | QStringList searchList; | 265 | QStringList searchList; |
266 | QString searchForDrinkName, lastDrinkName, tempName; | 266 | QString searchForDrinkName, lastDrinkName, tempName; |
267 | 267 | ||
268 | InputDialog *fileDlg; | 268 | InputDialog *fileDlg; |
269 | fileDlg = new InputDialog(this,tr("Find by Alcohol"),TRUE, 0); | 269 | fileDlg = new InputDialog(this,tr("Find by Alcohol"),TRUE, 0); |
270 | fileDlg->exec(); | 270 | fileDlg->exec(); |
271 | if( fileDlg->result() == 1 ) { | 271 | if( fileDlg->result() == 1 ) { |
272 | searchForDrinkName = fileDlg->LineEdit1->text(); | 272 | searchForDrinkName = fileDlg->LineEdit1->text(); |
273 | 273 | ||
274 | dbFile.at(0); | 274 | dbFile.at(0); |
275 | QTextStream t( &dbFile); | 275 | QTextStream t( &dbFile); |
276 | 276 | ||
277 | QString s, s2; | 277 | QString s, s2; |
278 | while ( !t.eof()) { | 278 | while ( !t.eof()) { |
279 | s = t.readLine(); | 279 | s = t.readLine(); |
280 | if(s.find("#",0,TRUE) != -1) { | 280 | if(s.find("#",0,TRUE) != -1) { |
281 | lastDrinkName=s.right(s.length()-2); | 281 | lastDrinkName=s.right(s.length()-2); |
282 | // qDebug("last drink name "+lastDrinkName); | 282 | // qDebug("last drink name "+lastDrinkName); |
283 | } | 283 | } |
284 | else if( s.find( searchForDrinkName ,0, FALSE) != -1 && lastDrinkName != tempName ) { | 284 | else if( s.find( searchForDrinkName ,0, FALSE) != -1 && lastDrinkName != tempName ) { |
285 | // qDebug("appending "+lastDrinkName); | 285 | // qDebug("appending "+lastDrinkName); |
286 | searchList.append( lastDrinkName); | 286 | searchList.append( lastDrinkName); |
287 | tempName=lastDrinkName; | 287 | tempName=lastDrinkName; |
288 | } | 288 | } |
289 | // if( dbFile.atEnd() ) break; | 289 | // if( dbFile.atEnd() ) break; |
290 | 290 | ||
291 | } //oef | 291 | } //oef |
292 | if(searchList.count() >0) | 292 | if(searchList.count() >0) |
293 | showSearchResult(searchList); | 293 | showSearchResult(searchList); |
294 | else | 294 | else |
295 | QMessageBox::message(tr("Search"),tr("Sorry no results for\n")+ searchForDrinkName); | 295 | QMessageBox::message(tr("Search"),tr("Sorry no results for\n")+ searchForDrinkName); |
296 | } | 296 | } |
297 | delete fileDlg; | 297 | delete fileDlg; |
298 | } | 298 | } |
299 | 299 | ||
300 | void Bartender::showSearchResult(QStringList &searchList) { | 300 | void Bartender::showSearchResult(QStringList &searchList) { |
301 | QString result; | 301 | QString result; |
302 | Search_Results *searchDlg; | 302 | Search_Results *searchDlg; |
303 | 303 | ||
304 | searchList.sort(); | 304 | searchList.sort(); |
305 | 305 | ||
306 | searchDlg = new Search_Results(this, "Search Results", TRUE); | 306 | searchDlg = new Search_Results(this, "Search Results", TRUE); |
307 | searchDlg->ListBox1->insertStringList( searchList,-1); | 307 | searchDlg->ListBox1->insertStringList( searchList,-1); |
308 | QPEApplication::execDialog( searchDlg ); | 308 | QPEApplication::execDialog( searchDlg ); |
309 | 309 | ||
310 | if( searchDlg->result() == 1 ) { | 310 | if( searchDlg->result() == 1 ) { |
311 | result= searchDlg->ListBox1->currentText(); | 311 | result= searchDlg->ListBox1->currentText(); |
312 | } | 312 | } |
313 | QListViewItemIterator it2( DrinkView ); | 313 | QListViewItemIterator it2( DrinkView ); |
314 | for ( ; it2.current(); ++it2 ) { | 314 | for ( ; it2.current(); ++it2 ) { |
315 | if ( it2.current()->text(0)== result ) { | 315 | if ( it2.current()->text(0)== result ) { |
316 | // qDebug( it2.current()->text(0)); | 316 | // qDebug( it2.current()->text(0)); |
317 | showDrink(it2.current()); | 317 | showDrink(it2.current()); |
318 | } | 318 | } |
319 | } | 319 | } |
320 | delete searchDlg; | 320 | delete searchDlg; |
321 | } | 321 | } |
322 | 322 | ||
323 | void Bartender::doEdit() { | 323 | void Bartender::doEdit() { |
324 | if(DrinkView->currentItem() == NULL) { | 324 | if(DrinkView->currentItem() == NULL) { |
325 | fileNew(); | 325 | fileNew(); |
326 | } | 326 | } |
327 | 327 | ||
328 | QString myDrink; | 328 | QString myDrink; |
329 | myDrink= DrinkView->currentItem()->text(0); | 329 | myDrink= DrinkView->currentItem()->text(0); |
330 | dbFile.at(0); | 330 | dbFile.at(0); |
331 | int foundAt=0; | 331 | int foundAt=0; |
332 | New_Drink *newDrinks; | 332 | New_Drink *newDrinks; |
333 | newDrinks = new New_Drink(this,"Edit Drink....", TRUE); | 333 | newDrinks = new New_Drink(this,"Edit Drink....", TRUE); |
334 | QString newName, newIng; | 334 | QString newName, newIng; |
335 | QPEApplication::showDialog( newDrinks ); | 335 | QPEApplication::showDialog( newDrinks ); |
336 | QTextStream t( &dbFile); | 336 | QTextStream t( &dbFile); |
337 | 337 | ||
338 | QString s, s2; | 338 | QString s, s2; |
339 | while ( !t.eof()) { | 339 | while ( !t.eof()) { |
340 | s = t.readLine(); | 340 | s = t.readLine(); |
341 | if(s.find( myDrink, 0, TRUE) != -1) { | 341 | if(s.find( myDrink, 0, TRUE) != -1) { |
342 | foundAt = dbFile.at() - (s.length()+1); | 342 | foundAt = dbFile.at() - (s.length()+1); |
343 | for(int i=0;s2.find( "#", 0, TRUE) == -1;i++) { | 343 | for(int i=0;s2.find( "#", 0, TRUE) == -1;i++) { |
344 | s2 = t.readLine(); | 344 | s2 = t.readLine(); |
345 | if(s2.find("#",0,TRUE) == -1 || dbFile.atEnd() ) { | 345 | if(s2.find("#",0,TRUE) == -1 || dbFile.atEnd() ) { |
346 | // qDebug(s2); | 346 | // qDebug(s2); |
347 | newDrinks->MultiLineEdit1->append(s2); | 347 | newDrinks->MultiLineEdit1->append(s2); |
348 | newDrinks->LineEdit1->setText(myDrink); | 348 | newDrinks->LineEdit1->setText(myDrink); |
349 | } | 349 | } |
350 | if( dbFile.atEnd() ) break; | 350 | if( dbFile.atEnd() ) break; |
351 | } | 351 | } |
352 | } | 352 | } |
353 | } | 353 | } |
354 | newDrinks->exec(); | 354 | newDrinks->exec(); |
355 | newName = newDrinks->LineEdit1->text(); | 355 | newName = newDrinks->LineEdit1->text(); |
356 | newIng= newDrinks->MultiLineEdit1->text(); | 356 | newIng= newDrinks->MultiLineEdit1->text(); |
357 | 357 | ||
358 | if( newDrinks ->result() == 1 ) { | 358 | if( newDrinks ->result() == 1 ) { |
359 | if(dbFile.isOpen()) | 359 | if(dbFile.isOpen()) |
360 | dbFile.close(); | 360 | dbFile.close(); |
361 | if ( !dbFile.open( IO_ReadWrite )) { | 361 | if ( !dbFile.open( IO_ReadWrite )) { |
362 | QMessageBox::message( (tr("Note")), (tr("Drink database not opened sucessfully.\n")) ); | 362 | QMessageBox::message( (tr("Note")), (tr("Drink database not opened sucessfully.\n")) ); |
363 | return; | 363 | return; |
364 | } | 364 | } |
365 | int fd = dbFile.handle(); | 365 | int fd = dbFile.handle(); |
366 | lseek( fd, foundAt, SEEK_SET); | 366 | lseek( fd, foundAt, SEEK_SET); |
367 | 367 | ||
368 | // dbFile.at( foundAt); | 368 | // dbFile.at( foundAt); |
369 | #warning FIXME problems with editing drinks db | 369 | #warning FIXME problems with editing drinks db |
370 | ////////// FIXME write to user file | 370 | ////////// FIXME write to user file |
371 | QString newDrink="# "+newName+"\n"; | 371 | QString newDrink="# "+newName+"\n"; |
372 | newDrink.append(newIng+"\n"); | 372 | newDrink.append(newIng+"\n"); |
373 | qDebug("writing "+newDrink); | 373 | qDebug("writing "+newDrink); |
374 | dbFile.writeBlock( newDrink.latin1(), newDrink.length()); | 374 | dbFile.writeBlock( newDrink.latin1(), newDrink.length()); |
375 | clearList(); | 375 | clearList(); |
376 | 376 | ||
377 | dbFile.flush(); | 377 | dbFile.flush(); |
378 | 378 | ||
379 | initDrinkDb(); | 379 | initDrinkDb(); |
380 | } | 380 | } |
381 | } | 381 | } |
382 | 382 | ||
383 | void Bartender::clearList() { | 383 | void Bartender::clearList() { |
384 | DrinkView->clear(); | 384 | DrinkView->clear(); |
385 | } | 385 | } |
386 | 386 | ||
387 | void Bartender::doBac() { | 387 | void Bartender::doBac() { |
388 | BacDialog *bacDlg; | 388 | BacDialog *bacDlg; |
389 | bacDlg = new BacDialog(this,"BAC",TRUE); | 389 | bacDlg = new BacDialog(this,"BAC",TRUE); |
390 | QPEApplication::execDialog( bacDlg ); | 390 | QPEApplication::execDialog( bacDlg ); |
391 | delete bacDlg; | 391 | delete bacDlg; |
392 | } | 392 | } |
393 | 393 | ||
394 | void Bartender::openCurrentDrink() { | 394 | void Bartender::openCurrentDrink() { |
395 | if(DrinkView->currentItem() == NULL) return; | 395 | if(DrinkView->currentItem() == NULL) return; |
396 | showDrink(DrinkView->currentItem()); | 396 | showDrink(DrinkView->currentItem()); |
397 | } | 397 | } |
398 | 398 | ||
399 | void Bartender::fileMenuActivated( int item) { | 399 | void Bartender::fileMenuActivated( int item) { |
400 | qDebug("Item %d", item); | 400 | qDebug("Item %d", item); |
401 | switch(item) { | 401 | switch(item) { |
402 | case -3: // new -3 | 402 | case -3: // new -3 |
403 | fileNew(); | 403 | fileNew(); |
404 | break; | 404 | break; |
405 | case -4:// open -4 | 405 | case -4:// open -4 |
406 | openCurrentDrink(); | 406 | openCurrentDrink(); |
407 | break; | 407 | break; |
408 | case -5:// drink -5 | 408 | case -5:// drink -5 |
409 | doSearchByName(); | 409 | doSearchByName(); |
410 | 410 | ||
411 | break; | 411 | break; |
412 | case -6:// alcohol -6 | 412 | case -6:// alcohol -6 |
413 | doSearchByDrink(); | 413 | doSearchByDrink(); |
414 | 414 | ||
415 | break; | 415 | break; |
416 | 416 | ||
417 | } | 417 | } |
418 | } | 418 | } |
419 | 419 | ||
420 | void Bartender::editMenuActivated(int item) { | 420 | void Bartender::editMenuActivated(int item) { |
421 | qDebug("Item %d", item); | 421 | qDebug("Item %d", item); |
422 | /* | 422 | /* |
423 | edit -8 | 423 | edit -8 |
424 | */ | 424 | */ |
425 | switch(item) { | 425 | switch(item) { |
426 | case -8: | 426 | case -8: |
427 | doEdit() ; | 427 | doEdit() ; |
428 | break; | 428 | break; |
429 | 429 | ||
430 | } | 430 | } |
431 | } | 431 | } |
432 | 432 | ||
diff --git a/noncore/apps/opie-console/io_bt.cpp b/noncore/apps/opie-console/io_bt.cpp index 1a8c979..35a328f 100644 --- a/noncore/apps/opie-console/io_bt.cpp +++ b/noncore/apps/opie-console/io_bt.cpp | |||
@@ -1,92 +1,94 @@ | |||
1 | 1 | ||
2 | #include "io_bt.h" | 2 | #include "io_bt.h" |
3 | 3 | ||
4 | using namespace Opie::Core; | ||
5 | using namespace Opie::Core; | ||
4 | IOBt::IOBt( const Profile &config ) : IOSerial( config ) { | 6 | IOBt::IOBt( const Profile &config ) : IOSerial( config ) { |
5 | m_attach = 0; | 7 | m_attach = 0; |
6 | } | 8 | } |
7 | 9 | ||
8 | 10 | ||
9 | IOBt::~IOBt() { | 11 | IOBt::~IOBt() { |
10 | if ( m_attach ) { | 12 | if ( m_attach ) { |
11 | delete m_attach; | 13 | delete m_attach; |
12 | } | 14 | } |
13 | } | 15 | } |
14 | 16 | ||
15 | 17 | ||
16 | void IOBt::close() { | 18 | void IOBt::close() { |
17 | 19 | ||
18 | IOSerial::close(); | 20 | IOSerial::close(); |
19 | // still need error handling | 21 | // still need error handling |
20 | if ( m_attach ) { | 22 | if ( m_attach ) { |
21 | delete m_attach; | 23 | delete m_attach; |
22 | m_attach = 0; | 24 | m_attach = 0; |
23 | } | 25 | } |
24 | } | 26 | } |
25 | 27 | ||
26 | bool IOBt::open() { | 28 | bool IOBt::open() { |
27 | bool ret = false; | 29 | bool ret = false; |
28 | 30 | ||
29 | // only set up bt stuff if mac address was set, otherwise use the device set | 31 | // only set up bt stuff if mac address was set, otherwise use the device set |
30 | if ( !m_mac.isEmpty() ) { | 32 | if ( !m_mac.isEmpty() ) { |
31 | 33 | ||
32 | // now it should also be checked, if there is a connection to the device with that mac allready | 34 | // now it should also be checked, if there is a connection to the device with that mac allready |
33 | // hciattach here | 35 | // hciattach here |
34 | m_attach = new OProcess(); | 36 | m_attach = new OProcess(); |
35 | *m_attach << "hciattach /dev/ttyS2 any 57600"; | 37 | *m_attach << "hciattach /dev/ttyS2 any 57600"; |
36 | 38 | ||
37 | // then start hcid, then rcfomm handling (m_mac) | 39 | // then start hcid, then rcfomm handling (m_mac) |
38 | 40 | ||
39 | connect( m_attach, SIGNAL( processExited(OProcess*) ), | 41 | connect( m_attach, SIGNAL( processExited(Opie::Core::OProcess*) ), |
40 | this, SLOT( slotExited(OProcess*) ) ); | 42 | this, SLOT( slotExited(OProcess*) ) ); |
41 | 43 | ||
42 | if ( m_attach->start() ) { | 44 | if ( m_attach->start() ) { |
43 | ret = IOSerial::open(); | 45 | ret = IOSerial::open(); |
44 | } else { | 46 | } else { |
45 | qWarning("could not attach to device"); | 47 | qWarning("could not attach to device"); |
46 | delete m_attach; | 48 | delete m_attach; |
47 | m_attach = 0; | 49 | m_attach = 0; |
48 | } | 50 | } |
49 | } else { | 51 | } else { |
50 | // directly to the normal serial | 52 | // directly to the normal serial |
51 | // TODO: look first if the connection really exists. ( is set up ) | 53 | // TODO: look first if the connection really exists. ( is set up ) |
52 | 54 | ||
53 | ret =IOSerial::open(); | 55 | ret =IOSerial::open(); |
54 | } | 56 | } |
55 | return ret; | 57 | return ret; |
56 | } | 58 | } |
57 | 59 | ||
58 | void IOBt::reload( const Profile &config ) { | 60 | void IOBt::reload( const Profile &config ) { |
59 | m_device = config.readEntry("Device", BT_DEFAULT_DEVICE); | 61 | m_device = config.readEntry("Device", BT_DEFAULT_DEVICE); |
60 | m_mac = config.readEntry("Mac", BT_DEFAULT_MAC); | 62 | m_mac = config.readEntry("Mac", BT_DEFAULT_MAC); |
61 | m_baud = config.readNumEntry("Baud", BT_DEFAULT_BAUD); | 63 | m_baud = config.readNumEntry("Baud", BT_DEFAULT_BAUD); |
62 | m_parity = config.readNumEntry("Parity", BT_DEFAULT_PARITY); | 64 | m_parity = config.readNumEntry("Parity", BT_DEFAULT_PARITY); |
63 | m_dbits = config.readNumEntry("DataBits", BT_DEFAULT_DBITS); | 65 | m_dbits = config.readNumEntry("DataBits", BT_DEFAULT_DBITS); |
64 | m_sbits = config.readNumEntry("StopBits", BT_DEFAULT_SBITS); | 66 | m_sbits = config.readNumEntry("StopBits", BT_DEFAULT_SBITS); |
65 | m_flow = config.readNumEntry("Flow", BT_DEFAULT_FLOW); | 67 | m_flow = config.readNumEntry("Flow", BT_DEFAULT_FLOW); |
66 | } | 68 | } |
67 | 69 | ||
68 | 70 | ||
69 | QString IOBt::identifier() const { | 71 | QString IOBt::identifier() const { |
70 | return "bluetooth"; | 72 | return "bluetooth"; |
71 | } | 73 | } |
72 | 74 | ||
73 | QString IOBt::name() const { | 75 | QString IOBt::name() const { |
74 | return "BLuetooth IO Layer"; | 76 | return "BLuetooth IO Layer"; |
75 | } | 77 | } |
76 | 78 | ||
77 | void IOBt::slotExited( OProcess* proc ){ | 79 | void IOBt::slotExited( OProcess* proc ){ |
78 | close(); | 80 | close(); |
79 | delete proc; | 81 | delete proc; |
80 | } | 82 | } |
81 | 83 | ||
82 | QBitArray IOBt::supports() const { | 84 | QBitArray IOBt::supports() const { |
83 | return QBitArray( 3 ); | 85 | return QBitArray( 3 ); |
84 | } | 86 | } |
85 | 87 | ||
86 | bool IOBt::isConnected() { | 88 | bool IOBt::isConnected() { |
87 | return false; | 89 | return false; |
88 | } | 90 | } |
89 | 91 | ||
90 | void IOBt::send(const QByteArray &data) { | 92 | void IOBt::send(const QByteArray &data) { |
91 | qDebug( "Please overload me..." ); | 93 | qDebug( "Please overload me..." ); |
92 | } | 94 | } |
diff --git a/noncore/apps/opie-console/io_bt.h b/noncore/apps/opie-console/io_bt.h index df6dd38..00ca7e5 100644 --- a/noncore/apps/opie-console/io_bt.h +++ b/noncore/apps/opie-console/io_bt.h | |||
@@ -1,51 +1,51 @@ | |||
1 | #ifndef OPIE_IO_BT | 1 | #ifndef OPIE_IO_BT |
2 | #define OPIE_IO_BT | 2 | #define OPIE_IO_BT |
3 | 3 | ||
4 | #include <opie2/oprocess.h> | 4 | #include <opie2/oprocess.h> |
5 | #include "io_serial.h" | 5 | #include "io_serial.h" |
6 | 6 | ||
7 | /* Default values to be used if the profile information is incomplete */ | 7 | /* Default values to be used if the profile information is incomplete */ |
8 | #define BT_DEFAULT_DEVICE "/dev/ttyU0" | 8 | #define BT_DEFAULT_DEVICE "/dev/ttyU0" |
9 | #define BT_DEFAULT_BAUD 9600 | 9 | #define BT_DEFAULT_BAUD 9600 |
10 | #define BT_DEFAULT_PARITY 0 | 10 | #define BT_DEFAULT_PARITY 0 |
11 | #define BT_DEFAULT_DBITS 8 | 11 | #define BT_DEFAULT_DBITS 8 |
12 | #define BT_DEFAULT_SBITS 1 | 12 | #define BT_DEFAULT_SBITS 1 |
13 | #define BT_DEFAULT_FLOW 0 | 13 | #define BT_DEFAULT_FLOW 0 |
14 | #define BT_DEFAULT_MAC 0 | 14 | #define BT_DEFAULT_MAC 0 |
15 | 15 | ||
16 | 16 | ||
17 | /* IOSerial implements a RS232 IO Layer */ | 17 | /* IOSerial implements a RS232 IO Layer */ |
18 | 18 | ||
19 | class IOBt : public IOSerial { | 19 | class IOBt : public IOSerial { |
20 | 20 | ||
21 | Q_OBJECT | 21 | Q_OBJECT |
22 | 22 | ||
23 | public: | 23 | public: |
24 | 24 | ||
25 | IOBt(const Profile &); | 25 | IOBt(const Profile &); |
26 | ~IOBt(); | 26 | ~IOBt(); |
27 | 27 | ||
28 | virtual QString identifier() const; | 28 | virtual QString identifier() const; |
29 | virtual QString name() const; | 29 | virtual QString name() const; |
30 | virtual QBitArray supports() const; | 30 | virtual QBitArray supports() const; |
31 | virtual bool isConnected(); | 31 | virtual bool isConnected(); |
32 | 32 | ||
33 | signals: | 33 | signals: |
34 | void received(const QByteArray &); | 34 | void received(const QByteArray &); |
35 | void error(int, const QString &); | 35 | void error(int, const QString &); |
36 | 36 | ||
37 | public slots: | 37 | public slots: |
38 | virtual void send( const QByteArray& ); | 38 | virtual void send( const QByteArray& ); |
39 | virtual bool open(); | 39 | virtual bool open(); |
40 | virtual void close(); | 40 | virtual void close(); |
41 | virtual void reload(const Profile &); | 41 | virtual void reload(const Profile &); |
42 | 42 | ||
43 | private: | 43 | private: |
44 | OProcess *m_attach; | 44 | Opie::Core::OProcess *m_attach; |
45 | QString m_mac; | 45 | QString m_mac; |
46 | private slots: | 46 | private slots: |
47 | void slotExited(OProcess* proc); | 47 | void slotExited(Opie::Core::OProcess* proc); |
48 | 48 | ||
49 | }; | 49 | }; |
50 | 50 | ||
51 | #endif /* OPIE_IO_IRDA */ | 51 | #endif /* OPIE_IO_IRDA */ |
diff --git a/noncore/apps/opie-console/io_irda.cpp b/noncore/apps/opie-console/io_irda.cpp index b281b7d..ba0b0e5 100644 --- a/noncore/apps/opie-console/io_irda.cpp +++ b/noncore/apps/opie-console/io_irda.cpp | |||
@@ -1,77 +1,79 @@ | |||
1 | 1 | ||
2 | #include "io_irda.h" | 2 | #include "io_irda.h" |
3 | 3 | ||
4 | using namespace Opie::Core; | ||
5 | using namespace Opie::Core; | ||
4 | IOIrda::IOIrda( const Profile &config ) : IOSerial( config ) { | 6 | IOIrda::IOIrda( const Profile &config ) : IOSerial( config ) { |
5 | m_attach = 0; | 7 | m_attach = 0; |
6 | } | 8 | } |
7 | 9 | ||
8 | 10 | ||
9 | IOIrda::~IOIrda() { | 11 | IOIrda::~IOIrda() { |
10 | if ( m_attach ) { | 12 | if ( m_attach ) { |
11 | delete m_attach; | 13 | delete m_attach; |
12 | } | 14 | } |
13 | } | 15 | } |
14 | 16 | ||
15 | 17 | ||
16 | void IOIrda::close() { | 18 | void IOIrda::close() { |
17 | 19 | ||
18 | IOSerial::close(); | 20 | IOSerial::close(); |
19 | // still need error handling | 21 | // still need error handling |
20 | delete m_attach; | 22 | delete m_attach; |
21 | } | 23 | } |
22 | 24 | ||
23 | bool IOIrda::open() { | 25 | bool IOIrda::open() { |
24 | bool ret; | 26 | bool ret; |
25 | 27 | ||
26 | // irdaattach here | 28 | // irdaattach here |
27 | m_attach = new OProcess(); | 29 | m_attach = new OProcess(); |
28 | *m_attach << "irattach /dev/ttyS2 -s"; | 30 | *m_attach << "irattach /dev/ttyS2 -s"; |
29 | 31 | ||
30 | connect( m_attach, SIGNAL( processExited(OProcess*) ), | 32 | connect( m_attach, SIGNAL( processExited(Opie::Core::OProcess*) ), |
31 | this, SLOT( slotExited(OProcess*) ) ); | 33 | this, SLOT( slotExited(OProcess*) ) ); |
32 | 34 | ||
33 | if ( m_attach->start() ) { | 35 | if ( m_attach->start() ) { |
34 | ret= IOSerial::open(); | 36 | ret= IOSerial::open(); |
35 | } else { | 37 | } else { |
36 | // emit error!!! | 38 | // emit error!!! |
37 | qWarning("could not attach to device"); | 39 | qWarning("could not attach to device"); |
38 | delete m_attach; | 40 | delete m_attach; |
39 | m_attach = 0l; | 41 | m_attach = 0l; |
40 | } | 42 | } |
41 | return ret; | 43 | return ret; |
42 | } | 44 | } |
43 | 45 | ||
44 | void IOIrda::reload( const Profile &config ) { | 46 | void IOIrda::reload( const Profile &config ) { |
45 | m_device = config.readEntry("Device", IRDA_DEFAULT_DEVICE); | 47 | m_device = config.readEntry("Device", IRDA_DEFAULT_DEVICE); |
46 | m_baud = config.readNumEntry("Baud", IRDA_DEFAULT_BAUD); | 48 | m_baud = config.readNumEntry("Baud", IRDA_DEFAULT_BAUD); |
47 | m_parity = config.readNumEntry("Parity", IRDA_DEFAULT_PARITY); | 49 | m_parity = config.readNumEntry("Parity", IRDA_DEFAULT_PARITY); |
48 | m_dbits = config.readNumEntry("DataBits", IRDA_DEFAULT_DBITS); | 50 | m_dbits = config.readNumEntry("DataBits", IRDA_DEFAULT_DBITS); |
49 | m_sbits = config.readNumEntry("StopBits", IRDA_DEFAULT_SBITS); | 51 | m_sbits = config.readNumEntry("StopBits", IRDA_DEFAULT_SBITS); |
50 | m_flow = config.readNumEntry("Flow", IRDA_DEFAULT_FLOW); | 52 | m_flow = config.readNumEntry("Flow", IRDA_DEFAULT_FLOW); |
51 | } | 53 | } |
52 | 54 | ||
53 | 55 | ||
54 | QString IOIrda::identifier() const { | 56 | QString IOIrda::identifier() const { |
55 | return "irda"; | 57 | return "irda"; |
56 | } | 58 | } |
57 | 59 | ||
58 | QString IOIrda::name() const { | 60 | QString IOIrda::name() const { |
59 | return "Irda IO Layer"; | 61 | return "Irda IO Layer"; |
60 | } | 62 | } |
61 | 63 | ||
62 | void IOIrda::slotExited(OProcess* proc ){ | 64 | void IOIrda::slotExited(OProcess* proc ){ |
63 | close(); | 65 | close(); |
64 | delete proc; | 66 | delete proc; |
65 | } | 67 | } |
66 | 68 | ||
67 | QBitArray IOIrda::supports()const { | 69 | QBitArray IOIrda::supports()const { |
68 | return QBitArray( 3 ); | 70 | return QBitArray( 3 ); |
69 | } | 71 | } |
70 | 72 | ||
71 | bool IOIrda::isConnected() { | 73 | bool IOIrda::isConnected() { |
72 | return false; | 74 | return false; |
73 | } | 75 | } |
74 | 76 | ||
75 | void IOIrda::send(const QByteArray &data) { | 77 | void IOIrda::send(const QByteArray &data) { |
76 | qDebug( "Please overload me..." ); | 78 | qDebug( "Please overload me..." ); |
77 | } | 79 | } |
diff --git a/noncore/apps/opie-console/io_irda.h b/noncore/apps/opie-console/io_irda.h index 69bed7d..fb29686 100644 --- a/noncore/apps/opie-console/io_irda.h +++ b/noncore/apps/opie-console/io_irda.h | |||
@@ -1,49 +1,49 @@ | |||
1 | #ifndef OPIE_IO_IRDA | 1 | #ifndef OPIE_IO_IRDA |
2 | #define OPIE_IO_IRDA | 2 | #define OPIE_IO_IRDA |
3 | 3 | ||
4 | #include <opie2/oprocess.h> | 4 | #include <opie2/oprocess.h> |
5 | #include "io_serial.h" | 5 | #include "io_serial.h" |
6 | 6 | ||
7 | /* Default values to be used if the profile information is incomplete */ | 7 | /* Default values to be used if the profile information is incomplete */ |
8 | #define IRDA_DEFAULT_DEVICE "/dev/ircomm0" | 8 | #define IRDA_DEFAULT_DEVICE "/dev/ircomm0" |
9 | #define IRDA_DEFAULT_BAUD 9600 | 9 | #define IRDA_DEFAULT_BAUD 9600 |
10 | #define IRDA_DEFAULT_PARITY 0 | 10 | #define IRDA_DEFAULT_PARITY 0 |
11 | #define IRDA_DEFAULT_DBITS 8 | 11 | #define IRDA_DEFAULT_DBITS 8 |
12 | #define IRDA_DEFAULT_SBITS 1 | 12 | #define IRDA_DEFAULT_SBITS 1 |
13 | #define IRDA_DEFAULT_FLOW 0 | 13 | #define IRDA_DEFAULT_FLOW 0 |
14 | 14 | ||
15 | /* IOSerial implements a RS232 IO Layer */ | 15 | /* IOSerial implements a RS232 IO Layer */ |
16 | 16 | ||
17 | class IOIrda : public IOSerial { | 17 | class IOIrda : public IOSerial { |
18 | 18 | ||
19 | Q_OBJECT | 19 | Q_OBJECT |
20 | 20 | ||
21 | public: | 21 | public: |
22 | 22 | ||
23 | IOIrda(const Profile &); | 23 | IOIrda(const Profile &); |
24 | ~IOIrda(); | 24 | ~IOIrda(); |
25 | 25 | ||
26 | virtual QString identifier() const; | 26 | virtual QString identifier() const; |
27 | virtual QString name() const; | 27 | virtual QString name() const; |
28 | virtual QBitArray supports() const; | 28 | virtual QBitArray supports() const; |
29 | virtual bool isConnected(); | 29 | virtual bool isConnected(); |
30 | 30 | ||
31 | signals: | 31 | signals: |
32 | void received(const QByteArray &); | 32 | void received(const QByteArray &); |
33 | void error(int, const QString &); | 33 | void error(int, const QString &); |
34 | 34 | ||
35 | public slots: | 35 | public slots: |
36 | virtual void send( const QByteArray& ); | 36 | virtual void send( const QByteArray& ); |
37 | virtual bool open(); | 37 | virtual bool open(); |
38 | virtual void close(); | 38 | virtual void close(); |
39 | virtual void reload(const Profile &); | 39 | virtual void reload(const Profile &); |
40 | 40 | ||
41 | private: | 41 | private: |
42 | OProcess *m_attach; | 42 | Opie::Core::OProcess *m_attach; |
43 | 43 | ||
44 | private slots: | 44 | private slots: |
45 | void slotExited(OProcess* proc); | 45 | void slotExited(Opie::Core::OProcess* proc); |
46 | 46 | ||
47 | }; | 47 | }; |
48 | 48 | ||
49 | #endif /* OPIE_IO_IRDA */ | 49 | #endif /* OPIE_IO_IRDA */ |
diff --git a/noncore/apps/opie-console/io_modem.cpp b/noncore/apps/opie-console/io_modem.cpp index 1ce680a..b74d076 100644 --- a/noncore/apps/opie-console/io_modem.cpp +++ b/noncore/apps/opie-console/io_modem.cpp | |||
@@ -1,106 +1,108 @@ | |||
1 | 1 | ||
2 | #include "io_modem.h" | 2 | #include "io_modem.h" |
3 | 3 | ||
4 | #include "dialer.h" | 4 | #include "dialer.h" |
5 | 5 | ||
6 | using namespace Opie::Core; | ||
7 | using namespace Opie::Core; | ||
6 | IOModem::IOModem( const Profile &profile ) | 8 | IOModem::IOModem( const Profile &profile ) |
7 | : IOSerial( profile ) { | 9 | : IOSerial( profile ) { |
8 | m_profile = profile; | 10 | m_profile = profile; |
9 | } | 11 | } |
10 | 12 | ||
11 | 13 | ||
12 | IOModem::~IOModem() { | 14 | IOModem::~IOModem() { |
13 | 15 | ||
14 | } | 16 | } |
15 | 17 | ||
16 | 18 | ||
17 | void IOModem::close() { | 19 | void IOModem::close() { |
18 | // Hangup, discarding result | 20 | // Hangup, discarding result |
19 | //int fd = rawIO(); | 21 | //int fd = rawIO(); |
20 | internDetach(); | 22 | internDetach(); |
21 | Dialer d(m_profile, m_fd); | 23 | Dialer d(m_profile, m_fd); |
22 | d.setHangupOnly(); | 24 | d.setHangupOnly(); |
23 | //d.exec(); | 25 | //d.exec(); |
24 | internAttach(); | 26 | internAttach(); |
25 | //closeRawIO(fd); | 27 | //closeRawIO(fd); |
26 | 28 | ||
27 | IOSerial::close(); | 29 | IOSerial::close(); |
28 | } | 30 | } |
29 | 31 | ||
30 | bool IOModem::open() { | 32 | bool IOModem::open() { |
31 | bool ret = IOSerial::open(); | 33 | bool ret = IOSerial::open(); |
32 | if(!ret) return false; | 34 | if(!ret) return false; |
33 | 35 | ||
34 | //int fd = rawIO(); | 36 | //int fd = rawIO(); |
35 | internDetach(); | 37 | internDetach(); |
36 | Dialer d(m_profile, m_fd); | 38 | Dialer d(m_profile, m_fd); |
37 | 39 | ||
38 | int result = d.exec(); | 40 | int result = d.exec(); |
39 | internAttach(); | 41 | internAttach(); |
40 | //closeRawIO(fd); | 42 | //closeRawIO(fd); |
41 | if(result == QDialog::Accepted) | 43 | if(result == QDialog::Accepted) |
42 | { | 44 | { |
43 | return true; | 45 | return true; |
44 | } | 46 | } |
45 | else | 47 | else |
46 | { | 48 | { |
47 | close(); | 49 | close(); |
48 | return false; | 50 | return false; |
49 | } | 51 | } |
50 | } | 52 | } |
51 | 53 | ||
52 | void IOModem::reload( const Profile &config ) { | 54 | void IOModem::reload( const Profile &config ) { |
53 | 55 | ||
54 | m_device = config.readEntry("Device", MODEM_DEFAULT_DEVICE); | 56 | m_device = config.readEntry("Device", MODEM_DEFAULT_DEVICE); |
55 | m_baud = config.readNumEntry("Baud", MODEM_DEFAULT_BAUD); | 57 | m_baud = config.readNumEntry("Baud", MODEM_DEFAULT_BAUD); |
56 | m_parity = config.readNumEntry("Parity", MODEM_DEFAULT_PARITY); | 58 | m_parity = config.readNumEntry("Parity", MODEM_DEFAULT_PARITY); |
57 | m_dbits = config.readNumEntry("DataBits", MODEM_DEFAULT_DBITS); | 59 | m_dbits = config.readNumEntry("DataBits", MODEM_DEFAULT_DBITS); |
58 | m_sbits = config.readNumEntry("StopBits", MODEM_DEFAULT_SBITS); | 60 | m_sbits = config.readNumEntry("StopBits", MODEM_DEFAULT_SBITS); |
59 | m_flow = config.readNumEntry("Flow", MODEM_DEFAULT_FLOW); | 61 | m_flow = config.readNumEntry("Flow", MODEM_DEFAULT_FLOW); |
60 | 62 | ||
61 | m_initString = config.readEntry("InitString", MODEM_DEFAULT_INIT_STRING ); | 63 | m_initString = config.readEntry("InitString", MODEM_DEFAULT_INIT_STRING ); |
62 | m_resetString = config.readEntry("ResetString", MODEM_DEFAULT_RESET_STRING ); | 64 | m_resetString = config.readEntry("ResetString", MODEM_DEFAULT_RESET_STRING ); |
63 | m_dialPref1 = config.readEntry("DialPrefix1", MODEM_DEFAULT_DIAL_PREFIX1 ); | 65 | m_dialPref1 = config.readEntry("DialPrefix1", MODEM_DEFAULT_DIAL_PREFIX1 ); |
64 | m_dialSuf1 = config.readEntry("DialSuffix1", MODEM_DEFAULT_DIAL_SUFFIX1 ); | 66 | m_dialSuf1 = config.readEntry("DialSuffix1", MODEM_DEFAULT_DIAL_SUFFIX1 ); |
65 | m_dialPref2 = config.readEntry("DialPrefix2", MODEM_DEFAULT_DIAL_PREFIX1 ); | 67 | m_dialPref2 = config.readEntry("DialPrefix2", MODEM_DEFAULT_DIAL_PREFIX1 ); |
66 | m_dialSuf2 = config.readEntry("DialSuffix2", MODEM_DEFAULT_DIAL_SUFFIX1 ); | 68 | m_dialSuf2 = config.readEntry("DialSuffix2", MODEM_DEFAULT_DIAL_SUFFIX1 ); |
67 | m_dialPref3 = config.readEntry("DialPrefix3", MODEM_DEFAULT_DIAL_PREFIX1 ); | 69 | m_dialPref3 = config.readEntry("DialPrefix3", MODEM_DEFAULT_DIAL_PREFIX1 ); |
68 | m_dialSuf3 = config.readEntry("DialSuffix3", MODEM_DEFAULT_DIAL_SUFFIX1 ); | 70 | m_dialSuf3 = config.readEntry("DialSuffix3", MODEM_DEFAULT_DIAL_SUFFIX1 ); |
69 | m_connect = config.readEntry("DefaultConnect" MODEM_DEFAULT_CONNECT_STRING ); | 71 | m_connect = config.readEntry("DefaultConnect" MODEM_DEFAULT_CONNECT_STRING ); |
70 | m_hangup = config.readEntry("HangupString", MODEM_DEFAULT_HANGUP_STRING ); | 72 | m_hangup = config.readEntry("HangupString", MODEM_DEFAULT_HANGUP_STRING ); |
71 | m_cancel = config.readEntry("CancelString", MODEM_DEFAULT_CANCEL_STRING ); | 73 | m_cancel = config.readEntry("CancelString", MODEM_DEFAULT_CANCEL_STRING ); |
72 | m_dialTime = config.readNumEntry("DialTime", MODEM_DEFAULT_DIAL_TIME ); | 74 | m_dialTime = config.readNumEntry("DialTime", MODEM_DEFAULT_DIAL_TIME ); |
73 | m_delayRedial = config.readNumEntry("DelayRedial", MODEM_DEFAULT_DELAY_REDIAL ); | 75 | m_delayRedial = config.readNumEntry("DelayRedial", MODEM_DEFAULT_DELAY_REDIAL ); |
74 | m_numberTries = config.readNumEntry("NumberTries", MODEM_DEFAULT_NUMBER_TRIES ); | 76 | m_numberTries = config.readNumEntry("NumberTries", MODEM_DEFAULT_NUMBER_TRIES ); |
75 | m_dtrDropTime = config.readNumEntry("DTRDRopTime", MODEM_DEFAULT_DTR_DROP_TIME ); | 77 | m_dtrDropTime = config.readNumEntry("DTRDRopTime", MODEM_DEFAULT_DTR_DROP_TIME ); |
76 | m_bpsDetect = config.readBoolEntry("BPSDetect", MODEM_DEFAULT_BPS_DETECT ); | 78 | m_bpsDetect = config.readBoolEntry("BPSDetect", MODEM_DEFAULT_BPS_DETECT ); |
77 | m_dcdLines = config.readBoolEntry("DCDLines", MODEM_DEFAULT_DCD_LINES ); | 79 | m_dcdLines = config.readBoolEntry("DCDLines", MODEM_DEFAULT_DCD_LINES ); |
78 | m_multiLineUntag = config.readBoolEntry("MultiLineUntag", MODEM_DEFAULT_MULTI_LINE_UNTAG ); | 80 | m_multiLineUntag = config.readBoolEntry("MultiLineUntag", MODEM_DEFAULT_MULTI_LINE_UNTAG ); |
79 | } | 81 | } |
80 | 82 | ||
81 | 83 | ||
82 | QString IOModem::identifier() const { | 84 | QString IOModem::identifier() const { |
83 | return "modem"; | 85 | return "modem"; |
84 | } | 86 | } |
85 | 87 | ||
86 | QString IOModem::name() const { | 88 | QString IOModem::name() const { |
87 | return "Modem IO Layer"; | 89 | return "Modem IO Layer"; |
88 | } | 90 | } |
89 | 91 | ||
90 | void IOModem::slotExited(OProcess* proc ){ | 92 | void IOModem::slotExited(OProcess* proc ){ |
91 | close(); | 93 | close(); |
92 | /* delete it afterwards */ | 94 | /* delete it afterwards */ |
93 | delete proc; | 95 | delete proc; |
94 | } | 96 | } |
95 | 97 | ||
96 | QBitArray IOModem::supports()const { | 98 | QBitArray IOModem::supports()const { |
97 | return QBitArray( 3 ); | 99 | return QBitArray( 3 ); |
98 | } | 100 | } |
99 | 101 | ||
100 | bool IOModem::isConnected() { | 102 | bool IOModem::isConnected() { |
101 | return false; | 103 | return false; |
102 | } | 104 | } |
103 | 105 | ||
104 | void IOModem::send(const QByteArray &data) { | 106 | void IOModem::send(const QByteArray &data) { |
105 | qDebug( "Please overload me..." ); | 107 | qDebug( "Please overload me..." ); |
106 | } | 108 | } |
diff --git a/noncore/apps/opie-console/io_modem.h b/noncore/apps/opie-console/io_modem.h index 96ec3ef..5b99e00 100644 --- a/noncore/apps/opie-console/io_modem.h +++ b/noncore/apps/opie-console/io_modem.h | |||
@@ -1,74 +1,74 @@ | |||
1 | #ifndef OPIE_IO_MODEM | 1 | #ifndef OPIE_IO_MODEM |
2 | #define OPIE_IO_MODEM | 2 | #define OPIE_IO_MODEM |
3 | 3 | ||
4 | #include <opie2/oprocess.h> | 4 | #include <opie2/oprocess.h> |
5 | #include "io_serial.h" | 5 | #include "io_serial.h" |
6 | #include "profile.h" | 6 | #include "profile.h" |
7 | 7 | ||
8 | /* Default values to be used if the profile information is incomplete */ | 8 | /* Default values to be used if the profile information is incomplete */ |
9 | #define MODEM_DEFAULT_DEVICE "/dev/ttyS0" | 9 | #define MODEM_DEFAULT_DEVICE "/dev/ttyS0" |
10 | #define MODEM_DEFAULT_BAUD 9600 | 10 | #define MODEM_DEFAULT_BAUD 9600 |
11 | #define MODEM_DEFAULT_PARITY 0 | 11 | #define MODEM_DEFAULT_PARITY 0 |
12 | #define MODEM_DEFAULT_DBITS 8 | 12 | #define MODEM_DEFAULT_DBITS 8 |
13 | #define MODEM_DEFAULT_SBITS 1 | 13 | #define MODEM_DEFAULT_SBITS 1 |
14 | #define MODEM_DEFAULT_FLOW 0 | 14 | #define MODEM_DEFAULT_FLOW 0 |
15 | 15 | ||
16 | #define MODEM_DEFAULT_INIT_STRING "AT" | 16 | #define MODEM_DEFAULT_INIT_STRING "AT" |
17 | #define MODEM_DEFAULT_RESET_STRING "ATZ~" | 17 | #define MODEM_DEFAULT_RESET_STRING "ATZ~" |
18 | #define MODEM_DEFAULT_DIAL_PREFIX1 "ATDT" | 18 | #define MODEM_DEFAULT_DIAL_PREFIX1 "ATDT" |
19 | #define MODEM_DEFAULT_DIAL_SUFFIX1 "" | 19 | #define MODEM_DEFAULT_DIAL_SUFFIX1 "" |
20 | #define MODEM_DEFAULT_DIAL_PREFIX2 "" | 20 | #define MODEM_DEFAULT_DIAL_PREFIX2 "" |
21 | #define MODEM_DEFAULT_DIAL_SUFFIX2 "" | 21 | #define MODEM_DEFAULT_DIAL_SUFFIX2 "" |
22 | #define MODEM_DEFAULT_DIAL_PREFIX3 "" | 22 | #define MODEM_DEFAULT_DIAL_PREFIX3 "" |
23 | #define MODEM_DEFAULT_DIAL_SUFFIX3 "" | 23 | #define MODEM_DEFAULT_DIAL_SUFFIX3 "" |
24 | #define MODEM_DEFAULT_CONNECT_STRING "CONNECT" | 24 | #define MODEM_DEFAULT_CONNECT_STRING "CONNECT" |
25 | #define MODEM_DEFAULT_HANGUP_STRING "+++ATH" | 25 | #define MODEM_DEFAULT_HANGUP_STRING "+++ATH" |
26 | #define MODEM_DEFAULT_CANCEL_STRING "" | 26 | #define MODEM_DEFAULT_CANCEL_STRING "" |
27 | #define MODEM_DEFAULT_DIAL_TIME 45 | 27 | #define MODEM_DEFAULT_DIAL_TIME 45 |
28 | #define MODEM_DEFAULT_DELAY_REDIAL 2 | 28 | #define MODEM_DEFAULT_DELAY_REDIAL 2 |
29 | #define MODEM_DEFAULT_NUMBER_TRIES 10 | 29 | #define MODEM_DEFAULT_NUMBER_TRIES 10 |
30 | #define MODEM_DEFAULT_DTR_DROP_TIME 1 | 30 | #define MODEM_DEFAULT_DTR_DROP_TIME 1 |
31 | #define MODEM_DEFAULT_BPS_DETECT 0 // bool | 31 | #define MODEM_DEFAULT_BPS_DETECT 0 // bool |
32 | #define MODEM_DEFAULT_DCD_LINES 1 //bool | 32 | #define MODEM_DEFAULT_DCD_LINES 1 //bool |
33 | #define MODEM_DEFAULT_MULTI_LINE_UNTAG 0 // bool | 33 | #define MODEM_DEFAULT_MULTI_LINE_UNTAG 0 // bool |
34 | 34 | ||
35 | /* IOSerial implements a RS232 IO Layer */ | 35 | /* IOSerial implements a RS232 IO Layer */ |
36 | 36 | ||
37 | class IOModem : public IOSerial { | 37 | class IOModem : public IOSerial { |
38 | 38 | ||
39 | Q_OBJECT | 39 | Q_OBJECT |
40 | 40 | ||
41 | public: | 41 | public: |
42 | 42 | ||
43 | IOModem(const Profile &); | 43 | IOModem(const Profile &); |
44 | ~IOModem(); | 44 | ~IOModem(); |
45 | 45 | ||
46 | virtual QString identifier() const; | 46 | virtual QString identifier() const; |
47 | virtual QString name() const; | 47 | virtual QString name() const; |
48 | virtual QBitArray supports() const; | 48 | virtual QBitArray supports() const; |
49 | virtual bool isConnected(); | 49 | virtual bool isConnected(); |
50 | 50 | ||
51 | signals: | 51 | signals: |
52 | void received(const QByteArray &); | 52 | void received(const QByteArray &); |
53 | void error(int, const QString &); | 53 | void error(int, const QString &); |
54 | 54 | ||
55 | public slots: | 55 | public slots: |
56 | virtual void send( const QByteArray& ); | 56 | virtual void send( const QByteArray& ); |
57 | virtual bool open(); | 57 | virtual bool open(); |
58 | virtual void close(); | 58 | virtual void close(); |
59 | virtual void reload(const Profile &); | 59 | virtual void reload(const Profile &); |
60 | 60 | ||
61 | private: | 61 | private: |
62 | 62 | ||
63 | QString m_initString, m_resetString, m_dialPref1, m_dialSuf1, m_dialPref2, | 63 | QString m_initString, m_resetString, m_dialPref1, m_dialSuf1, m_dialPref2, |
64 | m_dialSuf2, m_dialPref3, m_dialSuf3, m_connect, m_hangup, m_cancel; | 64 | m_dialSuf2, m_dialPref3, m_dialSuf3, m_connect, m_hangup, m_cancel; |
65 | int m_dialTime, m_delayRedial, m_numberTries, m_dtrDropTime, | 65 | int m_dialTime, m_delayRedial, m_numberTries, m_dtrDropTime, |
66 | m_bpsDetect, m_dcdLines, m_multiLineUntag; | 66 | m_bpsDetect, m_dcdLines, m_multiLineUntag; |
67 | Profile m_profile; | 67 | Profile m_profile; |
68 | 68 | ||
69 | private slots: | 69 | private slots: |
70 | void slotExited(OProcess* proc); | 70 | void slotExited(Opie::Core::OProcess* proc); |
71 | 71 | ||
72 | }; | 72 | }; |
73 | 73 | ||
74 | #endif | 74 | #endif |
diff --git a/noncore/apps/opie-console/mainwindow.cpp b/noncore/apps/opie-console/mainwindow.cpp index 197f799..06a8f7d 100644 --- a/noncore/apps/opie-console/mainwindow.cpp +++ b/noncore/apps/opie-console/mainwindow.cpp | |||
@@ -1,727 +1,728 @@ | |||
1 | #include <assert.h> | 1 | #include <assert.h> |
2 | 2 | ||
3 | #include <qaction.h> | 3 | #include <qaction.h> |
4 | #include <qmenubar.h> | 4 | #include <qmenubar.h> |
5 | #include <qtoolbar.h> | 5 | #include <qtoolbar.h> |
6 | #include <qmessagebox.h> | 6 | #include <qmessagebox.h> |
7 | #include <qwhatsthis.h> | 7 | #include <qwhatsthis.h> |
8 | #include <qfileinfo.h> | 8 | #include <qfileinfo.h> |
9 | 9 | ||
10 | #include <qpe/filemanager.h> | 10 | #include <qpe/filemanager.h> |
11 | 11 | ||
12 | #include <opie2/ofiledialog.h> | 12 | #include <opie2/ofiledialog.h> |
13 | 13 | ||
14 | #include "TEmulation.h" | 14 | #include "TEmulation.h" |
15 | #include "profileeditordialog.h" | 15 | #include "profileeditordialog.h" |
16 | #include "configdialog.h" | 16 | #include "configdialog.h" |
17 | #include "default.h" | 17 | #include "default.h" |
18 | #include "profilemanager.h" | 18 | #include "profilemanager.h" |
19 | #include "mainwindow.h" | 19 | #include "mainwindow.h" |
20 | #include "tabwidget.h" | 20 | #include "tabwidget.h" |
21 | #include "transferdialog.h" | 21 | #include "transferdialog.h" |
22 | #include "function_keyboard.h" | 22 | #include "function_keyboard.h" |
23 | #include "emulation_handler.h" | 23 | #include "emulation_handler.h" |
24 | #include "script.h" | 24 | #include "script.h" |
25 | 25 | ||
26 | 26 | ||
27 | using namespace Opie::Ui; | ||
27 | MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) { | 28 | MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) { |
28 | KeyTrans::loadAll(); | 29 | KeyTrans::loadAll(); |
29 | for (int i = 0; i < KeyTrans::count(); i++ ) { | 30 | for (int i = 0; i < KeyTrans::count(); i++ ) { |
30 | KeyTrans* s = KeyTrans::find(i ); | 31 | KeyTrans* s = KeyTrans::find(i ); |
31 | assert( s ); | 32 | assert( s ); |
32 | } | 33 | } |
33 | m_factory = new MetaFactory(); | 34 | m_factory = new MetaFactory(); |
34 | Default def(m_factory); | 35 | Default def(m_factory); |
35 | m_sessions.setAutoDelete( TRUE ); | 36 | m_sessions.setAutoDelete( TRUE ); |
36 | m_curSession = 0; | 37 | m_curSession = 0; |
37 | m_manager = new ProfileManager( m_factory ); | 38 | m_manager = new ProfileManager( m_factory ); |
38 | m_manager->load(); | 39 | m_manager->load(); |
39 | m_scriptsData.setAutoDelete(TRUE); | 40 | m_scriptsData.setAutoDelete(TRUE); |
40 | 41 | ||
41 | initUI(); | 42 | initUI(); |
42 | populateProfiles(); | 43 | populateProfiles(); |
43 | populateScripts(); | 44 | populateScripts(); |
44 | } | 45 | } |
45 | 46 | ||
46 | void MainWindow::initUI() { | 47 | void MainWindow::initUI() { |
47 | 48 | ||
48 | setToolBarsMovable( FALSE ); | 49 | setToolBarsMovable( FALSE ); |
49 | 50 | ||
50 | /* tool bar for the menu */ | 51 | /* tool bar for the menu */ |
51 | m_tool = new QToolBar( this ); | 52 | m_tool = new QToolBar( this ); |
52 | m_tool->setHorizontalStretchable( TRUE ); | 53 | m_tool->setHorizontalStretchable( TRUE ); |
53 | 54 | ||
54 | m_bar = new QMenuBar( m_tool ); | 55 | m_bar = new QMenuBar( m_tool ); |
55 | m_console = new QPopupMenu( this ); | 56 | m_console = new QPopupMenu( this ); |
56 | m_scripts = new QPopupMenu( this ); | 57 | m_scripts = new QPopupMenu( this ); |
57 | m_sessionsPop= new QPopupMenu( this ); | 58 | m_sessionsPop= new QPopupMenu( this ); |
58 | m_scriptsPop = new QPopupMenu( this ); | 59 | m_scriptsPop = new QPopupMenu( this ); |
59 | 60 | ||
60 | /* add a toolbar for icons */ | 61 | /* add a toolbar for icons */ |
61 | m_icons = new QToolBar(this); | 62 | m_icons = new QToolBar(this); |
62 | 63 | ||
63 | /* | 64 | /* |
64 | * the settings action | 65 | * the settings action |
65 | */ | 66 | */ |
66 | m_setProfiles = new QAction(tr("Configure Profiles"), | 67 | m_setProfiles = new QAction(tr("Configure Profiles"), |
67 | Resource::loadPixmap( "SettingsIcon" ), | 68 | Resource::loadPixmap( "SettingsIcon" ), |
68 | QString::null, 0, this, 0); | 69 | QString::null, 0, this, 0); |
69 | m_setProfiles->addTo( m_console ); | 70 | m_setProfiles->addTo( m_console ); |
70 | connect( m_setProfiles, SIGNAL(activated() ), | 71 | connect( m_setProfiles, SIGNAL(activated() ), |
71 | this, SLOT(slotConfigure() ) ); | 72 | this, SLOT(slotConfigure() ) ); |
72 | 73 | ||
73 | m_console->insertSeparator(); | 74 | m_console->insertSeparator(); |
74 | /* | 75 | /* |
75 | * new Action for new sessions | 76 | * new Action for new sessions |
76 | */ | 77 | */ |
77 | QAction* newCon = new QAction(tr("New Profile"), | 78 | QAction* newCon = new QAction(tr("New Profile"), |
78 | Resource::loadPixmap( "new" ), | 79 | Resource::loadPixmap( "new" ), |
79 | QString::null, 0, this, 0); | 80 | QString::null, 0, this, 0); |
80 | newCon->addTo( m_console ); | 81 | newCon->addTo( m_console ); |
81 | connect( newCon, SIGNAL(activated() ), | 82 | connect( newCon, SIGNAL(activated() ), |
82 | this, SLOT(slotNew() ) ); | 83 | this, SLOT(slotNew() ) ); |
83 | 84 | ||
84 | m_console->insertSeparator(); | 85 | m_console->insertSeparator(); |
85 | 86 | ||
86 | QAction *saveCon = new QAction( tr("Save Profile" ), | 87 | QAction *saveCon = new QAction( tr("Save Profile" ), |
87 | Resource::loadPixmap( "save" ), QString::null, | 88 | Resource::loadPixmap( "save" ), QString::null, |
88 | 0, this, 0 ); | 89 | 0, this, 0 ); |
89 | saveCon->addTo( m_console ); | 90 | saveCon->addTo( m_console ); |
90 | connect( saveCon, SIGNAL(activated() ), | 91 | connect( saveCon, SIGNAL(activated() ), |
91 | this, SLOT(slotSaveSession() ) ); | 92 | this, SLOT(slotSaveSession() ) ); |
92 | m_console->insertSeparator(); | 93 | m_console->insertSeparator(); |
93 | 94 | ||
94 | /* | 95 | /* |
95 | * connect action | 96 | * connect action |
96 | */ | 97 | */ |
97 | m_connect = new QAction( tr("Connect"), Resource::loadPixmap("console/connected"), | 98 | m_connect = new QAction( tr("Connect"), Resource::loadPixmap("console/connected"), |
98 | QString::null, 0, this, 0 ); | 99 | QString::null, 0, this, 0 ); |
99 | m_connect->addTo( m_console ); | 100 | m_connect->addTo( m_console ); |
100 | connect(m_connect, SIGNAL(activated() ), | 101 | connect(m_connect, SIGNAL(activated() ), |
101 | this, SLOT(slotConnect() ) ); | 102 | this, SLOT(slotConnect() ) ); |
102 | 103 | ||
103 | /* | 104 | /* |
104 | * disconnect action | 105 | * disconnect action |
105 | */ | 106 | */ |
106 | m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"), | 107 | m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"), |
107 | QString::null, 0, this, 0 ); | 108 | QString::null, 0, this, 0 ); |
108 | m_disconnect->addTo( m_console ); | 109 | m_disconnect->addTo( m_console ); |
109 | connect(m_disconnect, SIGNAL(activated() ), | 110 | connect(m_disconnect, SIGNAL(activated() ), |
110 | this, SLOT(slotDisconnect() ) ); | 111 | this, SLOT(slotDisconnect() ) ); |
111 | 112 | ||
112 | m_console->insertSeparator(); | 113 | m_console->insertSeparator(); |
113 | 114 | ||
114 | 115 | ||
115 | m_quickLaunch = new QAction( tr("QuickLaunch"), Resource::loadPixmap("console/konsole_mini"), QString::null, 0, this, 0 ); | 116 | m_quickLaunch = new QAction( tr("QuickLaunch"), Resource::loadPixmap("console/konsole_mini"), QString::null, 0, this, 0 ); |
116 | m_quickLaunch->addTo( m_icons ); | 117 | m_quickLaunch->addTo( m_icons ); |
117 | connect( m_quickLaunch, SIGNAL( activated() ), | 118 | connect( m_quickLaunch, SIGNAL( activated() ), |
118 | this, SLOT( slotQuickLaunch() ) ); | 119 | this, SLOT( slotQuickLaunch() ) ); |
119 | 120 | ||
120 | QWhatsThis::add( m_icons, tr( "The shell button launches the \"default\" profile. If there is none default values are taken" ) ); | 121 | QWhatsThis::add( m_icons, tr( "The shell button launches the \"default\" profile. If there is none default values are taken" ) ); |
121 | 122 | ||
122 | m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null, | 123 | m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null, |
123 | 0, this, 0 ); | 124 | 0, this, 0 ); |
124 | m_transfer->addTo( m_console ); | 125 | m_transfer->addTo( m_console ); |
125 | connect(m_transfer, SIGNAL(activated() ), | 126 | connect(m_transfer, SIGNAL(activated() ), |
126 | this, SLOT(slotTransfer() ) ); | 127 | this, SLOT(slotTransfer() ) ); |
127 | 128 | ||
128 | 129 | ||
129 | 130 | ||
130 | /* | 131 | /* |
131 | * immediate change of line wrap policy | 132 | * immediate change of line wrap policy |
132 | */ | 133 | */ |
133 | m_isWrapped = false; | 134 | m_isWrapped = false; |
134 | m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 ); | 135 | m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 ); |
135 | m_wrap->addTo( m_console ); | 136 | m_wrap->addTo( m_console ); |
136 | connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) ); | 137 | connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) ); |
137 | 138 | ||
138 | /* | 139 | /* |
139 | * fullscreen | 140 | * fullscreen |
140 | */ | 141 | */ |
141 | m_isFullscreen = false; | 142 | m_isFullscreen = false; |
142 | 143 | ||
143 | m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" ) | 144 | m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" ) |
144 | , QString::null, 0, this, 0); | 145 | , QString::null, 0, this, 0); |
145 | m_fullscreen->addTo( m_console ); | 146 | m_fullscreen->addTo( m_console ); |
146 | connect( m_fullscreen, SIGNAL( activated() ), | 147 | connect( m_fullscreen, SIGNAL( activated() ), |
147 | this, SLOT( slotFullscreen() ) ); | 148 | this, SLOT( slotFullscreen() ) ); |
148 | 149 | ||
149 | m_console->insertSeparator(); | 150 | m_console->insertSeparator(); |
150 | 151 | ||
151 | QAction *a = new QAction(); | 152 | QAction *a = new QAction(); |
152 | a->setText( tr("Save history") ); | 153 | a->setText( tr("Save history") ); |
153 | a->addTo( m_console ); | 154 | a->addTo( m_console ); |
154 | connect(a, SIGNAL(activated() ), | 155 | connect(a, SIGNAL(activated() ), |
155 | this, SLOT(slotSaveHistory() ) ); | 156 | this, SLOT(slotSaveHistory() ) ); |
156 | /* | 157 | /* |
157 | * terminate action | 158 | * terminate action |
158 | */ | 159 | */ |
159 | m_terminate = new QAction(); | 160 | m_terminate = new QAction(); |
160 | m_terminate->setText( tr("Terminate") ); | 161 | m_terminate->setText( tr("Terminate") ); |
161 | m_terminate->addTo( m_console ); | 162 | m_terminate->addTo( m_console ); |
162 | connect(m_terminate, SIGNAL(activated() ), | 163 | connect(m_terminate, SIGNAL(activated() ), |
163 | this, SLOT(slotTerminate() ) ); | 164 | this, SLOT(slotTerminate() ) ); |
164 | 165 | ||
165 | m_closewindow = new QAction(); | 166 | m_closewindow = new QAction(); |
166 | m_closewindow->setText( tr("Close Window") ); | 167 | m_closewindow->setText( tr("Close Window") ); |
167 | m_closewindow->addTo( m_console ); | 168 | m_closewindow->addTo( m_console ); |
168 | connect( m_closewindow, SIGNAL(activated() ), | 169 | connect( m_closewindow, SIGNAL(activated() ), |
169 | this, SLOT(slotClose() ) ); | 170 | this, SLOT(slotClose() ) ); |
170 | 171 | ||
171 | 172 | ||
172 | /* | 173 | /* |
173 | * script actions | 174 | * script actions |
174 | */ | 175 | */ |
175 | m_runScript_id = m_scripts->insertItem(tr("Run Script"), m_scriptsPop, -1, 0); | 176 | m_runScript_id = m_scripts->insertItem(tr("Run Script"), m_scriptsPop, -1, 0); |
176 | connect(m_scriptsPop, SIGNAL(activated(int)), this, SLOT(slotRunScript(int))); | 177 | connect(m_scriptsPop, SIGNAL(activated(int)), this, SLOT(slotRunScript(int))); |
177 | 178 | ||
178 | m_recordScript = new QAction(tr("Record Script"), QString::null, 0, this, 0); | 179 | m_recordScript = new QAction(tr("Record Script"), QString::null, 0, this, 0); |
179 | m_recordScript->addTo(m_scripts); | 180 | m_recordScript->addTo(m_scripts); |
180 | connect(m_recordScript, SIGNAL(activated()), this, SLOT(slotRecordScript())); | 181 | connect(m_recordScript, SIGNAL(activated()), this, SLOT(slotRecordScript())); |
181 | 182 | ||
182 | m_saveScript = new QAction(tr("Save Script"), QString::null, 0, this, 0); | 183 | m_saveScript = new QAction(tr("Save Script"), QString::null, 0, this, 0); |
183 | m_saveScript->addTo(m_scripts); | 184 | m_saveScript->addTo(m_scripts); |
184 | connect(m_saveScript, SIGNAL(activated()), this, SLOT(slotSaveScript())); | 185 | connect(m_saveScript, SIGNAL(activated()), this, SLOT(slotSaveScript())); |
185 | 186 | ||
186 | 187 | ||
187 | /* | 188 | /* |
188 | * action that open/closes the keyboard | 189 | * action that open/closes the keyboard |
189 | */ | 190 | */ |
190 | m_openKeys = new QAction (tr("Open Keyboard..."), | 191 | m_openKeys = new QAction (tr("Open Keyboard..."), |
191 | Resource::loadPixmap( "console/keys/keyboard_icon" ), | 192 | Resource::loadPixmap( "console/keys/keyboard_icon" ), |
192 | QString::null, 0, this, 0); | 193 | QString::null, 0, this, 0); |
193 | m_openKeys->setToggleAction(true); | 194 | m_openKeys->setToggleAction(true); |
194 | connect (m_openKeys, SIGNAL(toggled(bool)), this, SLOT(slotOpenKeb(bool))); | 195 | connect (m_openKeys, SIGNAL(toggled(bool)), this, SLOT(slotOpenKeb(bool))); |
195 | 196 | ||
196 | /* insert the submenu */ | 197 | /* insert the submenu */ |
197 | m_console->insertItem(tr("New from Profile"), m_sessionsPop, | 198 | m_console->insertItem(tr("New from Profile"), m_sessionsPop, |
198 | -1, 0); | 199 | -1, 0); |
199 | 200 | ||
200 | /* insert the connection menu */ | 201 | /* insert the connection menu */ |
201 | m_bar->insertItem( tr("Connection"), m_console ); | 202 | m_bar->insertItem( tr("Connection"), m_console ); |
202 | 203 | ||
203 | /* the scripts menu */ | 204 | /* the scripts menu */ |
204 | m_bar->insertItem( tr("Scripts"), m_scripts ); | 205 | m_bar->insertItem( tr("Scripts"), m_scripts ); |
205 | 206 | ||
206 | /* and the keyboard */ | 207 | /* and the keyboard */ |
207 | m_keyBar = new QToolBar(this); | 208 | m_keyBar = new QToolBar(this); |
208 | addToolBar( m_keyBar, "Keyboard", QMainWindow::Top, TRUE ); | 209 | addToolBar( m_keyBar, "Keyboard", QMainWindow::Top, TRUE ); |
209 | m_keyBar->setHorizontalStretchable( TRUE ); | 210 | m_keyBar->setHorizontalStretchable( TRUE ); |
210 | m_keyBar->hide(); | 211 | m_keyBar->hide(); |
211 | 212 | ||
212 | m_kb = new FunctionKeyboard(m_keyBar); | 213 | m_kb = new FunctionKeyboard(m_keyBar); |
213 | connect(m_kb, SIGNAL(keyPressed(FKey,ushort,ushort,bool)), | 214 | connect(m_kb, SIGNAL(keyPressed(FKey,ushort,ushort,bool)), |
214 | this, SLOT(slotKeyReceived(FKey,ushort,ushort,bool))); | 215 | this, SLOT(slotKeyReceived(FKey,ushort,ushort,bool))); |
215 | 216 | ||
216 | 217 | ||
217 | a = new QAction(tr("Copy"), | 218 | a = new QAction(tr("Copy"), |
218 | Resource::loadPixmap("copy"), QString::null, | 219 | Resource::loadPixmap("copy"), QString::null, |
219 | 0, this, 0 ); | 220 | 0, this, 0 ); |
220 | //a->addTo( m_icons ); | 221 | //a->addTo( m_icons ); |
221 | connect( a, SIGNAL(activated() ), | 222 | connect( a, SIGNAL(activated() ), |
222 | this, SLOT(slotCopy() ) ); | 223 | this, SLOT(slotCopy() ) ); |
223 | 224 | ||
224 | QAction *paste = new QAction(tr("Paste"), | 225 | QAction *paste = new QAction(tr("Paste"), |
225 | Resource::loadPixmap("paste"), QString::null, | 226 | Resource::loadPixmap("paste"), QString::null, |
226 | 0, this, 0 ); | 227 | 0, this, 0 ); |
227 | connect( paste, SIGNAL(activated() ), | 228 | connect( paste, SIGNAL(activated() ), |
228 | this, SLOT(slotPaste() ) ); | 229 | this, SLOT(slotPaste() ) ); |
229 | 230 | ||
230 | 231 | ||
231 | newCon->addTo( m_icons ); | 232 | newCon->addTo( m_icons ); |
232 | //m_setProfiles->addTo( m_icons ); | 233 | //m_setProfiles->addTo( m_icons ); |
233 | paste->addTo( m_icons ); | 234 | paste->addTo( m_icons ); |
234 | m_openKeys->addTo(m_icons); | 235 | m_openKeys->addTo(m_icons); |
235 | m_fullscreen->addTo( m_icons ); | 236 | m_fullscreen->addTo( m_icons ); |
236 | 237 | ||
237 | m_connect->setEnabled( false ); | 238 | m_connect->setEnabled( false ); |
238 | m_disconnect->setEnabled( false ); | 239 | m_disconnect->setEnabled( false ); |
239 | m_terminate->setEnabled( false ); | 240 | m_terminate->setEnabled( false ); |
240 | m_transfer->setEnabled( false ); | 241 | m_transfer->setEnabled( false ); |
241 | m_scripts->setItemEnabled(m_runScript_id, false); | 242 | m_scripts->setItemEnabled(m_runScript_id, false); |
242 | m_recordScript->setEnabled( false ); | 243 | m_recordScript->setEnabled( false ); |
243 | m_saveScript->setEnabled( false ); | 244 | m_saveScript->setEnabled( false ); |
244 | m_fullscreen->setEnabled( false ); | 245 | m_fullscreen->setEnabled( false ); |
245 | m_closewindow->setEnabled( false ); | 246 | m_closewindow->setEnabled( false ); |
246 | m_wrap->setEnabled( false ); | 247 | m_wrap->setEnabled( false ); |
247 | 248 | ||
248 | /* | 249 | /* |
249 | * connect to the menu activation | 250 | * connect to the menu activation |
250 | */ | 251 | */ |
251 | connect( m_sessionsPop, SIGNAL(activated(int) ), | 252 | connect( m_sessionsPop, SIGNAL(activated(int) ), |
252 | this, SLOT(slotProfile(int) ) ); | 253 | this, SLOT(slotProfile(int) ) ); |
253 | 254 | ||
254 | m_consoleWindow = new TabWidget( this, "blah"); | 255 | m_consoleWindow = new TabWidget( this, "blah"); |
255 | connect(m_consoleWindow, SIGNAL(activated(Session*) ), | 256 | connect(m_consoleWindow, SIGNAL(activated(Session*) ), |
256 | this, SLOT(slotSessionChanged(Session*) ) ); | 257 | this, SLOT(slotSessionChanged(Session*) ) ); |
257 | setCentralWidget( m_consoleWindow ); | 258 | setCentralWidget( m_consoleWindow ); |
258 | 259 | ||
259 | slotQuickLaunch(); | 260 | slotQuickLaunch(); |
260 | } | 261 | } |
261 | 262 | ||
262 | ProfileManager* MainWindow::manager() { | 263 | ProfileManager* MainWindow::manager() { |
263 | return m_manager; | 264 | return m_manager; |
264 | } | 265 | } |
265 | TabWidget* MainWindow::tabWidget() { | 266 | TabWidget* MainWindow::tabWidget() { |
266 | return m_consoleWindow; | 267 | return m_consoleWindow; |
267 | } | 268 | } |
268 | void MainWindow::populateProfiles() { | 269 | void MainWindow::populateProfiles() { |
269 | m_sessionsPop->clear(); | 270 | m_sessionsPop->clear(); |
270 | Profile::ValueList list = manager()->all(); | 271 | Profile::ValueList list = manager()->all(); |
271 | for (Profile::ValueList::Iterator it = list.begin(); it != list.end(); ++it ) { | 272 | for (Profile::ValueList::Iterator it = list.begin(); it != list.end(); ++it ) { |
272 | m_sessionsPop->insertItem( (*it).name() ); | 273 | m_sessionsPop->insertItem( (*it).name() ); |
273 | } | 274 | } |
274 | 275 | ||
275 | } | 276 | } |
276 | 277 | ||
277 | void MainWindow::populateScripts() { | 278 | void MainWindow::populateScripts() { |
278 | m_scriptsPop->clear(); | 279 | m_scriptsPop->clear(); |
279 | m_scriptsData.clear(); | 280 | m_scriptsData.clear(); |
280 | DocLnkSet files(QPEApplication::documentDir(), "text/plain"); | 281 | DocLnkSet files(QPEApplication::documentDir(), "text/plain"); |
281 | QListIterator<DocLnk> dit(files.children()); | 282 | QListIterator<DocLnk> dit(files.children()); |
282 | for (; dit.current(); ++dit) { | 283 | for (; dit.current(); ++dit) { |
283 | if (*dit && (*dit)->name().length()>0) { | 284 | if (*dit && (*dit)->name().length()>0) { |
284 | QFileInfo info((*dit)->file()); | 285 | QFileInfo info((*dit)->file()); |
285 | if (info.extension(false) == "script") { | 286 | if (info.extension(false) == "script") { |
286 | m_scriptsData.append(new DocLnk(**dit)); | 287 | m_scriptsData.append(new DocLnk(**dit)); |
287 | m_scriptsPop->insertItem((*dit)->name()); | 288 | m_scriptsPop->insertItem((*dit)->name()); |
288 | } | 289 | } |
289 | } | 290 | } |
290 | } | 291 | } |
291 | 292 | ||
292 | } | 293 | } |
293 | 294 | ||
294 | MainWindow::~MainWindow() { | 295 | MainWindow::~MainWindow() { |
295 | delete m_factory; | 296 | delete m_factory; |
296 | manager()->save(); | 297 | manager()->save(); |
297 | } | 298 | } |
298 | 299 | ||
299 | MetaFactory* MainWindow::factory() { | 300 | MetaFactory* MainWindow::factory() { |
300 | return m_factory; | 301 | return m_factory; |
301 | } | 302 | } |
302 | 303 | ||
303 | Session* MainWindow::currentSession() { | 304 | Session* MainWindow::currentSession() { |
304 | return m_curSession; | 305 | return m_curSession; |
305 | } | 306 | } |
306 | 307 | ||
307 | QList<Session> MainWindow::sessions() { | 308 | QList<Session> MainWindow::sessions() { |
308 | return m_sessions; | 309 | return m_sessions; |
309 | } | 310 | } |
310 | 311 | ||
311 | void MainWindow::slotNew() { | 312 | void MainWindow::slotNew() { |
312 | ProfileEditorDialog dlg(factory() ); | 313 | ProfileEditorDialog dlg(factory() ); |
313 | dlg.setCaption( tr("New Connection") ); | 314 | dlg.setCaption( tr("New Connection") ); |
314 | int ret = QPEApplication::execDialog( &dlg ); | 315 | int ret = QPEApplication::execDialog( &dlg ); |
315 | 316 | ||
316 | if ( ret == QDialog::Accepted ) { | 317 | if ( ret == QDialog::Accepted ) { |
317 | create( dlg.profile() ); | 318 | create( dlg.profile() ); |
318 | } | 319 | } |
319 | } | 320 | } |
320 | 321 | ||
321 | void MainWindow::slotRecordScript() { | 322 | void MainWindow::slotRecordScript() { |
322 | if (currentSession()) { | 323 | if (currentSession()) { |
323 | currentSession()->emulationHandler()->startRecording(); | 324 | currentSession()->emulationHandler()->startRecording(); |
324 | m_saveScript->setEnabled(true); | 325 | m_saveScript->setEnabled(true); |
325 | m_recordScript->setEnabled(false); | 326 | m_recordScript->setEnabled(false); |
326 | } | 327 | } |
327 | } | 328 | } |
328 | 329 | ||
329 | void MainWindow::slotSaveScript() { | 330 | void MainWindow::slotSaveScript() { |
330 | if (currentSession() && currentSession()->emulationHandler()->isRecording()) { | 331 | if (currentSession() && currentSession()->emulationHandler()->isRecording()) { |
331 | QMap<QString, QStringList> map; | 332 | QMap<QString, QStringList> map; |
332 | QStringList text; | 333 | QStringList text; |
333 | text << "text/plain"; | 334 | text << "text/plain"; |
334 | map.insert(tr("Script"), text ); | 335 | map.insert(tr("Script"), text ); |
335 | QString filename = Opie::OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map); | 336 | QString filename = OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map); |
336 | if (!filename.isEmpty()) { | 337 | if (!filename.isEmpty()) { |
337 | QFileInfo info(filename); | 338 | QFileInfo info(filename); |
338 | if (info.extension(FALSE) != "script") | 339 | if (info.extension(FALSE) != "script") |
339 | filename += ".script"; | 340 | filename += ".script"; |
340 | DocLnk nf; | 341 | DocLnk nf; |
341 | nf.setType("text/plain"); | 342 | nf.setType("text/plain"); |
342 | nf.setFile(filename); | 343 | nf.setFile(filename); |
343 | nf.setName(info.fileName()); | 344 | nf.setName(info.fileName()); |
344 | FileManager fm; | 345 | FileManager fm; |
345 | fm.saveFile(nf, currentSession()->emulationHandler()->script()->script()); | 346 | fm.saveFile(nf, currentSession()->emulationHandler()->script()->script()); |
346 | currentSession()->emulationHandler()->clearScript(); | 347 | currentSession()->emulationHandler()->clearScript(); |
347 | m_saveScript->setEnabled(false); | 348 | m_saveScript->setEnabled(false); |
348 | m_recordScript->setEnabled(true); | 349 | m_recordScript->setEnabled(true); |
349 | populateScripts(); | 350 | populateScripts(); |
350 | } | 351 | } |
351 | } | 352 | } |
352 | } | 353 | } |
353 | 354 | ||
354 | void MainWindow::slotRunScript(int id) { | 355 | void MainWindow::slotRunScript(int id) { |
355 | if (currentSession()) { | 356 | if (currentSession()) { |
356 | int index = m_scriptsPop->indexOf(id); | 357 | int index = m_scriptsPop->indexOf(id); |
357 | DocLnk *lnk = m_scriptsData.at(index); | 358 | DocLnk *lnk = m_scriptsData.at(index); |
358 | QString filePath = lnk->file(); | 359 | QString filePath = lnk->file(); |
359 | Script script(filePath); | 360 | Script script(filePath); |
360 | currentSession()->emulationHandler()->runScript(&script); | 361 | currentSession()->emulationHandler()->runScript(&script); |
361 | } | 362 | } |
362 | } | 363 | } |
363 | 364 | ||
364 | void MainWindow::slotConnect() { | 365 | void MainWindow::slotConnect() { |
365 | if ( currentSession() ) { | 366 | if ( currentSession() ) { |
366 | bool ret = currentSession()->layer()->open(); | 367 | bool ret = currentSession()->layer()->open(); |
367 | if(!ret) QMessageBox::warning(currentSession()->widgetStack(), | 368 | if(!ret) QMessageBox::warning(currentSession()->widgetStack(), |
368 | QObject::tr("Failed"), | 369 | QObject::tr("Failed"), |
369 | QObject::tr("Connecting failed for this session.")); | 370 | QObject::tr("Connecting failed for this session.")); |
370 | else { | 371 | else { |
371 | m_connect->setEnabled( false ); | 372 | m_connect->setEnabled( false ); |
372 | m_disconnect->setEnabled( true ); | 373 | m_disconnect->setEnabled( true ); |
373 | 374 | ||
374 | // if it does not support file transfer, disable the menu entry | 375 | // if it does not support file transfer, disable the menu entry |
375 | if ( ( m_curSession->layer() )->supports()[1] == 0 ) { | 376 | if ( ( m_curSession->layer() )->supports()[1] == 0 ) { |
376 | m_transfer->setEnabled( false ); | 377 | m_transfer->setEnabled( false ); |
377 | } else { | 378 | } else { |
378 | m_transfer->setEnabled( true ); | 379 | m_transfer->setEnabled( true ); |
379 | } | 380 | } |
380 | 381 | ||
381 | m_recordScript->setEnabled( true ); | 382 | m_recordScript->setEnabled( true ); |
382 | m_scripts->setItemEnabled(m_runScript_id, true); | 383 | m_scripts->setItemEnabled(m_runScript_id, true); |
383 | } | 384 | } |
384 | } | 385 | } |
385 | } | 386 | } |
386 | 387 | ||
387 | void MainWindow::slotDisconnect() { | 388 | void MainWindow::slotDisconnect() { |
388 | if ( currentSession() ) { | 389 | if ( currentSession() ) { |
389 | currentSession()->layer()->close(); | 390 | currentSession()->layer()->close(); |
390 | m_connect->setEnabled( true ); | 391 | m_connect->setEnabled( true ); |
391 | m_disconnect->setEnabled( false ); | 392 | m_disconnect->setEnabled( false ); |
392 | m_transfer->setEnabled( false ); | 393 | m_transfer->setEnabled( false ); |
393 | m_recordScript->setEnabled( false); | 394 | m_recordScript->setEnabled( false); |
394 | m_saveScript->setEnabled( false ); | 395 | m_saveScript->setEnabled( false ); |
395 | m_scripts->setItemEnabled(m_runScript_id, false); | 396 | m_scripts->setItemEnabled(m_runScript_id, false); |
396 | } | 397 | } |
397 | } | 398 | } |
398 | 399 | ||
399 | void MainWindow::slotTerminate() { | 400 | void MainWindow::slotTerminate() { |
400 | if ( currentSession() ) | 401 | if ( currentSession() ) |
401 | currentSession()->layer()->close(); | 402 | currentSession()->layer()->close(); |
402 | 403 | ||
403 | slotClose(); | 404 | slotClose(); |
404 | /* FIXME move to the next session */ | 405 | /* FIXME move to the next session */ |
405 | } | 406 | } |
406 | 407 | ||
407 | 408 | ||
408 | 409 | ||
409 | 410 | ||
410 | 411 | ||
411 | 412 | ||
412 | void MainWindow::slotQuickLaunch() { | 413 | void MainWindow::slotQuickLaunch() { |
413 | Profile prof = manager()->profile( "default" ); | 414 | Profile prof = manager()->profile( "default" ); |
414 | if ( prof.name() == "default" ) { | 415 | if ( prof.name() == "default" ) { |
415 | create( prof ); | 416 | create( prof ); |
416 | } else { | 417 | } else { |
417 | Profile newProf = Profile( "default", "console", "default" , 0, 3, 0 ); | 418 | Profile newProf = Profile( "default", "console", "default" , 0, 3, 0 ); |
418 | newProf.setAutoConnect( true ); | 419 | newProf.setAutoConnect( true ); |
419 | create( newProf ); | 420 | create( newProf ); |
420 | slotSaveSession(); | 421 | slotSaveSession(); |
421 | } | 422 | } |
422 | 423 | ||
423 | } | 424 | } |
424 | 425 | ||
425 | void MainWindow::slotConfigure() { | 426 | void MainWindow::slotConfigure() { |
426 | ConfigDialog conf( manager()->all(), factory() ); | 427 | ConfigDialog conf( manager()->all(), factory() ); |
427 | 428 | ||
428 | int ret = QPEApplication::execDialog( &conf ); | 429 | int ret = QPEApplication::execDialog( &conf ); |
429 | 430 | ||
430 | if ( QDialog::Accepted == ret ) { | 431 | if ( QDialog::Accepted == ret ) { |
431 | manager()->setProfiles( conf.list() ); | 432 | manager()->setProfiles( conf.list() ); |
432 | manager()->save(); | 433 | manager()->save(); |
433 | populateProfiles(); | 434 | populateProfiles(); |
434 | } | 435 | } |
435 | } | 436 | } |
436 | /* | 437 | /* |
437 | * we will remove | 438 | * we will remove |
438 | * this window from the tabwidget | 439 | * this window from the tabwidget |
439 | * remove it from the list | 440 | * remove it from the list |
440 | * delete it | 441 | * delete it |
441 | * and set the currentSession() | 442 | * and set the currentSession() |
442 | */ | 443 | */ |
443 | void MainWindow::slotClose() { | 444 | void MainWindow::slotClose() { |
444 | if (!currentSession() ) | 445 | if (!currentSession() ) |
445 | return; | 446 | return; |
446 | 447 | ||
447 | Session* ses = currentSession(); | 448 | Session* ses = currentSession(); |
448 | qWarning("removing! currentSession %s", currentSession()->name().latin1() ); | 449 | qWarning("removing! currentSession %s", currentSession()->name().latin1() ); |
449 | /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */ | 450 | /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */ |
450 | m_curSession = NULL; | 451 | m_curSession = NULL; |
451 | tabWidget()->remove( /*currentSession()*/ses ); | 452 | tabWidget()->remove( /*currentSession()*/ses ); |
452 | /*it's autodelete */ | 453 | /*it's autodelete */ |
453 | m_sessions.remove( ses ); | 454 | m_sessions.remove( ses ); |
454 | qWarning("after remove!!"); | 455 | qWarning("after remove!!"); |
455 | 456 | ||
456 | if (!currentSession() ) { | 457 | if (!currentSession() ) { |
457 | m_connect->setEnabled( false ); | 458 | m_connect->setEnabled( false ); |
458 | m_disconnect->setEnabled( false ); | 459 | m_disconnect->setEnabled( false ); |
459 | m_terminate->setEnabled( false ); | 460 | m_terminate->setEnabled( false ); |
460 | m_transfer->setEnabled( false ); | 461 | m_transfer->setEnabled( false ); |
461 | m_recordScript->setEnabled( false ); | 462 | m_recordScript->setEnabled( false ); |
462 | m_saveScript->setEnabled( false ); | 463 | m_saveScript->setEnabled( false ); |
463 | m_scripts->setItemEnabled(m_runScript_id, false); | 464 | m_scripts->setItemEnabled(m_runScript_id, false); |
464 | m_fullscreen->setEnabled( false ); | 465 | m_fullscreen->setEnabled( false ); |
465 | m_wrap->setEnabled( false ); | 466 | m_wrap->setEnabled( false ); |
466 | m_closewindow->setEnabled( false ); | 467 | m_closewindow->setEnabled( false ); |
467 | } | 468 | } |
468 | 469 | ||
469 | m_kb->loadDefaults(); | 470 | m_kb->loadDefaults(); |
470 | } | 471 | } |
471 | 472 | ||
472 | /* | 473 | /* |
473 | * We will get the name | 474 | * We will get the name |
474 | * Then the profile | 475 | * Then the profile |
475 | * and then we will make a profile | 476 | * and then we will make a profile |
476 | */ | 477 | */ |
477 | void MainWindow::slotProfile( int id) { | 478 | void MainWindow::slotProfile( int id) { |
478 | Profile prof = manager()->profile( m_sessionsPop->text( id) ); | 479 | Profile prof = manager()->profile( m_sessionsPop->text( id) ); |
479 | create( prof ); | 480 | create( prof ); |
480 | } | 481 | } |
481 | 482 | ||
482 | 483 | ||
483 | 484 | ||
484 | void MainWindow::create( const Profile& prof ) { | 485 | void MainWindow::create( const Profile& prof ) { |
485 | if(m_curSession) | 486 | if(m_curSession) |
486 | if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); | 487 | if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); |
487 | 488 | ||
488 | Session *ses = manager()->fromProfile( prof, tabWidget() ); | 489 | Session *ses = manager()->fromProfile( prof, tabWidget() ); |
489 | 490 | ||
490 | if((!ses) || (!ses->layer()) || (!ses->widgetStack())) | 491 | if((!ses) || (!ses->layer()) || (!ses->widgetStack())) |
491 | { | 492 | { |
492 | QMessageBox::warning(this, | 493 | QMessageBox::warning(this, |
493 | QObject::tr("Session failed"), | 494 | QObject::tr("Session failed"), |
494 | QObject::tr("<qt>Cannot open session: Not all components were found.</qt>")); | 495 | QObject::tr("<qt>Cannot open session: Not all components were found.</qt>")); |
495 | //if(ses) delete ses; | 496 | //if(ses) delete ses; |
496 | return; | 497 | return; |
497 | } | 498 | } |
498 | 499 | ||
499 | m_sessions.append( ses ); | 500 | m_sessions.append( ses ); |
500 | tabWidget()->add( ses ); | 501 | tabWidget()->add( ses ); |
501 | tabWidget()->repaint(); | 502 | tabWidget()->repaint(); |
502 | m_curSession = ses; | 503 | m_curSession = ses; |
503 | 504 | ||
504 | // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it | 505 | // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it |
505 | m_connect->setEnabled( true ); | 506 | m_connect->setEnabled( true ); |
506 | m_disconnect->setEnabled( false ); | 507 | m_disconnect->setEnabled( false ); |
507 | m_terminate->setEnabled( true ); | 508 | m_terminate->setEnabled( true ); |
508 | m_fullscreen->setEnabled( true ); | 509 | m_fullscreen->setEnabled( true ); |
509 | m_wrap->setEnabled( true ); | 510 | m_wrap->setEnabled( true ); |
510 | m_closewindow->setEnabled( true ); | 511 | m_closewindow->setEnabled( true ); |
511 | m_transfer->setEnabled( false ); | 512 | m_transfer->setEnabled( false ); |
512 | m_recordScript->setEnabled( false ); | 513 | m_recordScript->setEnabled( false ); |
513 | m_saveScript->setEnabled( false ); | 514 | m_saveScript->setEnabled( false ); |
514 | m_scripts->setItemEnabled(m_runScript_id, false); | 515 | m_scripts->setItemEnabled(m_runScript_id, false); |
515 | 516 | ||
516 | // is io_layer wants direct connection, then autoconnect | 517 | // is io_layer wants direct connection, then autoconnect |
517 | //if ( ( m_curSession->layer() )->supports()[0] == 1 ) { | 518 | //if ( ( m_curSession->layer() )->supports()[0] == 1 ) { |
518 | if (prof.autoConnect()) { | 519 | if (prof.autoConnect()) { |
519 | slotConnect(); | 520 | slotConnect(); |
520 | } | 521 | } |
521 | 522 | ||
522 | 523 | ||
523 | QWidget *w = currentSession()->widget(); | 524 | QWidget *w = currentSession()->widget(); |
524 | if(w) w->setFocus(); | 525 | if(w) w->setFocus(); |
525 | 526 | ||
526 | if(currentSession()->profile().readNumEntry("Wrap", 80)){ | 527 | if(currentSession()->profile().readNumEntry("Wrap", 80)){ |
527 | m_isWrapped = true; | 528 | m_isWrapped = true; |
528 | } else { | 529 | } else { |
529 | m_isWrapped = false; | 530 | m_isWrapped = false; |
530 | } | 531 | } |
531 | 532 | ||
532 | m_kb->load(currentSession()->profile()); | 533 | m_kb->load(currentSession()->profile()); |
533 | } | 534 | } |
534 | 535 | ||
535 | void MainWindow::slotTransfer() | 536 | void MainWindow::slotTransfer() |
536 | { | 537 | { |
537 | if ( currentSession() ) { | 538 | if ( currentSession() ) { |
538 | Session *mysession = currentSession(); | 539 | Session *mysession = currentSession(); |
539 | TransferDialog dlg(/*mysession->widgetStack()*/this, this); | 540 | TransferDialog dlg(/*mysession->widgetStack()*/this, this); |
540 | mysession->setTransferDialog(&dlg); | 541 | mysession->setTransferDialog(&dlg); |
541 | //dlg.reparent(mysession->widgetStack(), QPoint(0, 0)); | 542 | //dlg.reparent(mysession->widgetStack(), QPoint(0, 0)); |
542 | //dlg.showMaximized(); | 543 | //dlg.showMaximized(); |
543 | currentSession()->widgetStack()->addWidget(&dlg, -1); | 544 | currentSession()->widgetStack()->addWidget(&dlg, -1); |
544 | dlg.show(); | 545 | dlg.show(); |
545 | //dlg.exec(); | 546 | //dlg.exec(); |
546 | while(dlg.isRunning()) qApp->processEvents(); | 547 | while(dlg.isRunning()) qApp->processEvents(); |
547 | mysession->setTransferDialog(0l); | 548 | mysession->setTransferDialog(0l); |
548 | } | 549 | } |
549 | } | 550 | } |
550 | 551 | ||
551 | 552 | ||
552 | void MainWindow::slotOpenKeb(bool state) { | 553 | void MainWindow::slotOpenKeb(bool state) { |
553 | 554 | ||
554 | if (state) m_keyBar->show(); | 555 | if (state) m_keyBar->show(); |
555 | else m_keyBar->hide(); | 556 | else m_keyBar->hide(); |
556 | 557 | ||
557 | } | 558 | } |
558 | 559 | ||
559 | 560 | ||
560 | void MainWindow::slotOpenButtons( bool state ) { | 561 | void MainWindow::slotOpenButtons( bool state ) { |
561 | 562 | ||
562 | if ( state ) { | 563 | if ( state ) { |
563 | m_buttonBar->show(); | 564 | m_buttonBar->show(); |
564 | } else { | 565 | } else { |
565 | m_buttonBar->hide(); | 566 | m_buttonBar->hide(); |
566 | } | 567 | } |
567 | } | 568 | } |
568 | 569 | ||
569 | 570 | ||
570 | 571 | ||
571 | void MainWindow::slotSessionChanged( Session* ses ) { | 572 | void MainWindow::slotSessionChanged( Session* ses ) { |
572 | qWarning("changed!"); | 573 | qWarning("changed!"); |
573 | 574 | ||
574 | if(m_curSession) | 575 | if(m_curSession) |
575 | if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); | 576 | if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); |
576 | if(ses) | 577 | if(ses) |
577 | if(ses->transferDialog()) ses->transferDialog()->show(); | 578 | if(ses->transferDialog()) ses->transferDialog()->show(); |
578 | 579 | ||
579 | if ( ses ) { | 580 | if ( ses ) { |
580 | m_curSession = ses; | 581 | m_curSession = ses; |
581 | qDebug(QString("is connected : %1").arg( m_curSession->layer()->isConnected() ) ); | 582 | qDebug(QString("is connected : %1").arg( m_curSession->layer()->isConnected() ) ); |
582 | if ( m_curSession->layer()->isConnected() ) { | 583 | if ( m_curSession->layer()->isConnected() ) { |
583 | m_connect->setEnabled( false ); | 584 | m_connect->setEnabled( false ); |
584 | m_disconnect->setEnabled( true ); | 585 | m_disconnect->setEnabled( true ); |
585 | m_recordScript->setEnabled(!m_curSession->emulationHandler()->isRecording()); | 586 | m_recordScript->setEnabled(!m_curSession->emulationHandler()->isRecording()); |
586 | m_saveScript->setEnabled(m_curSession->emulationHandler()->isRecording()); | 587 | m_saveScript->setEnabled(m_curSession->emulationHandler()->isRecording()); |
587 | m_scripts->setItemEnabled(m_runScript_id, true); | 588 | m_scripts->setItemEnabled(m_runScript_id, true); |
588 | } else { | 589 | } else { |
589 | m_connect->setEnabled( true ); | 590 | m_connect->setEnabled( true ); |
590 | m_disconnect->setEnabled( false ); | 591 | m_disconnect->setEnabled( false ); |
591 | m_recordScript->setEnabled( false ); | 592 | m_recordScript->setEnabled( false ); |
592 | m_saveScript->setEnabled( false ); | 593 | m_saveScript->setEnabled( false ); |
593 | m_scripts->setItemEnabled(m_runScript_id, false); | 594 | m_scripts->setItemEnabled(m_runScript_id, false); |
594 | } | 595 | } |
595 | 596 | ||
596 | if ( ( m_curSession->layer() )->supports()[1] == 0 ) { | 597 | if ( ( m_curSession->layer() )->supports()[1] == 0 ) { |
597 | m_transfer->setEnabled( false ); | 598 | m_transfer->setEnabled( false ); |
598 | } else { | 599 | } else { |
599 | m_transfer->setEnabled( true ); | 600 | m_transfer->setEnabled( true ); |
600 | } | 601 | } |
601 | 602 | ||
602 | QWidget *w = m_curSession->widget(); | 603 | QWidget *w = m_curSession->widget(); |
603 | if(w) w->setFocus(); | 604 | if(w) w->setFocus(); |
604 | 605 | ||
605 | if(currentSession()->profile().readNumEntry("Wrap", 80)){ | 606 | if(currentSession()->profile().readNumEntry("Wrap", 80)){ |
606 | m_isWrapped = true; | 607 | m_isWrapped = true; |
607 | } else { | 608 | } else { |
608 | m_isWrapped = false; | 609 | m_isWrapped = false; |
609 | } | 610 | } |
610 | 611 | ||
611 | m_kb->load(currentSession()->profile()); | 612 | m_kb->load(currentSession()->profile()); |
612 | } | 613 | } |
613 | } | 614 | } |
614 | 615 | ||
615 | void MainWindow::slotWrap() | 616 | void MainWindow::slotWrap() |
616 | { | 617 | { |
617 | if(m_curSession) | 618 | if(m_curSession) |
618 | { | 619 | { |
619 | EmulationHandler *e = m_curSession->emulationHandler(); | 620 | EmulationHandler *e = m_curSession->emulationHandler(); |
620 | if(e) | 621 | if(e) |
621 | { | 622 | { |
622 | if(m_isWrapped) | 623 | if(m_isWrapped) |
623 | { | 624 | { |
624 | e->setWrap(80); | 625 | e->setWrap(80); |
625 | m_isWrapped = false; | 626 | m_isWrapped = false; |
626 | } | 627 | } |
627 | else | 628 | else |
628 | { | 629 | { |
629 | e->setWrap(0); | 630 | e->setWrap(0); |
630 | m_isWrapped = true; | 631 | m_isWrapped = true; |
631 | } | 632 | } |
632 | } | 633 | } |
633 | } | 634 | } |
634 | } | 635 | } |
635 | 636 | ||
636 | void MainWindow::slotFullscreen() { | 637 | void MainWindow::slotFullscreen() { |
637 | 638 | ||
638 | 639 | ||
639 | 640 | ||
640 | if ( m_isFullscreen ) { | 641 | if ( m_isFullscreen ) { |
641 | ( m_curSession->widgetStack() )->reparent( savedParentFullscreen, 0, QPoint(0,0), true ); | 642 | ( m_curSession->widgetStack() )->reparent( savedParentFullscreen, 0, QPoint(0,0), true ); |
642 | ( m_curSession->widgetStack() )->resize( savedParentFullscreen->width(), savedParentFullscreen->height() ); | 643 | ( m_curSession->widgetStack() )->resize( savedParentFullscreen->width(), savedParentFullscreen->height() ); |
643 | ( m_curSession->emulationHandler() )->cornerButton()->hide(); | 644 | ( m_curSession->emulationHandler() )->cornerButton()->hide(); |
644 | disconnect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); | 645 | disconnect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); |
645 | 646 | ||
646 | } else { | 647 | } else { |
647 | savedParentFullscreen = ( m_curSession->widgetStack() )->parentWidget(); | 648 | savedParentFullscreen = ( m_curSession->widgetStack() )->parentWidget(); |
648 | ( m_curSession->widgetStack() )->setFrameStyle( QFrame::NoFrame ); | 649 | ( m_curSession->widgetStack() )->setFrameStyle( QFrame::NoFrame ); |
649 | ( m_curSession->widgetStack() )->reparent( 0, WStyle_Tool | WStyle_Customize | WStyle_StaysOnTop | 650 | ( m_curSession->widgetStack() )->reparent( 0, WStyle_Tool | WStyle_Customize | WStyle_StaysOnTop |
650 | , QPoint(0,0), false ); | 651 | , QPoint(0,0), false ); |
651 | ( m_curSession->widgetStack() )->resize( qApp->desktop()->width(), qApp->desktop()->height() ); | 652 | ( m_curSession->widgetStack() )->resize( qApp->desktop()->width(), qApp->desktop()->height() ); |
652 | ( m_curSession->widgetStack() )->setFocus(); | 653 | ( m_curSession->widgetStack() )->setFocus(); |
653 | ( m_curSession->widgetStack() )->show(); | 654 | ( m_curSession->widgetStack() )->show(); |
654 | 655 | ||
655 | ( ( m_curSession->emulationHandler() )->cornerButton() )->show(); | 656 | ( ( m_curSession->emulationHandler() )->cornerButton() )->show(); |
656 | 657 | ||
657 | connect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); | 658 | connect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); |
658 | } | 659 | } |
659 | 660 | ||
660 | m_isFullscreen = !m_isFullscreen; | 661 | m_isFullscreen = !m_isFullscreen; |
661 | } | 662 | } |
662 | 663 | ||
663 | 664 | ||
664 | void MainWindow::slotKeyReceived(FKey k, ushort, ushort, bool pressed) { | 665 | void MainWindow::slotKeyReceived(FKey k, ushort, ushort, bool pressed) { |
665 | 666 | ||
666 | if ( m_curSession ) { | 667 | if ( m_curSession ) { |
667 | 668 | ||
668 | QEvent::Type state; | 669 | QEvent::Type state; |
669 | 670 | ||
670 | if (pressed) state = QEvent::KeyPress; | 671 | if (pressed) state = QEvent::KeyPress; |
671 | else state = QEvent::KeyRelease; | 672 | else state = QEvent::KeyRelease; |
672 | 673 | ||
673 | QKeyEvent ke(state, k.qcode, k.unicode, 0, QString(QChar(k.unicode))); | 674 | QKeyEvent ke(state, k.qcode, k.unicode, 0, QString(QChar(k.unicode))); |
674 | 675 | ||
675 | // is this the best way to do this? cant figure out any other way to work | 676 | // is this the best way to do this? cant figure out any other way to work |
676 | QApplication::sendEvent((QObject *)m_curSession->widget(), &ke); | 677 | QApplication::sendEvent((QObject *)m_curSession->widget(), &ke); |
677 | ke.ignore(); | 678 | ke.ignore(); |
678 | } | 679 | } |
679 | } | 680 | } |
680 | void MainWindow::slotCopy() { | 681 | void MainWindow::slotCopy() { |
681 | if (!currentSession() ) return; | 682 | if (!currentSession() ) return; |
682 | currentSession()->emulationHandler()->copy(); | 683 | currentSession()->emulationHandler()->copy(); |
683 | } | 684 | } |
684 | void MainWindow::slotPaste() { | 685 | void MainWindow::slotPaste() { |
685 | if (!currentSession() ) return; | 686 | if (!currentSession() ) return; |
686 | currentSession()->emulationHandler()->paste(); | 687 | currentSession()->emulationHandler()->paste(); |
687 | } | 688 | } |
688 | 689 | ||
689 | /* | 690 | /* |
690 | * Save the session | 691 | * Save the session |
691 | */ | 692 | */ |
692 | 693 | ||
693 | void MainWindow::slotSaveSession() { | 694 | void MainWindow::slotSaveSession() { |
694 | if (!currentSession() ) { | 695 | if (!currentSession() ) { |
695 | QMessageBox::information(this, tr("Save Connection"), | 696 | QMessageBox::information(this, tr("Save Connection"), |
696 | tr("<qt>There is no Connection.</qt>"), 1 ); | 697 | tr("<qt>There is no Connection.</qt>"), 1 ); |
697 | return; | 698 | return; |
698 | } | 699 | } |
699 | manager()->add( currentSession()->profile() ); | 700 | manager()->add( currentSession()->profile() ); |
700 | manager()->save(); | 701 | manager()->save(); |
701 | populateProfiles(); | 702 | populateProfiles(); |
702 | } | 703 | } |
703 | void MainWindow::slotSaveHistory() { | 704 | void MainWindow::slotSaveHistory() { |
704 | QMap<QString, QStringList> map; | 705 | QMap<QString, QStringList> map; |
705 | QStringList text; | 706 | QStringList text; |
706 | text << "text/plain"; | 707 | text << "text/plain"; |
707 | map.insert(tr("History"), text ); | 708 | map.insert(tr("History"), text ); |
708 | QString filename = Opie::OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map); | 709 | QString filename = OFileDialog::getSaveFileName(2, QPEApplication::documentDir(), QString::null, map); |
709 | if (filename.isEmpty() ) return; | 710 | if (filename.isEmpty() ) return; |
710 | 711 | ||
711 | QFileInfo info(filename); | 712 | QFileInfo info(filename); |
712 | 713 | ||
713 | DocLnk nf; | 714 | DocLnk nf; |
714 | nf.setType("text/plain"); | 715 | nf.setType("text/plain"); |
715 | nf.setFile(filename); | 716 | nf.setFile(filename); |
716 | nf.setName(info.fileName()); | 717 | nf.setName(info.fileName()); |
717 | 718 | ||
718 | 719 | ||
719 | QFile file(filename); | 720 | QFile file(filename); |
720 | file.open(IO_WriteOnly ); | 721 | file.open(IO_WriteOnly ); |
721 | QTextStream str(&file ); | 722 | QTextStream str(&file ); |
722 | if ( currentSession() ) | 723 | if ( currentSession() ) |
723 | currentSession()->emulationHandler()->emulation()->streamHistory(&str); | 724 | currentSession()->emulationHandler()->emulation()->streamHistory(&str); |
724 | 725 | ||
725 | file.close(); | 726 | file.close(); |
726 | nf.writeLink(); | 727 | nf.writeLink(); |
727 | } | 728 | } |
diff --git a/noncore/apps/opie-console/profileeditordialog.cpp b/noncore/apps/opie-console/profileeditordialog.cpp index 6e1e23e..dc42d8b 100644 --- a/noncore/apps/opie-console/profileeditordialog.cpp +++ b/noncore/apps/opie-console/profileeditordialog.cpp | |||
@@ -1,241 +1,242 @@ | |||
1 | #include <qlayout.h> | 1 | #include <qlayout.h> |
2 | #include <qlineedit.h> | 2 | #include <qlineedit.h> |
3 | #include <qlabel.h> | 3 | #include <qlabel.h> |
4 | #include <qmessagebox.h> | 4 | #include <qmessagebox.h> |
5 | #include <qcombobox.h> | 5 | #include <qcombobox.h> |
6 | #include <qcheckbox.h> | 6 | #include <qcheckbox.h> |
7 | #include <qscrollview.h> | 7 | #include <qscrollview.h> |
8 | 8 | ||
9 | #include "metafactory.h" | 9 | #include "metafactory.h" |
10 | #include "profileeditordialog.h" | 10 | #include "profileeditordialog.h" |
11 | 11 | ||
12 | using namespace Opie::Ui; | ||
12 | namespace { | 13 | namespace { |
13 | void setCurrent( const QString& str, QComboBox* bo ) { | 14 | void setCurrent( const QString& str, QComboBox* bo ) { |
14 | for (int i = 0; i < bo->count(); i++ ) { | 15 | for (int i = 0; i < bo->count(); i++ ) { |
15 | if ( bo->text(i) == str ) { | 16 | if ( bo->text(i) == str ) { |
16 | bo->setCurrentItem( i ); | 17 | bo->setCurrentItem( i ); |
17 | } | 18 | } |
18 | } | 19 | } |
19 | }; | 20 | }; |
20 | } | 21 | } |
21 | 22 | ||
22 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact, | 23 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact, |
23 | const Profile& prof ) | 24 | const Profile& prof ) |
24 | : QDialog(0, 0, TRUE), m_fact( fact ), m_prof( prof ) | 25 | : QDialog(0, 0, TRUE), m_fact( fact ), m_prof( prof ) |
25 | { | 26 | { |
26 | initUI(); | 27 | initUI(); |
27 | 28 | ||
28 | // Apply current profile | 29 | // Apply current profile |
29 | // plugin_plugin->load(profile); | 30 | // plugin_plugin->load(profile); |
30 | // ... (reset profile name line edit etc.) | 31 | // ... (reset profile name line edit etc.) |
31 | } | 32 | } |
32 | 33 | ||
33 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact ) | 34 | ProfileEditorDialog::ProfileEditorDialog( MetaFactory* fact ) |
34 | : QDialog(0, 0, TRUE), m_fact( fact ) | 35 | : QDialog(0, 0, TRUE), m_fact( fact ) |
35 | { | 36 | { |
36 | // Default profile | 37 | // Default profile |
37 | m_prof = Profile(tr("New Profile"), "serial", "default", Profile::Black, Profile::White, Profile::VT102); | 38 | m_prof = Profile(tr("New Profile"), "serial", "default", Profile::Black, Profile::White, Profile::VT102); |
38 | 39 | ||
39 | initUI(); | 40 | initUI(); |
40 | 41 | ||
41 | // Apply current profile | 42 | // Apply current profile |
42 | // plugin_plugin->load(profile); | 43 | // plugin_plugin->load(profile); |
43 | } | 44 | } |
44 | 45 | ||
45 | Profile ProfileEditorDialog::profile() const | 46 | Profile ProfileEditorDialog::profile() const |
46 | { | 47 | { |
47 | return m_prof; | 48 | return m_prof; |
48 | } | 49 | } |
49 | 50 | ||
50 | void ProfileEditorDialog::initUI() | 51 | void ProfileEditorDialog::initUI() |
51 | { | 52 | { |
52 | m_con = m_term = m_key = 0l; | 53 | m_con = m_term = m_key = 0l; |
53 | 54 | ||
54 | 55 | ||
55 | QVBoxLayout *mainLayout = new QVBoxLayout( this ); | 56 | QVBoxLayout *mainLayout = new QVBoxLayout( this ); |
56 | tabWidget = new OTabWidget( this ); | 57 | tabWidget = new OTabWidget( this ); |
57 | tabWidget->setTabStyle(OTabWidget::TextTab); | 58 | tabWidget->setTabStyle(OTabWidget::TextTab); |
58 | mainLayout->add(tabWidget); | 59 | mainLayout->add(tabWidget); |
59 | 60 | ||
60 | /* base tabs */ | 61 | /* base tabs */ |
61 | tabprof = new QWidget(this); | 62 | tabprof = new QWidget(this); |
62 | m_tabTerm = new QWidget(this); | 63 | m_tabTerm = new QWidget(this); |
63 | m_tabCon = new QWidget(this); | 64 | m_tabCon = new QWidget(this); |
64 | m_tabKey = new QWidget(this); | 65 | m_tabKey = new QWidget(this); |
65 | 66 | ||
66 | m_svCon = new QScrollView( m_tabCon ); | 67 | m_svCon = new QScrollView( m_tabCon ); |
67 | m_svCon->setResizePolicy( QScrollView::AutoOneFit ); | 68 | m_svCon->setResizePolicy( QScrollView::AutoOneFit ); |
68 | //m_svCon->setHScrollBarMode( QScrollView::AlwaysOff ); | 69 | //m_svCon->setHScrollBarMode( QScrollView::AlwaysOff ); |
69 | m_svCon->setFrameShape( QFrame::NoFrame ); | 70 | m_svCon->setFrameShape( QFrame::NoFrame ); |
70 | m_svTerm = new QScrollView( m_tabTerm ); | 71 | m_svTerm = new QScrollView( m_tabTerm ); |
71 | m_svTerm->setResizePolicy( QScrollView::AutoOneFit ); | 72 | m_svTerm->setResizePolicy( QScrollView::AutoOneFit ); |
72 | //m_svTerm->setHScrollBarMode( QScrollView::AlwaysOff ); | 73 | //m_svTerm->setHScrollBarMode( QScrollView::AlwaysOff ); |
73 | m_svTerm->setFrameShape( QFrame::NoFrame ); | 74 | m_svTerm->setFrameShape( QFrame::NoFrame ); |
74 | 75 | ||
75 | /* base layout for tabs */ | 76 | /* base layout for tabs */ |
76 | m_layCon = new QHBoxLayout( m_tabCon , 2 ); | 77 | m_layCon = new QHBoxLayout( m_tabCon , 2 ); |
77 | m_layTerm = new QHBoxLayout( m_tabTerm, 2 ); | 78 | m_layTerm = new QHBoxLayout( m_tabTerm, 2 ); |
78 | m_layKey = new QHBoxLayout( m_tabKey, 2 ); | 79 | m_layKey = new QHBoxLayout( m_tabKey, 2 ); |
79 | 80 | ||
80 | m_layCon->addWidget( m_svCon ); | 81 | m_layCon->addWidget( m_svCon ); |
81 | m_layTerm->addWidget( m_svTerm ); | 82 | m_layTerm->addWidget( m_svTerm ); |
82 | 83 | ||
83 | // profile tab | 84 | // profile tab |
84 | 85 | ||
85 | QLabel *name = new QLabel(QObject::tr("Profile name"), tabprof); | 86 | QLabel *name = new QLabel(QObject::tr("Profile name"), tabprof); |
86 | m_name = new QLineEdit(tabprof); | 87 | m_name = new QLineEdit(tabprof); |
87 | QLabel *con = new QLabel(tr("Connection"), tabprof ); | 88 | QLabel *con = new QLabel(tr("Connection"), tabprof ); |
88 | QLabel *term = new QLabel(tr("Terminal"), tabprof ); | 89 | QLabel *term = new QLabel(tr("Terminal"), tabprof ); |
89 | m_conCmb = new QComboBox( tabprof ); | 90 | m_conCmb = new QComboBox( tabprof ); |
90 | m_termCmb = new QComboBox( tabprof ); | 91 | m_termCmb = new QComboBox( tabprof ); |
91 | m_autoConnect = new QCheckBox(tr("Auto connect after load"), tabprof); | 92 | m_autoConnect = new QCheckBox(tr("Auto connect after load"), tabprof); |
92 | 93 | ||
93 | // layouting | 94 | // layouting |
94 | QVBoxLayout *vbox3 = new QVBoxLayout(tabprof, 2); | 95 | QVBoxLayout *vbox3 = new QVBoxLayout(tabprof, 2); |
95 | vbox3->add(name); | 96 | vbox3->add(name); |
96 | vbox3->add(m_name); | 97 | vbox3->add(m_name); |
97 | vbox3->add(con ); | 98 | vbox3->add(con ); |
98 | vbox3->add(m_conCmb ); | 99 | vbox3->add(m_conCmb ); |
99 | vbox3->add(term ); | 100 | vbox3->add(term ); |
100 | vbox3->add(m_termCmb ); | 101 | vbox3->add(m_termCmb ); |
101 | vbox3->add(m_autoConnect); | 102 | vbox3->add(m_autoConnect); |
102 | vbox3->addStretch(1); | 103 | vbox3->addStretch(1); |
103 | 104 | ||
104 | m_showconntab = 0; | 105 | m_showconntab = 0; |
105 | tabWidget->addTab(tabprof, "", QObject::tr("Profile")); | 106 | tabWidget->addTab(tabprof, "", QObject::tr("Profile")); |
106 | tabWidget->addTab(m_tabCon, "", QObject::tr("Connection")); | 107 | tabWidget->addTab(m_tabCon, "", QObject::tr("Connection")); |
107 | tabWidget->addTab(m_tabTerm, "", QObject::tr("Terminal")); | 108 | tabWidget->addTab(m_tabTerm, "", QObject::tr("Terminal")); |
108 | tabWidget->addTab(m_tabKey, "", QObject::tr("Special Keys")); | 109 | tabWidget->addTab(m_tabKey, "", QObject::tr("Special Keys")); |
109 | tabWidget->setCurrentTab( tabprof ); | 110 | tabWidget->setCurrentTab( tabprof ); |
110 | 111 | ||
111 | 112 | ||
112 | // fill the comboboxes | 113 | // fill the comboboxes |
113 | QStringList list = m_fact->connectionWidgets(); | 114 | QStringList list = m_fact->connectionWidgets(); |
114 | QStringList::Iterator it; | 115 | QStringList::Iterator it; |
115 | for (it =list.begin(); it != list.end(); ++it ) { | 116 | for (it =list.begin(); it != list.end(); ++it ) { |
116 | m_conCmb->insertItem( (*it) ); | 117 | m_conCmb->insertItem( (*it) ); |
117 | } | 118 | } |
118 | list = m_fact->terminalWidgets(); | 119 | list = m_fact->terminalWidgets(); |
119 | for (it =list.begin(); it != list.end(); ++it ) { | 120 | for (it =list.begin(); it != list.end(); ++it ) { |
120 | m_termCmb->insertItem( (*it) ); | 121 | m_termCmb->insertItem( (*it) ); |
121 | } | 122 | } |
122 | 123 | ||
123 | // load profile values | 124 | // load profile values |
124 | m_name->setText(m_prof.name()); | 125 | m_name->setText(m_prof.name()); |
125 | slotKeyActivated( "Default Keyboard" ); | 126 | slotKeyActivated( "Default Keyboard" ); |
126 | setCurrent( m_fact->external(m_prof.ioLayerName() ), m_conCmb ); | 127 | setCurrent( m_fact->external(m_prof.ioLayerName() ), m_conCmb ); |
127 | setCurrent( m_fact->external(m_prof.terminalName() ), m_termCmb ); | 128 | setCurrent( m_fact->external(m_prof.terminalName() ), m_termCmb ); |
128 | slotConActivated( m_fact->external(m_prof.ioLayerName() ) ); | 129 | slotConActivated( m_fact->external(m_prof.ioLayerName() ) ); |
129 | slotTermActivated( m_fact->external(m_prof.terminalName() ) ); | 130 | slotTermActivated( m_fact->external(m_prof.terminalName() ) ); |
130 | m_autoConnect->setChecked(m_prof.autoConnect()); | 131 | m_autoConnect->setChecked(m_prof.autoConnect()); |
131 | 132 | ||
132 | 133 | ||
133 | // signal and slots | 134 | // signal and slots |
134 | connect(m_conCmb, SIGNAL(activated(const QString&) ), | 135 | connect(m_conCmb, SIGNAL(activated(const QString&) ), |
135 | this, SLOT(slotConActivated(const QString&) ) ); | 136 | this, SLOT(slotConActivated(const QString&) ) ); |
136 | connect(m_termCmb, SIGNAL(activated(const QString&) ), | 137 | connect(m_termCmb, SIGNAL(activated(const QString&) ), |
137 | this, SLOT(slotTermActivated(const QString&) ) ); | 138 | this, SLOT(slotTermActivated(const QString&) ) ); |
138 | 139 | ||
139 | } | 140 | } |
140 | 141 | ||
141 | ProfileEditorDialog::~ProfileEditorDialog() { | 142 | ProfileEditorDialog::~ProfileEditorDialog() { |
142 | 143 | ||
143 | } | 144 | } |
144 | void ProfileEditorDialog::accept() | 145 | void ProfileEditorDialog::accept() |
145 | { | 146 | { |
146 | if(profName().isEmpty()) | 147 | if(profName().isEmpty()) |
147 | { | 148 | { |
148 | QMessageBox::information(this, | 149 | QMessageBox::information(this, |
149 | QObject::tr("Invalid profile"), | 150 | QObject::tr("Invalid profile"), |
150 | QObject::tr("Please enter a profile name.")); | 151 | QObject::tr("Please enter a profile name.")); |
151 | return; | 152 | return; |
152 | } | 153 | } |
153 | // Save profile and plugin profile | 154 | // Save profile and plugin profile |
154 | //if(plugin_plugin) plugin_plugin->save(); | 155 | //if(plugin_plugin) plugin_plugin->save(); |
155 | 156 | ||
156 | // Save general values | 157 | // Save general values |
157 | m_prof.setName( profName() ); | 158 | m_prof.setName( profName() ); |
158 | m_prof.setIOLayer( m_fact->internal(m_conCmb ->currentText() ) ); | 159 | m_prof.setIOLayer( m_fact->internal(m_conCmb ->currentText() ) ); |
159 | m_prof.setTerminalName( m_fact->internal(m_termCmb->currentText() ) ); | 160 | m_prof.setTerminalName( m_fact->internal(m_termCmb->currentText() ) ); |
160 | m_prof.setAutoConnect( m_autoConnect->isChecked() ); | 161 | m_prof.setAutoConnect( m_autoConnect->isChecked() ); |
161 | 162 | ||
162 | if (m_con ) | 163 | if (m_con ) |
163 | m_con->save( m_prof ); | 164 | m_con->save( m_prof ); |
164 | if (m_term ) | 165 | if (m_term ) |
165 | m_term->save( m_prof ); | 166 | m_term->save( m_prof ); |
166 | if (m_key) | 167 | if (m_key) |
167 | m_key->save( m_prof ); | 168 | m_key->save( m_prof ); |
168 | 169 | ||
169 | QDialog::accept(); | 170 | QDialog::accept(); |
170 | } | 171 | } |
171 | 172 | ||
172 | 173 | ||
173 | QString ProfileEditorDialog::profName()const | 174 | QString ProfileEditorDialog::profName()const |
174 | { | 175 | { |
175 | return m_name->text(); | 176 | return m_name->text(); |
176 | } | 177 | } |
177 | 178 | ||
178 | QCString ProfileEditorDialog::profType()const | 179 | QCString ProfileEditorDialog::profType()const |
179 | { | 180 | { |
180 | /*QStringList w = m_fact->configWidgets(); | 181 | /*QStringList w = m_fact->configWidgets(); |
181 | for(QStringList::Iterator it = w.begin(); it != w.end(); it++) | 182 | for(QStringList::Iterator it = w.begin(); it != w.end(); it++) |
182 | if(device_box->currentText() == m_fact->name((*it))) return (*it); | 183 | if(device_box->currentText() == m_fact->name((*it))) return (*it); |
183 | */ | 184 | */ |
184 | return QCString(); | 185 | return QCString(); |
185 | } | 186 | } |
186 | /* | 187 | /* |
187 | * we need to switch the widget | 188 | * we need to switch the widget |
188 | */ | 189 | */ |
189 | void ProfileEditorDialog::slotConActivated( const QString& str ) { | 190 | void ProfileEditorDialog::slotConActivated( const QString& str ) { |
190 | 191 | ||
191 | delete m_con; | 192 | delete m_con; |
192 | 193 | ||
193 | m_con = m_fact->newConnectionPlugin( str, m_svCon->viewport() ); | 194 | m_con = m_fact->newConnectionPlugin( str, m_svCon->viewport() ); |
194 | 195 | ||
195 | if ( !m_con ) { | 196 | if ( !m_con ) { |
196 | m_con = new NoOptions( str, m_svCon->viewport(), "name"); | 197 | m_con = new NoOptions( str, m_svCon->viewport(), "name"); |
197 | } | 198 | } |
198 | 199 | ||
199 | // FIXME ugly hack right. Right solution would be to look into the layer and see if it | 200 | // FIXME ugly hack right. Right solution would be to look into the layer and see if it |
200 | // supports auto connect and then set it as prefered | 201 | // supports auto connect and then set it as prefered |
201 | if ( m_conCmb ->currentText() == tr("Local Console") ) { | 202 | if ( m_conCmb ->currentText() == tr("Local Console") ) { |
202 | m_autoConnect->setChecked( true ); | 203 | m_autoConnect->setChecked( true ); |
203 | m_prof.writeEntry("Terminal", Profile::Linux ); | 204 | m_prof.writeEntry("Terminal", Profile::Linux ); |
204 | slotTermActivated( m_fact->external (m_prof.terminalName() ) ); | 205 | slotTermActivated( m_fact->external (m_prof.terminalName() ) ); |
205 | } else { | 206 | } else { |
206 | m_prof.writeEntry("Terminal", Profile::VT102 ); | 207 | m_prof.writeEntry("Terminal", Profile::VT102 ); |
207 | slotTermActivated( m_fact->external (m_prof.terminalName() ) ); | 208 | slotTermActivated( m_fact->external (m_prof.terminalName() ) ); |
208 | m_autoConnect->setChecked( false ); | 209 | m_autoConnect->setChecked( false ); |
209 | } | 210 | } |
210 | 211 | ||
211 | m_con->load( m_prof ); | 212 | m_con->load( m_prof ); |
212 | m_svCon->addChild( m_con ); | 213 | m_svCon->addChild( m_con ); |
213 | } | 214 | } |
214 | 215 | ||
215 | 216 | ||
216 | /* | 217 | /* |
217 | * we need to switch the widget | 218 | * we need to switch the widget |
218 | */ | 219 | */ |
219 | void ProfileEditorDialog::slotTermActivated( const QString& str ) { | 220 | void ProfileEditorDialog::slotTermActivated( const QString& str ) { |
220 | 221 | ||
221 | delete m_term; | 222 | delete m_term; |
222 | 223 | ||
223 | m_term = m_fact->newTerminalPlugin( str, m_svTerm->viewport() ); | 224 | m_term = m_fact->newTerminalPlugin( str, m_svTerm->viewport() ); |
224 | 225 | ||
225 | if ( m_term ) { | 226 | if ( m_term ) { |
226 | m_term->load( m_prof ); | 227 | m_term->load( m_prof ); |
227 | m_svTerm->addChild( m_term ); | 228 | m_svTerm->addChild( m_term ); |
228 | } | 229 | } |
229 | } | 230 | } |
230 | 231 | ||
231 | void ProfileEditorDialog::slotKeyActivated(const QString &str) { | 232 | void ProfileEditorDialog::slotKeyActivated(const QString &str) { |
232 | delete m_key; | 233 | delete m_key; |
233 | m_key = m_fact->newKeyboardPlugin( str, m_tabKey ); | 234 | m_key = m_fact->newKeyboardPlugin( str, m_tabKey ); |
234 | 235 | ||
235 | if (m_key) { | 236 | if (m_key) { |
236 | 237 | ||
237 | m_key->load(m_prof); | 238 | m_key->load(m_prof); |
238 | m_layKey->addWidget(m_key); | 239 | m_layKey->addWidget(m_key); |
239 | } | 240 | } |
240 | 241 | ||
241 | } | 242 | } |
diff --git a/noncore/apps/opie-console/profileeditordialog.h b/noncore/apps/opie-console/profileeditordialog.h index 97bd650..e7a88e9 100644 --- a/noncore/apps/opie-console/profileeditordialog.h +++ b/noncore/apps/opie-console/profileeditordialog.h | |||
@@ -1,61 +1,61 @@ | |||
1 | #ifndef PROFILE_EDITOR_DIALOG | 1 | #ifndef PROFILE_EDITOR_DIALOG |
2 | #define PROFILE_EDITOR_DIALOG | 2 | #define PROFILE_EDITOR_DIALOG |
3 | 3 | ||
4 | #include <qdialog.h> | 4 | #include <qdialog.h> |
5 | #include <opie2/otabwidget.h> | 5 | #include <opie2/otabwidget.h> |
6 | 6 | ||
7 | #include "profile.h" | 7 | #include "profile.h" |
8 | 8 | ||
9 | class MetaFactory; | 9 | class MetaFactory; |
10 | class EditBase; | 10 | class EditBase; |
11 | class QTabWidget; | 11 | class QTabWidget; |
12 | class QHBoxLayout; | 12 | class QHBoxLayout; |
13 | class QLineEdit; | 13 | class QLineEdit; |
14 | class QComboBox; | 14 | class QComboBox; |
15 | class QCheckBox; | 15 | class QCheckBox; |
16 | class QLabel; | 16 | class QLabel; |
17 | class QScrollView; | 17 | class QScrollView; |
18 | class ProfileDialogWidget; | 18 | class ProfileDialogWidget; |
19 | 19 | ||
20 | class ProfileEditorDialog : public QDialog { | 20 | class ProfileEditorDialog : public QDialog { |
21 | Q_OBJECT | 21 | Q_OBJECT |
22 | public: | 22 | public: |
23 | ProfileEditorDialog(MetaFactory* fact, | 23 | ProfileEditorDialog(MetaFactory* fact, |
24 | const Profile& prof ); | 24 | const Profile& prof ); |
25 | ProfileEditorDialog(MetaFactory* fact ); | 25 | ProfileEditorDialog(MetaFactory* fact ); |
26 | ~ProfileEditorDialog(); | 26 | ~ProfileEditorDialog(); |
27 | Profile profile()const; | 27 | Profile profile()const; |
28 | 28 | ||
29 | 29 | ||
30 | 30 | ||
31 | public slots: | 31 | public slots: |
32 | void accept(); | 32 | void accept(); |
33 | 33 | ||
34 | private slots: | 34 | private slots: |
35 | void slotConActivated(const QString& ); | 35 | void slotConActivated(const QString& ); |
36 | void slotTermActivated( const QString& ); | 36 | void slotTermActivated( const QString& ); |
37 | void slotKeyActivated(const QString&); | 37 | void slotKeyActivated(const QString&); |
38 | private: | 38 | private: |
39 | void initUI(); | 39 | void initUI(); |
40 | QString profName()const; | 40 | QString profName()const; |
41 | QCString profType()const; | 41 | QCString profType()const; |
42 | 42 | ||
43 | MetaFactory* m_fact; | 43 | MetaFactory* m_fact; |
44 | QHBoxLayout* m_lay; | 44 | QHBoxLayout* m_lay; |
45 | Profile m_prof; | 45 | Profile m_prof; |
46 | 46 | ||
47 | QLineEdit *m_name; | 47 | QLineEdit *m_name; |
48 | QComboBox *m_conCmb, *m_termCmb; | 48 | QComboBox *m_conCmb, *m_termCmb; |
49 | QCheckBox *m_autoConnect; | 49 | QCheckBox *m_autoConnect; |
50 | 50 | ||
51 | QScrollView *m_svCon, *m_svTerm; | 51 | QScrollView *m_svCon, *m_svTerm; |
52 | 52 | ||
53 | QWidget *m_tabCon, *m_tabTerm, *m_tabKey; | 53 | QWidget *m_tabCon, *m_tabTerm, *m_tabKey; |
54 | ProfileDialogWidget* m_con, *m_term, *m_key; | 54 | ProfileDialogWidget* m_con, *m_term, *m_key; |
55 | QHBoxLayout *m_layCon, *m_layTerm, *m_layKey; | 55 | QHBoxLayout *m_layCon, *m_layTerm, *m_layKey; |
56 | OTabWidget *tabWidget; | 56 | Opie::Ui::OTabWidget *tabWidget; |
57 | QWidget *tabprof; | 57 | QWidget *tabprof; |
58 | int m_showconntab; | 58 | int m_showconntab; |
59 | }; | 59 | }; |
60 | 60 | ||
61 | #endif | 61 | #endif |
diff --git a/noncore/apps/opie-console/sz_transfer.cpp b/noncore/apps/opie-console/sz_transfer.cpp index 2f82417..5958e93 100644 --- a/noncore/apps/opie-console/sz_transfer.cpp +++ b/noncore/apps/opie-console/sz_transfer.cpp | |||
@@ -1,84 +1,86 @@ | |||
1 | 1 | ||
2 | #include "sz_transfer.h" | 2 | #include "sz_transfer.h" |
3 | #include <qfile.h> | 3 | #include <qfile.h> |
4 | #include <stdio.h> | 4 | #include <stdio.h> |
5 | #include <sys/termios.h> | 5 | #include <sys/termios.h> |
6 | 6 | ||
7 | 7 | ||
8 | 8 | ||
9 | using namespace Opie::Core; | ||
10 | using namespace Opie::Core; | ||
9 | SzTransfer::SzTransfer(Type t, IOLayer *layer) : FileTransferLayer(layer), m_t(t) | 11 | SzTransfer::SzTransfer(Type t, IOLayer *layer) : FileTransferLayer(layer), m_t(t) |
10 | { | 12 | { |
11 | } | 13 | } |
12 | 14 | ||
13 | SzTransfer::~SzTransfer() { | 15 | SzTransfer::~SzTransfer() { |
14 | } | 16 | } |
15 | 17 | ||
16 | void SzTransfer::sendFile(const QFile& file) { | 18 | void SzTransfer::sendFile(const QFile& file) { |
17 | 19 | ||
18 | sendFile(file.name()); | 20 | sendFile(file.name()); |
19 | } | 21 | } |
20 | 22 | ||
21 | void SzTransfer::sendFile(const QString& file) { | 23 | void SzTransfer::sendFile(const QString& file) { |
22 | 24 | ||
23 | //setcbreak(2); /* raw no echo */ | 25 | //setcbreak(2); /* raw no echo */ |
24 | 26 | ||
25 | proc = new OProcess; | 27 | proc = new OProcess; |
26 | *proc << "sz"; | 28 | *proc << "sz"; |
27 | *proc << "-v" << "-v" << "-b" << file; | 29 | *proc << "-v" << "-v" << "-b" << file; |
28 | connect(proc, SIGNAL(processExited(OProcess*)), | 30 | connect(proc, SIGNAL(processExited(Opie::Core::OProcess*)), |
29 | this, SLOT(sent())); | 31 | this, SLOT(sent())); |
30 | connect(proc, SIGNAL(receivedStdout(OProcess*,char*,int)), | 32 | connect(proc, SIGNAL(receivedStdout(Opie::Core::OProcess*,char*,int)), |
31 | this, SLOT(SzReceivedStdout(OProcess*,char*,int))); | 33 | this, SLOT(SzReceivedStdout(OProcess*,char*,int))); |
32 | connect(proc, SIGNAL(receivedStderr(OProcess*,char*,int)), | 34 | connect(proc, SIGNAL(receivedStderr(Opie::Core::OProcess*,char*,int)), |
33 | this, SLOT(SzReceivedStderr(OProcess*,char*,int))); | 35 | this, SLOT(SzReceivedStderr(OProcess*,char*,int))); |
34 | connect(layer(), SIGNAL(received(const QByteArray&)), | 36 | connect(layer(), SIGNAL(received(const QByteArray&)), |
35 | this, SLOT(receivedStdin(const QByteArray&))); | 37 | this, SLOT(receivedStdin(const QByteArray&))); |
36 | proc->start(OProcess::NotifyOnExit, OProcess::All); | 38 | proc->start(OProcess::NotifyOnExit, OProcess::All); |
37 | 39 | ||
38 | } | 40 | } |
39 | 41 | ||
40 | void SzTransfer::SzReceivedStdout(OProcess *, char *buffer, int buflen) { | 42 | void SzTransfer::SzReceivedStdout(OProcess *, char *buffer, int buflen) { |
41 | 43 | ||
42 | qWarning("recieved from sz on stdout %d bytes", buflen); | 44 | qWarning("recieved from sz on stdout %d bytes", buflen); |
43 | 45 | ||
44 | QByteArray data(buflen); | 46 | QByteArray data(buflen); |
45 | data.fill(*buffer, buflen); | 47 | data.fill(*buffer, buflen); |
46 | for (uint i = 0; i < data.count(); i++ ) { | 48 | for (uint i = 0; i < data.count(); i++ ) { |
47 | printf("%c", buffer[i] ); | 49 | printf("%c", buffer[i] ); |
48 | } | 50 | } |
49 | printf("\n"); | 51 | printf("\n"); |
50 | 52 | ||
51 | // send out through the io layer | 53 | // send out through the io layer |
52 | layer()->send(data); | 54 | layer()->send(data); |
53 | } | 55 | } |
54 | 56 | ||
55 | void SzTransfer::SzReceivedStderr(OProcess *, char *buffer, int length) { | 57 | void SzTransfer::SzReceivedStderr(OProcess *, char *buffer, int length) { |
56 | 58 | ||
57 | // parse and show data in a progress dialog/widget | 59 | // parse and show data in a progress dialog/widget |
58 | printf("stderr:\n"); | 60 | printf("stderr:\n"); |
59 | //for (int i = 0; i < length; i++) | 61 | //for (int i = 0; i < length; i++) |
60 | // printf("%c", buffer[i]); | 62 | // printf("%c", buffer[i]); |
61 | //printf("\n"); | 63 | //printf("\n"); |
62 | } | 64 | } |
63 | 65 | ||
64 | void SzTransfer::receivedStdin(const QByteArray &data) { | 66 | void SzTransfer::receivedStdin(const QByteArray &data) { |
65 | 67 | ||
66 | qWarning("recieved from io_serial %d bytes", data.size()); | 68 | qWarning("recieved from io_serial %d bytes", data.size()); |
67 | 69 | ||
68 | // recieved data from the io layer goes to sz | 70 | // recieved data from the io layer goes to sz |
69 | proc->writeStdin(data.data(), data.size()); | 71 | proc->writeStdin(data.data(), data.size()); |
70 | 72 | ||
71 | } | 73 | } |
72 | 74 | ||
73 | void SzTransfer::sent() { | 75 | void SzTransfer::sent() { |
74 | 76 | ||
75 | qWarning("sent file"); | 77 | qWarning("sent file"); |
76 | 78 | ||
77 | //setcbreak(0); /* default */ | 79 | //setcbreak(0); /* default */ |
78 | 80 | ||
79 | 81 | ||
80 | delete proc; | 82 | delete proc; |
81 | disconnect(layer(), SIGNAL(received(const QByteArray&)), | 83 | disconnect(layer(), SIGNAL(received(const QByteArray&)), |
82 | this, SLOT(receivedStdin(const QByteArray&))); | 84 | this, SLOT(receivedStdin(const QByteArray&))); |
83 | 85 | ||
84 | } | 86 | } |
diff --git a/noncore/apps/opie-console/sz_transfer.h b/noncore/apps/opie-console/sz_transfer.h index aa97c32..0505215 100644 --- a/noncore/apps/opie-console/sz_transfer.h +++ b/noncore/apps/opie-console/sz_transfer.h | |||
@@ -1,40 +1,40 @@ | |||
1 | #ifndef OPIE_FL_SZ_H | 1 | #ifndef OPIE_FL_SZ_H |
2 | #define OPIE_FL_SZ_H | 2 | #define OPIE_FL_SZ_H |
3 | 3 | ||
4 | #include "file_layer.h" | 4 | #include "file_layer.h" |
5 | #include <opie2/oprocess.h> | 5 | #include <opie2/oprocess.h> |
6 | 6 | ||
7 | class SzTransfer : public FileTransferLayer { | 7 | class SzTransfer : public FileTransferLayer { |
8 | 8 | ||
9 | Q_OBJECT | 9 | Q_OBJECT |
10 | 10 | ||
11 | public: | 11 | public: |
12 | enum Type { | 12 | enum Type { |
13 | SZ=0, | 13 | SZ=0, |
14 | SX, | 14 | SX, |
15 | SY | 15 | SY |
16 | }; | 16 | }; |
17 | 17 | ||
18 | SzTransfer( Type t, IOLayer * ); | 18 | SzTransfer( Type t, IOLayer * ); |
19 | ~SzTransfer(); | 19 | ~SzTransfer(); |
20 | 20 | ||
21 | public slots: | 21 | public slots: |
22 | /** | 22 | /** |
23 | * send a file over the layer | 23 | * send a file over the layer |
24 | */ | 24 | */ |
25 | void sendFile( const QString& file ) ; | 25 | void sendFile( const QString& file ) ; |
26 | void sendFile( const QFile& ); | 26 | void sendFile( const QFile& ); |
27 | void sent(); | 27 | void sent(); |
28 | 28 | ||
29 | private slots: | 29 | private slots: |
30 | void SzReceivedStdout(OProcess *, char *, int); | 30 | void SzReceivedStdout(Opie::Core::OProcess *, char *, int); |
31 | void SzReceivedStderr(OProcess *, char *, int); | 31 | void SzReceivedStderr(Opie::Core::OProcess *, char *, int); |
32 | void receivedStdin(const QByteArray &); | 32 | void receivedStdin(const QByteArray &); |
33 | 33 | ||
34 | private: | 34 | private: |
35 | OProcess *proc; | 35 | Opie::Core::OProcess *proc; |
36 | Type m_t; | 36 | Type m_t; |
37 | 37 | ||
38 | }; | 38 | }; |
39 | 39 | ||
40 | #endif | 40 | #endif |
diff --git a/noncore/apps/opie-console/tabwidget.cpp b/noncore/apps/opie-console/tabwidget.cpp index 419f8ac..6429e3c 100644 --- a/noncore/apps/opie-console/tabwidget.cpp +++ b/noncore/apps/opie-console/tabwidget.cpp | |||
@@ -1,44 +1,45 @@ | |||
1 | 1 | ||
2 | #include "tabwidget.h" | 2 | #include "tabwidget.h" |
3 | 3 | ||
4 | using namespace Opie::Ui; | ||
4 | TabWidget::TabWidget( QWidget* parent, const char* name ) | 5 | TabWidget::TabWidget( QWidget* parent, const char* name ) |
5 | : OTabWidget( parent, name ) { | 6 | : OTabWidget( parent, name ) { |
6 | connect(this, SIGNAL( currentChanged(QWidget*) ), | 7 | connect(this, SIGNAL( currentChanged(QWidget*) ), |
7 | this, SLOT( slotCurChanged(QWidget*) ) ); | 8 | this, SLOT( slotCurChanged(QWidget*) ) ); |
8 | } | 9 | } |
9 | 10 | ||
10 | TabWidget::~TabWidget() { | 11 | TabWidget::~TabWidget() { |
11 | } | 12 | } |
12 | 13 | ||
13 | void TabWidget::add( Session* ses ) { | 14 | void TabWidget::add( Session* ses ) { |
14 | qWarning("session ses " + ses->name() ); | 15 | qWarning("session ses " + ses->name() ); |
15 | if ( !ses->widgetStack() ) return; | 16 | if ( !ses->widgetStack() ) return; |
16 | //reparent( ses->widgetStack(), QPoint() ); | 17 | //reparent( ses->widgetStack(), QPoint() ); |
17 | addTab( ses->widgetStack(), "console/konsole", ses->name() ); | 18 | addTab( ses->widgetStack(), "console/konsole", ses->name() ); |
18 | //addTab( ses->widgetStack(), ses->name() ); | 19 | //addTab( ses->widgetStack(), ses->name() ); |
19 | m_map.insert( ses->widgetStack(), ses ); | 20 | m_map.insert( ses->widgetStack(), ses ); |
20 | } | 21 | } |
21 | 22 | ||
22 | void TabWidget::remove( Session* ses ) { | 23 | void TabWidget::remove( Session* ses ) { |
23 | m_map.remove( ses->widgetStack() ); | 24 | m_map.remove( ses->widgetStack() ); |
24 | removePage( ses->widgetStack() ); | 25 | removePage( ses->widgetStack() ); |
25 | } | 26 | } |
26 | 27 | ||
27 | void TabWidget::slotCurChanged( QWidget* wid ) { | 28 | void TabWidget::slotCurChanged( QWidget* wid ) { |
28 | QMap<QWidget*, Session*>::Iterator it; | 29 | QMap<QWidget*, Session*>::Iterator it; |
29 | it = m_map.find( wid ); | 30 | it = m_map.find( wid ); |
30 | if ( it == m_map.end() ) { | 31 | if ( it == m_map.end() ) { |
31 | return; | 32 | return; |
32 | } | 33 | } |
33 | 34 | ||
34 | emit activated( it.data() ); | 35 | emit activated( it.data() ); |
35 | } | 36 | } |
36 | void TabWidget::setCurrent( Session* ses ) { | 37 | void TabWidget::setCurrent( Session* ses ) { |
37 | if (!ses ) | 38 | if (!ses ) |
38 | return; | 39 | return; |
39 | 40 | ||
40 | //showPage( ses->widgetStack() ); | 41 | //showPage( ses->widgetStack() ); |
41 | setCurrentTab( ses->widgetStack() ); | 42 | setCurrentTab( ses->widgetStack() ); |
42 | } | 43 | } |
43 | 44 | ||
44 | 45 | ||
diff --git a/noncore/apps/opie-console/tabwidget.h b/noncore/apps/opie-console/tabwidget.h index 98450a3..0138645 100644 --- a/noncore/apps/opie-console/tabwidget.h +++ b/noncore/apps/opie-console/tabwidget.h | |||
@@ -1,29 +1,29 @@ | |||
1 | #ifndef OPIE_TAB_WIDGET_H | 1 | #ifndef OPIE_TAB_WIDGET_H |
2 | #define OPIE_TAB_WIDGET_H | 2 | #define OPIE_TAB_WIDGET_H |
3 | 3 | ||
4 | #include <qmap.h> | 4 | #include <qmap.h> |
5 | #include <opie2/otabwidget.h> | 5 | #include <opie2/otabwidget.h> |
6 | 6 | ||
7 | #include "session.h" | 7 | #include "session.h" |
8 | /** | 8 | /** |
9 | * This is our central tab widget | 9 | * This is our central tab widget |
10 | * we can add sessions here | 10 | * we can add sessions here |
11 | */ | 11 | */ |
12 | class TabWidget : public OTabWidget{ | 12 | class TabWidget : public Opie::Ui::OTabWidget{ |
13 | Q_OBJECT | 13 | Q_OBJECT |
14 | public: | 14 | public: |
15 | TabWidget(QWidget *parent, const char* name ); | 15 | TabWidget(QWidget *parent, const char* name ); |
16 | ~TabWidget(); | 16 | ~TabWidget(); |
17 | void add( Session* ); | 17 | void add( Session* ); |
18 | void remove( Session* ); | 18 | void remove( Session* ); |
19 | void setCurrent( Session* ); | 19 | void setCurrent( Session* ); |
20 | 20 | ||
21 | signals: | 21 | signals: |
22 | void activated(Session* ses ); | 22 | void activated(Session* ses ); |
23 | private slots: | 23 | private slots: |
24 | void slotCurChanged( QWidget* wid ); | 24 | void slotCurChanged( QWidget* wid ); |
25 | private: | 25 | private: |
26 | QMap<QWidget*, Session*> m_map; | 26 | QMap<QWidget*, Session*> m_map; |
27 | }; | 27 | }; |
28 | 28 | ||
29 | #endif | 29 | #endif |
diff --git a/noncore/apps/opie-console/test/senderui.cpp b/noncore/apps/opie-console/test/senderui.cpp index b1725db..df27055 100644 --- a/noncore/apps/opie-console/test/senderui.cpp +++ b/noncore/apps/opie-console/test/senderui.cpp | |||
@@ -1,77 +1,79 @@ | |||
1 | #include <stdlib.h> | 1 | #include <stdlib.h> |
2 | #include <stdio.h> | 2 | #include <stdio.h> |
3 | #include <fcntl.h> | 3 | #include <fcntl.h> |
4 | #include <sys/termios.h> | 4 | #include <sys/termios.h> |
5 | 5 | ||
6 | #include <qmultilineedit.h> | 6 | #include <qmultilineedit.h> |
7 | #include <qsocketnotifier.h> | 7 | #include <qsocketnotifier.h> |
8 | 8 | ||
9 | #include "../profile.h" | 9 | #include "../profile.h" |
10 | #include "../io_serial.h" | 10 | #include "../io_serial.h" |
11 | #include "../filetransfer.h" | 11 | #include "../filetransfer.h" |
12 | #include "../filereceive.h" | 12 | #include "../filereceive.h" |
13 | 13 | ||
14 | #include <opie2/oprocess.h> | 14 | #include <opie2/oprocess.h> |
15 | 15 | ||
16 | #include "senderui.h" | 16 | #include "senderui.h" |
17 | 17 | ||
18 | using namespace Opie::Core; | ||
19 | using namespace Opie::Core; | ||
18 | SenderUI::SenderUI() | 20 | SenderUI::SenderUI() |
19 | : Sender() { | 21 | : Sender() { |
20 | 22 | ||
21 | /* we do that manually */ | 23 | /* we do that manually */ |
22 | Profile prof; | 24 | Profile prof; |
23 | QString str = "/dev/bty0"; | 25 | QString str = "/dev/bty0"; |
24 | prof.writeEntry("Device",str ); | 26 | prof.writeEntry("Device",str ); |
25 | prof.writeEntry("Baud", 19200 ); | 27 | prof.writeEntry("Baud", 19200 ); |
26 | 28 | ||
27 | qWarning("prof " + prof.readEntry("Device") + " " + str); | 29 | qWarning("prof " + prof.readEntry("Device") + " " + str); |
28 | ser = new IOSerial(prof); | 30 | ser = new IOSerial(prof); |
29 | connect(ser, SIGNAL(received(const QByteArray&) ), | 31 | connect(ser, SIGNAL(received(const QByteArray&) ), |
30 | this, SLOT(got(const QByteArray&) ) ); | 32 | this, SLOT(got(const QByteArray&) ) ); |
31 | 33 | ||
32 | if ( ser->open() ) | 34 | if ( ser->open() ) |
33 | qWarning("opened!!!"); | 35 | qWarning("opened!!!"); |
34 | else | 36 | else |
35 | qWarning("could not open"); | 37 | qWarning("could not open"); |
36 | 38 | ||
37 | 39 | ||
38 | } | 40 | } |
39 | SenderUI::~SenderUI() { | 41 | SenderUI::~SenderUI() { |
40 | 42 | ||
41 | } | 43 | } |
42 | void SenderUI::slotSendFile() { | 44 | void SenderUI::slotSendFile() { |
43 | 45 | ||
44 | sz = new FileTransfer(FileTransfer::SY, ser); | 46 | sz = new FileTransfer(FileTransfer::SY, ser); |
45 | sz->sendFile("/home/ich/bootopie-v06-13.jffs2"); | 47 | sz->sendFile("/home/ich/bootopie-v06-13.jffs2"); |
46 | 48 | ||
47 | connect (sz, SIGNAL(sent()), | 49 | connect (sz, SIGNAL(sent()), |
48 | this, SLOT(fileTransComplete())); | 50 | this, SLOT(fileTransComplete())); |
49 | } | 51 | } |
50 | 52 | ||
51 | void SenderUI::slotSend() { | 53 | void SenderUI::slotSend() { |
52 | QCString str = MultiLineEdit1->text().utf8(); | 54 | QCString str = MultiLineEdit1->text().utf8(); |
53 | qWarning("sending: %s", str.data() ); | 55 | qWarning("sending: %s", str.data() ); |
54 | str = str.replace( QRegExp("\n"), "\r"); | 56 | str = str.replace( QRegExp("\n"), "\r"); |
55 | ser->send( str ); | 57 | ser->send( str ); |
56 | } | 58 | } |
57 | void SenderUI::got(const QByteArray& ar) { | 59 | void SenderUI::got(const QByteArray& ar) { |
58 | qWarning("got:"); | 60 | qWarning("got:"); |
59 | for ( uint i = 0; i < ar.count(); i++ ) { | 61 | for ( uint i = 0; i < ar.count(); i++ ) { |
60 | printf("%c", ar[i] ); | 62 | printf("%c", ar[i] ); |
61 | } | 63 | } |
62 | printf("\n"); | 64 | printf("\n"); |
63 | } | 65 | } |
64 | 66 | ||
65 | void SenderUI::fileTransComplete() { | 67 | void SenderUI::fileTransComplete() { |
66 | 68 | ||
67 | qWarning("file transfer complete"); | 69 | qWarning("file transfer complete"); |
68 | } | 70 | } |
69 | void SenderUI::send() { | 71 | void SenderUI::send() { |
70 | 72 | ||
71 | } | 73 | } |
72 | void SenderUI::slotRev(){ | 74 | void SenderUI::slotRev(){ |
73 | qWarning("Going to receive!"); | 75 | qWarning("Going to receive!"); |
74 | FileReceive *rev = new FileReceive( FileReceive::SZ, ser ); | 76 | FileReceive *rev = new FileReceive( FileReceive::SZ, ser ); |
75 | rev->receive(); | 77 | rev->receive(); |
76 | 78 | ||
77 | } | 79 | } |
diff --git a/noncore/apps/opie-console/test/senderui.h b/noncore/apps/opie-console/test/senderui.h index c130dcf..15f0743 100644 --- a/noncore/apps/opie-console/test/senderui.h +++ b/noncore/apps/opie-console/test/senderui.h | |||
@@ -1,34 +1,34 @@ | |||
1 | #ifndef SENDER_UI_H | 1 | #ifndef SENDER_UI_H |
2 | #define SENDER_UI_H | 2 | #define SENDER_UI_H |
3 | 3 | ||
4 | #include <qcstring.h> | 4 | #include <qcstring.h> |
5 | 5 | ||
6 | #include "sender.h" | 6 | #include "sender.h" |
7 | 7 | ||
8 | class IOSerial; | 8 | class IOSerial; |
9 | class FileTransfer; | 9 | class FileTransfer; |
10 | class QSocketNotifier; | 10 | class QSocketNotifier; |
11 | class OProcess; | 11 | namespace Opie {namespace Core {class Opie::Core::OProcess;}} |
12 | class SenderUI : public Sender { | 12 | class SenderUI : public Sender { |
13 | Q_OBJECT | 13 | Q_OBJECT |
14 | public: | 14 | public: |
15 | SenderUI(); | 15 | SenderUI(); |
16 | ~SenderUI(); | 16 | ~SenderUI(); |
17 | 17 | ||
18 | public slots: | 18 | public slots: |
19 | void send(); | 19 | void send(); |
20 | void slotSendFile(); | 20 | void slotSendFile(); |
21 | void slotSend(); | 21 | void slotSend(); |
22 | void slotRev(); | 22 | void slotRev(); |
23 | void got(const QByteArray& ); | 23 | void got(const QByteArray& ); |
24 | void fileTransComplete(); | 24 | void fileTransComplete(); |
25 | private: | 25 | private: |
26 | IOSerial* ser; | 26 | IOSerial* ser; |
27 | FileTransfer* sz; | 27 | FileTransfer* sz; |
28 | int m_fd; | 28 | int m_fd; |
29 | QSocketNotifier* m_sock; | 29 | QSocketNotifier* m_sock; |
30 | OProcess* m_proc; | 30 | Opie::Core::OProcess* m_proc; |
31 | }; | 31 | }; |
32 | 32 | ||
33 | 33 | ||
34 | #endif | 34 | #endif |
diff --git a/noncore/apps/opie-console/transferdialog.cpp b/noncore/apps/opie-console/transferdialog.cpp index d494a6c..75eb443 100644 --- a/noncore/apps/opie-console/transferdialog.cpp +++ b/noncore/apps/opie-console/transferdialog.cpp | |||
@@ -1,275 +1,276 @@ | |||
1 | #include <qlayout.h> | 1 | #include <qlayout.h> |
2 | #include <qcombobox.h> | 2 | #include <qcombobox.h> |
3 | #include <qlabel.h> | 3 | #include <qlabel.h> |
4 | #include <qlineedit.h> | 4 | #include <qlineedit.h> |
5 | #include <qpushbutton.h> | 5 | #include <qpushbutton.h> |
6 | #include <qmessagebox.h> | 6 | #include <qmessagebox.h> |
7 | #include <qprogressbar.h> | 7 | #include <qprogressbar.h> |
8 | #include <qradiobutton.h> | 8 | #include <qradiobutton.h> |
9 | #include <qbuttongroup.h> | 9 | #include <qbuttongroup.h> |
10 | 10 | ||
11 | #include <opie2/ofiledialog.h> | 11 | #include <opie2/ofiledialog.h> |
12 | 12 | ||
13 | #include "metafactory.h" | 13 | #include "metafactory.h" |
14 | #include "mainwindow.h" | 14 | #include "mainwindow.h" |
15 | 15 | ||
16 | #include "transferdialog.h" | 16 | #include "transferdialog.h" |
17 | 17 | ||
18 | using namespace Opie::Ui; | ||
18 | TransferDialog::TransferDialog(QWidget *parent, MainWindow *mainwindow, const char *) | 19 | TransferDialog::TransferDialog(QWidget *parent, MainWindow *mainwindow, const char *) |
19 | : QDialog(parent, 0l, false), m_win(mainwindow) | 20 | : QDialog(parent, 0l, false), m_win(mainwindow) |
20 | { | 21 | { |
21 | m_lay = 0l; | 22 | m_lay = 0l; |
22 | m_recvlay = 0l; | 23 | m_recvlay = 0l; |
23 | QVBoxLayout *vbox, *vbox2; | 24 | QVBoxLayout *vbox, *vbox2; |
24 | QHBoxLayout *hbox, *hbox2, *hbox3; | 25 | QHBoxLayout *hbox, *hbox2, *hbox3; |
25 | QLabel *file, *mode, *progress, *status; | 26 | QLabel *file, *mode, *progress, *status; |
26 | QButtonGroup *group; | 27 | QButtonGroup *group; |
27 | QRadioButton *mode_send, *mode_receive; | 28 | QRadioButton *mode_send, *mode_receive; |
28 | 29 | ||
29 | m_autocleanup = 0; | 30 | m_autocleanup = 0; |
30 | m_running = true; | 31 | m_running = true; |
31 | 32 | ||
32 | group = new QButtonGroup(QObject::tr("Transfer mode"), this); | 33 | group = new QButtonGroup(QObject::tr("Transfer mode"), this); |
33 | mode_send = new QRadioButton(QObject::tr("Send"), group); | 34 | mode_send = new QRadioButton(QObject::tr("Send"), group); |
34 | mode_receive = new QRadioButton(QObject::tr("Receive"), group); | 35 | mode_receive = new QRadioButton(QObject::tr("Receive"), group); |
35 | group->insert(mode_send, id_send); | 36 | group->insert(mode_send, id_send); |
36 | group->insert(mode_receive, id_receive); | 37 | group->insert(mode_receive, id_receive); |
37 | vbox2 = new QVBoxLayout(group, 2); | 38 | vbox2 = new QVBoxLayout(group, 2); |
38 | vbox2->addSpacing(10); | 39 | vbox2->addSpacing(10); |
39 | hbox3 = new QHBoxLayout(vbox2, 2); | 40 | hbox3 = new QHBoxLayout(vbox2, 2); |
40 | hbox3->add(mode_send); | 41 | hbox3->add(mode_send); |
41 | hbox3->add(mode_receive); | 42 | hbox3->add(mode_receive); |
42 | mode_send->setChecked(true); | 43 | mode_send->setChecked(true); |
43 | m_transfermode = id_send; | 44 | m_transfermode = id_send; |
44 | 45 | ||
45 | file = new QLabel(QObject::tr("Send file"), this); | 46 | file = new QLabel(QObject::tr("Send file"), this); |
46 | mode = new QLabel(QObject::tr("Transfer protocol"), this); | 47 | mode = new QLabel(QObject::tr("Transfer protocol"), this); |
47 | progress = new QLabel(QObject::tr("Progress"), this); | 48 | progress = new QLabel(QObject::tr("Progress"), this); |
48 | status = new QLabel(QObject::tr("Status"), this); | 49 | status = new QLabel(QObject::tr("Status"), this); |
49 | 50 | ||
50 | statusbar = new QLabel(QObject::tr("Ready"), this); | 51 | statusbar = new QLabel(QObject::tr("Ready"), this); |
51 | statusbar->setFrameStyle(QFrame::Panel | QFrame::Sunken); | 52 | statusbar->setFrameStyle(QFrame::Panel | QFrame::Sunken); |
52 | 53 | ||
53 | protocol = new QComboBox(this); | 54 | protocol = new QComboBox(this); |
54 | QStringList list = m_win->factory()->fileTransferLayers(); | 55 | QStringList list = m_win->factory()->fileTransferLayers(); |
55 | for (QStringList::Iterator it = list.begin(); it != list.end(); ++it) | 56 | for (QStringList::Iterator it = list.begin(); it != list.end(); ++it) |
56 | protocol->insertItem((*it)); | 57 | protocol->insertItem((*it)); |
57 | 58 | ||
58 | filename = new QLineEdit(this); | 59 | filename = new QLineEdit(this); |
59 | 60 | ||
60 | progressbar = new QProgressBar(this); | 61 | progressbar = new QProgressBar(this); |
61 | progressbar->setProgress(0); | 62 | progressbar->setProgress(0); |
62 | 63 | ||
63 | selector = new QPushButton("...", this); | 64 | selector = new QPushButton("...", this); |
64 | ok = new QPushButton(QObject::tr("Start transfer"), this); | 65 | ok = new QPushButton(QObject::tr("Start transfer"), this); |
65 | cancel = new QPushButton(QObject::tr("Cancel"), this); | 66 | cancel = new QPushButton(QObject::tr("Cancel"), this); |
66 | 67 | ||
67 | vbox = new QVBoxLayout(this, 2); | 68 | vbox = new QVBoxLayout(this, 2); |
68 | vbox->add(group); | 69 | vbox->add(group); |
69 | vbox->add(file); | 70 | vbox->add(file); |
70 | hbox = new QHBoxLayout(vbox, 0); | 71 | hbox = new QHBoxLayout(vbox, 0); |
71 | hbox->add(filename); | 72 | hbox->add(filename); |
72 | hbox->add(selector); | 73 | hbox->add(selector); |
73 | vbox->add(mode); | 74 | vbox->add(mode); |
74 | vbox->add(protocol); | 75 | vbox->add(protocol); |
75 | vbox->add(progress); | 76 | vbox->add(progress); |
76 | vbox->add(progressbar); | 77 | vbox->add(progressbar); |
77 | vbox->add(status); | 78 | vbox->add(status); |
78 | vbox->add(statusbar); | 79 | vbox->add(statusbar); |
79 | vbox->addStretch(1); | 80 | vbox->addStretch(1); |
80 | hbox2 = new QHBoxLayout(vbox, 2); | 81 | hbox2 = new QHBoxLayout(vbox, 2); |
81 | hbox2->add(ok); | 82 | hbox2->add(ok); |
82 | hbox2->add(cancel); | 83 | hbox2->add(cancel); |
83 | 84 | ||
84 | setCaption(QObject::tr("File transfer")); | 85 | setCaption(QObject::tr("File transfer")); |
85 | show(); | 86 | show(); |
86 | 87 | ||
87 | connect(selector, SIGNAL(clicked()), SLOT(slotFilename())); | 88 | connect(selector, SIGNAL(clicked()), SLOT(slotFilename())); |
88 | connect(ok, SIGNAL(clicked()), SLOT(slotTransfer())); | 89 | connect(ok, SIGNAL(clicked()), SLOT(slotTransfer())); |
89 | connect(cancel, SIGNAL(clicked()), SLOT(slotCancel())); | 90 | connect(cancel, SIGNAL(clicked()), SLOT(slotCancel())); |
90 | connect(group, SIGNAL(clicked(int)), SLOT(slotMode(int))); | 91 | connect(group, SIGNAL(clicked(int)), SLOT(slotMode(int))); |
91 | } | 92 | } |
92 | 93 | ||
93 | TransferDialog::~TransferDialog() | 94 | TransferDialog::~TransferDialog() |
94 | { | 95 | { |
95 | } | 96 | } |
96 | 97 | ||
97 | void TransferDialog::slotFilename() | 98 | void TransferDialog::slotFilename() |
98 | { | 99 | { |
99 | QString f; | 100 | QString f; |
100 | 101 | ||
101 | f = Opie::OFileDialog::getOpenFileName(0); | 102 | f = OFileDialog::getOpenFileName(0); |
102 | if(!f.isNull()) filename->setText(f); | 103 | if(!f.isNull()) filename->setText(f); |
103 | } | 104 | } |
104 | 105 | ||
105 | void TransferDialog::slotTransfer() | 106 | void TransferDialog::slotTransfer() |
106 | { | 107 | { |
107 | if((m_transfermode == id_send) && (filename->text().isEmpty())) | 108 | if((m_transfermode == id_send) && (filename->text().isEmpty())) |
108 | { | 109 | { |
109 | QMessageBox::information(this, | 110 | QMessageBox::information(this, |
110 | QObject::tr("Attention"), | 111 | QObject::tr("Attention"), |
111 | QObject::tr("No file has been specified.")); | 112 | QObject::tr("No file has been specified.")); |
112 | return; | 113 | return; |
113 | } | 114 | } |
114 | 115 | ||
115 | ok->setEnabled(false); | 116 | ok->setEnabled(false); |
116 | 117 | ||
117 | cleanup(); | 118 | cleanup(); |
118 | m_autocleanup = 0; | 119 | m_autocleanup = 0; |
119 | 120 | ||
120 | if(m_transfermode == id_send) statusbar->setText(QObject::tr("Sending...")); | 121 | if(m_transfermode == id_send) statusbar->setText(QObject::tr("Sending...")); |
121 | else statusbar->setText(QObject::tr("Receiving...")); | 122 | else statusbar->setText(QObject::tr("Receiving...")); |
122 | 123 | ||
123 | if(m_transfermode == id_send) | 124 | if(m_transfermode == id_send) |
124 | { | 125 | { |
125 | m_lay = m_win->factory()->newFileTransfer(protocol->currentText(), m_win->currentSession()->layer()); | 126 | m_lay = m_win->factory()->newFileTransfer(protocol->currentText(), m_win->currentSession()->layer()); |
126 | m_lay->sendFile(filename->text()); | 127 | m_lay->sendFile(filename->text()); |
127 | 128 | ||
128 | connect(m_lay, SIGNAL(progress(const QString&,int,int,int,int,int)), | 129 | connect(m_lay, SIGNAL(progress(const QString&,int,int,int,int,int)), |
129 | SLOT(slotProgress(const QString&,int,int,int,int,int))); | 130 | SLOT(slotProgress(const QString&,int,int,int,int,int))); |
130 | connect(m_lay, SIGNAL(error(int,const QString&)), SLOT(slotError(int,const QString&))); | 131 | connect(m_lay, SIGNAL(error(int,const QString&)), SLOT(slotError(int,const QString&))); |
131 | connect(m_lay, SIGNAL(sent()), SLOT(slotSent())); | 132 | connect(m_lay, SIGNAL(sent()), SLOT(slotSent())); |
132 | } | 133 | } |
133 | else | 134 | else |
134 | { | 135 | { |
135 | m_recvlay = m_win->factory()->newReceive(protocol->currentText(), m_win->currentSession()->layer()); | 136 | m_recvlay = m_win->factory()->newReceive(protocol->currentText(), m_win->currentSession()->layer()); |
136 | m_recvlay->receive(); | 137 | m_recvlay->receive(); |
137 | 138 | ||
138 | connect(m_recvlay, SIGNAL(progress(const QString&,int,int,int,int,int)), | 139 | connect(m_recvlay, SIGNAL(progress(const QString&,int,int,int,int,int)), |
139 | SLOT(slotProgress(const QString&,int,int,int,int,int))); | 140 | SLOT(slotProgress(const QString&,int,int,int,int,int))); |
140 | connect(m_recvlay, SIGNAL(error(int,const QString&)), SLOT(slotError(int,const QString&))); | 141 | connect(m_recvlay, SIGNAL(error(int,const QString&)), SLOT(slotError(int,const QString&))); |
141 | connect(m_recvlay, SIGNAL(received(const QString&)), SLOT(slotReceived(const QString&))); | 142 | connect(m_recvlay, SIGNAL(received(const QString&)), SLOT(slotReceived(const QString&))); |
142 | } | 143 | } |
143 | } | 144 | } |
144 | 145 | ||
145 | void TransferDialog::cleanup() | 146 | void TransferDialog::cleanup() |
146 | { | 147 | { |
147 | if(m_lay) | 148 | if(m_lay) |
148 | { | 149 | { |
149 | m_lay->cancel(); | 150 | m_lay->cancel(); |
150 | delete m_lay; | 151 | delete m_lay; |
151 | m_lay = 0l; | 152 | m_lay = 0l; |
152 | } | 153 | } |
153 | if(m_recvlay) | 154 | if(m_recvlay) |
154 | { | 155 | { |
155 | m_recvlay->cancel(); | 156 | m_recvlay->cancel(); |
156 | delete m_recvlay; | 157 | delete m_recvlay; |
157 | m_recvlay = 0l; | 158 | m_recvlay = 0l; |
158 | } | 159 | } |
159 | } | 160 | } |
160 | 161 | ||
161 | void TransferDialog::slotCancel() | 162 | void TransferDialog::slotCancel() |
162 | { | 163 | { |
163 | ok->setEnabled(true); | 164 | ok->setEnabled(true); |
164 | statusbar->setText(QObject::tr("Ready")); | 165 | statusbar->setText(QObject::tr("Ready")); |
165 | 166 | ||
166 | if((m_lay) || (m_recvlay)) | 167 | if((m_lay) || (m_recvlay)) |
167 | { | 168 | { |
168 | cleanup(); | 169 | cleanup(); |
169 | if(m_autocleanup) | 170 | if(m_autocleanup) |
170 | { | 171 | { |
171 | m_running = false; | 172 | m_running = false; |
172 | close(); | 173 | close(); |
173 | } | 174 | } |
174 | else | 175 | else |
175 | { | 176 | { |
176 | QMessageBox::information(this, | 177 | QMessageBox::information(this, |
177 | QObject::tr("Cancelled"), | 178 | QObject::tr("Cancelled"), |
178 | QObject::tr("The file transfer has been cancelled.")); | 179 | QObject::tr("The file transfer has been cancelled.")); |
179 | } | 180 | } |
180 | } | 181 | } |
181 | else | 182 | else |
182 | { | 183 | { |
183 | m_running = false; | 184 | m_running = false; |
184 | close(); | 185 | close(); |
185 | } | 186 | } |
186 | } | 187 | } |
187 | 188 | ||
188 | void TransferDialog::slotProgress(const QString& , int progress, int , int , int, int ) | 189 | void TransferDialog::slotProgress(const QString& , int progress, int , int , int, int ) |
189 | { | 190 | { |
190 | progressbar->setProgress(progress); | 191 | progressbar->setProgress(progress); |
191 | } | 192 | } |
192 | 193 | ||
193 | void TransferDialog::slotError(int error, const QString& ) | 194 | void TransferDialog::slotError(int error, const QString& ) |
194 | { | 195 | { |
195 | statusbar->setText(QObject::tr("Ready")); | 196 | statusbar->setText(QObject::tr("Ready")); |
196 | 197 | ||
197 | switch(error) | 198 | switch(error) |
198 | { | 199 | { |
199 | case FileTransferLayer::NotSupported: | 200 | case FileTransferLayer::NotSupported: |
200 | QMessageBox::critical(this, | 201 | QMessageBox::critical(this, |
201 | QObject::tr("Error"), | 202 | QObject::tr("Error"), |
202 | QObject::tr("Operation not supported.")); | 203 | QObject::tr("Operation not supported.")); |
203 | break; | 204 | break; |
204 | case FileTransferLayer::StartError: | 205 | case FileTransferLayer::StartError: |
205 | QMessageBox::critical(this, | 206 | QMessageBox::critical(this, |
206 | QObject::tr("Error"), | 207 | QObject::tr("Error"), |
207 | QObject::tr("Transfer could not be started.")); | 208 | QObject::tr("Transfer could not be started.")); |
208 | break; | 209 | break; |
209 | case FileTransferLayer::NoError: | 210 | case FileTransferLayer::NoError: |
210 | QMessageBox::critical(this, | 211 | QMessageBox::critical(this, |
211 | QObject::tr("Error"), | 212 | QObject::tr("Error"), |
212 | QObject::tr("No error.")); | 213 | QObject::tr("No error.")); |
213 | break; | 214 | break; |
214 | case FileTransferLayer::Undefined: | 215 | case FileTransferLayer::Undefined: |
215 | QMessageBox::critical(this, | 216 | QMessageBox::critical(this, |
216 | QObject::tr("Error"), | 217 | QObject::tr("Error"), |
217 | QObject::tr("Undefined error occured.")); | 218 | QObject::tr("Undefined error occured.")); |
218 | break; | 219 | break; |
219 | case FileTransferLayer::Incomplete: | 220 | case FileTransferLayer::Incomplete: |
220 | QMessageBox::critical(this, | 221 | QMessageBox::critical(this, |
221 | QObject::tr("Error"), | 222 | QObject::tr("Error"), |
222 | QObject::tr("Incomplete transfer.")); | 223 | QObject::tr("Incomplete transfer.")); |
223 | break; | 224 | break; |
224 | case FileTransferLayer::Unknown: | 225 | case FileTransferLayer::Unknown: |
225 | default: | 226 | default: |
226 | QMessageBox::critical(this, | 227 | QMessageBox::critical(this, |
227 | QObject::tr("Error"), | 228 | QObject::tr("Error"), |
228 | QObject::tr("Unknown error occured.")); | 229 | QObject::tr("Unknown error occured.")); |
229 | break; | 230 | break; |
230 | } | 231 | } |
231 | 232 | ||
232 | m_autocleanup = 1; | 233 | m_autocleanup = 1; |
233 | } | 234 | } |
234 | 235 | ||
235 | void TransferDialog::slotSent() | 236 | void TransferDialog::slotSent() |
236 | { | 237 | { |
237 | progressbar->setProgress(100); | 238 | progressbar->setProgress(100); |
238 | QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been sent.")); | 239 | QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been sent.")); |
239 | ok->setEnabled(true); | 240 | ok->setEnabled(true); |
240 | progressbar->setProgress(0); | 241 | progressbar->setProgress(0); |
241 | statusbar->setText(QObject::tr("Ready")); | 242 | statusbar->setText(QObject::tr("Ready")); |
242 | m_autocleanup = 1; | 243 | m_autocleanup = 1; |
243 | } | 244 | } |
244 | 245 | ||
245 | void TransferDialog::slotReceived(const QString& ) | 246 | void TransferDialog::slotReceived(const QString& ) |
246 | { | 247 | { |
247 | progressbar->setProgress(100); | 248 | progressbar->setProgress(100); |
248 | QMessageBox::information(this, QObject::tr("Received"), QObject::tr("File has been received.")); | 249 | QMessageBox::information(this, QObject::tr("Received"), QObject::tr("File has been received.")); |
249 | //QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been received as %1.").arg(file)); | 250 | //QMessageBox::information(this, QObject::tr("Sent"), QObject::tr("File has been received as %1.").arg(file)); |
250 | ok->setEnabled(true); | 251 | ok->setEnabled(true); |
251 | progressbar->setProgress(0); | 252 | progressbar->setProgress(0); |
252 | statusbar->setText(QObject::tr("Ready")); | 253 | statusbar->setText(QObject::tr("Ready")); |
253 | m_autocleanup = 1; | 254 | m_autocleanup = 1; |
254 | } | 255 | } |
255 | 256 | ||
256 | void TransferDialog::slotMode(int id) | 257 | void TransferDialog::slotMode(int id) |
257 | { | 258 | { |
258 | if(id == id_send) | 259 | if(id == id_send) |
259 | { | 260 | { |
260 | selector->setEnabled(true); | 261 | selector->setEnabled(true); |
261 | filename->setEnabled(true); | 262 | filename->setEnabled(true); |
262 | } | 263 | } |
263 | else | 264 | else |
264 | { | 265 | { |
265 | selector->setEnabled(false); | 266 | selector->setEnabled(false); |
266 | filename->setEnabled(false); | 267 | filename->setEnabled(false); |
267 | } | 268 | } |
268 | m_transfermode = id; | 269 | m_transfermode = id; |
269 | } | 270 | } |
270 | 271 | ||
271 | bool TransferDialog::isRunning() | 272 | bool TransferDialog::isRunning() |
272 | { | 273 | { |
273 | return m_running; | 274 | return m_running; |
274 | } | 275 | } |
275 | 276 | ||
diff --git a/noncore/apps/opie-reader/QTReaderApp.cpp b/noncore/apps/opie-reader/QTReaderApp.cpp index b0d589e..b072854 100644 --- a/noncore/apps/opie-reader/QTReaderApp.cpp +++ b/noncore/apps/opie-reader/QTReaderApp.cpp | |||
@@ -1,538 +1,538 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. Allrights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. Allrights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qt Palmtop Environment. | 4 | ** This file is part of Qt Palmtop Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
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 | #include "useqpe.h" | 20 | #include "useqpe.h" |
21 | #include <qregexp.h> | 21 | #include <qregexp.h> |
22 | #include <qclipboard.h> | 22 | #include <qclipboard.h> |
23 | #include <qwidgetstack.h> | 23 | #include <qwidgetstack.h> |
24 | #ifdef USEQPE | 24 | #ifdef USEQPE |
25 | #include <qmenubar.h> | 25 | #include <qmenubar.h> |
26 | #include <qpe/qpetoolbar.h> | 26 | #include <qtoolbar.h> |
27 | #endif | 27 | #endif |
28 | #include <qmenubar.h> | 28 | #include <qmenubar.h> |
29 | #include <qtoolbar.h> | 29 | #include <qtoolbar.h> |
30 | #ifdef USEQPE | 30 | #ifdef USEQPE |
31 | #include <qpe/menubutton.h> | 31 | #include <qpe/menubutton.h> |
32 | #include <qpe/fontdatabase.h> | 32 | #include <qpe/fontdatabase.h> |
33 | #endif | 33 | #endif |
34 | #include <qcombobox.h> | 34 | #include <qcombobox.h> |
35 | #include <qpopupmenu.h> | 35 | #include <qpopupmenu.h> |
36 | #include <qaction.h> | 36 | #include <qaction.h> |
37 | #include <qapplication.h> | 37 | #include <qapplication.h> |
38 | #include <qlineedit.h> | 38 | #include <qlineedit.h> |
39 | #include <qtoolbutton.h> | 39 | #include <qtoolbutton.h> |
40 | #include <qspinbox.h> | 40 | #include <qspinbox.h> |
41 | #include <qobjectlist.h> | 41 | #include <qobjectlist.h> |
42 | #ifdef USEQPE | 42 | #ifdef USEQPE |
43 | #include <qpe/global.h> | 43 | #include <qpe/global.h> |
44 | #include <qpe/applnk.h> | 44 | #include <qpe/applnk.h> |
45 | #endif | 45 | #endif |
46 | #include <qfileinfo.h> | 46 | #include <qfileinfo.h> |
47 | #include <stdlib.h> //getenv | 47 | #include <stdlib.h> //getenv |
48 | #include <qprogressbar.h> | 48 | #include <qprogressbar.h> |
49 | #ifdef USEQPE | 49 | #ifdef USEQPE |
50 | #include <qpe/config.h> | 50 | #include <qpe/config.h> |
51 | #endif | 51 | #endif |
52 | #include <qbuttongroup.h> | 52 | #include <qbuttongroup.h> |
53 | #include <qradiobutton.h> | 53 | #include <qradiobutton.h> |
54 | #ifdef USEQPE | 54 | #ifdef USEQPE |
55 | #include <qpe/qcopenvelope_qws.h> | 55 | #include <qpe/qcopenvelope_qws.h> |
56 | #endif | 56 | #endif |
57 | #include "QTReader.h" | 57 | #include "QTReader.h" |
58 | #include "GraphicWin.h" | 58 | #include "GraphicWin.h" |
59 | #include "Bkmks.h" | 59 | #include "Bkmks.h" |
60 | #include "cbkmkselector.h" | 60 | #include "cbkmkselector.h" |
61 | #include "infowin.h" | 61 | #include "infowin.h" |
62 | #include "ToolbarPrefs.h" | 62 | #include "ToolbarPrefs.h" |
63 | #include "Prefs.h" | 63 | #include "Prefs.h" |
64 | #include "CAnnoEdit.h" | 64 | #include "CAnnoEdit.h" |
65 | #include "QFloatBar.h" | 65 | #include "QFloatBar.h" |
66 | #include "FixedFont.h" | 66 | #include "FixedFont.h" |
67 | #include "URLDialog.h" | 67 | #include "URLDialog.h" |
68 | //#include <qpe/fontdatabase.h> | 68 | //#include <qpe/fontdatabase.h> |
69 | 69 | ||
70 | #ifdef USEQPE | 70 | #ifdef USEQPE |
71 | #include <qpe/resource.h> | 71 | #include <qpe/resource.h> |
72 | #include <qpe/qpeapplication.h> | 72 | #include <qpe/qpeapplication.h> |
73 | #include "fileBrowser.h" | 73 | #include "fileBrowser.h" |
74 | #else | 74 | #else |
75 | #include "qfiledialog.h" | 75 | #include "qfiledialog.h" |
76 | #endif | 76 | #endif |
77 | 77 | ||
78 | #include "QTReaderApp.h" | 78 | #include "QTReaderApp.h" |
79 | #include "CDrawBuffer.h" | 79 | #include "CDrawBuffer.h" |
80 | #include "Filedata.h" | 80 | #include "Filedata.h" |
81 | #include "opie.h" | 81 | #include "opie.h" |
82 | #include "names.h" | 82 | #include "names.h" |
83 | #include "CEncoding_tables.h" | 83 | #include "CEncoding_tables.h" |
84 | #include "CloseDialog.h" | 84 | #include "CloseDialog.h" |
85 | 85 | ||
86 | bool CheckVersion(int&, int&, char&); | 86 | bool CheckVersion(int&, int&, char&); |
87 | 87 | ||
88 | #ifdef _WINDOWS | 88 | #ifdef _WINDOWS |
89 | #define PICDIR "c:\\uqtreader\\pics\\" | 89 | #define PICDIR "c:\\uqtreader\\pics\\" |
90 | #else | 90 | #else |
91 | #ifdef USEQPE | 91 | #ifdef USEQPE |
92 | #define PICDIR "opie-reader/" | 92 | #define PICDIR "opie-reader/" |
93 | #else | 93 | #else |
94 | #define PICDIR "/home/tim/uqtreader/pics/" | 94 | #define PICDIR "/home/tim/uqtreader/pics/" |
95 | #endif | 95 | #endif |
96 | #endif | 96 | #endif |
97 | 97 | ||
98 | unsigned long QTReaderApp::m_uid = 0; | 98 | unsigned long QTReaderApp::m_uid = 0; |
99 | 99 | ||
100 | void QTReaderApp::setScrollState(bool _b) { m_scrollButton->setOn(_b); } | 100 | void QTReaderApp::setScrollState(bool _b) { m_scrollButton->setOn(_b); } |
101 | 101 | ||
102 | #ifdef USEQPE | 102 | #ifdef USEQPE |
103 | #define geticon(iconname) Resource::loadPixmap( iconname ) | 103 | #define geticon(iconname) Resource::loadPixmap( iconname ) |
104 | #define getmyicon(iconname) Resource::loadPixmap( PICDIR iconname ) | 104 | #define getmyicon(iconname) Resource::loadPixmap( PICDIR iconname ) |
105 | #else | 105 | #else |
106 | #define geticon(iconname) QPixmap(PICDIR iconname ".png") | 106 | #define geticon(iconname) QPixmap(PICDIR iconname ".png") |
107 | #define getmyicon(iconname) geticon(iconname) | 107 | #define getmyicon(iconname) geticon(iconname) |
108 | //#define geticon(iconname) QIconSet( QPixmap(PICDIR iconname) ) | 108 | //#define geticon(iconname) QIconSet( QPixmap(PICDIR iconname) ) |
109 | #endif | 109 | #endif |
110 | 110 | ||
111 | #ifndef _WINDOWS | 111 | #ifndef _WINDOWS |
112 | #include <unistd.h> | 112 | #include <unistd.h> |
113 | #endif | 113 | #endif |
114 | #include <stddef.h> | 114 | #include <stddef.h> |
115 | #ifndef _WINDOWS | 115 | #ifndef _WINDOWS |
116 | #include <dirent.h> | 116 | #include <dirent.h> |
117 | #endif | 117 | #endif |
118 | 118 | ||
119 | void QTReaderApp::listBkmkFiles() | 119 | void QTReaderApp::listBkmkFiles() |
120 | { | 120 | { |
121 | bkmkselector->clear(); | 121 | bkmkselector->clear(); |
122 | bkmkselector->setText("Cancel"); | 122 | bkmkselector->setText("Cancel"); |
123 | #ifndef USEQPE | 123 | #ifndef USEQPE |
124 | int cnt = 0; | 124 | int cnt = 0; |
125 | 125 | ||
126 | QDir d = QDir::home(); // "/" | 126 | QDir d = QDir::home(); // "/" |
127 | if ( !d.cd(APPDIR) ) { // "/tmp" | 127 | if ( !d.cd(APPDIR) ) { // "/tmp" |
128 | qWarning( "Cannot find the \"~/" APPDIR "\" directory" ); | 128 | qWarning( "Cannot find the \"~/" APPDIR "\" directory" ); |
129 | d = QDir::home(); | 129 | d = QDir::home(); |
130 | d.mkdir(APPDIR); | 130 | d.mkdir(APPDIR); |
131 | d.cd(APPDIR); | 131 | d.cd(APPDIR); |
132 | } | 132 | } |
133 | 133 | ||
134 | 134 | ||
135 | 135 | ||
136 | 136 | ||
137 | d.setFilter( QDir::Files | QDir::NoSymLinks ); | 137 | d.setFilter( QDir::Files | QDir::NoSymLinks ); |
138 | // d.setSorting( QDir::Size | QDir::Reversed ); | 138 | // d.setSorting( QDir::Size | QDir::Reversed ); |
139 | 139 | ||
140 | const QFileInfoList *list = d.entryInfoList(); | 140 | const QFileInfoList *list = d.entryInfoList(); |
141 | QFileInfoListIterator it( *list ); // create list iterator | 141 | QFileInfoListIterator it( *list ); // create list iterator |
142 | QFileInfo *fi; // pointer for traversing | 142 | QFileInfo *fi; // pointer for traversing |
143 | 143 | ||
144 | while ( (fi=it.current()) ) { // for each file... | 144 | while ( (fi=it.current()) ) { // for each file... |
145 | 145 | ||
146 | bkmkselector->insertItem(fi->fileName()); | 146 | bkmkselector->insertItem(fi->fileName()); |
147 | cnt++; | 147 | cnt++; |
148 | 148 | ||
149 | //qDebug( "%10li %s", fi->size(), fi->fileName().data() ); | 149 | //qDebug( "%10li %s", fi->size(), fi->fileName().data() ); |
150 | ++it; // goto next list element | 150 | ++it; // goto next list element |
151 | } | 151 | } |
152 | 152 | ||
153 | #else /* USEQPE */ | 153 | #else /* USEQPE */ |
154 | int cnt = 0; | 154 | int cnt = 0; |
155 | DIR *d; | 155 | DIR *d; |
156 | d = opendir((const char *)Global::applicationFileName(APPDIR,"")); | 156 | d = opendir((const char *)Global::applicationFileName(APPDIR,"")); |
157 | 157 | ||
158 | while(1) | 158 | while(1) |
159 | { | 159 | { |
160 | struct dirent* de; | 160 | struct dirent* de; |
161 | struct stat buf; | 161 | struct stat buf; |
162 | de = readdir(d); | 162 | de = readdir(d); |
163 | if (de == NULL) break; | 163 | if (de == NULL) break; |
164 | 164 | ||
165 | if (lstat((const char *)Global::applicationFileName(APPDIR,de->d_name),&buf) == 0 && S_ISREG(buf.st_mode)) | 165 | if (lstat((const char *)Global::applicationFileName(APPDIR,de->d_name),&buf) == 0 && S_ISREG(buf.st_mode)) |
166 | { | 166 | { |
167 | bkmkselector->insertItem(de->d_name); | 167 | bkmkselector->insertItem(de->d_name); |
168 | cnt++; | 168 | cnt++; |
169 | } | 169 | } |
170 | } | 170 | } |
171 | 171 | ||
172 | closedir(d); | 172 | closedir(d); |
173 | #endif | 173 | #endif |
174 | if (cnt > 0) | 174 | if (cnt > 0) |
175 | { | 175 | { |
176 | //tjw menu->hide(); | 176 | //tjw menu->hide(); |
177 | editorStack->raiseWidget( bkmkselector ); | 177 | editorStack->raiseWidget( bkmkselector ); |
178 | hidetoolbars(); | 178 | hidetoolbars(); |
179 | m_nBkmkAction = cRmBkmkFile; | 179 | m_nBkmkAction = cRmBkmkFile; |
180 | } | 180 | } |
181 | else | 181 | else |
182 | QMessageBox::information(this, PROGNAME, "No bookmark files"); | 182 | QMessageBox::information(this, PROGNAME, "No bookmark files"); |
183 | } | 183 | } |
184 | 184 | ||
185 | void QTReaderApp::hidetoolbars() | 185 | void QTReaderApp::hidetoolbars() |
186 | { | 186 | { |
187 | menubar->hide(); | 187 | menubar->hide(); |
188 | if (fileBar != NULL) fileBar->hide(); | 188 | if (fileBar != NULL) fileBar->hide(); |
189 | if (viewBar != NULL) viewBar->hide(); | 189 | if (viewBar != NULL) viewBar->hide(); |
190 | if (navBar != NULL) navBar->hide(); | 190 | if (navBar != NULL) navBar->hide(); |
191 | if (markBar != NULL) markBar->hide(); | 191 | if (markBar != NULL) markBar->hide(); |
192 | if (m_fontVisible) m_fontBar->hide(); | 192 | if (m_fontVisible) m_fontBar->hide(); |
193 | if (regVisible) | 193 | if (regVisible) |
194 | { | 194 | { |
195 | #ifdef USEQPE | 195 | #ifdef USEQPE |
196 | Global::hideInputMethod(); | 196 | Global::hideInputMethod(); |
197 | #endif | 197 | #endif |
198 | regBar->hide(); | 198 | regBar->hide(); |
199 | } | 199 | } |
200 | if (searchVisible) | 200 | if (searchVisible) |
201 | { | 201 | { |
202 | #ifdef USEQPE | 202 | #ifdef USEQPE |
203 | Global::hideInputMethod(); | 203 | Global::hideInputMethod(); |
204 | #endif | 204 | #endif |
205 | searchBar->hide(); | 205 | searchBar->hide(); |
206 | } | 206 | } |
207 | } | 207 | } |
208 | 208 | ||
209 | QTReaderApp::QTReaderApp( QWidget *parent, const char *name, WFlags f ) | 209 | QTReaderApp::QTReaderApp( QWidget *parent, const char *name, WFlags f ) |
210 | : QMainWindow( parent, name, f ), bFromDocView( FALSE ), m_dontSave(false), | 210 | : QMainWindow( parent, name, f ), bFromDocView( FALSE ), m_dontSave(false), |
211 | fileBar(NULL), navBar(NULL), viewBar(NULL), markBar(NULL) | 211 | fileBar(NULL), navBar(NULL), viewBar(NULL), markBar(NULL) |
212 | { | 212 | { |
213 | m_url_clipboard = false; | 213 | m_url_clipboard = false; |
214 | m_url_localfile = false; | 214 | m_url_localfile = false; |
215 | m_url_globalfile = false; | 215 | m_url_globalfile = false; |
216 | ftime(&m_lastkeytime); | 216 | ftime(&m_lastkeytime); |
217 | //// qDebug("Application directory = %s", (const tchar *)QPEApplication::documentDir()); | 217 | //// qDebug("Application directory = %s", (const tchar *)QPEApplication::documentDir()); |
218 | //// qDebug("Application directory = %s", (const tchar *)Global::applicationFileName("uqtreader","bkmks.xml")); | 218 | //// qDebug("Application directory = %s", (const tchar *)Global::applicationFileName("uqtreader","bkmks.xml")); |
219 | 219 | ||
220 | m_bcloseDisabled = true; | 220 | m_bcloseDisabled = true; |
221 | m_disableesckey = false; | 221 | m_disableesckey = false; |
222 | pBkmklist = NULL; | 222 | pBkmklist = NULL; |
223 | pOpenlist = NULL; | 223 | pOpenlist = NULL; |
224 | // doc = 0; | 224 | // doc = 0; |
225 | 225 | ||
226 | m_fBkmksChanged = false; | 226 | m_fBkmksChanged = false; |
227 | 227 | ||
228 | QString lang = getenv( "LANG" ); | 228 | QString lang = getenv( "LANG" ); |
229 | QString rot = getenv( "QWS_DISPLAY" ); | 229 | QString rot = getenv( "QWS_DISPLAY" ); |
230 | 230 | ||
231 | /* | 231 | /* |
232 | int m_rot = 0; | 232 | int m_rot = 0; |
233 | if (rot.contains("Rot90")) | 233 | if (rot.contains("Rot90")) |
234 | { | 234 | { |
235 | m_rot = 90; | 235 | m_rot = 90; |
236 | } | 236 | } |
237 | else if (rot.contains("Rot180")) | 237 | else if (rot.contains("Rot180")) |
238 | { | 238 | { |
239 | m_rot = 180; | 239 | m_rot = 180; |
240 | } | 240 | } |
241 | else if (rot.contains("Rot270")) | 241 | else if (rot.contains("Rot270")) |
242 | { | 242 | { |
243 | m_rot = 270; | 243 | m_rot = 270; |
244 | } | 244 | } |
245 | 245 | ||
246 | // qDebug("Initial Rotation(%d):%s", m_rot, (const char*)rot); | 246 | // qDebug("Initial Rotation(%d):%s", m_rot, (const char*)rot); |
247 | */ | 247 | */ |
248 | m_autogenstr = "^ *[A-Z].*[a-z] *$"; | 248 | m_autogenstr = "^ *[A-Z].*[a-z] *$"; |
249 | 249 | ||
250 | #ifdef USEQPE | 250 | #ifdef USEQPE |
251 | setIcon( Resource::loadPixmap( PICDIR "uqtreader") ); | 251 | setIcon( Resource::loadPixmap( PICDIR "uqtreader") ); |
252 | #else | 252 | #else |
253 | setIcon( QPixmap (PICDIR "uqtreader.png") ); | 253 | setIcon( QPixmap (PICDIR "uqtreader.png") ); |
254 | #endif /* USEQPE */ | 254 | #endif /* USEQPE */ |
255 | 255 | ||
256 | // QToolBar *bar = new QToolBar( this ); | 256 | // QToolBar *bar = new QToolBar( this ); |
257 | // menubar = new QToolBar( this ); | 257 | // menubar = new QToolBar( this ); |
258 | #ifdef USEQPE | 258 | #ifdef USEQPE |
259 | Config config( APPDIR ); | 259 | Config config( APPDIR ); |
260 | #else | 260 | #else |
261 | QDir d = QDir::home(); // "/" | 261 | QDir d = QDir::home(); // "/" |
262 | if ( !d.cd(APPDIR) ) { // "/tmp" | 262 | if ( !d.cd(APPDIR) ) { // "/tmp" |
263 | qWarning( "Cannot find the \"~/" APPDIR "\" directory" ); | 263 | qWarning( "Cannot find the \"~/" APPDIR "\" directory" ); |
264 | d = QDir::home(); | 264 | d = QDir::home(); |
265 | d.mkdir(APPDIR); | 265 | d.mkdir(APPDIR); |
266 | d.cd(APPDIR); | 266 | d.cd(APPDIR); |
267 | } | 267 | } |
268 | QFileInfo fi(d, INIFILE); | 268 | QFileInfo fi(d, INIFILE); |
269 | // qDebug("Path:%s", (const char*)fi.absFilePath()); | 269 | // qDebug("Path:%s", (const char*)fi.absFilePath()); |
270 | Config config(fi.absFilePath()); | 270 | Config config(fi.absFilePath()); |
271 | #endif | 271 | #endif |
272 | config.setGroup("Toolbar"); | 272 | config.setGroup("Toolbar"); |
273 | m_tbmovesave = m_tbmove = config.readBoolEntry("Movable", false); | 273 | m_tbmovesave = m_tbmove = config.readBoolEntry("Movable", false); |
274 | m_tbpolsave = m_tbpol = (ToolbarPolicy)config.readNumEntry("Policy", 1); | 274 | m_tbpolsave = m_tbpol = (ToolbarPolicy)config.readNumEntry("Policy", 1); |
275 | m_tbposition = (ToolBarDock)config.readNumEntry("Position", 2); | 275 | m_tbposition = (ToolBarDock)config.readNumEntry("Position", 2); |
276 | menubar = new QToolBar("Menus", this, m_tbposition); | 276 | menubar = new QToolBar("Menus", this, m_tbposition); |
277 | 277 | ||
278 | // fileBar = new QToolBar("File", this); | 278 | // fileBar = new QToolBar("File", this); |
279 | // QToolBar* viewBar = new QToolBar("File", this); | 279 | // QToolBar* viewBar = new QToolBar("File", this); |
280 | // QToolBar* navBar = new QToolBar("File", this); | 280 | // QToolBar* navBar = new QToolBar("File", this); |
281 | // QToolBar* markBar = new QToolBar("File", this); | 281 | // QToolBar* markBar = new QToolBar("File", this); |
282 | 282 | ||
283 | #ifdef USEQPE | 283 | #ifdef USEQPE |
284 | mb = new QMenuBar( menubar ); | 284 | mb = new QMenuBar( menubar ); |
285 | #else | 285 | #else |
286 | mb = new QMenuBar( menubar ); | 286 | mb = new QMenuBar( menubar ); |
287 | #endif | 287 | #endif |
288 | 288 | ||
289 | //#ifdef USEQPE | 289 | //#ifdef USEQPE |
290 | QPopupMenu* tmp = new QPopupMenu(mb); | 290 | QPopupMenu* tmp = new QPopupMenu(mb); |
291 | mb->insertItem( geticon( "AppsIcon" ), tmp ); | 291 | mb->insertItem( geticon( "AppsIcon" ), tmp ); |
292 | //#else | 292 | //#else |
293 | // QMenuBar* tmp = mb; | 293 | // QMenuBar* tmp = mb; |
294 | //#endif | 294 | //#endif |
295 | 295 | ||
296 | QPopupMenu *file = new QPopupMenu( mb ); | 296 | QPopupMenu *file = new QPopupMenu( mb ); |
297 | tmp->insertItem( tr( "File" ), file ); | 297 | tmp->insertItem( tr( "File" ), file ); |
298 | 298 | ||
299 | QPopupMenu *navigation = new QPopupMenu(mb); | 299 | QPopupMenu *navigation = new QPopupMenu(mb); |
300 | tmp->insertItem( tr( "Navigation" ), navigation ); | 300 | tmp->insertItem( tr( "Navigation" ), navigation ); |
301 | 301 | ||
302 | QPopupMenu *view = new QPopupMenu( mb ); | 302 | QPopupMenu *view = new QPopupMenu( mb ); |
303 | tmp->insertItem( tr( "View" ), view ); | 303 | tmp->insertItem( tr( "View" ), view ); |
304 | 304 | ||
305 | QPopupMenu *marks = new QPopupMenu( this ); | 305 | QPopupMenu *marks = new QPopupMenu( this ); |
306 | tmp->insertItem( tr( "Marks" ), marks ); | 306 | tmp->insertItem( tr( "Marks" ), marks ); |
307 | 307 | ||
308 | QPopupMenu *settings = new QPopupMenu( this ); | 308 | QPopupMenu *settings = new QPopupMenu( this ); |
309 | tmp->insertItem( tr( "Settings" ), settings ); | 309 | tmp->insertItem( tr( "Settings" ), settings ); |
310 | 310 | ||
311 | // addToolBar(menubar, "Menus",QMainWindow::Top); | 311 | // addToolBar(menubar, "Menus",QMainWindow::Top); |
312 | // addToolBar(fileBar, "Toolbar",QMainWindow::Top); | 312 | // addToolBar(fileBar, "Toolbar",QMainWindow::Top); |
313 | 313 | ||
314 | // QPopupMenu *edit = new QPopupMenu( this ); | 314 | // QPopupMenu *edit = new QPopupMenu( this ); |
315 | 315 | ||
316 | /* | 316 | /* |
317 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); | 317 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); |
318 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); | 318 | connect( a, SIGNAL( activated() ), this, SLOT( fileNew() ) ); |
319 | a->addTo( bar ); | 319 | a->addTo( bar ); |
320 | a->addTo( file ); | 320 | a->addTo( file ); |
321 | */ | 321 | */ |
322 | 322 | ||
323 | editorStack = new QWidgetStack( this ); | 323 | editorStack = new QWidgetStack( this ); |
324 | setCentralWidget( editorStack ); | 324 | setCentralWidget( editorStack ); |
325 | 325 | ||
326 | searchVisible = FALSE; | 326 | searchVisible = FALSE; |
327 | regVisible = FALSE; | 327 | regVisible = FALSE; |
328 | m_fontVisible = false; | 328 | m_fontVisible = false; |
329 | 329 | ||
330 | m_annoWin = new CAnnoEdit(editorStack); | 330 | m_annoWin = new CAnnoEdit(editorStack); |
331 | editorStack->addWidget(m_annoWin, get_unique_id()); | 331 | editorStack->addWidget(m_annoWin, get_unique_id()); |
332 | connect( m_annoWin, SIGNAL( finished(const QString&,const QString&) ), this, SLOT( addAnno(const QString&,const QString&) ) ); | 332 | connect( m_annoWin, SIGNAL( finished(const QString&,const QString&) ), this, SLOT( addAnno(const QString&,const QString&) ) ); |
333 | connect( m_annoWin, SIGNAL( cancelled() ), this, SLOT( infoClose() ) ); | 333 | connect( m_annoWin, SIGNAL( cancelled() ), this, SLOT( infoClose() ) ); |
334 | 334 | ||
335 | m_infoWin = new infowin(editorStack); | 335 | m_infoWin = new infowin(editorStack); |
336 | editorStack->addWidget(m_infoWin, get_unique_id()); | 336 | editorStack->addWidget(m_infoWin, get_unique_id()); |
337 | connect( m_infoWin, SIGNAL( Close() ), this, SLOT( infoClose() ) ); | 337 | connect( m_infoWin, SIGNAL( Close() ), this, SLOT( infoClose() ) ); |
338 | 338 | ||
339 | m_graphicwin = new GraphicWin(editorStack); | 339 | m_graphicwin = new GraphicWin(editorStack); |
340 | editorStack->addWidget(m_graphicwin, get_unique_id()); | 340 | editorStack->addWidget(m_graphicwin, get_unique_id()); |
341 | connect( m_graphicwin, SIGNAL( Closed() ), this, SLOT( infoClose() ) ); | 341 | connect( m_graphicwin, SIGNAL( Closed() ), this, SLOT( infoClose() ) ); |
342 | 342 | ||
343 | // bkmkselector = new QListBox(editorStack, "Bookmarks"); | 343 | // bkmkselector = new QListBox(editorStack, "Bookmarks"); |
344 | bkmkselector = new CBkmkSelector(editorStack, "Bookmarks"); | 344 | bkmkselector = new CBkmkSelector(editorStack, "Bookmarks"); |
345 | // connect(bkmkselector, SIGNAL( selected(const QString&) ), this, SLOT( gotobkmk(const QString&) ) ); | 345 | // connect(bkmkselector, SIGNAL( selected(const QString&) ), this, SLOT( gotobkmk(const QString&) ) ); |
346 | connect(bkmkselector, SIGNAL( selected(int) ), this, SLOT( gotobkmk(int) ) ); | 346 | connect(bkmkselector, SIGNAL( selected(int) ), this, SLOT( gotobkmk(int) ) ); |
347 | connect(bkmkselector, SIGNAL( cancelled() ), this, SLOT( cancelbkmk() ) ); | 347 | connect(bkmkselector, SIGNAL( cancelled() ), this, SLOT( cancelbkmk() ) ); |
348 | editorStack->addWidget( bkmkselector, get_unique_id() ); | 348 | editorStack->addWidget( bkmkselector, get_unique_id() ); |
349 | 349 | ||
350 | /* | 350 | /* |
351 | importSelector = new FileSelector( "*", editorStack, "importselector", false ); | 351 | importSelector = new FileSelector( "*", editorStack, "importselector", false ); |
352 | connect( importSelector, SIGNAL( fileSelected(const DocLnk&) ), this, SLOT( importFile(const DocLnk&) ) ); | 352 | connect( importSelector, SIGNAL( fileSelected(const DocLnk&) ), this, SLOT( importFile(const DocLnk&) ) ); |
353 | 353 | ||
354 | editorStack->addWidget( importSelector, get_unique_id() ); | 354 | editorStack->addWidget( importSelector, get_unique_id() ); |
355 | 355 | ||
356 | // don't need the close visible, it is redundant... | 356 | // don't need the close visible, it is redundant... |
357 | importSelector->setCloseVisible( FALSE ); | 357 | importSelector->setCloseVisible( FALSE ); |
358 | */ | 358 | */ |
359 | // qDebug("Reading file list"); | 359 | // qDebug("Reading file list"); |
360 | readfilelist(); | 360 | readfilelist(); |
361 | 361 | ||
362 | reader = new QTReader( editorStack ); | 362 | reader = new QTReader( editorStack ); |
363 | 363 | ||
364 | reader->bDoUpdates = false; | 364 | reader->bDoUpdates = false; |
365 | 365 | ||
366 | #ifdef USEQPE | 366 | #ifdef USEQPE |
367 | ((QPEApplication*)qApp)->setStylusOperation(reader, QPEApplication::RightOnHold); | 367 | ((QPEApplication*)qApp)->setStylusOperation(reader, QPEApplication::RightOnHold); |
368 | #endif | 368 | #endif |
369 | 369 | ||
370 | // qDebug("Reading config"); | 370 | // qDebug("Reading config"); |
371 | // Config config( APPDIR ); | 371 | // Config config( APPDIR ); |
372 | config.setGroup( "View" ); | 372 | config.setGroup( "View" ); |
373 | m_debounce = config.readNumEntry("Debounce", 0); | 373 | m_debounce = config.readNumEntry("Debounce", 0); |
374 | #ifdef USEQPE | 374 | #ifdef USEQPE |
375 | m_bFloatingDialog = config.readBoolEntry("FloatDialogs", false); | 375 | m_bFloatingDialog = config.readBoolEntry("FloatDialogs", false); |
376 | #else | 376 | #else |
377 | m_bFloatingDialog = config.readBoolEntry("FloatDialogs", true); | 377 | m_bFloatingDialog = config.readBoolEntry("FloatDialogs", true); |
378 | #endif | 378 | #endif |
379 | reader->bstripcr = config.readBoolEntry( "StripCr", true ); | 379 | reader->bstripcr = config.readBoolEntry( "StripCr", true ); |
380 | reader->bfulljust = config.readBoolEntry( "FullJust", false ); | 380 | reader->bfulljust = config.readBoolEntry( "FullJust", false ); |
381 | reader->setextraspace(config.readNumEntry( "ExtraSpace", 0 )); | 381 | reader->setextraspace(config.readNumEntry( "ExtraSpace", 0 )); |
382 | reader->setlead(config.readNumEntry( "ExtraLead", 0 )); | 382 | reader->setlead(config.readNumEntry( "ExtraLead", 0 )); |
383 | reader->btextfmt = config.readBoolEntry( "TextFmt", false ); | 383 | reader->btextfmt = config.readBoolEntry( "TextFmt", false ); |
384 | reader->bautofmt = config.readBoolEntry( "AutoFmt", true ); | 384 | reader->bautofmt = config.readBoolEntry( "AutoFmt", true ); |
385 | reader->bstriphtml = config.readBoolEntry( "StripHtml", false ); | 385 | reader->bstriphtml = config.readBoolEntry( "StripHtml", false ); |
386 | reader->bpeanut = config.readBoolEntry( "Peanut", false ); | 386 | reader->bpeanut = config.readBoolEntry( "Peanut", false ); |
387 | reader->bdehyphen = config.readBoolEntry( "Dehyphen", false ); | 387 | reader->bdehyphen = config.readBoolEntry( "Dehyphen", false ); |
388 | reader->bdepluck = config.readBoolEntry( "Depluck", false ); | 388 | reader->bdepluck = config.readBoolEntry( "Depluck", false ); |
389 | reader->bdejpluck = config.readBoolEntry( "Dejpluck", false ); | 389 | reader->bdejpluck = config.readBoolEntry( "Dejpluck", false ); |
390 | reader->bonespace = config.readBoolEntry( "OneSpace", false ); | 390 | reader->bonespace = config.readBoolEntry( "OneSpace", false ); |
391 | reader->bunindent = config.readBoolEntry( "Unindent", false ); | 391 | reader->bunindent = config.readBoolEntry( "Unindent", false ); |
392 | reader->brepara = config.readBoolEntry( "Repara", false ); | 392 | reader->brepara = config.readBoolEntry( "Repara", false ); |
393 | reader->bdblspce = config.readBoolEntry( "DoubleSpace", false ); | 393 | reader->bdblspce = config.readBoolEntry( "DoubleSpace", false ); |
394 | reader->bindenter = config.readNumEntry( "Indent", 0 ); | 394 | reader->bindenter = config.readNumEntry( "Indent", 0 ); |
395 | reader->m_textsize = config.readNumEntry( "FontSize", 12 ); | 395 | reader->m_textsize = config.readNumEntry( "FontSize", 12 ); |
396 | reader->m_delay = config.readNumEntry( "ScrollDelay", 5184); | 396 | reader->m_delay = config.readNumEntry( "ScrollDelay", 5184); |
397 | reader->m_lastfile = config.readEntry( "LastFile", QString::null ); | 397 | reader->m_lastfile = config.readEntry( "LastFile", QString::null ); |
398 | reader->m_lastposn = config.readNumEntry( "LastPosn", 0 ); | 398 | reader->m_lastposn = config.readNumEntry( "LastPosn", 0 ); |
399 | reader->m_bpagemode = config.readBoolEntry( "PageMode", true ); | 399 | reader->m_bpagemode = config.readBoolEntry( "PageMode", true ); |
400 | reader->m_bMonoSpaced = config.readBoolEntry( "MonoSpaced", false); | 400 | reader->m_bMonoSpaced = config.readBoolEntry( "MonoSpaced", false); |
401 | reader->m_swapmouse = config.readBoolEntry( "SwapMouse", false); | 401 | reader->m_swapmouse = config.readBoolEntry( "SwapMouse", false); |
402 | reader->m_fontname = config.readEntry( "Fontname", "helvetica" ); | 402 | reader->m_fontname = config.readEntry( "Fontname", "helvetica" ); |
403 | reader->m_encd = config.readNumEntry( "Encoding", 0 ); | 403 | reader->m_encd = config.readNumEntry( "Encoding", 0 ); |
404 | reader->m_charpc = config.readNumEntry( "CharSpacing", 100 ); | 404 | reader->m_charpc = config.readNumEntry( "CharSpacing", 100 ); |
405 | reader->m_overlap = config.readNumEntry( "Overlap", 0 ); | 405 | reader->m_overlap = config.readNumEntry( "Overlap", 0 ); |
406 | reader->m_border = config.readNumEntry( "Margin", 6 ); | 406 | reader->m_border = config.readNumEntry( "Margin", 6 ); |
407 | #ifdef REPALM | 407 | #ifdef REPALM |
408 | reader->brepalm = config.readBoolEntry( "Repalm", true ); | 408 | reader->brepalm = config.readBoolEntry( "Repalm", true ); |
409 | #endif | 409 | #endif |
410 | reader->bremap = config.readBoolEntry( "Remap", true ); | 410 | reader->bremap = config.readBoolEntry( "Remap", true ); |
411 | reader->bmakebold = config.readBoolEntry( "MakeBold", false ); | 411 | reader->bmakebold = config.readBoolEntry( "MakeBold", false ); |
412 | reader->setContinuous(config.readBoolEntry( "Continuous", true )); | 412 | reader->setContinuous(config.readBoolEntry( "Continuous", true )); |
413 | m_targetapp = config.readEntry( "TargetApp", QString::null ); | 413 | m_targetapp = config.readEntry( "TargetApp", QString::null ); |
414 | m_targetmsg = config.readEntry( "TargetMsg", QString::null ); | 414 | m_targetmsg = config.readEntry( "TargetMsg", QString::null ); |
415 | #ifdef _SCROLLPIPE | 415 | #ifdef _SCROLLPIPE |
416 | reader->m_pipetarget = config.readEntry( "PipeTarget", QString::null ); | 416 | reader->m_pipetarget = config.readEntry( "PipeTarget", QString::null ); |
417 | reader->m_pauseAfterEachPara = config.readBoolEntry( "PauseAfterPara", true ); | 417 | reader->m_pauseAfterEachPara = config.readBoolEntry( "PauseAfterPara", true ); |
418 | #endif | 418 | #endif |
419 | m_twoTouch = config.readBoolEntry( "TwoTouch", false); | 419 | m_twoTouch = config.readBoolEntry( "TwoTouch", false); |
420 | m_doAnnotation = config.readBoolEntry( "Annotation", false); | 420 | m_doAnnotation = config.readBoolEntry( "Annotation", false); |
421 | m_doDictionary = config.readBoolEntry( "Dictionary", false); | 421 | m_doDictionary = config.readBoolEntry( "Dictionary", false); |
422 | m_doClipboard = config.readBoolEntry( "Clipboard", false); | 422 | m_doClipboard = config.readBoolEntry( "Clipboard", false); |
423 | m_spaceTarget = (ActionTypes)config.readNumEntry("SpaceTarget", cesAutoScroll); | 423 | m_spaceTarget = (ActionTypes)config.readNumEntry("SpaceTarget", cesAutoScroll); |
424 | m_escapeTarget = (ActionTypes)config.readNumEntry("EscapeTarget", cesNone); | 424 | m_escapeTarget = (ActionTypes)config.readNumEntry("EscapeTarget", cesNone); |
425 | m_returnTarget = (ActionTypes)config.readNumEntry("ReturnTarget", cesFullScreen); | 425 | m_returnTarget = (ActionTypes)config.readNumEntry("ReturnTarget", cesFullScreen); |
426 | m_leftTarget = (ActionTypes)config.readNumEntry("LeftTarget", cesZoomOut); | 426 | m_leftTarget = (ActionTypes)config.readNumEntry("LeftTarget", cesZoomOut); |
427 | m_rightTarget = (ActionTypes)config.readNumEntry("RightTarget", cesZoomIn); | 427 | m_rightTarget = (ActionTypes)config.readNumEntry("RightTarget", cesZoomIn); |
428 | m_upTarget = (ActionTypes)config.readNumEntry("UpTarget", cesPageUp); | 428 | m_upTarget = (ActionTypes)config.readNumEntry("UpTarget", cesPageUp); |
429 | m_downTarget = (ActionTypes)config.readNumEntry("DownTarget", cesPageDown); | 429 | m_downTarget = (ActionTypes)config.readNumEntry("DownTarget", cesPageDown); |
430 | 430 | ||
431 | m_leftScroll = config.readBoolEntry("LeftScroll", false); | 431 | m_leftScroll = config.readBoolEntry("LeftScroll", false); |
432 | m_rightScroll = config.readBoolEntry("RightScroll", false); | 432 | m_rightScroll = config.readBoolEntry("RightScroll", false); |
433 | m_upScroll = config.readBoolEntry("UpScroll", true); | 433 | m_upScroll = config.readBoolEntry("UpScroll", true); |
434 | m_downScroll = config.readBoolEntry("DownScroll", true); | 434 | m_downScroll = config.readBoolEntry("DownScroll", true); |
435 | 435 | ||
436 | m_propogatefontchange = config.readBoolEntry( "RequestorFontChange", false); | 436 | m_propogatefontchange = config.readBoolEntry( "RequestorFontChange", false); |
437 | reader->setBaseSize(config.readNumEntry( "Basesize", 10 )); | 437 | reader->setBaseSize(config.readNumEntry( "Basesize", 10 )); |
438 | 438 | ||
439 | #ifndef USEQPE | 439 | #ifndef USEQPE |
440 | config.setGroup( "Geometry" ); | 440 | config.setGroup( "Geometry" ); |
441 | setGeometry(0,0, | 441 | setGeometry(0,0, |
442 | config.readNumEntry( "width", QApplication::desktop()->width()/2 ), | 442 | config.readNumEntry( "width", QApplication::desktop()->width()/2 ), |
443 | config.readNumEntry( "height", QApplication::desktop()->height()/2 )); | 443 | config.readNumEntry( "height", QApplication::desktop()->height()/2 )); |
444 | move( | 444 | move( |
445 | config.readNumEntry( "x", 20 ), | 445 | config.readNumEntry( "x", 20 ), |
446 | config.readNumEntry( "y", 20 )); | 446 | config.readNumEntry( "y", 20 )); |
447 | #endif | 447 | #endif |
448 | 448 | ||
449 | 449 | ||
450 | 450 | ||
451 | setTwoTouch(m_twoTouch); | 451 | setTwoTouch(m_twoTouch); |
452 | 452 | ||
453 | connect( reader, SIGNAL( OnShowPicture(QImage&) ), this, SLOT( showgraphic(QImage&) ) ); | 453 | connect( reader, SIGNAL( OnShowPicture(QImage&) ), this, SLOT( showgraphic(QImage&) ) ); |
454 | 454 | ||
455 | connect( reader, SIGNAL( OnRedraw() ), this, SLOT( OnRedraw() ) ); | 455 | connect( reader, SIGNAL( OnRedraw() ), this, SLOT( OnRedraw() ) ); |
456 | connect( reader, SIGNAL( OnWordSelected(const QString&,size_t,const QString&) ), this, SLOT( OnWordSelected(const QString&,size_t,const QString&) ) ); | 456 | connect( reader, SIGNAL( OnWordSelected(const QString&,size_t,const QString&) ), this, SLOT( OnWordSelected(const QString&,size_t,const QString&) ) ); |
457 | connect( reader, SIGNAL( OnURLSelected(const QString&) ), this, SLOT( OnURLSelected(const QString&) ) ); | 457 | connect( reader, SIGNAL( OnURLSelected(const QString&) ), this, SLOT( OnURLSelected(const QString&) ) ); |
458 | editorStack->addWidget( reader, get_unique_id() ); | 458 | editorStack->addWidget( reader, get_unique_id() ); |
459 | 459 | ||
460 | m_preferences_action = new QAction( tr( "Configuration" ), geticon( "SettingsIcon" ), QString::null, 0, this, NULL); | 460 | m_preferences_action = new QAction( tr( "Configuration" ), geticon( "SettingsIcon" ), QString::null, 0, this, NULL); |
461 | connect( m_preferences_action, SIGNAL( activated() ), this, SLOT( showprefs() ) ); | 461 | connect( m_preferences_action, SIGNAL( activated() ), this, SLOT( showprefs() ) ); |
462 | m_preferences_action->addTo( settings ); | 462 | m_preferences_action->addTo( settings ); |
463 | 463 | ||
464 | m_saveconfig_action = new QAction( tr( "Save Config" ), QString::null, 0, this, NULL); | 464 | m_saveconfig_action = new QAction( tr( "Save Config" ), QString::null, 0, this, NULL); |
465 | connect( m_saveconfig_action, SIGNAL( activated() ), this, SLOT( SaveConfig() ) ); | 465 | connect( m_saveconfig_action, SIGNAL( activated() ), this, SLOT( SaveConfig() ) ); |
466 | m_saveconfig_action->addTo( settings ); | 466 | m_saveconfig_action->addTo( settings ); |
467 | 467 | ||
468 | m_loadconfig_action = new QAction( tr( "Load Config" ), QString::null, 0, this, NULL); | 468 | m_loadconfig_action = new QAction( tr( "Load Config" ), QString::null, 0, this, NULL); |
469 | connect( m_loadconfig_action, SIGNAL( activated() ), this, SLOT( LoadConfig() ) ); | 469 | connect( m_loadconfig_action, SIGNAL( activated() ), this, SLOT( LoadConfig() ) ); |
470 | m_loadconfig_action->addTo( settings ); | 470 | m_loadconfig_action->addTo( settings ); |
471 | 471 | ||
472 | m_tidyconfig_action = new QAction( tr( "Delete Config" ), QString::null, 0, this, NULL); | 472 | m_tidyconfig_action = new QAction( tr( "Delete Config" ), QString::null, 0, this, NULL); |
473 | connect( m_tidyconfig_action, SIGNAL( activated() ), this, SLOT( TidyConfig() ) ); | 473 | connect( m_tidyconfig_action, SIGNAL( activated() ), this, SLOT( TidyConfig() ) ); |
474 | m_tidyconfig_action->addTo( settings ); | 474 | m_tidyconfig_action->addTo( settings ); |
475 | 475 | ||
476 | settings->insertSeparator(); | 476 | settings->insertSeparator(); |
477 | m_toolbarprefs_action = new QAction( tr( "Toolbars" ), QString::null, 0, this, NULL); | 477 | m_toolbarprefs_action = new QAction( tr( "Toolbars" ), QString::null, 0, this, NULL); |
478 | connect( m_toolbarprefs_action, SIGNAL( activated() ), this, SLOT( showtoolbarprefs() ) ); | 478 | connect( m_toolbarprefs_action, SIGNAL( activated() ), this, SLOT( showtoolbarprefs() ) ); |
479 | m_toolbarprefs_action->addTo( settings ); | 479 | m_toolbarprefs_action->addTo( settings ); |
480 | 480 | ||
481 | m_open_action = new QAction( tr( "Open" ), geticon( "fileopen" ), QString::null, 0, this, 0 ); | 481 | m_open_action = new QAction( tr( "Open" ), geticon( "fileopen" ), QString::null, 0, this, 0 ); |
482 | connect( m_open_action, SIGNAL( activated() ), this, SLOT( fileOpen() ) ); | 482 | connect( m_open_action, SIGNAL( activated() ), this, SLOT( fileOpen() ) ); |
483 | m_open_action->addTo( file ); | 483 | m_open_action->addTo( file ); |
484 | 484 | ||
485 | m_close_action = new QAction( tr( "Close" ), geticon( "close" ), QString::null, 0, this, 0 ); | 485 | m_close_action = new QAction( tr( "Close" ), geticon( "close" ), QString::null, 0, this, 0 ); |
486 | connect( m_close_action, SIGNAL( activated() ), this, SLOT( fileClose() ) ); | 486 | connect( m_close_action, SIGNAL( activated() ), this, SLOT( fileClose() ) ); |
487 | m_close_action->addTo( file ); | 487 | m_close_action->addTo( file ); |
488 | 488 | ||
489 | #ifdef _SCRIPT | 489 | #ifdef _SCRIPT |
490 | a = new QAction( tr( "Run Script" ), QString::null, 0, this, NULL); | 490 | a = new QAction( tr( "Run Script" ), QString::null, 0, this, NULL); |
491 | connect( a, SIGNAL( activated() ), this, SLOT( RunScript() ) ); | 491 | connect( a, SIGNAL( activated() ), this, SLOT( RunScript() ) ); |
492 | a->addTo( file ); | 492 | a->addTo( file ); |
493 | #endif | 493 | #endif |
494 | /* | 494 | /* |
495 | a = new QAction( tr( "Revert" ), geticon( "close" ), QString::null, 0, this, 0 ); | 495 | a = new QAction( tr( "Revert" ), geticon( "close" ), QString::null, 0, this, 0 ); |
496 | connect( a, SIGNAL( activated() ), this, SLOT( fileRevert() ) ); | 496 | connect( a, SIGNAL( activated() ), this, SLOT( fileRevert() ) ); |
497 | a->addTo( file ); | 497 | a->addTo( file ); |
498 | 498 | ||
499 | a = new QAction( tr( "Cut" ), geticon( "cut" ), QString::null, 0, this, 0 ); | 499 | a = new QAction( tr( "Cut" ), geticon( "cut" ), QString::null, 0, this, 0 ); |
500 | connect( a, SIGNAL( activated() ), this, SLOT( editCut() ) ); | 500 | connect( a, SIGNAL( activated() ), this, SLOT( editCut() ) ); |
501 | a->addTo( filebar() ); | 501 | a->addTo( filebar() ); |
502 | a->addTo( edit ); | 502 | a->addTo( edit ); |
503 | */ | 503 | */ |
504 | 504 | ||
505 | m_info_action = new QAction( tr( "Info" ), geticon( "UtilsIcon" ), QString::null, 0, this, NULL); | 505 | m_info_action = new QAction( tr( "Info" ), geticon( "UtilsIcon" ), QString::null, 0, this, NULL); |
506 | connect( m_info_action, SIGNAL( activated() ), this, SLOT( showinfo() ) ); | 506 | connect( m_info_action, SIGNAL( activated() ), this, SLOT( showinfo() ) ); |
507 | m_info_action->addTo( file ); | 507 | m_info_action->addTo( file ); |
508 | 508 | ||
509 | m_touch_action = new QAction( tr( "Two/One Touch" ), geticon( "1to1" ), QString::null, 0, this, NULL, true ); | 509 | m_touch_action = new QAction( tr( "Two/One Touch" ), geticon( "1to1" ), QString::null, 0, this, NULL, true ); |
510 | connect( m_touch_action, SIGNAL( toggled(bool) ), this, SLOT( setTwoTouch(bool) ) ); | 510 | connect( m_touch_action, SIGNAL( toggled(bool) ), this, SLOT( setTwoTouch(bool) ) ); |
511 | m_touch_action->setOn(m_twoTouch); | 511 | m_touch_action->setOn(m_twoTouch); |
512 | m_touch_action->addTo( file ); | 512 | m_touch_action->addTo( file ); |
513 | 513 | ||
514 | m_find_action = new QAction( tr( "Find..." ), geticon( "find" ), QString::null, 0, this, NULL); | 514 | m_find_action = new QAction( tr( "Find..." ), geticon( "find" ), QString::null, 0, this, NULL); |
515 | connect( m_find_action, SIGNAL( activated() ), this, SLOT( editFind() ) ); | 515 | connect( m_find_action, SIGNAL( activated() ), this, SLOT( editFind() ) ); |
516 | file->insertSeparator(); | 516 | file->insertSeparator(); |
517 | // a->addTo( bar ); | 517 | // a->addTo( bar ); |
518 | m_find_action->addTo( file ); | 518 | m_find_action->addTo( file ); |
519 | 519 | ||
520 | m_exportlinks_action = new QAction( tr( "Export Links" ), QString::null, 0, this, NULL); | 520 | m_exportlinks_action = new QAction( tr( "Export Links" ), QString::null, 0, this, NULL); |
521 | connect( m_exportlinks_action, SIGNAL( activated() ), this, SLOT( ExportLinks() ) ); | 521 | connect( m_exportlinks_action, SIGNAL( activated() ), this, SLOT( ExportLinks() ) ); |
522 | m_exportlinks_action->addTo( file ); | 522 | m_exportlinks_action->addTo( file ); |
523 | 523 | ||
524 | m_scrollButton = new QAction( tr( "Scroll" ), getmyicon( "panel-arrow-down" ), QString::null, 0, this, 0, true ); | 524 | m_scrollButton = new QAction( tr( "Scroll" ), getmyicon( "panel-arrow-down" ), QString::null, 0, this, 0, true ); |
525 | connect( m_scrollButton, SIGNAL( toggled(bool) ), this, SLOT( autoScroll(bool) ) ); | 525 | connect( m_scrollButton, SIGNAL( toggled(bool) ), this, SLOT( autoScroll(bool) ) ); |
526 | m_scrollButton->addTo(navigation); | 526 | m_scrollButton->addTo(navigation); |
527 | m_scrollButton->setOn(false); | 527 | m_scrollButton->setOn(false); |
528 | 528 | ||
529 | m_start_action = new QAction( tr( "Goto Start" ), geticon( "start" ), QString::null, 0, this, NULL); | 529 | m_start_action = new QAction( tr( "Goto Start" ), geticon( "start" ), QString::null, 0, this, NULL); |
530 | connect( m_start_action, SIGNAL( activated() ), this, SLOT( gotoStart() ) ); | 530 | connect( m_start_action, SIGNAL( activated() ), this, SLOT( gotoStart() ) ); |
531 | m_start_action->addTo(navigation); | 531 | m_start_action->addTo(navigation); |
532 | 532 | ||
533 | m_end_action = new QAction( tr( "Goto End" ), geticon( "finish" ), QString::null, 0, this, NULL); | 533 | m_end_action = new QAction( tr( "Goto End" ), geticon( "finish" ), QString::null, 0, this, NULL); |
534 | connect( m_end_action, SIGNAL( activated() ), this, SLOT( gotoEnd() ) ); | 534 | connect( m_end_action, SIGNAL( activated() ), this, SLOT( gotoEnd() ) ); |
535 | m_end_action->addTo(navigation); | 535 | m_end_action->addTo(navigation); |
536 | 536 | ||
537 | m_jump_action = new QAction( tr( "Jump" ), geticon( "rotate" ), QString::null, 0, this, NULL); | 537 | m_jump_action = new QAction( tr( "Jump" ), geticon( "rotate" ), QString::null, 0, this, NULL); |
538 | connect( m_jump_action, SIGNAL( activated() ), this, SLOT( jump() ) ); | 538 | connect( m_jump_action, SIGNAL( activated() ), this, SLOT( jump() ) ); |
diff --git a/noncore/apps/opie-sheet/main.cpp b/noncore/apps/opie-sheet/main.cpp index c7a7d88..861473e 100644 --- a/noncore/apps/opie-sheet/main.cpp +++ b/noncore/apps/opie-sheet/main.cpp | |||
@@ -1,20 +1,23 @@ | |||
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 | /* | 10 | /* |
11 | * Opie Sheet (formerly Sheet/Qt) | 11 | * Opie Sheet (formerly Sheet/Qt) |
12 | * by Serdar Ozler <sozler@sitebest.com> | 12 | * by Serdar Ozler <sozler@sitebest.com> |
13 | */ | 13 | */ |
14 | 14 | ||
15 | |||
15 | #include "mainwindow.h" | 16 | #include "mainwindow.h" |
16 | 17 | ||
17 | #include <opie2/oapplicationfactory.h> | 18 | #include <opie2/oapplicationfactory.h> |
18 | 19 | ||
20 | using namespace Opie::Core; | ||
21 | |||
19 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) | 22 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) |
20 | 23 | ||
diff --git a/noncore/apps/opie-write/main.cpp b/noncore/apps/opie-write/main.cpp index 6a8aaaa..036fe48 100644 --- a/noncore/apps/opie-write/main.cpp +++ b/noncore/apps/opie-write/main.cpp | |||
@@ -1,28 +1,30 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of the Qtopia Environment. | 4 | ** This file is part of the Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** Licensees holding valid Qtopia Developer license may use this | 6 | ** Licensees holding valid Qtopia Developer license may use this |
7 | ** file in accordance with the Qtopia Developer License Agreement | 7 | ** file in accordance with the Qtopia Developer License Agreement |
8 | ** provided with the Software. | 8 | ** provided with the Software. |
9 | ** | 9 | ** |
10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING | 10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING |
11 | ** THE WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 11 | ** THE WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
12 | ** PURPOSE. | 12 | ** PURPOSE. |
13 | ** | 13 | ** |
14 | ** email sales@trolltech.com for information about Qtopia License | 14 | ** email sales@trolltech.com for information about Qtopia License |
15 | ** Agreements. | 15 | ** Agreements. |
16 | ** | 16 | ** |
17 | ** Contact info@trolltech.com if any conditions of this licensing are | 17 | ** Contact info@trolltech.com if any conditions of this licensing are |
18 | ** not clear to you. | 18 | ** not clear to you. |
19 | ** | 19 | ** |
20 | **********************************************************************/ | 20 | **********************************************************************/ |
21 | 21 | ||
22 | |||
22 | #include "mainwindow.h" | 23 | #include "mainwindow.h" |
23 | 24 | ||
24 | #include <opie2/oapplicationfactory.h> | 25 | #include <opie2/oapplicationfactory.h> |
25 | 26 | ||
27 | using namespace Opie::Core; | ||
26 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) | 28 | OPIE_EXPORT_APP( OApplicationFactory<MainWindow> ) |
27 | 29 | ||
28 | 30 | ||
diff --git a/noncore/apps/oxygen/main.cpp b/noncore/apps/oxygen/main.cpp index 276b90d..e2a602b 100644 --- a/noncore/apps/oxygen/main.cpp +++ b/noncore/apps/oxygen/main.cpp | |||
@@ -1,23 +1,25 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | application: : Oxygen | 2 | application: : Oxygen |
3 | 3 | ||
4 | begin : September 2002 | 4 | begin : September 2002 |
5 | copyright : ( C ) 2002 by Carsten Niehaus | 5 | copyright : ( C ) 2002 by Carsten Niehaus |
6 | email : cniehaus@handhelds.org | 6 | email : cniehaus@handhelds.org |
7 | **************************************************************************/ | 7 | **************************************************************************/ |
8 | 8 | ||
9 | /*************************************************************************** | 9 | /*************************************************************************** |
10 | * * | 10 | * * |
11 | * This program is free software; you can redistribute it and/or modify * | 11 | * This program is free software; you can redistribute it and/or modify * |
12 | * it under the terms of the GNU General Public License as published by * | 12 | * it under the terms of the GNU General Public License as published by * |
13 | * the Free Software Foundation; either version 2 of the License, or * | 13 | * the Free Software Foundation; either version 2 of the License, or * |
14 | * ( at your option ) any later version. * | 14 | * ( at your option ) any later version. * |
15 | * * | 15 | * * |
16 | **************************************************************************/ | 16 | **************************************************************************/ |
17 | 17 | ||
18 | #include <opie2/oapplicationfactory.h> | 18 | #include <opie2/oapplicationfactory.h> |
19 | 19 | ||
20 | #include "oxygen.h" | 20 | #include "oxygen.h" |
21 | 21 | ||
22 | 22 | ||
23 | using namespace Opie::Core; | ||
24 | using namespace Opie::Core; | ||
23 | OPIE_EXPORT_APP( OApplicationFactory<Oxygen> ) | 25 | OPIE_EXPORT_APP( OApplicationFactory<Oxygen> ) |
diff --git a/noncore/apps/tableviewer/main.cpp b/noncore/apps/tableviewer/main.cpp index 80a76e0..7ef281c 100644 --- a/noncore/apps/tableviewer/main.cpp +++ b/noncore/apps/tableviewer/main.cpp | |||
@@ -1,25 +1,27 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
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 | #include "tableviewer.h" | 20 | #include "tableviewer.h" |
21 | 21 | ||
22 | #include <opie2/oapplicationfactory.h> | 22 | #include <opie2/oapplicationfactory.h> |
23 | 23 | ||
24 | using namespace Opie::Core; | ||
24 | OPIE_EXPORT_APP( OApplicationFactory<TableViewerWindow> ) | 25 | OPIE_EXPORT_APP( OApplicationFactory<TableViewerWindow> ) |
26 | using namespace Opie::Core; | ||
25 | 27 | ||
diff --git a/noncore/apps/tableviewer/tableviewer.cpp b/noncore/apps/tableviewer/tableviewer.cpp index 4c6d809..102b94c 100644 --- a/noncore/apps/tableviewer/tableviewer.cpp +++ b/noncore/apps/tableviewer/tableviewer.cpp | |||
@@ -1,480 +1,480 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
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 | 20 | ||
21 | /* local includes */ | 21 | /* local includes */ |
22 | #include "tableviewer.h" | 22 | #include "tableviewer.h" |
23 | #include "ui/tvbrowseview.h" | 23 | #include "ui/tvbrowseview.h" |
24 | #include "ui/tvfilterview.h" | 24 | #include "ui/tvfilterview.h" |
25 | #include "ui/tvlistview.h" | 25 | #include "ui/tvlistview.h" |
26 | #include "ui/tveditview.h" | 26 | #include "ui/tveditview.h" |
27 | #include "ui/tvkeyedit.h" | 27 | #include "ui/tvkeyedit.h" |
28 | #include "db/datacache.h" | 28 | #include "db/datacache.h" |
29 | 29 | ||
30 | /* QPE includes */ | 30 | /* QPE includes */ |
31 | #include <qpe/fileselector.h> | 31 | #include <qpe/fileselector.h> |
32 | #include <qpe/resource.h> | 32 | #include <qpe/resource.h> |
33 | #include <qpe/qpetoolbar.h> | 33 | #include <qtoolbar.h> |
34 | 34 | ||
35 | /* QTE includes */ | 35 | /* QTE includes */ |
36 | #include <qmenubar.h> | 36 | #include <qmenubar.h> |
37 | #include <qpopupmenu.h> | 37 | #include <qpopupmenu.h> |
38 | #include <qapplication.h> | 38 | #include <qapplication.h> |
39 | #include <qwidgetstack.h> | 39 | #include <qwidgetstack.h> |
40 | #include <qlayout.h> | 40 | #include <qlayout.h> |
41 | #include <qbuffer.h> | 41 | #include <qbuffer.h> |
42 | /*! | 42 | /*! |
43 | \class TableViewerWindow | 43 | \class TableViewerWindow |
44 | \brief The main window widget of the application | 44 | \brief The main window widget of the application |
45 | 45 | ||
46 | This is the main widget of the table viewer application. | 46 | This is the main widget of the table viewer application. |
47 | It is the co-ordination point. | 47 | It is the co-ordination point. |
48 | */ | 48 | */ |
49 | 49 | ||
50 | /*! | 50 | /*! |
51 | Constructs a new TableViewerWindow | 51 | Constructs a new TableViewerWindow |
52 | */ | 52 | */ |
53 | TableViewerWindow::TableViewerWindow(QWidget *parent, const char *name, WFlags f) | 53 | TableViewerWindow::TableViewerWindow(QWidget *parent, const char *name, WFlags f) |
54 | : QMainWindow(parent, name, f) | 54 | : QMainWindow(parent, name, f) |
55 | { | 55 | { |
56 | setCaption(tr("Table Viewer")); | 56 | setCaption(tr("Table Viewer")); |
57 | 57 | ||
58 | /* Build data */ | 58 | /* Build data */ |
59 | ds = new DBStore(); | 59 | ds = new DBStore(); |
60 | doc.setType("text/x-xml-tableviewer"); | 60 | doc.setType("text/x-xml-tableviewer"); |
61 | doc.setName("table"); | 61 | doc.setName("table"); |
62 | 62 | ||
63 | dirty = FALSE; | 63 | dirty = FALSE; |
64 | ts.current_column = 0; | 64 | ts.current_column = 0; |
65 | ts.kRep = ds->getKeys(); | 65 | ts.kRep = ds->getKeys(); |
66 | 66 | ||
67 | /* build menus */ | 67 | /* build menus */ |
68 | menu = new QMenuBar(this, 0); | 68 | menu = new QMenuBar(this, 0); |
69 | 69 | ||
70 | QPopupMenu *file_menu = new QPopupMenu; | 70 | QPopupMenu *file_menu = new QPopupMenu; |
71 | file_menu->insertItem("New", this, SLOT(newDocument())); | 71 | file_menu->insertItem("New", this, SLOT(newDocument())); |
72 | 72 | ||
73 | file_menu->insertItem("Open", this, SLOT(selectDocument())); | 73 | file_menu->insertItem("Open", this, SLOT(selectDocument())); |
74 | file_menu->insertSeparator(); | 74 | file_menu->insertSeparator(); |
75 | file_menu->insertItem("Properties"); | 75 | file_menu->insertItem("Properties"); |
76 | 76 | ||
77 | /* later will want to set this up to clean up first via this, SLOT(quit) */ | 77 | /* later will want to set this up to clean up first via this, SLOT(quit) */ |
78 | menu->insertItem("Document", file_menu); | 78 | menu->insertItem("Document", file_menu); |
79 | 79 | ||
80 | QPopupMenu *edit_menu = new QPopupMenu; | 80 | QPopupMenu *edit_menu = new QPopupMenu; |
81 | edit_menu->insertItem("Edit Item", this, SLOT(editItemSlot())); | 81 | edit_menu->insertItem("Edit Item", this, SLOT(editItemSlot())); |
82 | edit_menu->insertItem("Edit Keys", this, SLOT(editKeysSlot())); | 82 | edit_menu->insertItem("Edit Keys", this, SLOT(editKeysSlot())); |
83 | edit_menu->insertItem("Edit filters", this, SLOT(filterViewSlot())); | 83 | edit_menu->insertItem("Edit filters", this, SLOT(filterViewSlot())); |
84 | menu->insertItem("Edit", edit_menu); | 84 | menu->insertItem("Edit", edit_menu); |
85 | 85 | ||
86 | QPopupMenu *view_menu = new QPopupMenu; | 86 | QPopupMenu *view_menu = new QPopupMenu; |
87 | view_menu->insertItem("Browse View", this, SLOT(browseViewSlot())); | 87 | view_menu->insertItem("Browse View", this, SLOT(browseViewSlot())); |
88 | view_menu->insertItem("List View", this, SLOT(listViewSlot())); | 88 | view_menu->insertItem("List View", this, SLOT(listViewSlot())); |
89 | menu->insertItem("View", view_menu); | 89 | menu->insertItem("View", view_menu); |
90 | 90 | ||
91 | QVBoxLayout *main_layout = new QVBoxLayout; | 91 | QVBoxLayout *main_layout = new QVBoxLayout; |
92 | 92 | ||
93 | /* Build tool bar */ | 93 | /* Build tool bar */ |
94 | navigation = new QToolBar(this, "navigation"); | 94 | navigation = new QToolBar(this, "navigation"); |
95 | QToolButton *newItemButton = new QToolButton( | 95 | QToolButton *newItemButton = new QToolButton( |
96 | QIconSet(Resource::loadPixmap("new")), "New Item", QString::null, | 96 | QIconSet(Resource::loadPixmap("new")), "New Item", QString::null, |
97 | this, SLOT(newItemSlot()), navigation, "New Item"); | 97 | this, SLOT(newItemSlot()), navigation, "New Item"); |
98 | QToolButton *editItemButton = new QToolButton( | 98 | QToolButton *editItemButton = new QToolButton( |
99 | QIconSet(Resource::loadPixmap("edit")), "Edit Item", QString::null, | 99 | QIconSet(Resource::loadPixmap("edit")), "Edit Item", QString::null, |
100 | this, SLOT(editItemSlot()), navigation, "Edit Item"); | 100 | this, SLOT(editItemSlot()), navigation, "Edit Item"); |
101 | QToolButton *deleteItemButton = new QToolButton( | 101 | QToolButton *deleteItemButton = new QToolButton( |
102 | QIconSet(Resource::loadPixmap("trash")), "Delete Item", | 102 | QIconSet(Resource::loadPixmap("trash")), "Delete Item", |
103 | QString::null, this, | 103 | QString::null, this, |
104 | SLOT(deleteItemSlot()), navigation, "Delete Item"); | 104 | SLOT(deleteItemSlot()), navigation, "Delete Item"); |
105 | 105 | ||
106 | navigation->addSeparator(); | 106 | navigation->addSeparator(); |
107 | 107 | ||
108 | QToolButton *firstItemButton = new QToolButton( | 108 | QToolButton *firstItemButton = new QToolButton( |
109 | QIconSet(Resource::loadPixmap("fastback")), "First Item", | 109 | QIconSet(Resource::loadPixmap("fastback")), "First Item", |
110 | QString::null, this, | 110 | QString::null, this, |
111 | SLOT(firstItem()), navigation, "First Item"); | 111 | SLOT(firstItem()), navigation, "First Item"); |
112 | QToolButton *previousItemButton = new QToolButton( | 112 | QToolButton *previousItemButton = new QToolButton( |
113 | QIconSet(Resource::loadPixmap("back")), "Previous Item", | 113 | QIconSet(Resource::loadPixmap("back")), "Previous Item", |
114 | QString::null, this, | 114 | QString::null, this, |
115 | SLOT(previousItem()), navigation, "Previous Item"); | 115 | SLOT(previousItem()), navigation, "Previous Item"); |
116 | QToolButton *nextItemButton = new QToolButton( | 116 | QToolButton *nextItemButton = new QToolButton( |
117 | QIconSet(Resource::loadPixmap("forward")), "Next Item", | 117 | QIconSet(Resource::loadPixmap("forward")), "Next Item", |
118 | QString::null, this, | 118 | QString::null, this, |
119 | SLOT(nextItem()), navigation, "Next Item"); | 119 | SLOT(nextItem()), navigation, "Next Item"); |
120 | QToolButton *lastItemButton = new QToolButton( | 120 | QToolButton *lastItemButton = new QToolButton( |
121 | QIconSet(Resource::loadPixmap("fastforward")), "Last Item", | 121 | QIconSet(Resource::loadPixmap("fastforward")), "Last Item", |
122 | QString::null, this, | 122 | QString::null, this, |
123 | SLOT(lastItem()), navigation, "Last Item"); | 123 | SLOT(lastItem()), navigation, "Last Item"); |
124 | 124 | ||
125 | navigation->addSeparator(); | 125 | navigation->addSeparator(); |
126 | QToolButton *browseButton = new QToolButton( | 126 | QToolButton *browseButton = new QToolButton( |
127 | QIconSet(Resource::loadPixmap("day")), "View Single Item", | 127 | QIconSet(Resource::loadPixmap("day")), "View Single Item", |
128 | QString::null, this, | 128 | QString::null, this, |
129 | SLOT(browseViewSlot()), navigation, "View Single Item"); | 129 | SLOT(browseViewSlot()), navigation, "View Single Item"); |
130 | QToolButton *listButton = new QToolButton( | 130 | QToolButton *listButton = new QToolButton( |
131 | QIconSet(Resource::loadPixmap("month")), "View Multiple Items", | 131 | QIconSet(Resource::loadPixmap("month")), "View Multiple Items", |
132 | QString::null, this, | 132 | QString::null, this, |
133 | SLOT(listViewSlot()), navigation, "View Multiple Items"); | 133 | SLOT(listViewSlot()), navigation, "View Multiple Items"); |
134 | 134 | ||
135 | setToolBarsMovable(FALSE); | 135 | setToolBarsMovable(FALSE); |
136 | setToolBarsMovable(FALSE); | 136 | setToolBarsMovable(FALSE); |
137 | setToolBarsMovable(FALSE); | 137 | setToolBarsMovable(FALSE); |
138 | 138 | ||
139 | /* Build widgets */ | 139 | /* Build widgets */ |
140 | browseView = new TVBrowseView(&ts, this, 0); | 140 | browseView = new TVBrowseView(&ts, this, 0); |
141 | listView = new TVListView(&ts, this, 0); | 141 | listView = new TVListView(&ts, this, 0); |
142 | filterView = new TVFilterView(&ts, this, 0); | 142 | filterView = new TVFilterView(&ts, this, 0); |
143 | fileSelector = new FileSelector("text/csv;text/x-xml-tableviewer", | 143 | fileSelector = new FileSelector("text/csv;text/x-xml-tableviewer", |
144 | this, "fileselector"); | 144 | this, "fileselector"); |
145 | fileSelector->setNewVisible(FALSE); | 145 | fileSelector->setNewVisible(FALSE); |
146 | fileSelector->setCloseVisible(FALSE); | 146 | fileSelector->setCloseVisible(FALSE); |
147 | 147 | ||
148 | cw = new QWidgetStack(this, 0); | 148 | cw = new QWidgetStack(this, 0); |
149 | cw->addWidget(listView, ListState); | 149 | cw->addWidget(listView, ListState); |
150 | cw->addWidget(browseView, BrowseState); | 150 | cw->addWidget(browseView, BrowseState); |
151 | cw->addWidget(filterView, FilterState); | 151 | cw->addWidget(filterView, FilterState); |
152 | cw->addWidget(fileSelector, FileState); | 152 | cw->addWidget(fileSelector, FileState); |
153 | 153 | ||
154 | current_view = FileState; | 154 | current_view = FileState; |
155 | cw->raiseWidget(current_view); | 155 | cw->raiseWidget(current_view); |
156 | fileSelector->reread(); | 156 | fileSelector->reread(); |
157 | 157 | ||
158 | connect(browseView, SIGNAL(searchOnKey(int,TVVariant)), | 158 | connect(browseView, SIGNAL(searchOnKey(int,TVVariant)), |
159 | this, SLOT(searchOnKey(int,TVVariant))); | 159 | this, SLOT(searchOnKey(int,TVVariant))); |
160 | connect(browseView, SIGNAL(sortChanged(int)), | 160 | connect(browseView, SIGNAL(sortChanged(int)), |
161 | this, SLOT(setPrimaryKey(int))); | 161 | this, SLOT(setPrimaryKey(int))); |
162 | 162 | ||
163 | connect(fileSelector, SIGNAL(closeMe()), this, SLOT(browseViewSlot())); | 163 | connect(fileSelector, SIGNAL(closeMe()), this, SLOT(browseViewSlot())); |
164 | connect(fileSelector, SIGNAL(fileSelected(const DocLnk&)), | 164 | connect(fileSelector, SIGNAL(fileSelected(const DocLnk&)), |
165 | this, SLOT(openDocument(const DocLnk&))); | 165 | this, SLOT(openDocument(const DocLnk&))); |
166 | 166 | ||
167 | main_layout->addWidget(menu); | 167 | main_layout->addWidget(menu); |
168 | main_layout->addWidget(cw); | 168 | main_layout->addWidget(cw); |
169 | 169 | ||
170 | setCentralWidget(cw); | 170 | setCentralWidget(cw); |
171 | 171 | ||
172 | } | 172 | } |
173 | 173 | ||
174 | /*! | 174 | /*! |
175 | Destroys the TableViewerWindow | 175 | Destroys the TableViewerWindow |
176 | */ | 176 | */ |
177 | TableViewerWindow::~TableViewerWindow() | 177 | TableViewerWindow::~TableViewerWindow() |
178 | { | 178 | { |
179 | if(dirty) | 179 | if(dirty) |
180 | saveDocument(); | 180 | saveDocument(); |
181 | } | 181 | } |
182 | 182 | ||
183 | /*! | 183 | /*! |
184 | Opens a file dialog and loads the file specified by the dialog | 184 | Opens a file dialog and loads the file specified by the dialog |
185 | */ | 185 | */ |
186 | void TableViewerWindow::selectDocument() | 186 | void TableViewerWindow::selectDocument() |
187 | { | 187 | { |
188 | if(dirty) | 188 | if(dirty) |
189 | saveDocument(); | 189 | saveDocument(); |
190 | current_view = FileState; | 190 | current_view = FileState; |
191 | cw->raiseWidget(current_view); | 191 | cw->raiseWidget(current_view); |
192 | fileSelector->reread(); | 192 | fileSelector->reread(); |
193 | } | 193 | } |
194 | 194 | ||
195 | void TableViewerWindow::saveDocument() | 195 | void TableViewerWindow::saveDocument() |
196 | { | 196 | { |
197 | if(!dirty) | 197 | if(!dirty) |
198 | return; | 198 | return; |
199 | 199 | ||
200 | FileManager fm; | 200 | FileManager fm; |
201 | QIODevice *dev = fm.saveFile(doc); | 201 | QIODevice *dev = fm.saveFile(doc); |
202 | 202 | ||
203 | if(!ds->saveSource(dev, doc.type())){ | 203 | if(!ds->saveSource(dev, doc.type())){ |
204 | qWarning("Save unsuccessful"); | 204 | qWarning("Save unsuccessful"); |
205 | return; | 205 | return; |
206 | } | 206 | } |
207 | dev->close(); | 207 | dev->close(); |
208 | dirty = FALSE; | 208 | dirty = FALSE; |
209 | } | 209 | } |
210 | 210 | ||
211 | void TableViewerWindow::newDocument() | 211 | void TableViewerWindow::newDocument() |
212 | { | 212 | { |
213 | DocLnk nf; | 213 | DocLnk nf; |
214 | nf.setType("text/x-xml-tableviewer"); | 214 | nf.setType("text/x-xml-tableviewer"); |
215 | nf.setName("table"); | 215 | nf.setName("table"); |
216 | 216 | ||
217 | delete ds; | 217 | delete ds; |
218 | ds = new DBStore(); | 218 | ds = new DBStore(); |
219 | 219 | ||
220 | ts.current_column = 0; | 220 | ts.current_column = 0; |
221 | ts.kRep = ds->getKeys(); | 221 | ts.kRep = ds->getKeys(); |
222 | browseView->reset(); | 222 | browseView->reset(); |
223 | listView->reset(); | 223 | listView->reset(); |
224 | filterView->reset(); | 224 | filterView->reset(); |
225 | 225 | ||
226 | doc = nf; | 226 | doc = nf; |
227 | dirty = FALSE; | 227 | dirty = FALSE; |
228 | 228 | ||
229 | current_view = BrowseState; | 229 | current_view = BrowseState; |
230 | cw->raiseWidget(current_view); | 230 | cw->raiseWidget(current_view); |
231 | 231 | ||
232 | /* now set up for editing the keys */ | 232 | /* now set up for editing the keys */ |
233 | ts.kRep->addKey("key", TVVariant::String); | 233 | ts.kRep->addKey("key", TVVariant::String); |
234 | editKeysSlot(); | 234 | editKeysSlot(); |
235 | } | 235 | } |
236 | 236 | ||
237 | void TableViewerWindow::setDocument(const QString &f) | 237 | void TableViewerWindow::setDocument(const QString &f) |
238 | { | 238 | { |
239 | openDocument(DocLnk(f, TRUE)); | 239 | openDocument(DocLnk(f, TRUE)); |
240 | } | 240 | } |
241 | 241 | ||
242 | void TableViewerWindow::openDocument(const DocLnk &f) | 242 | void TableViewerWindow::openDocument(const DocLnk &f) |
243 | { | 243 | { |
244 | 244 | ||
245 | if (!f.isValid()) | 245 | if (!f.isValid()) |
246 | return; | 246 | return; |
247 | 247 | ||
248 | FileManager fm; | 248 | FileManager fm; |
249 | QIODevice *dev = fm.openFile(f); | 249 | QIODevice *dev = fm.openFile(f); |
250 | doc = f; | 250 | doc = f; |
251 | 251 | ||
252 | if(ds->openSource(dev, doc.type())) { | 252 | if(ds->openSource(dev, doc.type())) { |
253 | DataElem *d; | 253 | DataElem *d; |
254 | 254 | ||
255 | browseView->reset(); | 255 | browseView->reset(); |
256 | listView->reset(); | 256 | listView->reset(); |
257 | filterView->reset(); | 257 | filterView->reset(); |
258 | 258 | ||
259 | current_view = BrowseState; | 259 | current_view = BrowseState; |
260 | cw->raiseWidget(current_view); | 260 | cw->raiseWidget(current_view); |
261 | 261 | ||
262 | /* set up new table state and ensure sub widgets have a reference */ | 262 | /* set up new table state and ensure sub widgets have a reference */ |
263 | ts.current_column = 0; | 263 | ts.current_column = 0; |
264 | ts.kRep = ds->getKeys(); | 264 | ts.kRep = ds->getKeys(); |
265 | browseView->rebuildKeys(); | 265 | browseView->rebuildKeys(); |
266 | listView->rebuildKeys(); | 266 | listView->rebuildKeys(); |
267 | filterView->rebuildKeys(); | 267 | filterView->rebuildKeys(); |
268 | 268 | ||
269 | ds->first(); | 269 | ds->first(); |
270 | /* set up the list view */ | 270 | /* set up the list view */ |
271 | listView->clearItems(); | 271 | listView->clearItems(); |
272 | do { | 272 | do { |
273 | d = ds->getCurrentData(); | 273 | d = ds->getCurrentData(); |
274 | if(d) | 274 | if(d) |
275 | listView->addItem(d); | 275 | listView->addItem(d); |
276 | } while(ds->next()); | 276 | } while(ds->next()); |
277 | 277 | ||
278 | /* Set up browse view, Will be based of structure of listView */ | 278 | /* Set up browse view, Will be based of structure of listView */ |
279 | listView->first(); | 279 | listView->first(); |
280 | ts.current_elem = listView->getCurrentData(); | 280 | ts.current_elem = listView->getCurrentData(); |
281 | browseView->rebuildData(); | 281 | browseView->rebuildData(); |
282 | listView->rebuildData(); | 282 | listView->rebuildData(); |
283 | 283 | ||
284 | QString scratch = "Table Viewer";/* later take from constant */ | 284 | QString scratch = "Table Viewer";/* later take from constant */ |
285 | scratch += " - "; | 285 | scratch += " - "; |
286 | scratch += ds->getName(); | 286 | scratch += ds->getName(); |
287 | setCaption(tr(scratch)); | 287 | setCaption(tr(scratch)); |
288 | 288 | ||
289 | dirty = FALSE; | 289 | dirty = FALSE; |
290 | } else { | 290 | } else { |
291 | qWarning(tr("could not load Document")); | 291 | qWarning(tr("could not load Document")); |
292 | } | 292 | } |
293 | dev->close(); | 293 | dev->close(); |
294 | } | 294 | } |
295 | 295 | ||
296 | /*! | 296 | /*! |
297 | Moves to the first item of the current table | 297 | Moves to the first item of the current table |
298 | */ | 298 | */ |
299 | void TableViewerWindow::firstItem() | 299 | void TableViewerWindow::firstItem() |
300 | { | 300 | { |
301 | listView->first(); | 301 | listView->first(); |
302 | ts.current_elem = listView->getCurrentData(); | 302 | ts.current_elem = listView->getCurrentData(); |
303 | browseView->rebuildData(); | 303 | browseView->rebuildData(); |
304 | } | 304 | } |
305 | 305 | ||
306 | /*! | 306 | /*! |
307 | Moves to the lat item of the current table | 307 | Moves to the lat item of the current table |
308 | */ | 308 | */ |
309 | void TableViewerWindow::lastItem() | 309 | void TableViewerWindow::lastItem() |
310 | { | 310 | { |
311 | listView->last(); | 311 | listView->last(); |
312 | ts.current_elem = listView->getCurrentData(); | 312 | ts.current_elem = listView->getCurrentData(); |
313 | browseView->rebuildData(); | 313 | browseView->rebuildData(); |
314 | } | 314 | } |
315 | 315 | ||
316 | /*! | 316 | /*! |
317 | Moves to the next item of the current table | 317 | Moves to the next item of the current table |
318 | */ | 318 | */ |
319 | void TableViewerWindow::nextItem() | 319 | void TableViewerWindow::nextItem() |
320 | { | 320 | { |
321 | listView->next(); | 321 | listView->next(); |
322 | ts.current_elem = listView->getCurrentData(); | 322 | ts.current_elem = listView->getCurrentData(); |
323 | browseView->rebuildData(); | 323 | browseView->rebuildData(); |
324 | } | 324 | } |
325 | 325 | ||
326 | /*! | 326 | /*! |
327 | Moves to the previous item of the current table | 327 | Moves to the previous item of the current table |
328 | */ | 328 | */ |
329 | void TableViewerWindow::previousItem() | 329 | void TableViewerWindow::previousItem() |
330 | { | 330 | { |
331 | listView->previous(); | 331 | listView->previous(); |
332 | ts.current_elem = listView->getCurrentData(); | 332 | ts.current_elem = listView->getCurrentData(); |
333 | browseView->rebuildData(); | 333 | browseView->rebuildData(); |
334 | } | 334 | } |
335 | 335 | ||
336 | /*! | 336 | /*! |
337 | Raises the List View. This is a mode change for the application. | 337 | Raises the List View. This is a mode change for the application. |
338 | */ | 338 | */ |
339 | void TableViewerWindow::listViewSlot() | 339 | void TableViewerWindow::listViewSlot() |
340 | { | 340 | { |
341 | if(current_view == FilterState) | 341 | if(current_view == FilterState) |
342 | applyFilter(); | 342 | applyFilter(); |
343 | current_view = ListState; | 343 | current_view = ListState; |
344 | cw->raiseWidget(current_view); | 344 | cw->raiseWidget(current_view); |
345 | } | 345 | } |
346 | 346 | ||
347 | void TableViewerWindow::applyFilter() | 347 | void TableViewerWindow::applyFilter() |
348 | { | 348 | { |
349 | DataElem *d; | 349 | DataElem *d; |
350 | 350 | ||
351 | listView->clearItems(); | 351 | listView->clearItems(); |
352 | ds->first(); | 352 | ds->first(); |
353 | do { | 353 | do { |
354 | d = ds->getCurrentData(); | 354 | d = ds->getCurrentData(); |
355 | if(d) | 355 | if(d) |
356 | if(filterView->passesFilter(d)) | 356 | if(filterView->passesFilter(d)) |
357 | listView->addItem(d); | 357 | listView->addItem(d); |
358 | } while(ds->next()); | 358 | } while(ds->next()); |
359 | listView->first(); | 359 | listView->first(); |
360 | listView->rebuildData(); | 360 | listView->rebuildData(); |
361 | } | 361 | } |
362 | 362 | ||
363 | /*! | 363 | /*! |
364 | Raises the Browse View. This is a mode change for the application. | 364 | Raises the Browse View. This is a mode change for the application. |
365 | */ | 365 | */ |
366 | void TableViewerWindow::browseViewSlot() | 366 | void TableViewerWindow::browseViewSlot() |
367 | { | 367 | { |
368 | if(current_view == FilterState) | 368 | if(current_view == FilterState) |
369 | applyFilter(); | 369 | applyFilter(); |
370 | 370 | ||
371 | ts.current_elem = listView->getCurrentData(); | 371 | ts.current_elem = listView->getCurrentData(); |
372 | browseView->rebuildData(); | 372 | browseView->rebuildData(); |
373 | 373 | ||
374 | current_view = BrowseState; | 374 | current_view = BrowseState; |
375 | cw->raiseWidget(current_view); | 375 | cw->raiseWidget(current_view); |
376 | } | 376 | } |
377 | 377 | ||
378 | /*! | 378 | /*! |
379 | Raises the List View. This is a mode change for the application. | 379 | Raises the List View. This is a mode change for the application. |
380 | */ | 380 | */ |
381 | void TableViewerWindow::filterViewSlot() | 381 | void TableViewerWindow::filterViewSlot() |
382 | { | 382 | { |
383 | current_view = FilterState; | 383 | current_view = FilterState; |
384 | cw->raiseWidget(current_view); | 384 | cw->raiseWidget(current_view); |
385 | } | 385 | } |
386 | 386 | ||
387 | 387 | ||
388 | 388 | ||
389 | 389 | ||
390 | void TableViewerWindow::editItemSlot() | 390 | void TableViewerWindow::editItemSlot() |
391 | { | 391 | { |
392 | if(TVEditView::openEditItemDialog(&ts, ts.current_elem, this)) { | 392 | if(TVEditView::openEditItemDialog(&ts, ts.current_elem, this)) { |
393 | listView->rebuildData(); | 393 | listView->rebuildData(); |
394 | browseView->rebuildData(); | 394 | browseView->rebuildData(); |
395 | dirty = TRUE; | 395 | dirty = TRUE; |
396 | } | 396 | } |
397 | } | 397 | } |
398 | 398 | ||
399 | void TableViewerWindow::newItemSlot() | 399 | void TableViewerWindow::newItemSlot() |
400 | { | 400 | { |
401 | DataElem *d = new DataElem(ds); | 401 | DataElem *d = new DataElem(ds); |
402 | if (TVEditView::openEditItemDialog(&ts, d, this)) { | 402 | if (TVEditView::openEditItemDialog(&ts, d, this)) { |
403 | 403 | ||
404 | ds->addItem(d); | 404 | ds->addItem(d); |
405 | ts.current_elem = d; | 405 | ts.current_elem = d; |
406 | applyFilter(); | 406 | applyFilter(); |
407 | listView->rebuildData(); | 407 | listView->rebuildData(); |
408 | browseView->rebuildData(); | 408 | browseView->rebuildData(); |
409 | dirty = TRUE; | 409 | dirty = TRUE; |
410 | } | 410 | } |
411 | } | 411 | } |
412 | 412 | ||
413 | void TableViewerWindow::deleteItemSlot() | 413 | void TableViewerWindow::deleteItemSlot() |
414 | { | 414 | { |
415 | /* delete the actual item, then do a 'filter' */ | 415 | /* delete the actual item, then do a 'filter' */ |
416 | DataElem *to_remove = ts.current_elem; | 416 | DataElem *to_remove = ts.current_elem; |
417 | 417 | ||
418 | if(!to_remove) | 418 | if(!to_remove) |
419 | return; | 419 | return; |
420 | 420 | ||
421 | listView->removeItem(); | 421 | listView->removeItem(); |
422 | ds->removeItem(to_remove); | 422 | ds->removeItem(to_remove); |
423 | 423 | ||
424 | applyFilter(); | 424 | applyFilter(); |
425 | listView->rebuildData(); | 425 | listView->rebuildData(); |
426 | browseView->rebuildData(); | 426 | browseView->rebuildData(); |
427 | dirty = TRUE; | 427 | dirty = TRUE; |
428 | } | 428 | } |
429 | 429 | ||
430 | void TableViewerWindow::editKeysSlot() | 430 | void TableViewerWindow::editKeysSlot() |
431 | { | 431 | { |
432 | DataElem *d; | 432 | DataElem *d; |
433 | KeyList *k = TVKeyEdit::openEditKeysDialog(&ts, this); | 433 | KeyList *k = TVKeyEdit::openEditKeysDialog(&ts, this); |
434 | 434 | ||
435 | if(k) { | 435 | if(k) { |
436 | /* set as new keys */ | 436 | /* set as new keys */ |
437 | ds->setKeys(k); | 437 | ds->setKeys(k); |
438 | 438 | ||
439 | ts.current_column = 0; | 439 | ts.current_column = 0; |
440 | ts.kRep = k; | 440 | ts.kRep = k; |
441 | 441 | ||
442 | browseView->reset(); | 442 | browseView->reset(); |
443 | listView->reset(); | 443 | listView->reset(); |
444 | filterView->reset(); | 444 | filterView->reset(); |
445 | 445 | ||
446 | browseView->rebuildKeys(); | 446 | browseView->rebuildKeys(); |
447 | listView->rebuildKeys(); | 447 | listView->rebuildKeys(); |
448 | filterView->rebuildKeys(); | 448 | filterView->rebuildKeys(); |
449 | 449 | ||
450 | ds->first(); | 450 | ds->first(); |
451 | /* set up the list view */ | 451 | /* set up the list view */ |
452 | listView->clearItems(); | 452 | listView->clearItems(); |
453 | do { | 453 | do { |
454 | d = ds->getCurrentData(); | 454 | d = ds->getCurrentData(); |
455 | if(d) | 455 | if(d) |
456 | listView->addItem(d); | 456 | listView->addItem(d); |
457 | } while(ds->next()); | 457 | } while(ds->next()); |
458 | 458 | ||
459 | /* Set up browse view, Will be based of structure of listView */ | 459 | /* Set up browse view, Will be based of structure of listView */ |
460 | dirty = TRUE; | 460 | dirty = TRUE; |
461 | } | 461 | } |
462 | } | 462 | } |
463 | 463 | ||
464 | /*! | 464 | /*! |
465 | A Slot that allows for widgets above to indicate a search should be | 465 | A Slot that allows for widgets above to indicate a search should be |
466 | done on a specified key index for a specified value | 466 | done on a specified key index for a specified value |
467 | */ | 467 | */ |
468 | void TableViewerWindow::searchOnKey(int i, TVVariant v) | 468 | void TableViewerWindow::searchOnKey(int i, TVVariant v) |
469 | { | 469 | { |
470 | listView->findItem(i, v); | 470 | listView->findItem(i, v); |
471 | ts.current_elem = listView->getCurrentData(); | 471 | ts.current_elem = listView->getCurrentData(); |
472 | browseView->rebuildData(); | 472 | browseView->rebuildData(); |
473 | } | 473 | } |
474 | 474 | ||
475 | void TableViewerWindow::setPrimaryKey(int i) | 475 | void TableViewerWindow::setPrimaryKey(int i) |
476 | { | 476 | { |
477 | ts.current_column = i; | 477 | ts.current_column = i; |
478 | listView->rebuildData(); | 478 | listView->rebuildData(); |
479 | browseView->rebuildData(); | 479 | browseView->rebuildData(); |
480 | } | 480 | } |
diff --git a/noncore/apps/tinykate/libkate/view/kateviewdialog.cpp b/noncore/apps/tinykate/libkate/view/kateviewdialog.cpp index 8e68262..c3a0a2e 100644 --- a/noncore/apps/tinykate/libkate/view/kateviewdialog.cpp +++ b/noncore/apps/tinykate/libkate/view/kateviewdialog.cpp | |||
@@ -1,561 +1,563 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | kateviewdialog.cpp - description | 2 | kateviewdialog.cpp - description |
3 | ------------------- | 3 | ------------------- |
4 | copyright : (C) 2001 by The Kate Team | 4 | copyright : (C) 2001 by The Kate Team |
5 | (C) 2002 by Joseph Wenninger | 5 | (C) 2002 by Joseph Wenninger |
6 | email : kwrite-devel@kde.org | 6 | email : kwrite-devel@kde.org |
7 | jowenn@kde.org | 7 | jowenn@kde.org |
8 | 8 | ||
9 | ***************************************************************************/ | 9 | ***************************************************************************/ |
10 | 10 | ||
11 | /*************************************************************************** | 11 | /*************************************************************************** |
12 | * * | 12 | * * |
13 | * This program is free software; you can redistribute it and/or modify * | 13 | * This program is free software; you can redistribute it and/or modify * |
14 | * it under the terms of the GNU General Public License as published by * | 14 | * it under the terms of the GNU General Public License as published by * |
15 | * the Free Software Foundation; either version 2 of the License, or * | 15 | * the Free Software Foundation; either version 2 of the License, or * |
16 | * (at your option) any later version. * | 16 | * (at your option) any later version. * |
17 | * * | 17 | * * |
18 | ***************************************************************************/ | 18 | ***************************************************************************/ |
19 | // Dialogs | 19 | // Dialogs |
20 | 20 | ||
21 | #include <stdio.h> | 21 | #include <stdio.h> |
22 | #include <stdlib.h> | 22 | #include <stdlib.h> |
23 | 23 | ||
24 | #include <qgrid.h> | 24 | #include <qgrid.h> |
25 | #include <qlabel.h> | 25 | #include <qlabel.h> |
26 | #include <qlayout.h> | 26 | #include <qlayout.h> |
27 | #include <qlistbox.h> | 27 | #include <qlistbox.h> |
28 | #include <qgroupbox.h> | 28 | #include <qgroupbox.h> |
29 | #include <qlineedit.h> | 29 | #include <qlineedit.h> |
30 | #include <qcheckbox.h> | 30 | #include <qcheckbox.h> |
31 | #include <qcollection.h> | 31 | #include <qcollection.h> |
32 | #include <qpushbutton.h> | 32 | #include <qpushbutton.h> |
33 | #include <qobjectlist.h> | 33 | #include <qobjectlist.h> |
34 | #include <qradiobutton.h> | 34 | #include <qradiobutton.h> |
35 | #include <qwhatsthis.h> | 35 | #include <qwhatsthis.h> |
36 | #include <qstringlist.h> | 36 | #include <qstringlist.h> |
37 | #include <klocale.h> | 37 | #include <klocale.h> |
38 | #include <kcolorbtn.h> | 38 | #include <kcolorbtn.h> |
39 | #include <kglobal.h> | 39 | #include <kglobal.h> |
40 | #include <qvbox.h> | 40 | #include <qvbox.h> |
41 | #include <qspinbox.h> | 41 | #include <qspinbox.h> |
42 | #include <qcombobox.h> | 42 | #include <qcombobox.h> |
43 | #include <kfontdialog.h> | 43 | #include <kfontdialog.h> |
44 | 44 | ||
45 | #include "../document/katedocument.h" | 45 | #include "../document/katedocument.h" |
46 | #include "kateviewdialog.h" | 46 | #include "kateviewdialog.h" |
47 | #include <opie2/ofontselector.h> | 47 | #include <opie2/ofontselector.h> |
48 | 48 | ||
49 | 49 | ||
50 | using namespace Opie::Ui; | ||
51 | using namespace Opie::Ui; | ||
50 | SearchDialog::SearchDialog( QWidget *parent, QStringList &searchFor, QStringList &replaceWith, int flags ) | 52 | SearchDialog::SearchDialog( QWidget *parent, QStringList &searchFor, QStringList &replaceWith, int flags ) |
51 | : KDialogBase( parent, 0L, true, i18n( "Find Text" ), Ok | Cancel, Ok ) | 53 | : KDialogBase( parent, 0L, true, i18n( "Find Text" ), Ok | Cancel, Ok ) |
52 | , m_replace( 0L ) | 54 | , m_replace( 0L ) |
53 | { | 55 | { |
54 | QWidget *page = new QWidget( this ); | 56 | QWidget *page = new QWidget( this ); |
55 | setMainWidget( page ); | 57 | setMainWidget( page ); |
56 | 58 | ||
57 | QVBoxLayout *topLayout = new QVBoxLayout( page, 0, spacingHint() ); | 59 | QVBoxLayout *topLayout = new QVBoxLayout( page, 0, spacingHint() ); |
58 | 60 | ||
59 | m_search = new QComboBox( true, page ); | 61 | m_search = new QComboBox( true, page ); |
60 | m_search->insertStringList( searchFor ); | 62 | m_search->insertStringList( searchFor ); |
61 | m_search->setMinimumWidth( m_search->sizeHint().width() ); | 63 | m_search->setMinimumWidth( m_search->sizeHint().width() ); |
62 | m_search->lineEdit()->selectAll(); | 64 | m_search->lineEdit()->selectAll(); |
63 | QLabel *label = new QLabel( m_search, i18n( "&Text To Find:" ), page ); | 65 | QLabel *label = new QLabel( m_search, i18n( "&Text To Find:" ), page ); |
64 | m_optRegExp = new QCheckBox( i18n( "Regular Expression" ), page ); | 66 | m_optRegExp = new QCheckBox( i18n( "Regular Expression" ), page ); |
65 | topLayout->addWidget( label ); | 67 | topLayout->addWidget( label ); |
66 | topLayout->addWidget( m_search ); | 68 | topLayout->addWidget( m_search ); |
67 | topLayout->addWidget( m_optRegExp ); | 69 | topLayout->addWidget( m_optRegExp ); |
68 | 70 | ||
69 | if( flags & KateView::sfReplace ) | 71 | if( flags & KateView::sfReplace ) |
70 | { | 72 | { |
71 | // make it a replace dialog | 73 | // make it a replace dialog |
72 | setCaption( i18n( "Replace Text" ) ); | 74 | setCaption( i18n( "Replace Text" ) ); |
73 | m_replace = new QComboBox( true, page ); | 75 | m_replace = new QComboBox( true, page ); |
74 | m_replace->insertStringList( replaceWith ); | 76 | m_replace->insertStringList( replaceWith ); |
75 | m_replace->setMinimumWidth( m_search->sizeHint().width() ); | 77 | m_replace->setMinimumWidth( m_search->sizeHint().width() ); |
76 | label = new QLabel( m_replace, i18n( "&Replace With:" ), page ); | 78 | label = new QLabel( m_replace, i18n( "&Replace With:" ), page ); |
77 | //m_optPlaceholders = new QCheckBox( i18n( "&Use Placeholders" ), page ); | 79 | //m_optPlaceholders = new QCheckBox( i18n( "&Use Placeholders" ), page ); |
78 | topLayout->addWidget( label ); | 80 | topLayout->addWidget( label ); |
79 | topLayout->addWidget( m_replace ); | 81 | topLayout->addWidget( m_replace ); |
80 | //topLayout->addWidget( m_optPlaceholders ); | 82 | //topLayout->addWidget( m_optPlaceholders ); |
81 | } | 83 | } |
82 | 84 | ||
83 | QGroupBox *group = new QGroupBox( i18n( "Options" ), page ); | 85 | QGroupBox *group = new QGroupBox( i18n( "Options" ), page ); |
84 | topLayout->addWidget( group, 10 ); | 86 | topLayout->addWidget( group, 10 ); |
85 | 87 | ||
86 | QGridLayout *gbox = new QGridLayout( group, 5, 2, spacingHint() ); | 88 | QGridLayout *gbox = new QGridLayout( group, 5, 2, spacingHint() ); |
87 | gbox->addRowSpacing( 0, fontMetrics().lineSpacing() ); | 89 | gbox->addRowSpacing( 0, fontMetrics().lineSpacing() ); |
88 | gbox->setRowStretch( 4, 10 ); | 90 | gbox->setRowStretch( 4, 10 ); |
89 | 91 | ||
90 | m_opt1 = new QCheckBox( i18n( "C&ase Sensitive" ), group ); | 92 | m_opt1 = new QCheckBox( i18n( "C&ase Sensitive" ), group ); |
91 | gbox->addWidget( m_opt1, 1, 0 ); | 93 | gbox->addWidget( m_opt1, 1, 0 ); |
92 | 94 | ||
93 | m_opt2 = new QCheckBox(i18n("&Whole Words Only" ), group ); | 95 | m_opt2 = new QCheckBox(i18n("&Whole Words Only" ), group ); |
94 | gbox->addWidget( m_opt2, 2, 0 ); | 96 | gbox->addWidget( m_opt2, 2, 0 ); |
95 | 97 | ||
96 | m_opt3 = new QCheckBox(i18n("&From Beginning" ), group ); | 98 | m_opt3 = new QCheckBox(i18n("&From Beginning" ), group ); |
97 | gbox->addWidget( m_opt3, 3, 0 ); | 99 | gbox->addWidget( m_opt3, 3, 0 ); |
98 | 100 | ||
99 | m_opt4 = new QCheckBox(i18n("Find &Backwards" ), group ); | 101 | m_opt4 = new QCheckBox(i18n("Find &Backwards" ), group ); |
100 | gbox->addWidget( m_opt4, 1, 1 ); | 102 | gbox->addWidget( m_opt4, 1, 1 ); |
101 | 103 | ||
102 | m_opt5 = new QCheckBox(i18n("&Selected Text" ), group ); | 104 | m_opt5 = new QCheckBox(i18n("&Selected Text" ), group ); |
103 | gbox->addWidget( m_opt5, 2, 1 ); | 105 | gbox->addWidget( m_opt5, 2, 1 ); |
104 | 106 | ||
105 | m_opt1->setChecked( flags & KateView::sfCaseSensitive ); | 107 | m_opt1->setChecked( flags & KateView::sfCaseSensitive ); |
106 | m_opt2->setChecked( flags & KateView::sfWholeWords ); | 108 | m_opt2->setChecked( flags & KateView::sfWholeWords ); |
107 | m_opt3->setChecked( flags & KateView::sfFromBeginning ); | 109 | m_opt3->setChecked( flags & KateView::sfFromBeginning ); |
108 | m_optRegExp->setChecked( flags & KateView::sfRegularExpression ); | 110 | m_optRegExp->setChecked( flags & KateView::sfRegularExpression ); |
109 | m_opt4->setChecked( flags & KateView::sfBackward ); | 111 | m_opt4->setChecked( flags & KateView::sfBackward ); |
110 | m_opt5->setChecked( flags & KateView::sfSelected ); | 112 | m_opt5->setChecked( flags & KateView::sfSelected ); |
111 | 113 | ||
112 | if( m_replace ) | 114 | if( m_replace ) |
113 | { | 115 | { |
114 | m_opt6 = new QCheckBox( i18n( "&Prompt On Replace" ), group ); | 116 | m_opt6 = new QCheckBox( i18n( "&Prompt On Replace" ), group ); |
115 | m_opt6->setChecked( flags & KateView::sfPrompt ); | 117 | m_opt6->setChecked( flags & KateView::sfPrompt ); |
116 | gbox->addWidget( m_opt6, 3, 1 ); | 118 | gbox->addWidget( m_opt6, 3, 1 ); |
117 | } | 119 | } |
118 | 120 | ||
119 | m_search->setFocus(); | 121 | m_search->setFocus(); |
120 | } | 122 | } |
121 | 123 | ||
122 | QString SearchDialog::getSearchFor() | 124 | QString SearchDialog::getSearchFor() |
123 | { | 125 | { |
124 | return m_search->currentText(); | 126 | return m_search->currentText(); |
125 | } | 127 | } |
126 | 128 | ||
127 | QString SearchDialog::getReplaceWith() | 129 | QString SearchDialog::getReplaceWith() |
128 | { | 130 | { |
129 | return m_replace->currentText(); | 131 | return m_replace->currentText(); |
130 | } | 132 | } |
131 | 133 | ||
132 | int SearchDialog::getFlags() | 134 | int SearchDialog::getFlags() |
133 | { | 135 | { |
134 | int flags = 0; | 136 | int flags = 0; |
135 | 137 | ||
136 | if( m_opt1->isChecked() ) flags |= KateView::sfCaseSensitive; | 138 | if( m_opt1->isChecked() ) flags |= KateView::sfCaseSensitive; |
137 | if( m_opt2->isChecked() ) flags |= KateView::sfWholeWords; | 139 | if( m_opt2->isChecked() ) flags |= KateView::sfWholeWords; |
138 | if( m_opt3->isChecked() ) flags |= KateView::sfFromBeginning; | 140 | if( m_opt3->isChecked() ) flags |= KateView::sfFromBeginning; |
139 | if( m_opt4->isChecked() ) flags |= KateView::sfBackward; | 141 | if( m_opt4->isChecked() ) flags |= KateView::sfBackward; |
140 | if( m_opt5->isChecked() ) flags |= KateView::sfSelected; | 142 | if( m_opt5->isChecked() ) flags |= KateView::sfSelected; |
141 | if( m_optRegExp->isChecked() ) flags |= KateView::sfRegularExpression; | 143 | if( m_optRegExp->isChecked() ) flags |= KateView::sfRegularExpression; |
142 | if( m_replace ) | 144 | if( m_replace ) |
143 | { | 145 | { |
144 | if( m_opt6->isChecked() ) | 146 | if( m_opt6->isChecked() ) |
145 | flags |= KateView::sfPrompt; | 147 | flags |= KateView::sfPrompt; |
146 | 148 | ||
147 | flags |= KateView::sfReplace; | 149 | flags |= KateView::sfReplace; |
148 | } | 150 | } |
149 | 151 | ||
150 | return flags; | 152 | return flags; |
151 | } | 153 | } |
152 | 154 | ||
153 | void SearchDialog::slotOk() | 155 | void SearchDialog::slotOk() |
154 | { | 156 | { |
155 | if ( !m_search->currentText().isEmpty() ) | 157 | if ( !m_search->currentText().isEmpty() ) |
156 | { | 158 | { |
157 | if ( !m_optRegExp->isChecked() ) | 159 | if ( !m_optRegExp->isChecked() ) |
158 | { | 160 | { |
159 | accept(); | 161 | accept(); |
160 | } | 162 | } |
161 | else | 163 | else |
162 | { | 164 | { |
163 | // Check for a valid regular expression. | 165 | // Check for a valid regular expression. |
164 | 166 | ||
165 | QRegExp regExp( m_search->currentText() ); | 167 | QRegExp regExp( m_search->currentText() ); |
166 | 168 | ||
167 | if ( regExp.isValid() ) | 169 | if ( regExp.isValid() ) |
168 | accept(); | 170 | accept(); |
169 | } | 171 | } |
170 | } | 172 | } |
171 | } | 173 | } |
172 | 174 | ||
173 | void SearchDialog::setSearchText( const QString &searchstr ) | 175 | void SearchDialog::setSearchText( const QString &searchstr ) |
174 | { | 176 | { |
175 | m_search->insertItem( searchstr, 0 ); | 177 | m_search->insertItem( searchstr, 0 ); |
176 | m_search->setCurrentItem( 0 ); | 178 | m_search->setCurrentItem( 0 ); |
177 | m_search->lineEdit()->selectAll(); | 179 | m_search->lineEdit()->selectAll(); |
178 | } | 180 | } |
179 | 181 | ||
180 | // this dialog is not modal | 182 | // this dialog is not modal |
181 | ReplacePrompt::ReplacePrompt( QWidget *parent ) | 183 | ReplacePrompt::ReplacePrompt( QWidget *parent ) |
182 | : KDialogBase(parent, 0L, false, i18n( "Replace Text" ), | 184 | : KDialogBase(parent, 0L, false, i18n( "Replace Text" ), |
183 | User3 | User2 | User1 | Close, User3, true, | 185 | User3 | User2 | User1 | Close, User3, true, |
184 | i18n("&All"), i18n("&No"), i18n("&Yes")) { | 186 | i18n("&All"), i18n("&No"), i18n("&Yes")) { |
185 | 187 | ||
186 | QWidget *page = new QWidget(this); | 188 | QWidget *page = new QWidget(this); |
187 | setMainWidget(page); | 189 | setMainWidget(page); |
188 | 190 | ||
189 | QBoxLayout *topLayout = new QVBoxLayout( page, 0, spacingHint() ); | 191 | QBoxLayout *topLayout = new QVBoxLayout( page, 0, spacingHint() ); |
190 | QLabel *label = new QLabel(i18n("Replace this occurence?"),page); | 192 | QLabel *label = new QLabel(i18n("Replace this occurence?"),page); |
191 | topLayout->addWidget(label ); | 193 | topLayout->addWidget(label ); |
192 | } | 194 | } |
193 | 195 | ||
194 | void ReplacePrompt::slotUser1( void ) { // All | 196 | void ReplacePrompt::slotUser1( void ) { // All |
195 | done(KateView::srAll); | 197 | done(KateView::srAll); |
196 | } | 198 | } |
197 | 199 | ||
198 | void ReplacePrompt::slotUser2( void ) { // No | 200 | void ReplacePrompt::slotUser2( void ) { // No |
199 | done(KateView::srNo); | 201 | done(KateView::srNo); |
200 | } | 202 | } |
201 | 203 | ||
202 | void ReplacePrompt::slotUser3( void ) { // Yes | 204 | void ReplacePrompt::slotUser3( void ) { // Yes |
203 | accept(); | 205 | accept(); |
204 | } | 206 | } |
205 | 207 | ||
206 | void ReplacePrompt::done(int r) { | 208 | void ReplacePrompt::done(int r) { |
207 | setResult(r); | 209 | setResult(r); |
208 | emit clicked(); | 210 | emit clicked(); |
209 | } | 211 | } |
210 | 212 | ||
211 | void ReplacePrompt::closeEvent(QCloseEvent *) { | 213 | void ReplacePrompt::closeEvent(QCloseEvent *) { |
212 | reject(); | 214 | reject(); |
213 | } | 215 | } |
214 | 216 | ||
215 | GotoLineDialog::GotoLineDialog(QWidget *parent, int line, int max) | 217 | GotoLineDialog::GotoLineDialog(QWidget *parent, int line, int max) |
216 | : KDialogBase(parent, 0L, true, i18n("Goto Line"), Ok | Cancel, Ok) { | 218 | : KDialogBase(parent, 0L, true, i18n("Goto Line"), Ok | Cancel, Ok) { |
217 | 219 | ||
218 | QWidget *page = new QWidget(this); | 220 | QWidget *page = new QWidget(this); |
219 | setMainWidget(page); | 221 | setMainWidget(page); |
220 | 222 | ||
221 | QVBoxLayout *topLayout = new QVBoxLayout( page, 0, spacingHint() ); | 223 | QVBoxLayout *topLayout = new QVBoxLayout( page, 0, spacingHint() ); |
222 | e1 = new QSpinBox(page); | 224 | e1 = new QSpinBox(page); |
223 | e1->setMinValue(1); | 225 | e1->setMinValue(1); |
224 | e1->setMaxValue(max); | 226 | e1->setMaxValue(max); |
225 | e1->setValue((int)line); | 227 | e1->setValue((int)line); |
226 | 228 | ||
227 | QLabel *label = new QLabel( e1,i18n("&Goto Line:"), page ); | 229 | QLabel *label = new QLabel( e1,i18n("&Goto Line:"), page ); |
228 | topLayout->addWidget(label); | 230 | topLayout->addWidget(label); |
229 | topLayout->addWidget(e1); | 231 | topLayout->addWidget(e1); |
230 | topLayout->addSpacing(spacingHint()); // A little bit extra space | 232 | topLayout->addSpacing(spacingHint()); // A little bit extra space |
231 | topLayout->addStretch(10); | 233 | topLayout->addStretch(10); |
232 | e1->setFocus(); | 234 | e1->setFocus(); |
233 | } | 235 | } |
234 | 236 | ||
235 | int GotoLineDialog::getLine() { | 237 | int GotoLineDialog::getLine() { |
236 | return e1->value(); | 238 | return e1->value(); |
237 | } | 239 | } |
238 | 240 | ||
239 | const int IndentConfigTab::flags[] = {KateView::cfAutoIndent, KateView::cfSpaceIndent, | 241 | const int IndentConfigTab::flags[] = {KateView::cfAutoIndent, KateView::cfSpaceIndent, |
240 | KateView::cfBackspaceIndents,KateView::cfTabIndents, KateView::cfKeepIndentProfile, KateView::cfKeepExtraSpaces}; | 242 | KateView::cfBackspaceIndents,KateView::cfTabIndents, KateView::cfKeepIndentProfile, KateView::cfKeepExtraSpaces}; |
241 | 243 | ||
242 | IndentConfigTab::IndentConfigTab(QWidget *parent, KateView *view) | 244 | IndentConfigTab::IndentConfigTab(QWidget *parent, KateView *view) |
243 | : QWidget(parent, 0L) | 245 | : QWidget(parent, 0L) |
244 | { | 246 | { |
245 | QVBoxLayout *layout = new QVBoxLayout(this, 0, KDialog::spacingHint() ); | 247 | QVBoxLayout *layout = new QVBoxLayout(this, 0, KDialog::spacingHint() ); |
246 | int configFlags = view->config(); | 248 | int configFlags = view->config(); |
247 | 249 | ||
248 | opt[0] = new QCheckBox(i18n("&Auto Indent"), this); | 250 | opt[0] = new QCheckBox(i18n("&Auto Indent"), this); |
249 | layout->addWidget(opt[0], 0, AlignLeft); | 251 | layout->addWidget(opt[0], 0, AlignLeft); |
250 | opt[0]->setChecked(configFlags & flags[0]); | 252 | opt[0]->setChecked(configFlags & flags[0]); |
251 | 253 | ||
252 | opt[1] = new QCheckBox(i18n("Indent With &Spaces"), this); | 254 | opt[1] = new QCheckBox(i18n("Indent With &Spaces"), this); |
253 | layout->addWidget(opt[1], 0, AlignLeft); | 255 | layout->addWidget(opt[1], 0, AlignLeft); |
254 | opt[1]->setChecked(configFlags & flags[1]); | 256 | opt[1]->setChecked(configFlags & flags[1]); |
255 | 257 | ||
256 | opt[2] = new QCheckBox(i18n("&Backspace Key Indents"), this); | 258 | opt[2] = new QCheckBox(i18n("&Backspace Key Indents"), this); |
257 | layout->addWidget(opt[2], 0, AlignLeft); | 259 | layout->addWidget(opt[2], 0, AlignLeft); |
258 | opt[2]->setChecked(configFlags & flags[2]); | 260 | opt[2]->setChecked(configFlags & flags[2]); |
259 | 261 | ||
260 | opt[3] = new QCheckBox(i18n("&Tab Key Indents"), this); | 262 | opt[3] = new QCheckBox(i18n("&Tab Key Indents"), this); |
261 | layout->addWidget(opt[3], 0, AlignLeft); | 263 | layout->addWidget(opt[3], 0, AlignLeft); |
262 | opt[3]->setChecked(configFlags & flags[3]); | 264 | opt[3]->setChecked(configFlags & flags[3]); |
263 | 265 | ||
264 | opt[4] = new QCheckBox(i18n("Keep Indent &Profile"), this); | 266 | opt[4] = new QCheckBox(i18n("Keep Indent &Profile"), this); |
265 | layout->addWidget(opt[4], 0, AlignLeft); | 267 | layout->addWidget(opt[4], 0, AlignLeft); |
266 | // opt[4]->setChecked(configFlags & flags[4]); | 268 | // opt[4]->setChecked(configFlags & flags[4]); |
267 | opt[4]->setChecked(true); | 269 | opt[4]->setChecked(true); |
268 | opt[4]->hide(); | 270 | opt[4]->hide(); |
269 | 271 | ||
270 | opt[5] = new QCheckBox(i18n("&Keep Extra Spaces"), this); | 272 | opt[5] = new QCheckBox(i18n("&Keep Extra Spaces"), this); |
271 | layout->addWidget(opt[5], 0, AlignLeft); | 273 | layout->addWidget(opt[5], 0, AlignLeft); |
272 | opt[5]->setChecked(configFlags & flags[5]); | 274 | opt[5]->setChecked(configFlags & flags[5]); |
273 | 275 | ||
274 | layout->addStretch(); | 276 | layout->addStretch(); |
275 | 277 | ||
276 | // What is this? help | 278 | // What is this? help |
277 | QWhatsThis::add(opt[0], i18n("When <b>Auto indent</b> is on, KateView will indent new lines to equal the indent on the previous line.<p>If the previous line is blank, the nearest line above with text is used")); | 279 | QWhatsThis::add(opt[0], i18n("When <b>Auto indent</b> is on, KateView will indent new lines to equal the indent on the previous line.<p>If the previous line is blank, the nearest line above with text is used")); |
278 | QWhatsThis::add(opt[1], i18n("Check this if you want to indent with spaces rather than tabs.<br>A Tab will be converted to <u>Tab-width</u> as set in the <b>edit</b> options")); | 280 | QWhatsThis::add(opt[1], i18n("Check this if you want to indent with spaces rather than tabs.<br>A Tab will be converted to <u>Tab-width</u> as set in the <b>edit</b> options")); |
279 | QWhatsThis::add(opt[2], i18n("This allows the <b>backspace</b> key to be used to indent.")); | 281 | QWhatsThis::add(opt[2], i18n("This allows the <b>backspace</b> key to be used to indent.")); |
280 | QWhatsThis::add(opt[3], i18n("This allows the <b>tab</b> key to be used to indent.")); | 282 | QWhatsThis::add(opt[3], i18n("This allows the <b>tab</b> key to be used to indent.")); |
281 | QWhatsThis::add(opt[4], i18n("This retains current indentation settings for future documents.")); | 283 | QWhatsThis::add(opt[4], i18n("This retains current indentation settings for future documents.")); |
282 | QWhatsThis::add(opt[5], i18n("Indentations of more than the selected number of spaces will not be shortened.")); | 284 | QWhatsThis::add(opt[5], i18n("Indentations of more than the selected number of spaces will not be shortened.")); |
283 | } | 285 | } |
284 | 286 | ||
285 | void IndentConfigTab::getData(KateView *view) { | 287 | void IndentConfigTab::getData(KateView *view) { |
286 | int configFlags, z; | 288 | int configFlags, z; |
287 | 289 | ||
288 | configFlags = view->config(); | 290 | configFlags = view->config(); |
289 | for (z = 0; z < numFlags; z++) { | 291 | for (z = 0; z < numFlags; z++) { |
290 | configFlags &= ~flags[z]; | 292 | configFlags &= ~flags[z]; |
291 | if (opt[z]->isChecked()) configFlags |= flags[z]; | 293 | if (opt[z]->isChecked()) configFlags |= flags[z]; |
292 | } | 294 | } |
293 | view->setConfig(configFlags); | 295 | view->setConfig(configFlags); |
294 | } | 296 | } |
295 | 297 | ||
296 | const int SelectConfigTab::flags[] = {KateView::cfPersistent, KateView::cfDelOnInput, | 298 | const int SelectConfigTab::flags[] = {KateView::cfPersistent, KateView::cfDelOnInput, |
297 | KateView::cfMouseAutoCopy, KateView::cfSingleSelection, KateView::cfVerticalSelect, KateView::cfXorSelect}; | 299 | KateView::cfMouseAutoCopy, KateView::cfSingleSelection, KateView::cfVerticalSelect, KateView::cfXorSelect}; |
298 | 300 | ||
299 | SelectConfigTab::SelectConfigTab(QWidget *parent, KateView *view) | 301 | SelectConfigTab::SelectConfigTab(QWidget *parent, KateView *view) |
300 | : QWidget(parent, 0L) | 302 | : QWidget(parent, 0L) |
301 | { | 303 | { |
302 | QVBoxLayout *layout = new QVBoxLayout(this, 0, KDialog::spacingHint() ); | 304 | QVBoxLayout *layout = new QVBoxLayout(this, 0, KDialog::spacingHint() ); |
303 | int configFlags = view->config(); | 305 | int configFlags = view->config(); |
304 | 306 | ||
305 | opt[0] = new QCheckBox(i18n("&Persistent Selections"), this); | 307 | opt[0] = new QCheckBox(i18n("&Persistent Selections"), this); |
306 | layout->addWidget(opt[0], 0, AlignLeft); | 308 | layout->addWidget(opt[0], 0, AlignLeft); |
307 | opt[0]->setChecked(configFlags & flags[0]); | 309 | opt[0]->setChecked(configFlags & flags[0]); |
308 | 310 | ||
309 | opt[1] = new QCheckBox(i18n("&Overwrite Selections"), this); | 311 | opt[1] = new QCheckBox(i18n("&Overwrite Selections"), this); |
310 | layout->addWidget(opt[1], 0, AlignLeft); | 312 | layout->addWidget(opt[1], 0, AlignLeft); |
311 | opt[1]->setChecked(configFlags & flags[1]); | 313 | opt[1]->setChecked(configFlags & flags[1]); |
312 | 314 | ||
313 | opt[2] = new QCheckBox(i18n("Mouse &Autocopy"), this); | 315 | opt[2] = new QCheckBox(i18n("Mouse &Autocopy"), this); |
314 | layout->addWidget(opt[2], 0, AlignLeft); | 316 | layout->addWidget(opt[2], 0, AlignLeft); |
315 | opt[2]->setChecked(configFlags & flags[2]); | 317 | opt[2]->setChecked(configFlags & flags[2]); |
316 | 318 | ||
317 | opt[3] = new QCheckBox(i18n("&X11-like Single Selection"), this); | 319 | opt[3] = new QCheckBox(i18n("&X11-like Single Selection"), this); |
318 | layout->addWidget(opt[3], 0, AlignLeft); | 320 | layout->addWidget(opt[3], 0, AlignLeft); |
319 | opt[3]->setChecked(configFlags & flags[3]); | 321 | opt[3]->setChecked(configFlags & flags[3]); |
320 | 322 | ||
321 | opt[4] = new QCheckBox(i18n("&Vertical Selections"), this); | 323 | opt[4] = new QCheckBox(i18n("&Vertical Selections"), this); |
322 | layout->addWidget(opt[4], 0, AlignLeft); | 324 | layout->addWidget(opt[4], 0, AlignLeft); |
323 | opt[4]->setChecked(configFlags & flags[4]); | 325 | opt[4]->setChecked(configFlags & flags[4]); |
324 | 326 | ||
325 | opt[5] = new QCheckBox(i18n("&Toggle Old"), this); | 327 | opt[5] = new QCheckBox(i18n("&Toggle Old"), this); |
326 | layout->addWidget(opt[5], 0, AlignLeft); | 328 | layout->addWidget(opt[5], 0, AlignLeft); |
327 | opt[5]->setChecked(configFlags & flags[5]); | 329 | opt[5]->setChecked(configFlags & flags[5]); |
328 | 330 | ||
329 | layout->addStretch(); | 331 | layout->addStretch(); |
330 | 332 | ||
331 | // What is this? help | 333 | // What is this? help |
332 | QWhatsThis::add(opt[0], i18n("Enabling this prevents key input or cursor movement by way of the arrow keys from causing the elimination of text selection.<p><b>Note:</b> If the Overwrite Selections option is activated then any typed character input or paste operation will replace the selected text.")); | 334 | QWhatsThis::add(opt[0], i18n("Enabling this prevents key input or cursor movement by way of the arrow keys from causing the elimination of text selection.<p><b>Note:</b> If the Overwrite Selections option is activated then any typed character input or paste operation will replace the selected text.")); |
333 | QWhatsThis::add(opt[1], i18n("When this is on, any keyed character input or paste operation will replace the selected text.")); | 335 | QWhatsThis::add(opt[1], i18n("When this is on, any keyed character input or paste operation will replace the selected text.")); |
334 | QWhatsThis::add(opt[2], i18n("When this is on, any text selected with the mouse will be automatically copied to the clipboard.")); | 336 | QWhatsThis::add(opt[2], i18n("When this is on, any text selected with the mouse will be automatically copied to the clipboard.")); |
335 | QWhatsThis::add(opt[3], i18n("Not implemented yet.")); | 337 | QWhatsThis::add(opt[3], i18n("Not implemented yet.")); |
336 | QWhatsThis::add(opt[4], i18n("Enabling this allows you to make vertical selections.")); | 338 | QWhatsThis::add(opt[4], i18n("Enabling this allows you to make vertical selections.")); |
337 | QWhatsThis::add(opt[5], i18n("Not yet implemented.")); | 339 | QWhatsThis::add(opt[5], i18n("Not yet implemented.")); |
338 | } | 340 | } |
339 | 341 | ||
340 | void SelectConfigTab::getData(KateView *view) { | 342 | void SelectConfigTab::getData(KateView *view) { |
341 | int configFlags, z; | 343 | int configFlags, z; |
342 | 344 | ||
343 | configFlags = view->config(); | 345 | configFlags = view->config(); |
344 | for (z = 0; z < numFlags; z++) { | 346 | for (z = 0; z < numFlags; z++) { |
345 | configFlags &= ~flags[z]; // clear flag | 347 | configFlags &= ~flags[z]; // clear flag |
346 | if (opt[z]->isChecked()) configFlags |= flags[z]; // set flag if checked | 348 | if (opt[z]->isChecked()) configFlags |= flags[z]; // set flag if checked |
347 | } | 349 | } |
348 | view->setConfig(configFlags); | 350 | view->setConfig(configFlags); |
349 | } | 351 | } |
350 | 352 | ||
351 | const int EditConfigTab::flags[] = {KateView::cfWordWrap, KateView::cfReplaceTabs, KateView::cfRemoveSpaces, | 353 | const int EditConfigTab::flags[] = {KateView::cfWordWrap, KateView::cfReplaceTabs, KateView::cfRemoveSpaces, |
352 | KateView::cfAutoBrackets, KateView::cfGroupUndo, KateView::cfShowTabs, KateView::cfSmartHome, | 354 | KateView::cfAutoBrackets, KateView::cfGroupUndo, KateView::cfShowTabs, KateView::cfSmartHome, |
353 | KateView::cfPageUDMovesCursor, KateView::cfWrapCursor}; | 355 | KateView::cfPageUDMovesCursor, KateView::cfWrapCursor}; |
354 | 356 | ||
355 | EditConfigTab::EditConfigTab(QWidget *parent, KateView *view) | 357 | EditConfigTab::EditConfigTab(QWidget *parent, KateView *view) |
356 | : QWidget(parent, 0L) { | 358 | : QWidget(parent, 0L) { |
357 | 359 | ||
358 | QHBoxLayout *mainLayout; | 360 | QHBoxLayout *mainLayout; |
359 | QVBoxLayout *cbLayout, *leLayout; | 361 | QVBoxLayout *cbLayout, *leLayout; |
360 | int configFlags; | 362 | int configFlags; |
361 | 363 | ||
362 | mainLayout = new QHBoxLayout(this, 0, KDialog::spacingHint() ); | 364 | mainLayout = new QHBoxLayout(this, 0, KDialog::spacingHint() ); |
363 | 365 | ||
364 | // checkboxes | 366 | // checkboxes |
365 | cbLayout = new QVBoxLayout( mainLayout ); | 367 | cbLayout = new QVBoxLayout( mainLayout ); |
366 | configFlags = view->config(); | 368 | configFlags = view->config(); |
367 | 369 | ||
368 | opt[0] = new QCheckBox(i18n("&Word wrap"), this); | 370 | opt[0] = new QCheckBox(i18n("&Word wrap"), this); |
369 | cbLayout->addWidget(opt[0], 0, AlignLeft); | 371 | cbLayout->addWidget(opt[0], 0, AlignLeft); |
370 | opt[0]->setChecked(view->doc()->wordWrap()); | 372 | opt[0]->setChecked(view->doc()->wordWrap()); |
371 | 373 | ||
372 | opt[1] = new QCheckBox(i18n("Replace &tabs with spaces"), this); | 374 | opt[1] = new QCheckBox(i18n("Replace &tabs with spaces"), this); |
373 | cbLayout->addWidget(opt[1], 0, AlignLeft); | 375 | cbLayout->addWidget(opt[1], 0, AlignLeft); |
374 | opt[1]->setChecked(configFlags & flags[1]); | 376 | opt[1]->setChecked(configFlags & flags[1]); |
375 | 377 | ||
376 | opt[2] = new QCheckBox(i18n("&Remove trailing spaces"), this); | 378 | opt[2] = new QCheckBox(i18n("&Remove trailing spaces"), this); |
377 | cbLayout->addWidget(opt[2], 0, AlignLeft); | 379 | cbLayout->addWidget(opt[2], 0, AlignLeft); |
378 | opt[2]->setChecked(configFlags & flags[2]); | 380 | opt[2]->setChecked(configFlags & flags[2]); |
379 | 381 | ||
380 | opt[3] = new QCheckBox(i18n("&Auto brackets"), this); | 382 | opt[3] = new QCheckBox(i18n("&Auto brackets"), this); |
381 | cbLayout->addWidget(opt[3], 0, AlignLeft); | 383 | cbLayout->addWidget(opt[3], 0, AlignLeft); |
382 | opt[3]->setChecked(configFlags & flags[3]); | 384 | opt[3]->setChecked(configFlags & flags[3]); |
383 | 385 | ||
384 | opt[4] = new QCheckBox(i18n("Group &undos"), this); | 386 | opt[4] = new QCheckBox(i18n("Group &undos"), this); |
385 | cbLayout->addWidget(opt[4], 0, AlignLeft); | 387 | cbLayout->addWidget(opt[4], 0, AlignLeft); |
386 | opt[4]->setChecked(configFlags & flags[4]); | 388 | opt[4]->setChecked(configFlags & flags[4]); |
387 | 389 | ||
388 | opt[5] = new QCheckBox(i18n("&Show tabs"), this); | 390 | opt[5] = new QCheckBox(i18n("&Show tabs"), this); |
389 | cbLayout->addWidget(opt[5], 0, AlignLeft); | 391 | cbLayout->addWidget(opt[5], 0, AlignLeft); |
390 | opt[5]->setChecked(configFlags & flags[5]); | 392 | opt[5]->setChecked(configFlags & flags[5]); |
391 | 393 | ||
392 | opt[6] = new QCheckBox(i18n("Smart &home"), this); | 394 | opt[6] = new QCheckBox(i18n("Smart &home"), this); |
393 | cbLayout->addWidget(opt[6], 0, AlignLeft); | 395 | cbLayout->addWidget(opt[6], 0, AlignLeft); |
394 | opt[6]->setChecked(configFlags & flags[6]); | 396 | opt[6]->setChecked(configFlags & flags[6]); |
395 | 397 | ||
396 | opt[7] = new QCheckBox(i18n("&Page up/down moves cursor"), this); | 398 | opt[7] = new QCheckBox(i18n("&Page up/down moves cursor"), this); |
397 | cbLayout->addWidget(opt[7], 0, AlignLeft); | 399 | cbLayout->addWidget(opt[7], 0, AlignLeft); |
398 | opt[7]->setChecked(configFlags & flags[7]); | 400 | opt[7]->setChecked(configFlags & flags[7]); |
399 | 401 | ||
400 | opt[8] = new QCheckBox(i18n("Wrap &cursor"), this); | 402 | opt[8] = new QCheckBox(i18n("Wrap &cursor"), this); |
401 | cbLayout->addWidget(opt[8], 0, AlignLeft); | 403 | cbLayout->addWidget(opt[8], 0, AlignLeft); |
402 | opt[8]->setChecked(configFlags & flags[8]); | 404 | opt[8]->setChecked(configFlags & flags[8]); |
403 | 405 | ||
404 | cbLayout->addStretch(); | 406 | cbLayout->addStretch(); |
405 | 407 | ||
406 | // edit lines | 408 | // edit lines |
407 | leLayout = new QVBoxLayout(); | 409 | leLayout = new QVBoxLayout(); |
408 | mainLayout->addLayout(leLayout,10); | 410 | mainLayout->addLayout(leLayout,10); |
409 | 411 | ||
410 | e1 = new QSpinBox(this); | 412 | e1 = new QSpinBox(this); |
411 | e1->setMinValue(20); | 413 | e1->setMinValue(20); |
412 | e1->setMaxValue( 200); | 414 | e1->setMaxValue( 200); |
413 | e1->setValue((int)(view->doc()->wordWrapAt())); | 415 | e1->setValue((int)(view->doc()->wordWrapAt())); |
414 | #warning fixme e1->setLabel(i18n("Wrap Words At:")); | 416 | #warning fixme e1->setLabel(i18n("Wrap Words At:")); |
415 | 417 | ||
416 | e2 = new QSpinBox(this); | 418 | e2 = new QSpinBox(this); |
417 | e2->setMinValue(1); | 419 | e2->setMinValue(1); |
418 | e2->setMaxValue(16); | 420 | e2->setMaxValue(16); |
419 | e2->setValue((int)view->tabWidth()); | 421 | e2->setValue((int)view->tabWidth()); |
420 | 422 | ||
421 | #warning fixme e2->setLabel(i18n("Tab/Indent Width:")); | 423 | #warning fixme e2->setLabel(i18n("Tab/Indent Width:")); |
422 | 424 | ||
423 | e3 = new QSpinBox(this); | 425 | e3 = new QSpinBox(this); |
424 | e3->setMinValue(5); | 426 | e3->setMinValue(5); |
425 | e3->setMaxValue( 30000); | 427 | e3->setMaxValue( 30000); |
426 | #warning fixme e3->setLabel(i18n("Undo steps:")); | 428 | #warning fixme e3->setLabel(i18n("Undo steps:")); |
427 | e3->setValue((int)view->undoSteps()); | 429 | e3->setValue((int)view->undoSteps()); |
428 | 430 | ||
429 | leLayout->addWidget(e1, 0, AlignLeft); | 431 | leLayout->addWidget(e1, 0, AlignLeft); |
430 | leLayout->addWidget(e2, 0, AlignLeft); | 432 | leLayout->addWidget(e2, 0, AlignLeft); |
431 | leLayout->addWidget(e3, 0, AlignLeft); | 433 | leLayout->addWidget(e3, 0, AlignLeft); |
432 | 434 | ||
433 | 435 | ||
434 | QVBox *box = new QVBox (this); | 436 | QVBox *box = new QVBox (this); |
435 | leLayout->addWidget (box, 0, AlignLeft); | 437 | leLayout->addWidget (box, 0, AlignLeft); |
436 | 438 | ||
437 | new QLabel (i18n("Encoding:"), box); | 439 | new QLabel (i18n("Encoding:"), box); |
438 | 440 | ||
439 | encoding = new QComboBox(box); | 441 | encoding = new QComboBox(box); |
440 | #warning fixme | 442 | #warning fixme |
441 | #if 0 | 443 | #if 0 |
442 | encoding->insertStringList (KGlobal::charsets()->availableEncodingNames()); | 444 | encoding->insertStringList (KGlobal::charsets()->availableEncodingNames()); |
443 | encoding->setCurrentItem (KGlobal::charsets()->availableEncodingNames().findIndex(view->doc()->encoding())); | 445 | encoding->setCurrentItem (KGlobal::charsets()->availableEncodingNames().findIndex(view->doc()->encoding())); |
444 | #endif | 446 | #endif |
445 | leLayout->addStretch(); | 447 | leLayout->addStretch(); |
446 | 448 | ||
447 | // What is this? help | 449 | // What is this? help |
448 | QWhatsThis::add(opt[0], i18n("Word wrap is a feature that causes the editor to automatically start a new line of text and move (wrap) the cursor to the beginning of that new line. KateView will automatically start a new line of text when the current line reaches the length specified by the Wrap Words At: option.<p><b>NOTE:<b> Word Wrap will not change existing lines or wrap them for easy reading as in some applications.")); | 450 | QWhatsThis::add(opt[0], i18n("Word wrap is a feature that causes the editor to automatically start a new line of text and move (wrap) the cursor to the beginning of that new line. KateView will automatically start a new line of text when the current line reaches the length specified by the Wrap Words At: option.<p><b>NOTE:<b> Word Wrap will not change existing lines or wrap them for easy reading as in some applications.")); |
449 | QWhatsThis::add(e1, i18n("If the Word Wrap option is selected this entry determines the length (in characters) at which the editor will automatically start a new line.")); | 451 | QWhatsThis::add(e1, i18n("If the Word Wrap option is selected this entry determines the length (in characters) at which the editor will automatically start a new line.")); |
450 | QWhatsThis::add(opt[1], i18n("KateView will replace any tabs with the number of spaces indicated in the Tab Width: entry.")); | 452 | QWhatsThis::add(opt[1], i18n("KateView will replace any tabs with the number of spaces indicated in the Tab Width: entry.")); |
451 | QWhatsThis::add(e2, i18n("If the Replace Tabs By Spaces option is selected this entry determines the number of spaces with which the editor will automatically replace tabs.")); | 453 | QWhatsThis::add(e2, i18n("If the Replace Tabs By Spaces option is selected this entry determines the number of spaces with which the editor will automatically replace tabs.")); |
452 | QWhatsThis::add(opt[2], i18n("KateView will automatically eliminate extra spaces at the ends of lines of text.")); | 454 | QWhatsThis::add(opt[2], i18n("KateView will automatically eliminate extra spaces at the ends of lines of text.")); |
453 | QWhatsThis::add(opt[3], i18n("When the user types a left bracket ([,(, or {) KateView automatically enters the right bracket (}, ), or ]) to the right of the cursor.")); | 455 | QWhatsThis::add(opt[3], i18n("When the user types a left bracket ([,(, or {) KateView automatically enters the right bracket (}, ), or ]) to the right of the cursor.")); |
454 | QWhatsThis::add(opt[4], i18n("Checking this will cause sequences of similar actions to be undone at once.")); | 456 | QWhatsThis::add(opt[4], i18n("Checking this will cause sequences of similar actions to be undone at once.")); |
455 | QWhatsThis::add(opt[5], i18n("The editor will display a symbol to indicate the presence of a tab in the text.")); | 457 | QWhatsThis::add(opt[5], i18n("The editor will display a symbol to indicate the presence of a tab in the text.")); |
456 | QWhatsThis::add(opt[6], i18n("Not yet implemented.")); | 458 | QWhatsThis::add(opt[6], i18n("Not yet implemented.")); |
457 | QWhatsThis::add(opt[7], i18n("If this is selected, the insertion cursor will be moved to the first/last line when pressing the page up/down buttons.<p>If not selected, it will remain at it's relative position in the visible text.")); | 459 | QWhatsThis::add(opt[7], i18n("If this is selected, the insertion cursor will be moved to the first/last line when pressing the page up/down buttons.<p>If not selected, it will remain at it's relative position in the visible text.")); |
458 | QWhatsThis::add(e3, i18n("Sets the number of undo/redo steps to record. More steps uses more memory.")); | 460 | QWhatsThis::add(e3, i18n("Sets the number of undo/redo steps to record. More steps uses more memory.")); |
459 | QWhatsThis::add(opt[8], i18n("When on, moving the insertion cursor using the <b>Left</b> and <b>Right</b> keys will go on to previous/next line at beginning/end of the line, similar to most editors.<p>When off, the insertion cursor cannot be moved left of the line start, but it can be moved off the line end, which can be very handy for programmers.")); | 461 | QWhatsThis::add(opt[8], i18n("When on, moving the insertion cursor using the <b>Left</b> and <b>Right</b> keys will go on to previous/next line at beginning/end of the line, similar to most editors.<p>When off, the insertion cursor cannot be moved left of the line start, but it can be moved off the line end, which can be very handy for programmers.")); |
460 | } | 462 | } |
461 | 463 | ||
462 | void EditConfigTab::getData(KateView *view) | 464 | void EditConfigTab::getData(KateView *view) |
463 | { | 465 | { |
464 | int configFlags, z; | 466 | int configFlags, z; |
465 | 467 | ||
466 | configFlags = view->config(); | 468 | configFlags = view->config(); |
467 | for (z = 1; z < numFlags; z++) { | 469 | for (z = 1; z < numFlags; z++) { |
468 | configFlags &= ~flags[z]; | 470 | configFlags &= ~flags[z]; |
469 | if (opt[z]->isChecked()) configFlags |= flags[z]; | 471 | if (opt[z]->isChecked()) configFlags |= flags[z]; |
470 | } | 472 | } |
471 | view->setConfig(configFlags); | 473 | view->setConfig(configFlags); |
472 | 474 | ||
473 | view->setEncoding (encoding->currentText()); | 475 | view->setEncoding (encoding->currentText()); |
474 | view->doc()->setWordWrapAt(e1->value()); | 476 | view->doc()->setWordWrapAt(e1->value()); |
475 | view->doc()->setWordWrap (opt[0]->isChecked()); | 477 | view->doc()->setWordWrap (opt[0]->isChecked()); |
476 | view->setTabWidth(e2->value()); | 478 | view->setTabWidth(e2->value()); |
477 | view->setUndoSteps(e3->value()); | 479 | view->setUndoSteps(e3->value()); |
478 | } | 480 | } |
479 | 481 | ||
480 | ColorConfig::ColorConfig( QWidget *parent, char *name ) | 482 | ColorConfig::ColorConfig( QWidget *parent, char *name ) |
481 | : QWidget( parent, name ) | 483 | : QWidget( parent, name ) |
482 | { | 484 | { |
483 | QGridLayout *glay = new QGridLayout( this, 6, 2, 0, KDialog::spacingHint()); | 485 | QGridLayout *glay = new QGridLayout( this, 6, 2, 0, KDialog::spacingHint()); |
484 | glay->setColStretch(1,1); | 486 | glay->setColStretch(1,1); |
485 | glay->setRowStretch(5,1); | 487 | glay->setRowStretch(5,1); |
486 | 488 | ||
487 | QLabel *label; | 489 | QLabel *label; |
488 | 490 | ||
489 | label = new QLabel( i18n("Background:"), this); | 491 | label = new QLabel( i18n("Background:"), this); |
490 | label->setAlignment( AlignRight|AlignVCenter ); | 492 | label->setAlignment( AlignRight|AlignVCenter ); |
491 | m_back = new KColorButton( this ); | 493 | m_back = new KColorButton( this ); |
492 | glay->addWidget( label, 0, 0 ); | 494 | glay->addWidget( label, 0, 0 ); |
493 | glay->addWidget( m_back, 0, 1 ); | 495 | glay->addWidget( m_back, 0, 1 ); |
494 | 496 | ||
495 | label = new QLabel( i18n("Selected:"), this); | 497 | label = new QLabel( i18n("Selected:"), this); |
496 | label->setAlignment( AlignRight|AlignVCenter ); | 498 | label->setAlignment( AlignRight|AlignVCenter ); |
497 | m_selected = new KColorButton( this ); | 499 | m_selected = new KColorButton( this ); |
498 | glay->addWidget( label, 2, 0 ); | 500 | glay->addWidget( label, 2, 0 ); |
499 | glay->addWidget( m_selected, 2, 1 ); | 501 | glay->addWidget( m_selected, 2, 1 ); |
500 | 502 | ||
501 | // QWhatsThis help | 503 | // QWhatsThis help |
502 | QWhatsThis::add(m_back, i18n("Sets the background color of the editing area")); | 504 | QWhatsThis::add(m_back, i18n("Sets the background color of the editing area")); |
503 | QWhatsThis::add(m_selected, i18n("Sets the background color of the selection. To set the text color for selected text, use the "<b>Configure Highlighting</b>" dialog.")); | 505 | QWhatsThis::add(m_selected, i18n("Sets the background color of the selection. To set the text color for selected text, use the "<b>Configure Highlighting</b>" dialog.")); |
504 | } | 506 | } |
505 | 507 | ||
506 | 508 | ||
507 | ColorConfig::~ColorConfig() | 509 | ColorConfig::~ColorConfig() |
508 | { | 510 | { |
509 | } | 511 | } |
510 | 512 | ||
511 | void ColorConfig::setColors(QColor *colors) | 513 | void ColorConfig::setColors(QColor *colors) |
512 | { | 514 | { |
513 | m_back->setColor( colors[0] ); | 515 | m_back->setColor( colors[0] ); |
514 | m_selected->setColor( colors[1] ); | 516 | m_selected->setColor( colors[1] ); |
515 | } | 517 | } |
516 | 518 | ||
517 | void ColorConfig::getColors(QColor *colors) | 519 | void ColorConfig::getColors(QColor *colors) |
518 | { | 520 | { |
519 | colors[0] = m_back->color(); | 521 | colors[0] = m_back->color(); |
520 | colors[1] = m_selected->color(); | 522 | colors[1] = m_selected->color(); |
521 | } | 523 | } |
522 | 524 | ||
523 | FontConfig::FontConfig( QWidget *parent, char *name ) | 525 | FontConfig::FontConfig( QWidget *parent, char *name ) |
524 | : QWidget( parent, name ) | 526 | : QWidget( parent, name ) |
525 | { | 527 | { |
526 | // sizemanagment | 528 | // sizemanagment |
527 | QGridLayout *grid = new QGridLayout( this, 1, 1 ); | 529 | QGridLayout *grid = new QGridLayout( this, 1, 1 ); |
528 | // QString familyStr = cfg. readEntry ( "FontFamily", "Helvetica" ); | 530 | // QString familyStr = cfg. readEntry ( "FontFamily", "Helvetica" ); |
529 | // QString styleStr = cfg. readEntry ( "FontStyle", "Regular" ); | 531 | // QString styleStr = cfg. readEntry ( "FontStyle", "Regular" ); |
530 | // int size = cfg. readNumEntry ( "FontSize", 10 ); | 532 | // int size = cfg. readNumEntry ( "FontSize", 10 ); |
531 | // OFontSelector *m_fontselect; | 533 | // OFontSelector *m_fontselect; |
532 | 534 | ||
533 | m_fontselect = new Opie::OFontSelector ( false, this, "FontTab" ); | 535 | m_fontselect = new Opie::OFontSelector ( false, this, "FontTab" ); |
534 | // m_fontselect-> setSelectedFont ( familyStr, styleStr, size ); | 536 | // m_fontselect-> setSelectedFont ( familyStr, styleStr, size ); |
535 | // QWhatsThis::add( m_fontselect, | 537 | // QWhatsThis::add( m_fontselect, |
536 | // tr( "Select the desired name, style and size of the default font applications will use." ) ); | 538 | // tr( "Select the desired name, style and size of the default font applications will use." ) ); |
537 | 539 | ||
538 | connect( m_fontselect, SIGNAL( fontSelected(const QFont&)), | 540 | connect( m_fontselect, SIGNAL( fontSelected(const QFont&)), |
539 | this, SLOT( slotFontSelected(const QFont&))); | 541 | this, SLOT( slotFontSelected(const QFont&))); |
540 | grid->addWidget( m_fontselect, 0, 0); | 542 | grid->addWidget( m_fontselect, 0, 0); |
541 | 543 | ||
542 | 544 | ||
543 | // #if 0 | 545 | // #if 0 |
544 | // m_fontchooser = new KFontChooser ( this ); | 546 | // m_fontchooser = new KFontChooser ( this ); |
545 | // m_fontchooser->enableColumn(KFontChooser::StyleList, false); | 547 | // m_fontchooser->enableColumn(KFontChooser::StyleList, false); |
546 | // grid->addWidget( m_fontchooser, 0, 0); | 548 | // grid->addWidget( m_fontchooser, 0, 0); |
547 | 549 | ||
548 | // connect (m_fontchooser, SIGNAL (fontSelected(const QFont&)), this, SLOT (slotFontSelected(const QFont&))); | 550 | // connect (m_fontchooser, SIGNAL (fontSelected(const QFont&)), this, SLOT (slotFontSelected(const QFont&))); |
549 | // #endif | 551 | // #endif |
550 | } | 552 | } |
551 | 553 | ||
552 | FontConfig::~FontConfig() | 554 | FontConfig::~FontConfig() |
553 | { | 555 | { |
554 | } | 556 | } |
555 | 557 | ||
556 | void FontConfig::setFont ( const QFont &font ) | 558 | void FontConfig::setFont ( const QFont &font ) |
557 | { | 559 | { |
558 | //#if 0 | 560 | //#if 0 |
559 | m_fontselect->setFont (font); | 561 | m_fontselect->setFont (font); |
560 | myFont = font; | 562 | myFont = font; |
561 | //#endif | 563 | //#endif |
diff --git a/noncore/apps/tinykate/libkate/view/kateviewdialog.h b/noncore/apps/tinykate/libkate/view/kateviewdialog.h index 98d8799..d081152 100644 --- a/noncore/apps/tinykate/libkate/view/kateviewdialog.h +++ b/noncore/apps/tinykate/libkate/view/kateviewdialog.h | |||
@@ -1,196 +1,196 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | kateviewdialog.h - description | 2 | kateviewdialog.h - description |
3 | ------------------- | 3 | ------------------- |
4 | copyright : (C) 2001 by The Kate Team | 4 | copyright : (C) 2001 by The Kate Team |
5 | (C) 2002 by Joseph Wenninger | 5 | (C) 2002 by Joseph Wenninger |
6 | email : kwrite-devel@kde.org | 6 | email : kwrite-devel@kde.org |
7 | jowenn@kde.org | 7 | jowenn@kde.org |
8 | 8 | ||
9 | ***************************************************************************/ | 9 | ***************************************************************************/ |
10 | 10 | ||
11 | /*************************************************************************** | 11 | /*************************************************************************** |
12 | * * | 12 | * * |
13 | * This program is free software; you can redistribute it and/or modify * | 13 | * This program is free software; you can redistribute it and/or modify * |
14 | * it under the terms of the GNU General Public License as published by * | 14 | * it under the terms of the GNU General Public License as published by * |
15 | * the Free Software Foundation; either version 2 of the License, or * | 15 | * the Free Software Foundation; either version 2 of the License, or * |
16 | * (at your option) any later version. * | 16 | * (at your option) any later version. * |
17 | * * | 17 | * * |
18 | ***************************************************************************/ | 18 | ***************************************************************************/ |
19 | // Dialogs | 19 | // Dialogs |
20 | 20 | ||
21 | #ifndef _KWDIALOG_H_ | 21 | #ifndef _KWDIALOG_H_ |
22 | #define _KWDIALOG_H_ | 22 | #define _KWDIALOG_H_ |
23 | 23 | ||
24 | 24 | ||
25 | class QCheckBox; | 25 | class QCheckBox; |
26 | class QLineEdit; | 26 | class QLineEdit; |
27 | class QPushButton; | 27 | class QPushButton; |
28 | class QRadioButton; | 28 | class QRadioButton; |
29 | class QSpinBox; | 29 | class QSpinBox; |
30 | class KColorButton; | 30 | class KColorButton; |
31 | class QComboBox; | 31 | class QComboBox; |
32 | 32 | ||
33 | #include <kdialogbase.h> | 33 | #include <kdialogbase.h> |
34 | #include <opie2/ofontselector.h> | 34 | #include <opie2/ofontselector.h> |
35 | #include "kateview.h" | 35 | #include "kateview.h" |
36 | 36 | ||
37 | class SearchDialog : public KDialogBase | 37 | class SearchDialog : public KDialogBase |
38 | { | 38 | { |
39 | Q_OBJECT | 39 | Q_OBJECT |
40 | 40 | ||
41 | public: | 41 | public: |
42 | SearchDialog( QWidget *parent, QStringList &searchFor, QStringList &replaceWith, int flags ); | 42 | SearchDialog( QWidget *parent, QStringList &searchFor, QStringList &replaceWith, int flags ); |
43 | QString getSearchFor(); | 43 | QString getSearchFor(); |
44 | QString getReplaceWith(); | 44 | QString getReplaceWith(); |
45 | int getFlags(); | 45 | int getFlags(); |
46 | void setSearchText( const QString &searchstr ); | 46 | void setSearchText( const QString &searchstr ); |
47 | 47 | ||
48 | protected slots: | 48 | protected slots: |
49 | void slotOk(); | 49 | void slotOk(); |
50 | 50 | ||
51 | protected: | 51 | protected: |
52 | QComboBox *m_search; | 52 | QComboBox *m_search; |
53 | QComboBox *m_replace; | 53 | QComboBox *m_replace; |
54 | QCheckBox *m_opt1; | 54 | QCheckBox *m_opt1; |
55 | QCheckBox *m_opt2; | 55 | QCheckBox *m_opt2; |
56 | QCheckBox *m_opt3; | 56 | QCheckBox *m_opt3; |
57 | QCheckBox *m_optRegExp; | 57 | QCheckBox *m_optRegExp; |
58 | QCheckBox *m_opt4; | 58 | QCheckBox *m_opt4; |
59 | QCheckBox *m_opt5; | 59 | QCheckBox *m_opt5; |
60 | QCheckBox *m_opt6; | 60 | QCheckBox *m_opt6; |
61 | }; | 61 | }; |
62 | 62 | ||
63 | class ReplacePrompt : public KDialogBase | 63 | class ReplacePrompt : public KDialogBase |
64 | { | 64 | { |
65 | Q_OBJECT | 65 | Q_OBJECT |
66 | 66 | ||
67 | public: | 67 | public: |
68 | 68 | ||
69 | ReplacePrompt(QWidget *parent); | 69 | ReplacePrompt(QWidget *parent); |
70 | 70 | ||
71 | signals: | 71 | signals: |
72 | 72 | ||
73 | void clicked(); | 73 | void clicked(); |
74 | 74 | ||
75 | protected slots: | 75 | protected slots: |
76 | 76 | ||
77 | void slotUser1( void ); // All | 77 | void slotUser1( void ); // All |
78 | void slotUser2( void ); // No | 78 | void slotUser2( void ); // No |
79 | void slotUser3( void ); // Yes | 79 | void slotUser3( void ); // Yes |
80 | virtual void done(int); | 80 | virtual void done(int); |
81 | 81 | ||
82 | protected: | 82 | protected: |
83 | 83 | ||
84 | void closeEvent(QCloseEvent *); | 84 | void closeEvent(QCloseEvent *); |
85 | }; | 85 | }; |
86 | 86 | ||
87 | class GotoLineDialog : public KDialogBase | 87 | class GotoLineDialog : public KDialogBase |
88 | { | 88 | { |
89 | Q_OBJECT | 89 | Q_OBJECT |
90 | 90 | ||
91 | public: | 91 | public: |
92 | 92 | ||
93 | GotoLineDialog(QWidget *parent, int line, int max); | 93 | GotoLineDialog(QWidget *parent, int line, int max); |
94 | int getLine(); | 94 | int getLine(); |
95 | 95 | ||
96 | protected: | 96 | protected: |
97 | 97 | ||
98 | QSpinBox *e1; | 98 | QSpinBox *e1; |
99 | QPushButton *btnOK; | 99 | QPushButton *btnOK; |
100 | }; | 100 | }; |
101 | 101 | ||
102 | class IndentConfigTab : public QWidget | 102 | class IndentConfigTab : public QWidget |
103 | { | 103 | { |
104 | Q_OBJECT | 104 | Q_OBJECT |
105 | 105 | ||
106 | public: | 106 | public: |
107 | 107 | ||
108 | IndentConfigTab(QWidget *parent, KateView *); | 108 | IndentConfigTab(QWidget *parent, KateView *); |
109 | void getData(KateView *); | 109 | void getData(KateView *); |
110 | 110 | ||
111 | protected: | 111 | protected: |
112 | 112 | ||
113 | static const int numFlags = 6; | 113 | static const int numFlags = 6; |
114 | static const int flags[numFlags]; | 114 | static const int flags[numFlags]; |
115 | QCheckBox *opt[numFlags]; | 115 | QCheckBox *opt[numFlags]; |
116 | }; | 116 | }; |
117 | 117 | ||
118 | class SelectConfigTab : public QWidget | 118 | class SelectConfigTab : public QWidget |
119 | { | 119 | { |
120 | Q_OBJECT | 120 | Q_OBJECT |
121 | 121 | ||
122 | public: | 122 | public: |
123 | 123 | ||
124 | SelectConfigTab(QWidget *parent, KateView *); | 124 | SelectConfigTab(QWidget *parent, KateView *); |
125 | void getData(KateView *); | 125 | void getData(KateView *); |
126 | 126 | ||
127 | protected: | 127 | protected: |
128 | 128 | ||
129 | static const int numFlags = 6; | 129 | static const int numFlags = 6; |
130 | static const int flags[numFlags]; | 130 | static const int flags[numFlags]; |
131 | QCheckBox *opt[numFlags]; | 131 | QCheckBox *opt[numFlags]; |
132 | }; | 132 | }; |
133 | 133 | ||
134 | class EditConfigTab : public QWidget | 134 | class EditConfigTab : public QWidget |
135 | { | 135 | { |
136 | Q_OBJECT | 136 | Q_OBJECT |
137 | 137 | ||
138 | public: | 138 | public: |
139 | 139 | ||
140 | EditConfigTab(QWidget *parent, KateView *); | 140 | EditConfigTab(QWidget *parent, KateView *); |
141 | void getData(KateView *); | 141 | void getData(KateView *); |
142 | 142 | ||
143 | protected: | 143 | protected: |
144 | 144 | ||
145 | static const int numFlags = 9; | 145 | static const int numFlags = 9; |
146 | static const int flags[numFlags]; | 146 | static const int flags[numFlags]; |
147 | QCheckBox *opt[numFlags]; | 147 | QCheckBox *opt[numFlags]; |
148 | QComboBox *encoding; | 148 | QComboBox *encoding; |
149 | 149 | ||
150 | 150 | ||
151 | QSpinBox *e1; | 151 | QSpinBox *e1; |
152 | QSpinBox *e2; | 152 | QSpinBox *e2; |
153 | QSpinBox *e3; | 153 | QSpinBox *e3; |
154 | }; | 154 | }; |
155 | 155 | ||
156 | class ColorConfig : public QWidget | 156 | class ColorConfig : public QWidget |
157 | { | 157 | { |
158 | Q_OBJECT | 158 | Q_OBJECT |
159 | 159 | ||
160 | public: | 160 | public: |
161 | 161 | ||
162 | ColorConfig( QWidget *parent = 0, char *name = 0 ); | 162 | ColorConfig( QWidget *parent = 0, char *name = 0 ); |
163 | ~ColorConfig(); | 163 | ~ColorConfig(); |
164 | 164 | ||
165 | void setColors( QColor * ); | 165 | void setColors( QColor * ); |
166 | void getColors( QColor * ); | 166 | void getColors( QColor * ); |
167 | 167 | ||
168 | private: | 168 | private: |
169 | 169 | ||
170 | KColorButton *m_back; | 170 | KColorButton *m_back; |
171 | KColorButton *m_selected; | 171 | KColorButton *m_selected; |
172 | }; | 172 | }; |
173 | 173 | ||
174 | class FontConfig : public QWidget | 174 | class FontConfig : public QWidget |
175 | { | 175 | { |
176 | Q_OBJECT | 176 | Q_OBJECT |
177 | 177 | ||
178 | public: | 178 | public: |
179 | 179 | ||
180 | FontConfig( QWidget *parent = 0, char *name = 0 ); | 180 | FontConfig( QWidget *parent = 0, char *name = 0 ); |
181 | ~FontConfig(); | 181 | ~FontConfig(); |
182 | 182 | ||
183 | void setFont ( const QFont &font ); | 183 | void setFont ( const QFont &font ); |
184 | QFont getFont ( ) { return myFont; }; | 184 | QFont getFont ( ) { return myFont; }; |
185 | 185 | ||
186 | private: | 186 | private: |
187 | Opie::OFontSelector *m_fontselect; | 187 | Opie::Opie::Ui::OFontSelector *m_fontselect; |
188 | // class KFontChooser *m_fontchooser; | 188 | // class KFontChooser *m_fontchooser; |
189 | QFont myFont; | 189 | QFont myFont; |
190 | 190 | ||
191 | private slots: | 191 | private slots: |
192 | void slotFontSelected( const QFont &font ); | 192 | void slotFontSelected( const QFont &font ); |
193 | }; | 193 | }; |
194 | 194 | ||
195 | 195 | ||
196 | #endif //_KWDIALOG_H_ | 196 | #endif //_KWDIALOG_H_ |
diff --git a/noncore/apps/tinykate/main.cpp b/noncore/apps/tinykate/main.cpp index e62930c..c14d10a 100644 --- a/noncore/apps/tinykate/main.cpp +++ b/noncore/apps/tinykate/main.cpp | |||
@@ -1,22 +1,25 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | |||
2 | main.cpp | 3 | main.cpp |
3 | ------------------- | 4 | ------------------- |
4 | begin : November 2002 | 5 | begin : November 2002 |
5 | copyright : (C) 2002 by Joseph Wenninger <jowenn@kde.org> | 6 | copyright : (C) 2002 by Joseph Wenninger <jowenn@kde.org> |
6 | ***************************************************************************/ | 7 | ***************************************************************************/ |
7 | 8 | ||
8 | /*************************************************************************** | 9 | /*************************************************************************** |
9 | * * | 10 | * * |
10 | * This program is free software; you can redistribute it and/or modify * | 11 | * This program is free software; you can redistribute it and/or modify * |
11 | * it under the terms of the GNU General Public License as published by * | 12 | * it under the terms of the GNU General Public License as published by * |
12 | * the Free Software Foundation. * | 13 | * the Free Software Foundation. * |
13 | * ONLY VERSION 2 OF THE LICENSE IS APPLICABLE * | 14 | * ONLY VERSION 2 OF THE LICENSE IS APPLICABLE * |
14 | * * | 15 | * * |
15 | ***************************************************************************/ | 16 | ***************************************************************************/ |
16 | 17 | ||
17 | #include <opie2/oapplicationfactory.h> | 18 | #include <opie2/oapplicationfactory.h> |
18 | 19 | ||
19 | #include "tinykate.h" | 20 | #include "tinykate.h" |
20 | 21 | ||
22 | using namespace Opie::Core; | ||
23 | |||
21 | OPIE_EXPORT_APP( OApplicationFactory<TinyKate> ) | 24 | OPIE_EXPORT_APP( OApplicationFactory<TinyKate> ) |
22 | 25 | ||
diff --git a/noncore/apps/tinykate/tinykate.cpp b/noncore/apps/tinykate/tinykate.cpp index 32c1eab..3c9a637 100644 --- a/noncore/apps/tinykate/tinykate.cpp +++ b/noncore/apps/tinykate/tinykate.cpp | |||
@@ -1,278 +1,279 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | tinykate.cpp | 2 | tinykate.cpp |
3 | Tiny KATE mainwindow | 3 | Tiny KATE mainwindow |
4 | ------------------- | 4 | ------------------- |
5 | begin : November 2002 | 5 | begin : November 2002 |
6 | copyright : (C) 2002 by Joseph Wenninger <jowenn@kde.org> | 6 | copyright : (C) 2002 by Joseph Wenninger <jowenn@kde.org> |
7 | ***************************************************************************/ | 7 | ***************************************************************************/ |
8 | 8 | ||
9 | /*************************************************************************** | 9 | /*************************************************************************** |
10 | * * | 10 | * * |
11 | * This program is free softwaSre; you can redistribute it and/or modify * | 11 | * This program is free softwaSre; you can redistribute it and/or modify * |
12 | * it under the terms of the GNU General Public License as published by * | 12 | * it under the terms of the GNU General Public License as published by * |
13 | * the Free Software Foundation. * | 13 | * the Free Software Foundation. * |
14 | * ONLY VERSION 2 OF THE LICENSE IS APPLICABLE * | 14 | * ONLY VERSION 2 OF THE LICENSE IS APPLICABLE * |
15 | * * | 15 | * * |
16 | ***************************************************************************/ | 16 | ***************************************************************************/ |
17 | #include <qaction.h> | 17 | #include <qaction.h> |
18 | #include <qtoolbutton.h> | 18 | #include <qtoolbutton.h> |
19 | #include <qmenubar.h> | 19 | #include <qmenubar.h> |
20 | #include <qpe/resource.h> | 20 | #include <qpe/resource.h> |
21 | #include <qpe/qpeapplication.h> | 21 | #include <qpe/qpeapplication.h> |
22 | 22 | ||
23 | #include <opie2/ofiledialog.h> | 23 | #include <opie2/ofiledialog.h> |
24 | 24 | ||
25 | #include "tinykate.h" | 25 | #include "tinykate.h" |
26 | 26 | ||
27 | #include <katedocument.h> | 27 | #include <katedocument.h> |
28 | #include <kglobal.h> | 28 | #include <kglobal.h> |
29 | 29 | ||
30 | using namespace Opie::Ui; | ||
30 | TinyKate::TinyKate( QWidget *parent, const char *name, WFlags f) : | 31 | TinyKate::TinyKate( QWidget *parent, const char *name, WFlags f) : |
31 | QMainWindow( parent, name, f ) | 32 | QMainWindow( parent, name, f ) |
32 | { | 33 | { |
33 | shutDown=false; | 34 | shutDown=false; |
34 | nextUnnamed=0; | 35 | nextUnnamed=0; |
35 | currentView=0; | 36 | currentView=0; |
36 | viewCount=0; | 37 | viewCount=0; |
37 | setCaption(tr("TinyKATE")); | 38 | setCaption(tr("TinyKATE")); |
38 | KGlobal::setAppName("TinyKATE"); | 39 | KGlobal::setAppName("TinyKATE"); |
39 | 40 | ||
40 | QMenuBar *mb = new QMenuBar( this ); | 41 | QMenuBar *mb = new QMenuBar( this ); |
41 | mb->setMargin( 0 ); | 42 | mb->setMargin( 0 ); |
42 | 43 | ||
43 | tabwidget=new OTabWidget(this); | 44 | tabwidget=new OTabWidget(this); |
44 | setCentralWidget(tabwidget); | 45 | setCentralWidget(tabwidget); |
45 | connect(tabwidget,SIGNAL(currentChanged(QWidget*)),this,SLOT(slotCurrentChanged(QWidget*))); | 46 | connect(tabwidget,SIGNAL(currentChanged(QWidget*)),this,SLOT(slotCurrentChanged(QWidget*))); |
46 | 47 | ||
47 | //FILE ACTIONS | 48 | //FILE ACTIONS |
48 | QPopupMenu *popup = new QPopupMenu( this ); | 49 | QPopupMenu *popup = new QPopupMenu( this ); |
49 | 50 | ||
50 | // Action for creating a new document | 51 | // Action for creating a new document |
51 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); | 52 | QAction *a = new QAction( tr( "New" ), Resource::loadPixmap( "new" ), QString::null, 0, this, 0 ); |
52 | a->addTo( popup ); | 53 | a->addTo( popup ); |
53 | connect(a, SIGNAL(activated()), this, SLOT(slotNew())); | 54 | connect(a, SIGNAL(activated()), this, SLOT(slotNew())); |
54 | 55 | ||
55 | // Action for opening an exisiting document | 56 | // Action for opening an exisiting document |
56 | a = new QAction( tr( "Open" ),Resource::loadPixmap( "fileopen" ) , QString::null, 0, this, 0 ); | 57 | a = new QAction( tr( "Open" ),Resource::loadPixmap( "fileopen" ) , QString::null, 0, this, 0 ); |
57 | a->addTo(popup); | 58 | a->addTo(popup); |
58 | connect(a, SIGNAL(activated()), this, SLOT(slotOpen())); | 59 | connect(a, SIGNAL(activated()), this, SLOT(slotOpen())); |
59 | 60 | ||
60 | 61 | ||
61 | // Action for saving document | 62 | // Action for saving document |
62 | a = new QAction( tr( "Save" ), Resource::loadPixmap( "save" ) , QString::null, 0, this, 0 ); | 63 | a = new QAction( tr( "Save" ), Resource::loadPixmap( "save" ) , QString::null, 0, this, 0 ); |
63 | a->addTo(popup); | 64 | a->addTo(popup); |
64 | connect(a, SIGNAL(activated()), this, SLOT(slotSave())); | 65 | connect(a, SIGNAL(activated()), this, SLOT(slotSave())); |
65 | 66 | ||
66 | // Action for saving document to a new name | 67 | // Action for saving document to a new name |
67 | a = new QAction( tr( "Save As" ),Resource::loadPixmap( "save" ) , QString::null, 0, this, 0 ); | 68 | a = new QAction( tr( "Save As" ),Resource::loadPixmap( "save" ) , QString::null, 0, this, 0 ); |
68 | a->addTo(popup); | 69 | a->addTo(popup); |
69 | connect(a, SIGNAL(activated()), this, SLOT(slotSaveAs())); | 70 | connect(a, SIGNAL(activated()), this, SLOT(slotSaveAs())); |
70 | 71 | ||
71 | // Action for closing the currently active document | 72 | // Action for closing the currently active document |
72 | a = new QAction( tr( "Close" ), Resource::loadPixmap( "quit_icon" ) , QString::null, 0, this, 0 ); | 73 | a = new QAction( tr( "Close" ), Resource::loadPixmap( "quit_icon" ) , QString::null, 0, this, 0 ); |
73 | a->addTo(popup); | 74 | a->addTo(popup); |
74 | connect(a, SIGNAL(activated()), this, SLOT(slotClose())); | 75 | connect(a, SIGNAL(activated()), this, SLOT(slotClose())); |
75 | 76 | ||
76 | 77 | ||
77 | mb->insertItem(tr("File"),popup); | 78 | mb->insertItem(tr("File"),popup); |
78 | 79 | ||
79 | //EDIT ACTIONS | 80 | //EDIT ACTIONS |
80 | 81 | ||
81 | // Action for cutting text | 82 | // Action for cutting text |
82 | editCut = new QToolButton( 0 ); | 83 | editCut = new QToolButton( 0 ); |
83 | editCut->setAutoRaise( true ); | 84 | editCut->setAutoRaise( true ); |
84 | editCut->setIconSet( Resource::loadPixmap( "cut" ) ); | 85 | editCut->setIconSet( Resource::loadPixmap( "cut" ) ); |
85 | 86 | ||
86 | // Action for Copying text | 87 | // Action for Copying text |
87 | editCopy = new QToolButton( 0 ); | 88 | editCopy = new QToolButton( 0 ); |
88 | editCopy->setAutoRaise( true ); | 89 | editCopy->setAutoRaise( true ); |
89 | editCopy->setIconSet( Resource::loadPixmap( "copy" ) ); | 90 | editCopy->setIconSet( Resource::loadPixmap( "copy" ) ); |
90 | 91 | ||
91 | // Action for pasting text | 92 | // Action for pasting text |
92 | editPaste = new QToolButton( 0 ); | 93 | editPaste = new QToolButton( 0 ); |
93 | editPaste->setAutoRaise( true ); | 94 | editPaste->setAutoRaise( true ); |
94 | editPaste->setIconSet( Resource::loadPixmap( "paste" ) ); | 95 | editPaste->setIconSet( Resource::loadPixmap( "paste" ) ); |
95 | 96 | ||
96 | // Action for finding / replacing text | 97 | // Action for finding / replacing text |
97 | editFindReplace = new QToolButton( 0 ); | 98 | editFindReplace = new QToolButton( 0 ); |
98 | editFindReplace->setAutoRaise( true ); | 99 | editFindReplace->setAutoRaise( true ); |
99 | editFindReplace->setIconSet( Resource::loadPixmap("find") ); | 100 | editFindReplace->setIconSet( Resource::loadPixmap("find") ); |
100 | 101 | ||
101 | // Action for undo | 102 | // Action for undo |
102 | editUndo = new QToolButton( 0 ); | 103 | editUndo = new QToolButton( 0 ); |
103 | editUndo->setAutoRaise( true ); | 104 | editUndo->setAutoRaise( true ); |
104 | editUndo->setIconSet( Resource::loadPixmap( "undo" ) ); | 105 | editUndo->setIconSet( Resource::loadPixmap( "undo" ) ); |
105 | 106 | ||
106 | // Action for redo | 107 | // Action for redo |
107 | editRedo = new QToolButton( 0 ); | 108 | editRedo = new QToolButton( 0 ); |
108 | editRedo->setAutoRaise( true ); | 109 | editRedo->setAutoRaise( true ); |
109 | editRedo->setIconSet( Resource::loadPixmap( "redo" ) ); | 110 | editRedo->setIconSet( Resource::loadPixmap( "redo" ) ); |
110 | 111 | ||
111 | //VIEW ACITONS | 112 | //VIEW ACITONS |
112 | popup = new QPopupMenu( this ); | 113 | popup = new QPopupMenu( this ); |
113 | 114 | ||
114 | viewIncFontSizes = new QAction( tr( "Font +" ), QString::null, 0, this, 0 ); | 115 | viewIncFontSizes = new QAction( tr( "Font +" ), QString::null, 0, this, 0 ); |
115 | viewIncFontSizes->addTo( popup ); | 116 | viewIncFontSizes->addTo( popup ); |
116 | 117 | ||
117 | viewDecFontSizes = new QAction( tr( "Font -" ), QString::null, 0, this, 0 ); | 118 | viewDecFontSizes = new QAction( tr( "Font -" ), QString::null, 0, this, 0 ); |
118 | viewDecFontSizes->addTo( popup ); | 119 | viewDecFontSizes->addTo( popup ); |
119 | 120 | ||
120 | mb->insertItem(tr("View"),popup); | 121 | mb->insertItem(tr("View"),popup); |
121 | 122 | ||
122 | popup = new QPopupMenu( this ); | 123 | popup = new QPopupMenu( this ); |
123 | mb->insertItem(tr("Utils"),popup); | 124 | mb->insertItem(tr("Utils"),popup); |
124 | 125 | ||
125 | 126 | ||
126 | mb->insertItem( editCut ); | 127 | mb->insertItem( editCut ); |
127 | mb->insertItem( editCopy ); | 128 | mb->insertItem( editCopy ); |
128 | mb->insertItem( editPaste ); | 129 | mb->insertItem( editPaste ); |
129 | mb->insertItem( editFindReplace ); | 130 | mb->insertItem( editFindReplace ); |
130 | mb->insertItem( editUndo ); | 131 | mb->insertItem( editUndo ); |
131 | mb->insertItem( editRedo ); | 132 | mb->insertItem( editRedo ); |
132 | 133 | ||
133 | 134 | ||
134 | //Highlight management | 135 | //Highlight management |
135 | hlmenu=new QPopupMenu(this); | 136 | hlmenu=new QPopupMenu(this); |
136 | HlManager *hlm=HlManager::self(); | 137 | HlManager *hlm=HlManager::self(); |
137 | for (int i=0;i<hlm->highlights();i++) | 138 | for (int i=0;i<hlm->highlights();i++) |
138 | { | 139 | { |
139 | hlmenu->insertItem(hlm->hlName(i),i); | 140 | hlmenu->insertItem(hlm->hlName(i),i); |
140 | } | 141 | } |
141 | popup->insertItem(tr("Highlighting"),hlmenu); | 142 | popup->insertItem(tr("Highlighting"),hlmenu); |
142 | 143 | ||
143 | 144 | ||
144 | utilSettings = new QAction( tr( "Settings" ), QString::null, 0, this, 0 ); | 145 | utilSettings = new QAction( tr( "Settings" ), QString::null, 0, this, 0 ); |
145 | utilSettings->addTo( popup); | 146 | utilSettings->addTo( popup); |
146 | 147 | ||
147 | if( qApp->argc() > 1) open(qApp->argv()[1]); | 148 | if( qApp->argc() > 1) open(qApp->argv()[1]); |
148 | else slotNew(); | 149 | else slotNew(); |
149 | 150 | ||
150 | } | 151 | } |
151 | 152 | ||
152 | TinyKate::~TinyKate( ) | 153 | TinyKate::~TinyKate( ) |
153 | { | 154 | { |
154 | qWarning("TinyKate destructor\n"); | 155 | qWarning("TinyKate destructor\n"); |
155 | 156 | ||
156 | shutDown=true; | 157 | shutDown=true; |
157 | while (currentView!=0) { | 158 | while (currentView!=0) { |
158 | slotClose(); | 159 | slotClose(); |
159 | } | 160 | } |
160 | 161 | ||
161 | if( KGlobal::config() != 0 ) { | 162 | if( KGlobal::config() != 0 ) { |
162 | qWarning("deleting KateConfig object..\n"); | 163 | qWarning("deleting KateConfig object..\n"); |
163 | delete KGlobal::config(); | 164 | delete KGlobal::config(); |
164 | } | 165 | } |
165 | } | 166 | } |
166 | 167 | ||
167 | void TinyKate::slotOpen( ) | 168 | void TinyKate::slotOpen( ) |
168 | { | 169 | { |
169 | QString filename = Opie::OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, | 170 | QString filename = OFileDialog::getOpenFileName( OFileSelector::EXTENDED_ALL, |
170 | QString::null); | 171 | QString::null); |
171 | if (!filename.isEmpty()) { | 172 | if (!filename.isEmpty()) { |
172 | open(filename); | 173 | open(filename); |
173 | } | 174 | } |
174 | } | 175 | } |
175 | 176 | ||
176 | void TinyKate::open(const QString & filename) | 177 | void TinyKate::open(const QString & filename) |
177 | { | 178 | { |
178 | KateDocument *kd= new KateDocument(false, false, this,0,this); | 179 | KateDocument *kd= new KateDocument(false, false, this,0,this); |
179 | KTextEditor::View *kv; | 180 | KTextEditor::View *kv; |
180 | QFileInfo fi(filename); | 181 | QFileInfo fi(filename); |
181 | QString filenamed = fi.fileName(); | 182 | QString filenamed = fi.fileName(); |
182 | tabwidget->addTab(kv=kd->createView(tabwidget,"bLAH"),"tinykate/tinykate", filenamed ); | 183 | tabwidget->addTab(kv=kd->createView(tabwidget,"bLAH"),"tinykate/tinykate", filenamed ); |
183 | qDebug(filename); | 184 | qDebug(filename); |
184 | 185 | ||
185 | kd->setDocName( filenamed); | 186 | kd->setDocName( filenamed); |
186 | kd->open( filename ); | 187 | kd->open( filename ); |
187 | viewCount++; | 188 | viewCount++; |
188 | } | 189 | } |
189 | 190 | ||
190 | void TinyKate::setDocument(const QString& fileref) | 191 | void TinyKate::setDocument(const QString& fileref) |
191 | { | 192 | { |
192 | open( fileref ); | 193 | open( fileref ); |
193 | } | 194 | } |
194 | 195 | ||
195 | void TinyKate::slotCurrentChanged( QWidget * view) | 196 | void TinyKate::slotCurrentChanged( QWidget * view) |
196 | { | 197 | { |
197 | if (currentView) { | 198 | if (currentView) { |
198 | 199 | ||
199 | disconnect(editCopy,SIGNAL(activated()),currentView,SLOT(copy())); | 200 | disconnect(editCopy,SIGNAL(activated()),currentView,SLOT(copy())); |
200 | disconnect(editCut,SIGNAL(activated()),currentView,SLOT(cut())); | 201 | disconnect(editCut,SIGNAL(activated()),currentView,SLOT(cut())); |
201 | disconnect(editPaste,SIGNAL(activated()),currentView,SLOT(paste())); | 202 | disconnect(editPaste,SIGNAL(activated()),currentView,SLOT(paste())); |
202 | disconnect(editUndo,SIGNAL(activated()),currentView,SLOT(undo())); | 203 | disconnect(editUndo,SIGNAL(activated()),currentView,SLOT(undo())); |
203 | disconnect(editRedo,SIGNAL(activated()),currentView,SLOT(redo())); | 204 | disconnect(editRedo,SIGNAL(activated()),currentView,SLOT(redo())); |
204 | disconnect(viewIncFontSizes,SIGNAL(activated()), currentView,SLOT(slotIncFontSizes())); | 205 | disconnect(viewIncFontSizes,SIGNAL(activated()), currentView,SLOT(slotIncFontSizes())); |
205 | disconnect(viewDecFontSizes,SIGNAL(activated()), currentView,SLOT(slotDecFontSizes())); | 206 | disconnect(viewDecFontSizes,SIGNAL(activated()), currentView,SLOT(slotDecFontSizes())); |
206 | disconnect(hlmenu,SIGNAL(activated(int)), currentView,SLOT(setHl(int))); | 207 | disconnect(hlmenu,SIGNAL(activated(int)), currentView,SLOT(setHl(int))); |
207 | disconnect(utilSettings,SIGNAL(activated()), currentView,SLOT(configDialog())); | 208 | disconnect(utilSettings,SIGNAL(activated()), currentView,SLOT(configDialog())); |
208 | } | 209 | } |
209 | 210 | ||
210 | currentView=(KTextEditor::View*)view; | 211 | currentView=(KTextEditor::View*)view; |
211 | 212 | ||
212 | connect(editCopy,SIGNAL(clicked()),currentView,SLOT(copy())); | 213 | connect(editCopy,SIGNAL(clicked()),currentView,SLOT(copy())); |
213 | connect(editCut,SIGNAL(clicked()),currentView,SLOT(cut())); | 214 | connect(editCut,SIGNAL(clicked()),currentView,SLOT(cut())); |
214 | connect(editPaste,SIGNAL(clicked()),currentView,SLOT(paste())); | 215 | connect(editPaste,SIGNAL(clicked()),currentView,SLOT(paste())); |
215 | connect(editUndo,SIGNAL(clicked()),currentView,SLOT(undo())); | 216 | connect(editUndo,SIGNAL(clicked()),currentView,SLOT(undo())); |
216 | connect(editRedo,SIGNAL(clicked()),currentView,SLOT(redo())); | 217 | connect(editRedo,SIGNAL(clicked()),currentView,SLOT(redo())); |
217 | connect(viewIncFontSizes,SIGNAL(activated()), currentView,SLOT(slotIncFontSizes())); | 218 | connect(viewIncFontSizes,SIGNAL(activated()), currentView,SLOT(slotIncFontSizes())); |
218 | connect(viewDecFontSizes,SIGNAL(activated()), currentView,SLOT(slotDecFontSizes())); | 219 | connect(viewDecFontSizes,SIGNAL(activated()), currentView,SLOT(slotDecFontSizes())); |
219 | connect(hlmenu,SIGNAL(activated(int)), currentView,SLOT(setHl(int))); | 220 | connect(hlmenu,SIGNAL(activated(int)), currentView,SLOT(setHl(int))); |
220 | connect(utilSettings,SIGNAL(activated()), currentView,SLOT(configDialog())); | 221 | connect(utilSettings,SIGNAL(activated()), currentView,SLOT(configDialog())); |
221 | 222 | ||
222 | } | 223 | } |
223 | 224 | ||
224 | void TinyKate::slotNew( ) | 225 | void TinyKate::slotNew( ) |
225 | { | 226 | { |
226 | KateDocument *kd= new KateDocument(false, false, this,0,this); | 227 | KateDocument *kd= new KateDocument(false, false, this,0,this); |
227 | KTextEditor::View *kv; | 228 | KTextEditor::View *kv; |
228 | tabwidget->addTab(kv=kd->createView(tabwidget,"BLAH"), | 229 | tabwidget->addTab(kv=kd->createView(tabwidget,"BLAH"), |
229 | "tinykate/tinykate", | 230 | "tinykate/tinykate", |
230 | tr("Unnamed %1").arg(nextUnnamed++)); | 231 | tr("Unnamed %1").arg(nextUnnamed++)); |
231 | viewCount++; | 232 | viewCount++; |
232 | } | 233 | } |
233 | 234 | ||
234 | void TinyKate::slotClose( ) | 235 | void TinyKate::slotClose( ) |
235 | { | 236 | { |
236 | if (currentView==0) return; | 237 | if (currentView==0) return; |
237 | KTextEditor::View *dv=currentView; | 238 | KTextEditor::View *dv=currentView; |
238 | currentView=0; | 239 | currentView=0; |
239 | tabwidget->removePage(dv); | 240 | tabwidget->removePage(dv); |
240 | delete dv->document(); | 241 | delete dv->document(); |
241 | viewCount--; | 242 | viewCount--; |
242 | if ((!viewCount) && (!shutDown)) slotNew(); | 243 | if ((!viewCount) && (!shutDown)) slotNew(); |
243 | } | 244 | } |
244 | 245 | ||
245 | void TinyKate::slotSave() { | 246 | void TinyKate::slotSave() { |
246 | // feel free to make this how you want | 247 | // feel free to make this how you want |
247 | if (currentView==0) return; | 248 | if (currentView==0) return; |
248 | 249 | ||
249 | // KateView *kv = (KateView*) currentView; | 250 | // KateView *kv = (KateView*) currentView; |
250 | KateDocument *kd = (KateDocument*) currentView->document(); | 251 | KateDocument *kd = (KateDocument*) currentView->document(); |
251 | // qDebug("saving file "+kd->docName()); | 252 | // qDebug("saving file "+kd->docName()); |
252 | if( kd->docName().isEmpty()) | 253 | if( kd->docName().isEmpty()) |
253 | slotSaveAs(); | 254 | slotSaveAs(); |
254 | else | 255 | else |
255 | kd->saveFile(); | 256 | kd->saveFile(); |
256 | // kv->save(); | 257 | // kv->save(); |
257 | // kd->saveFile(); | 258 | // kd->saveFile(); |
258 | } | 259 | } |
259 | 260 | ||
260 | void TinyKate::slotSaveAs() { | 261 | void TinyKate::slotSaveAs() { |
261 | if (currentView==0) return; | 262 | if (currentView==0) return; |
262 | KateDocument *kd = (KateDocument*) currentView->document(); | 263 | KateDocument *kd = (KateDocument*) currentView->document(); |
263 | 264 | ||
264 | QString filename= Opie::OFileDialog::getSaveFileName(OFileSelector::EXTENDED_ALL, | 265 | QString filename= OFileDialog::getSaveFileName(OFileSelector::EXTENDED_ALL, |
265 | QString::null); | 266 | QString::null); |
266 | if (!filename.isEmpty()) { | 267 | if (!filename.isEmpty()) { |
267 | qDebug("saving file "+filename); | 268 | qDebug("saving file "+filename); |
268 | QFileInfo fi(filename); | 269 | QFileInfo fi(filename); |
269 | QString filenamed = fi.fileName(); | 270 | QString filenamed = fi.fileName(); |
270 | kd->setDocFile( filename); | 271 | kd->setDocFile( filename); |
271 | kd->setDocName( filenamed); | 272 | kd->setDocName( filenamed); |
272 | kd->saveFile(); | 273 | kd->saveFile(); |
273 | // KTextEditor::View *dv = currentView; | 274 | // KTextEditor::View *dv = currentView; |
274 | // tabwidget->changeTab( dv, filenamed); | 275 | // tabwidget->changeTab( dv, filenamed); |
275 | // need to change tab label here | 276 | // need to change tab label here |
276 | } | 277 | } |
277 | 278 | ||
278 | } | 279 | } |
diff --git a/noncore/apps/tinykate/tinykate.h b/noncore/apps/tinykate/tinykate.h index f844c55..f435c03 100644 --- a/noncore/apps/tinykate/tinykate.h +++ b/noncore/apps/tinykate/tinykate.h | |||
@@ -1,66 +1,66 @@ | |||
1 | /*************************************************************************** | 1 | /*************************************************************************** |
2 | tinykate.h | 2 | tinykate.h |
3 | Tiny KATE mainwindow | 3 | Tiny KATE mainwindow |
4 | ------------------- | 4 | ------------------- |
5 | begin : November 2002 | 5 | begin : November 2002 |
6 | copyright : (C) 2002 by Joseph Wenninger <jowenn@kde.org> | 6 | copyright : (C) 2002 by Joseph Wenninger <jowenn@kde.org> |
7 | ***************************************************************************/ | 7 | ***************************************************************************/ |
8 | 8 | ||
9 | /*************************************************************************** | 9 | /*************************************************************************** |
10 | * * | 10 | * * |
11 | * This program is free software; you can redistribute it and/or modify * | 11 | * This program is free software; you can redistribute it and/or modify * |
12 | * it under the terms of the GNU General Public License as published by * | 12 | * it under the terms of the GNU General Public License as published by * |
13 | * the Free Software Foundation. * | 13 | * the Free Software Foundation. * |
14 | * ONLY VERSION 2 OF THE LICENSE IS APPLICABLE * | 14 | * ONLY VERSION 2 OF THE LICENSE IS APPLICABLE * |
15 | * * | 15 | * * |
16 | ***************************************************************************/ | 16 | ***************************************************************************/ |
17 | 17 | ||
18 | #ifndef __TINYKATE_H__ | 18 | #ifndef __TINYKATE_H__ |
19 | #define __TINYKATE_H__ | 19 | #define __TINYKATE_H__ |
20 | 20 | ||
21 | 21 | ||
22 | #include <qmainwindow.h> | 22 | #include <qmainwindow.h> |
23 | #include <opie2/otabwidget.h> | 23 | #include <opie2/otabwidget.h> |
24 | #include <ktexteditor.h> | 24 | #include <ktexteditor.h> |
25 | 25 | ||
26 | class QToolButton; | 26 | class QToolButton; |
27 | class QAction; | 27 | class QAction; |
28 | class QPopupMenu; | 28 | class QPopupMenu; |
29 | 29 | ||
30 | class TinyKate : public QMainWindow | 30 | class TinyKate : public QMainWindow |
31 | { | 31 | { |
32 | Q_OBJECT | 32 | Q_OBJECT |
33 | public: | 33 | public: |
34 | TinyKate( QWidget *parent=0, const char *name=0, WFlags f = 0); | 34 | TinyKate( QWidget *parent=0, const char *name=0, WFlags f = 0); |
35 | ~TinyKate( ); | 35 | ~TinyKate( ); |
36 | static QString appName() { return QString::fromLatin1( "kate" ); }; | 36 | static QString appName() { return QString::fromLatin1( "kate" ); }; |
37 | 37 | ||
38 | 38 | ||
39 | public slots: | 39 | public slots: |
40 | void slotNew(); | 40 | void slotNew(); |
41 | void setDocument(const QString& fileref); | 41 | void setDocument(const QString& fileref); |
42 | 42 | ||
43 | protected slots: | 43 | protected slots: |
44 | void slotOpen(); | 44 | void slotOpen(); |
45 | void slotClose(); | 45 | void slotClose(); |
46 | void slotCurrentChanged(QWidget *); | 46 | void slotCurrentChanged(QWidget *); |
47 | void slotSave(); | 47 | void slotSave(); |
48 | void slotSaveAs(); | 48 | void slotSaveAs(); |
49 | protected: | 49 | protected: |
50 | void open(const QString&); | 50 | void open(const QString&); |
51 | private: | 51 | private: |
52 | QString currentFileName; | 52 | QString currentFileName; |
53 | OTabWidget *tabwidget; | 53 | Opie::Ui::OTabWidget *tabwidget; |
54 | KTextEditor::View *currentView; | 54 | KTextEditor::View *currentView; |
55 | bool shutDown; | 55 | bool shutDown; |
56 | 56 | ||
57 | QToolButton *editCopy, *editCut, *editPaste, *editUndo, *editRedo, *editFindReplace; | 57 | QToolButton *editCopy, *editCut, *editPaste, *editUndo, *editRedo, *editFindReplace; |
58 | QAction *viewIncFontSizes, *viewDecFontSizes, *utilSettings; | 58 | QAction *viewIncFontSizes, *viewDecFontSizes, *utilSettings; |
59 | 59 | ||
60 | QPopupMenu *hlmenu; | 60 | QPopupMenu *hlmenu; |
61 | uint nextUnnamed; | 61 | uint nextUnnamed; |
62 | uint viewCount; | 62 | uint viewCount; |
63 | }; | 63 | }; |
64 | 64 | ||
65 | 65 | ||
66 | #endif // __TINYKATE_H__ | 66 | #endif // __TINYKATE_H__ |
diff --git a/noncore/apps/zsafe/zsafe.cpp b/noncore/apps/zsafe/zsafe.cpp index a3467e5..3df55eb 100644 --- a/noncore/apps/zsafe/zsafe.cpp +++ b/noncore/apps/zsafe/zsafe.cpp | |||
@@ -1,546 +1,545 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** | 2 | ** |
3 | ** Created: Sat Apr 6 17:57:45 2002 | 3 | ** Created: Sat Apr 6 17:57:45 2002 |
4 | ** | 4 | ** |
5 | ** Author: Carsten Schneider <CarstenSchneider@t-online.de> | 5 | ** Author: Carsten Schneider <CarstenSchneider@t-online.de> |
6 | ** | 6 | ** |
7 | ** $Id$ | 7 | ** $Id$ |
8 | ** | 8 | ** |
9 | ** Homepage: http://home.t-online.de/home/CarstenSchneider/zsafe/index.html | 9 | ** Homepage: http://home.t-online.de/home/CarstenSchneider/zsafe/index.html |
10 | ** | 10 | ** |
11 | ** Compile Flags: | 11 | ** Compile Flags: |
12 | ** Zaurus arm : -DNO_OPIE | 12 | ** Zaurus arm : -DNO_OPIE |
13 | ** Zaurus Opie arm: none | 13 | ** Zaurus Opie arm: none |
14 | ** Linux Desktop : -DDESKTOP | 14 | ** Linux Desktop : -DDESKTOP |
15 | ** Windows Desktop: -DDESKTOP -DWIN32 | 15 | ** Windows Desktop: -DDESKTOP -DWIN32 |
16 | ** | 16 | ** |
17 | ** for japanese version additional use: -DJPATCH_HDE | 17 | ** for japanese version additional use: -DJPATCH_HDE |
18 | ** | 18 | ** |
19 | ****************************************************************************/ | 19 | ****************************************************************************/ |
20 | #include "zsafe.h" | 20 | #include "zsafe.h" |
21 | #include "newdialog.h" | 21 | #include "newdialog.h" |
22 | #include "searchdialog.h" | 22 | #include "searchdialog.h" |
23 | #include "categorydialog.h" | 23 | #include "categorydialog.h" |
24 | #include "passworddialog.h" | 24 | #include "passworddialog.h" |
25 | #include "infoform.h" | 25 | #include "infoform.h" |
26 | #include "zlistview.h" | 26 | #include "zlistview.h" |
27 | #include "shadedlistitem.h" | 27 | #include "shadedlistitem.h" |
28 | 28 | ||
29 | #ifndef DESKTOP | 29 | #ifndef DESKTOP |
30 | #ifndef NO_OPIE | 30 | #ifndef NO_OPIE |
31 | #include <opie2/ofiledialog.h> | 31 | #include <opie2/ofiledialog.h> |
32 | 32 | ||
33 | using Opie::OFileDialog; | 33 | using namespace Opie::Ui; |
34 | using Opie::OFileSelector; | ||
35 | #else | 34 | #else |
36 | #include "scqtfileedit.h" | 35 | #include "scqtfileedit.h" |
37 | #endif | 36 | #endif |
38 | #endif | 37 | #endif |
39 | 38 | ||
40 | #include <qclipboard.h> | 39 | #include <qclipboard.h> |
41 | 40 | ||
42 | #include <stdio.h> | 41 | #include <stdio.h> |
43 | 42 | ||
44 | #include <sys/types.h> | 43 | #include <sys/types.h> |
45 | #include <sys/stat.h> | 44 | #include <sys/stat.h> |
46 | #include <fcntl.h> | 45 | #include <fcntl.h> |
47 | #include <stdlib.h> | 46 | #include <stdlib.h> |
48 | #ifndef WIN32 | 47 | #ifndef WIN32 |
49 | #include <unistd.h> | 48 | #include <unistd.h> |
50 | #endif | 49 | #endif |
51 | #include <string.h> | 50 | #include <string.h> |
52 | #include <errno.h> | 51 | #include <errno.h> |
53 | 52 | ||
54 | #include <qmenubar.h> | 53 | #include <qmenubar.h> |
55 | #include <qpopupmenu.h> | 54 | #include <qpopupmenu.h> |
56 | 55 | ||
57 | #ifdef DESKTOP | 56 | #ifdef DESKTOP |
58 | #include <qfiledialog.h> | 57 | #include <qfiledialog.h> |
59 | #ifndef WIN32 | 58 | #ifndef WIN32 |
60 | #include <qsettings.h> | 59 | #include <qsettings.h> |
61 | #else | 60 | #else |
62 | #include "qsettings.h" | 61 | #include "qsettings.h" |
63 | #endif | 62 | #endif |
64 | #include <qapplication.h> | 63 | #include <qapplication.h> |
65 | #else | 64 | #else |
66 | #include <qfile.h> | 65 | #include <qfile.h> |
67 | #include <qpe/fileselector.h> | 66 | #include <qpe/fileselector.h> |
68 | #include <qpe/global.h> | 67 | #include <qpe/global.h> |
69 | #include <qpe/qpeapplication.h> | 68 | #include <qpe/qpeapplication.h> |
70 | #include <qpe/resource.h> | 69 | #include <qpe/resource.h> |
71 | #include <qpe/config.h> | 70 | #include <qpe/config.h> |
72 | #endif | 71 | #endif |
73 | 72 | ||
74 | #include <qtimer.h> | 73 | #include <qtimer.h> |
75 | #include <qlayout.h> | 74 | #include <qlayout.h> |
76 | #include <qmessagebox.h> | 75 | #include <qmessagebox.h> |
77 | #include <qfile.h> | 76 | #include <qfile.h> |
78 | #include <qtextstream.h> | 77 | #include <qtextstream.h> |
79 | #include <qheader.h> | 78 | #include <qheader.h> |
80 | #include <qlistview.h> | 79 | #include <qlistview.h> |
81 | #include <qtoolbutton.h> | 80 | #include <qtoolbutton.h> |
82 | #include <qvariant.h> | 81 | #include <qvariant.h> |
83 | #include <qtooltip.h> | 82 | #include <qtooltip.h> |
84 | #include <qwhatsthis.h> | 83 | #include <qwhatsthis.h> |
85 | #include <qimage.h> | 84 | #include <qimage.h> |
86 | #include <qpixmap.h> | 85 | #include <qpixmap.h> |
87 | #include <qlineedit.h> | 86 | #include <qlineedit.h> |
88 | #include <qmultilineedit.h> | 87 | #include <qmultilineedit.h> |
89 | #include <qregexp.h> | 88 | #include <qregexp.h> |
90 | #include <qdir.h> | 89 | #include <qdir.h> |
91 | #include <qtextbrowser.h> | 90 | #include <qtextbrowser.h> |
92 | #include <qlabel.h> | 91 | #include <qlabel.h> |
93 | #include <qcombobox.h> | 92 | #include <qcombobox.h> |
94 | 93 | ||
95 | #include "krc2.h" | 94 | #include "krc2.h" |
96 | 95 | ||
97 | #include "wait.h" | 96 | #include "wait.h" |
98 | 97 | ||
99 | extern int DeskW, DeskH; | 98 | extern int DeskW, DeskH; |
100 | #ifdef DESKTOP | 99 | #ifdef DESKTOP |
101 | extern QApplication *appl; | 100 | extern QApplication *appl; |
102 | #else | 101 | #else |
103 | extern QPEApplication *appl; | 102 | extern QPEApplication *appl; |
104 | #endif | 103 | #endif |
105 | 104 | ||
106 | #ifdef JPATCH_HDE | 105 | #ifdef JPATCH_HDE |
107 | #define tr(arg) arg | 106 | #define tr(arg) arg |
108 | #endif | 107 | #endif |
109 | 108 | ||
110 | 109 | ||
111 | #ifdef DESKTOP | 110 | #ifdef DESKTOP |
112 | #ifndef WIN32 | 111 | #ifndef WIN32 |
113 | const QString APP_KEY="/.zsafe/"; | 112 | const QString APP_KEY="/.zsafe/"; |
114 | #else | 113 | #else |
115 | const QString APP_KEY=""; | 114 | const QString APP_KEY=""; |
116 | #endif | 115 | #endif |
117 | #else | 116 | #else |
118 | const QString APP_KEY=""; | 117 | const QString APP_KEY=""; |
119 | #endif | 118 | #endif |
120 | 119 | ||
121 | // include xmp images | 120 | // include xmp images |
122 | #include "pics/zsafe/copy.xpm" | 121 | #include "pics/zsafe/copy.xpm" |
123 | #include "pics/zsafe/cut.xpm" | 122 | #include "pics/zsafe/cut.xpm" |
124 | #include "pics/zsafe/edit.xpm" | 123 | #include "pics/zsafe/edit.xpm" |
125 | #include "pics/zsafe/editdelete.xpm" | 124 | #include "pics/zsafe/editdelete.xpm" |
126 | #include "pics/zsafe/find.xpm" | 125 | #include "pics/zsafe/find.xpm" |
127 | #include "pics/zsafe/folder_open.xpm" | 126 | #include "pics/zsafe/folder_open.xpm" |
128 | #include "pics/zsafe/help_icon.xpm" | 127 | #include "pics/zsafe/help_icon.xpm" |
129 | #include "pics/zsafe/new.xpm" | 128 | #include "pics/zsafe/new.xpm" |
130 | #include "pics/zsafe/paste.xpm" | 129 | #include "pics/zsafe/paste.xpm" |
131 | #include "pics/zsafe/quit_icon.xpm" | 130 | #include "pics/zsafe/quit_icon.xpm" |
132 | #include "pics/zsafe/save.xpm" | 131 | #include "pics/zsafe/save.xpm" |
133 | #include "pics/zsafe/trash.xpm" | 132 | #include "pics/zsafe/trash.xpm" |
134 | #include "pics/zsafe/expand.xpm" | 133 | #include "pics/zsafe/expand.xpm" |
135 | #include "pics/zsafe/export.xpm" | 134 | #include "pics/zsafe/export.xpm" |
136 | #include "pics/zsafe/import.xpm" | 135 | #include "pics/zsafe/import.xpm" |
137 | #include "pics/zsafe/zsafe.xpm" | 136 | #include "pics/zsafe/zsafe.xpm" |
138 | 137 | ||
139 | static const char* const bank_cards_data[] = { | 138 | static const char* const bank_cards_data[] = { |
140 | "14 14 16 1", | 139 | "14 14 16 1", |
141 | ". c None", | 140 | ". c None", |
142 | "# c #000000", | 141 | "# c #000000", |
143 | "b c #0000de", | 142 | "b c #0000de", |
144 | "a c #0000e6", | 143 | "a c #0000e6", |
145 | "j c #41de83", | 144 | "j c #41de83", |
146 | "k c #4acecd", | 145 | "k c #4acecd", |
147 | "h c #4aced5", | 146 | "h c #4aced5", |
148 | "g c #5a40cd", | 147 | "g c #5a40cd", |
149 | "d c #5a44d5", | 148 | "d c #5a44d5", |
150 | "l c #9440d5", | 149 | "l c #9440d5", |
151 | "m c #b4ce4a", | 150 | "m c #b4ce4a", |
152 | "n c #cd4883", | 151 | "n c #cd4883", |
153 | "e c #d5ae10", | 152 | "e c #d5ae10", |
154 | "f c #de3ce6", | 153 | "f c #de3ce6", |
155 | "i c #e640e6", | 154 | "i c #e640e6", |
156 | "c c #ffffff", | 155 | "c c #ffffff", |
157 | "..............", | 156 | "..............", |
158 | ".###########..", | 157 | ".###########..", |
159 | ".#ababababa#..", | 158 | ".#ababababa#..", |
160 | ".#babbbabbb#..", | 159 | ".#babbbabbb#..", |
161 | ".#ccccccccc#..", | 160 | ".#ccccccccc#..", |
162 | ".#cdcefcghc#..", | 161 | ".#cdcefcghc#..", |
163 | ".#ccccccccc#..", | 162 | ".#ccccccccc#..", |
164 | ".#cicjkclic#..", | 163 | ".#cicjkclic#..", |
165 | ".#ccccccccc#..", | 164 | ".#ccccccccc#..", |
166 | ".#cmchlcnec#..", | 165 | ".#cmchlcnec#..", |
167 | ".#ccccccccc#..", | 166 | ".#ccccccccc#..", |
168 | ".###########..", | 167 | ".###########..", |
169 | "..............", | 168 | "..............", |
170 | ".............."}; | 169 | ".............."}; |
171 | 170 | ||
172 | 171 | ||
173 | static const char* const passwords_data[] = { | 172 | static const char* const passwords_data[] = { |
174 | "16 16 20 1", | 173 | "16 16 20 1", |
175 | ". c None", | 174 | ". c None", |
176 | "# c #000000", | 175 | "# c #000000", |
177 | "r c #000083", | 176 | "r c #000083", |
178 | "p c #0000c5", | 177 | "p c #0000c5", |
179 | "q c #0000ff", | 178 | "q c #0000ff", |
180 | "n c #008100", | 179 | "n c #008100", |
181 | "l c #00c200", | 180 | "l c #00c200", |
182 | "m c #00ff00", | 181 | "m c #00ff00", |
183 | "j c #838100", | 182 | "j c #838100", |
184 | "a c #c55900", | 183 | "a c #c55900", |
185 | "h c #c5c200", | 184 | "h c #c5c200", |
186 | "o c #c5c2ff", | 185 | "o c #c5c2ff", |
187 | "k c #c5ffc5", | 186 | "k c #c5ffc5", |
188 | "f c #ff0000", | 187 | "f c #ff0000", |
189 | "d c #ff8100", | 188 | "d c #ff8100", |
190 | "b c #ffaa5a", | 189 | "b c #ffaa5a", |
191 | "e c #ffc2c5", | 190 | "e c #ffc2c5", |
192 | "c c #ffdeac", | 191 | "c c #ffdeac", |
193 | "i c #ffff00", | 192 | "i c #ffff00", |
194 | "g c #ffffc5", | 193 | "g c #ffffc5", |
195 | "............###.", | 194 | "............###.", |
196 | "...........#abb#", | 195 | "...........#abb#", |
197 | "..........#cbab#", | 196 | "..........#cbab#", |
198 | ".........#cbdd#.", | 197 | ".........#cbdd#.", |
199 | "######..#cbdd#..", | 198 | "######..#cbdd#..", |
200 | "#eeff#..#add#...", | 199 | "#eeff#..#add#...", |
201 | "#eeff#######....", | 200 | "#eeff#######....", |
202 | "#ccdbdd#........", | 201 | "#ccdbdd#........", |
203 | "#dddbdd###......", | 202 | "#dddbdd###......", |
204 | "#gghihhjj#......", | 203 | "#gghihhjj#......", |
205 | "#hhhihhjj###....", | 204 | "#hhhihhjj###....", |
206 | "#kklmllnnnn#....", | 205 | "#kklmllnnnn#....", |
207 | "#lllmllnnnn#....", | 206 | "#lllmllnnnn#....", |
208 | "#oopqpprprr#....", | 207 | "#oopqpprprr#....", |
209 | "#oopqpprprr#....", | 208 | "#oopqpprprr#....", |
210 | "############...."}; | 209 | "############...."}; |
211 | 210 | ||
212 | static const char* const software_data[] = { | 211 | static const char* const software_data[] = { |
213 | "16 16 5 1", | 212 | "16 16 5 1", |
214 | ". c None", | 213 | ". c None", |
215 | "# c #000000", | 214 | "# c #000000", |
216 | "b c #838183", | 215 | "b c #838183", |
217 | "c c #c5ffff", | 216 | "c c #c5ffff", |
218 | "a c #ffffff", | 217 | "a c #ffffff", |
219 | "................", | 218 | "................", |
220 | ".##############.", | 219 | ".##############.", |
221 | "#aaaaaaaaaaaaaa#", | 220 | "#aaaaaaaaaaaaaa#", |
222 | "#abbbbbbbbbbbbb#", | 221 | "#abbbbbbbbbbbbb#", |
223 | "#ab##########ab#", | 222 | "#ab##########ab#", |
224 | "#ab#c########ab#", | 223 | "#ab#c########ab#", |
225 | "#ab#c#c######ab#", | 224 | "#ab#c#c######ab#", |
226 | "#ab##########ab#", | 225 | "#ab##########ab#", |
227 | "#ab##########ab#", | 226 | "#ab##########ab#", |
228 | "#ab##########ab#", | 227 | "#ab##########ab#", |
229 | "#ab##########ab#", | 228 | "#ab##########ab#", |
230 | "#ab##########ab#", | 229 | "#ab##########ab#", |
231 | "#aaaaaaaaaaaaab#", | 230 | "#aaaaaaaaaaaaab#", |
232 | "#bbbbbbbbbbbbbb#", | 231 | "#bbbbbbbbbbbbbb#", |
233 | ".##############.", | 232 | ".##############.", |
234 | "................"}; | 233 | "................"}; |
235 | 234 | ||
236 | static const char* const general_data[] = { | 235 | static const char* const general_data[] = { |
237 | "14 14 98 2", | 236 | "14 14 98 2", |
238 | "Qt c None", | 237 | "Qt c None", |
239 | ".k c #000000", | 238 | ".k c #000000", |
240 | "#x c #080808", | 239 | "#x c #080808", |
241 | "#F c #101008", | 240 | "#F c #101008", |
242 | "#q c #101010", | 241 | "#q c #101010", |
243 | "#i c #101410", | 242 | "#i c #101410", |
244 | "## c #101810", | 243 | "## c #101810", |
245 | ".m c #181818", | 244 | ".m c #181818", |
246 | ".3 c #181c18", | 245 | ".3 c #181c18", |
247 | ".I c #182018", | 246 | ".I c #182018", |
248 | ".T c #202420", | 247 | ".T c #202420", |
249 | "#D c #202820", | 248 | "#D c #202820", |
250 | "#y c #292c29", | 249 | "#y c #292c29", |
251 | ".c c #293029", | 250 | ".c c #293029", |
252 | ".d c #313031", | 251 | ".d c #313031", |
253 | "#E c #313429", | 252 | "#E c #313429", |
254 | "#r c #313831", | 253 | "#r c #313831", |
255 | ".j c #393c31", | 254 | ".j c #393c31", |
256 | "#j c #394039", | 255 | "#j c #394039", |
257 | "#C c #414841", | 256 | "#C c #414841", |
258 | ".w c #4a554a", | 257 | ".w c #4a554a", |
259 | ".a c #4a594a", | 258 | ".a c #4a594a", |
260 | ".# c #525052", | 259 | ".# c #525052", |
261 | ".l c #52594a", | 260 | ".l c #52594a", |
262 | "#f c #525952", | 261 | "#f c #525952", |
263 | "#v c #525d52", | 262 | "#v c #525d52", |
264 | ".O c #5a4c4a", | 263 | ".O c #5a4c4a", |
265 | ".9 c #5a595a", | 264 | ".9 c #5a595a", |
266 | ".A c #5a5d52", | 265 | ".A c #5a5d52", |
267 | ".B c #624c52", | 266 | ".B c #624c52", |
268 | ".0 c #625552", | 267 | ".0 c #625552", |
269 | "#o c #626562", | 268 | "#o c #626562", |
270 | ".R c #626962", | 269 | ".R c #626962", |
271 | "#. c #626d5a", | 270 | "#. c #626d5a", |
272 | "#p c #626d62", | 271 | "#p c #626d62", |
273 | ".2 c #627162", | 272 | ".2 c #627162", |
274 | "#h c #6a6d62", | 273 | "#h c #6a6d62", |
275 | "#z c #6a7562", | 274 | "#z c #6a7562", |
276 | "#w c #6a756a", | 275 | "#w c #6a756a", |
277 | ".C c #73656a", | 276 | ".C c #73656a", |
278 | ".P c #73696a", | 277 | ".P c #73696a", |
279 | "#a c #737d6a", | 278 | "#a c #737d6a", |
280 | ".U c #738573", | 279 | ".U c #738573", |
281 | ".E c #7b817b", | 280 | ".E c #7b817b", |
282 | "#B c #7b857b", | 281 | "#B c #7b857b", |
283 | "#s c #7b897b", | 282 | "#s c #7b897b", |
284 | "#n c #7b917b", | 283 | "#n c #7b917b", |
285 | ".b c #838d83", | 284 | ".b c #838d83", |
286 | ".7 c #839583", | 285 | ".7 c #839583", |
287 | ".n c #8b7d7b", | 286 | ".n c #8b7d7b", |
288 | "#g c #8b8583", | 287 | "#g c #8b8583", |
289 | ".g c #8b858b", | 288 | ".g c #8b858b", |
290 | ".r c #8b898b", | 289 | ".r c #8b898b", |
291 | ".s c #8b8d8b", | 290 | ".s c #8b8d8b", |
292 | ".i c #8b9183", | 291 | ".i c #8b9183", |
293 | ".8 c #8b918b", | 292 | ".8 c #8b918b", |
294 | "#A c #8b9d8b", | 293 | "#A c #8b9d8b", |
295 | ".S c #8ba183", | 294 | ".S c #8ba183", |
296 | ".Z c #94918b", | 295 | ".Z c #94918b", |
297 | ".N c #949994", | 296 | ".N c #949994", |
298 | ".F c #949d94", | 297 | ".F c #949d94", |
299 | ".x c #94a18b", | 298 | ".x c #94a18b", |
300 | ".v c #94a194", | 299 | ".v c #94a194", |
301 | ".Y c #94aa94", | 300 | ".Y c #94aa94", |
302 | ".h c #9c999c", | 301 | ".h c #9c999c", |
303 | ".Q c #9ca19c", | 302 | ".Q c #9ca19c", |
304 | "#u c #9ca59c", | 303 | "#u c #9ca59c", |
305 | ".H c #9caa9c", | 304 | ".H c #9caa9c", |
306 | "#e c #9cb29c", | 305 | "#e c #9cb29c", |
307 | "#m c #a4b29c", | 306 | "#m c #a4b29c", |
308 | "#t c #a4b2a4", | 307 | "#t c #a4b2a4", |
309 | ".M c #a4b69c", | 308 | ".M c #a4b69c", |
310 | "#l c #a4b6a4", | 309 | "#l c #a4b6a4", |
311 | ".z c #a4baa4", | 310 | ".z c #a4baa4", |
312 | ".f c #aca5ac", | 311 | ".f c #aca5ac", |
313 | ".q c #acaaac", | 312 | ".q c #acaaac", |
314 | "#d c #acbeac", | 313 | "#d c #acbeac", |
315 | ".6 c #acc2ac", | 314 | ".6 c #acc2ac", |
316 | ".o c #b4b2b4", | 315 | ".o c #b4b2b4", |
317 | ".t c #b4beb4", | 316 | ".t c #b4beb4", |
318 | "#k c #b4c2ac", | 317 | "#k c #b4c2ac", |
319 | ".5 c #b4cab4", | 318 | ".5 c #b4cab4", |
320 | ".D c #bdb6bd", | 319 | ".D c #bdb6bd", |
321 | ".G c #bdc6b4", | 320 | ".G c #bdc6b4", |
322 | "#c c #bdceb4", | 321 | "#c c #bdceb4", |
323 | ".X c #bdd2bd", | 322 | ".X c #bdd2bd", |
324 | ".4 c #bdd6bd", | 323 | ".4 c #bdd6bd", |
325 | ".1 c #c5bec5", | 324 | ".1 c #c5bec5", |
326 | ".e c #c5c2c5", | 325 | ".e c #c5c2c5", |
327 | ".u c #c5cac5", | 326 | ".u c #c5cac5", |
328 | "#b c #c5d6c5", | 327 | "#b c #c5d6c5", |
329 | ".J c #c5dec5", | 328 | ".J c #c5dec5", |
330 | ".p c #cdcacd", | 329 | ".p c #cdcacd", |
331 | ".W c #cddecd", | 330 | ".W c #cddecd", |
332 | ".L c #cde2cd", | 331 | ".L c #cde2cd", |
333 | ".K c #d5eacd", | 332 | ".K c #d5eacd", |
334 | ".V c #d5ead5", | 333 | ".V c #d5ead5", |
335 | ".y c #d5eed5", | 334 | ".y c #d5eed5", |
336 | "QtQtQtQtQtQtQtQtQtQtQtQtQtQt", | 335 | "QtQtQtQtQtQtQtQtQtQtQtQtQtQt", |
337 | "QtQtQt.#.a.b.cQtQtQtQtQtQtQt", | 336 | "QtQtQt.#.a.b.cQtQtQtQtQtQtQt", |
338 | "QtQt.d.e.f.g.h.i.c.j.dQt.kQt", | 337 | "QtQt.d.e.f.g.h.i.c.j.dQt.kQt", |
339 | ".a.l.m.n.o.p.q.r.s.t.u.v.wQt", | 338 | ".a.l.m.n.o.p.q.r.s.t.u.v.wQt", |
340 | ".x.y.z.A.B.C.D.p.q.E.F.G.H.I", | 339 | ".x.y.z.A.B.C.D.p.q.E.F.G.H.I", |
341 | ".I.J.K.L.M.N.O.P.o.p.Q.R.S.T", | 340 | ".I.J.K.L.M.N.O.P.o.p.Q.R.S.T", |
342 | "Qt.U.V.L.W.X.Y.Z.0.P.1.s.2.3", | 341 | "Qt.U.V.L.W.X.Y.Z.0.P.1.s.2.3", |
343 | "Qt.3.X.W.4.X.5.6.7.8.9.s#.##", | 342 | "Qt.3.X.W.4.X.5.6.7.8.9.s#.##", |
344 | "QtQt#a.X#b#c.5.6#d#e#f#g#h#i", | 343 | "QtQt#a.X#b#c.5.6#d#e#f#g#h#i", |
345 | "QtQtQt#j.7#k.6#d#l#m#n#o#p#q", | 344 | "QtQtQt#j.7#k.6#d#l#m#n#o#p#q", |
346 | "QtQtQtQt.k#r#s#m#t.H#u#v#w#x", | 345 | "QtQtQtQt.k#r#s#m#t.H#u#v#w#x", |
347 | "QtQtQtQtQtQt.k#y#z.v#A#B#C#x", | 346 | "QtQtQtQtQtQt.k#y#z.v#A#B#C#x", |
348 | "QtQtQtQtQtQtQtQt.k#D.w#s#E.k", | 347 | "QtQtQtQtQtQtQtQt.k#D.w#s#E.k", |
349 | "QtQtQtQtQtQtQtQtQtQtQt#x#FQt"}; | 348 | "QtQtQtQtQtQtQtQtQtQtQt#x#FQt"}; |
350 | 349 | ||
351 | // exit ZSafe and clear the clipboard for security reasons | 350 | // exit ZSafe and clear the clipboard for security reasons |
352 | void ZSafe::exitZs (int ec) | 351 | void ZSafe::exitZs (int ec) |
353 | { | 352 | { |
354 | QClipboard *cb = QApplication::clipboard(); | 353 | QClipboard *cb = QApplication::clipboard(); |
355 | cb->clear(); | 354 | cb->clear(); |
356 | 355 | ||
357 | exit (ec); | 356 | exit (ec); |
358 | } | 357 | } |
359 | 358 | ||
360 | 359 | ||
361 | // save the configuration into the file | 360 | // save the configuration into the file |
362 | void ZSafe::saveConf () | 361 | void ZSafe::saveConf () |
363 | { | 362 | { |
364 | if (conf) | 363 | if (conf) |
365 | { | 364 | { |
366 | delete conf; | 365 | delete conf; |
367 | 366 | ||
368 | #ifdef DESKTOP | 367 | #ifdef DESKTOP |
369 | #ifndef WIN32 | 368 | #ifndef WIN32 |
370 | conf = new QSettings (); | 369 | conf = new QSettings (); |
371 | conf->insertSearchPath (QSettings::Unix, QDir::homeDirPath()); | 370 | conf->insertSearchPath (QSettings::Unix, QDir::homeDirPath()); |
372 | #else | 371 | #else |
373 | conf = new QSettings (cfgFile); | 372 | conf = new QSettings (cfgFile); |
374 | conf->insertSearchPath (QSettings::Unix, cfgFile); | 373 | conf->insertSearchPath (QSettings::Unix, cfgFile); |
375 | #endif | 374 | #endif |
376 | #else | 375 | #else |
377 | conf = new Config (cfgFile, Config::File); | 376 | conf = new Config (cfgFile, Config::File); |
378 | conf->setGroup ("zsafe"); | 377 | conf->setGroup ("zsafe"); |
379 | #endif | 378 | #endif |
380 | } | 379 | } |
381 | } | 380 | } |
382 | 381 | ||
383 | 382 | ||
384 | /* | 383 | /* |
385 | * Constructs a ZSafe which is a child of 'parent', with the | 384 | * Constructs a ZSafe which is a child of 'parent', with the |
386 | * name 'name' and widget flags set to 'f' | 385 | * name 'name' and widget flags set to 'f' |
387 | * | 386 | * |
388 | * The dialog will by default be modeless, unless you set 'modal' to | 387 | * The dialog will by default be modeless, unless you set 'modal' to |
389 | * TRUE to construct a modal dialog. | 388 | * TRUE to construct a modal dialog. |
390 | */ | 389 | */ |
391 | ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) | 390 | ZSafe::ZSafe( QWidget* parent, const char* name, bool modal, WFlags fl ) |
392 | : QDialog( parent, name, modal, fl ), | 391 | : QDialog( parent, name, modal, fl ), |
393 | Edit(0l), Delete(0l), Find(0l), New(0l), ListView(0l) | 392 | Edit(0l), Delete(0l), Find(0l), New(0l), ListView(0l) |
394 | { | 393 | { |
395 | IsCut = false; | 394 | IsCut = false; |
396 | IsCopy = false; | 395 | IsCopy = false; |
397 | modified = false; | 396 | modified = false; |
398 | 397 | ||
399 | // set the config file | 398 | // set the config file |
400 | cfgFile=QDir::homeDirPath(); | 399 | cfgFile=QDir::homeDirPath(); |
401 | cfgFile += "/.zsafe.cfg"; | 400 | cfgFile += "/.zsafe.cfg"; |
402 | // set the icon path | 401 | // set the icon path |
403 | #ifdef NO_OPIE | 402 | #ifdef NO_OPIE |
404 | QString qpedir ((const char *)getenv("QPEDIR")); | 403 | QString qpedir ((const char *)getenv("QPEDIR")); |
405 | #else | 404 | #else |
406 | QString qpedir ((const char *)getenv("OPIEDIR")); | 405 | QString qpedir ((const char *)getenv("OPIEDIR")); |
407 | #endif | 406 | #endif |
408 | 407 | ||
409 | #ifdef DESKTOP | 408 | #ifdef DESKTOP |
410 | iconPath = QDir::homeDirPath() + "/pics/"; | 409 | iconPath = QDir::homeDirPath() + "/pics/"; |
411 | #else | 410 | #else |
412 | if (qpedir.isEmpty()) | 411 | if (qpedir.isEmpty()) |
413 | iconPath = "/home/QtPalmtop/pics/"; | 412 | iconPath = "/home/QtPalmtop/pics/"; |
414 | else | 413 | else |
415 | iconPath = qpedir + "/pics/"; | 414 | iconPath = qpedir + "/pics/"; |
416 | #endif | 415 | #endif |
417 | 416 | ||
418 | // create a zsafe configuration object | 417 | // create a zsafe configuration object |
419 | #ifdef DESKTOP | 418 | #ifdef DESKTOP |
420 | #ifndef WIN32 | 419 | #ifndef WIN32 |
421 | conf = new QSettings (); | 420 | conf = new QSettings (); |
422 | conf->insertSearchPath (QSettings::Unix, QDir::homeDirPath()); | 421 | conf->insertSearchPath (QSettings::Unix, QDir::homeDirPath()); |
423 | #else | 422 | #else |
424 | conf = new QSettings (cfgFile); | 423 | conf = new QSettings (cfgFile); |
425 | conf->insertSearchPath (QSettings::Unix, cfgFile); | 424 | conf->insertSearchPath (QSettings::Unix, cfgFile); |
426 | #endif | 425 | #endif |
427 | #else | 426 | #else |
428 | conf = new Config (cfgFile, Config::File); | 427 | conf = new Config (cfgFile, Config::File); |
429 | conf->setGroup ("zsafePrefs"); | 428 | conf->setGroup ("zsafePrefs"); |
430 | #endif | 429 | #endif |
431 | #ifdef DESKTOP | 430 | #ifdef DESKTOP |
432 | // #ifndef WIN32 | 431 | // #ifndef WIN32 |
433 | expandTree = conf->readBoolEntry(APP_KEY+"expandTree", false); | 432 | expandTree = conf->readBoolEntry(APP_KEY+"expandTree", false); |
434 | // #endif | 433 | // #endif |
435 | #else | 434 | #else |
436 | expandTree = conf->readNumEntry(APP_KEY+"expandTree", 0); | 435 | expandTree = conf->readNumEntry(APP_KEY+"expandTree", 0); |
437 | #endif | 436 | #endif |
438 | #ifndef DESKTOP | 437 | #ifndef DESKTOP |
439 | conf->setGroup ("zsafe"); | 438 | conf->setGroup ("zsafe"); |
440 | #endif | 439 | #endif |
441 | 440 | ||
442 | QPixmap copy_img((const char**) copy_xpm); | 441 | QPixmap copy_img((const char**) copy_xpm); |
443 | QPixmap cut_img((const char**) cut_xpm); | 442 | QPixmap cut_img((const char**) cut_xpm); |
444 | QPixmap edit_img((const char**) edit_xpm); | 443 | QPixmap edit_img((const char**) edit_xpm); |
445 | QPixmap editdelete_img((const char**) editdelete_xpm); | 444 | QPixmap editdelete_img((const char**) editdelete_xpm); |
446 | QPixmap find_img((const char**) find_xpm); | 445 | QPixmap find_img((const char**) find_xpm); |
447 | QPixmap folder_open_img((const char**) folder_open_xpm); | 446 | QPixmap folder_open_img((const char**) folder_open_xpm); |
448 | QPixmap help_icon_img((const char**) help_icon_xpm); | 447 | QPixmap help_icon_img((const char**) help_icon_xpm); |
449 | QPixmap new_img((const char**) new_xpm); | 448 | QPixmap new_img((const char**) new_xpm); |
450 | QPixmap paste_img((const char**) paste_xpm); | 449 | QPixmap paste_img((const char**) paste_xpm); |
451 | QPixmap quit_icon_img((const char**) quit_icon_xpm); | 450 | QPixmap quit_icon_img((const char**) quit_icon_xpm); |
452 | QPixmap save_img((const char**) save_xpm); | 451 | QPixmap save_img((const char**) save_xpm); |
453 | QPixmap trash_img((const char**) trash_xpm); | 452 | QPixmap trash_img((const char**) trash_xpm); |
454 | QPixmap expand_img((const char**) expand_xpm); | 453 | QPixmap expand_img((const char**) expand_xpm); |
455 | QPixmap export_img((const char**) export_xpm); | 454 | QPixmap export_img((const char**) export_xpm); |
456 | QPixmap import_img((const char**) import_xpm); | 455 | QPixmap import_img((const char**) import_xpm); |
457 | 456 | ||
458 | QPixmap bank_cards( ( const char** ) bank_cards_data ); | 457 | QPixmap bank_cards( ( const char** ) bank_cards_data ); |
459 | QPixmap passwords( ( const char** ) passwords_data ); | 458 | QPixmap passwords( ( const char** ) passwords_data ); |
460 | QPixmap software( ( const char** ) software_data ); | 459 | QPixmap software( ( const char** ) software_data ); |
461 | QPixmap general( ( const char** ) general_data ); | 460 | QPixmap general( ( const char** ) general_data ); |
462 | if ( !name ) | 461 | if ( !name ) |
463 | setName( "ZSafe" ); | 462 | setName( "ZSafe" ); |
464 | 463 | ||
465 | #ifdef DESKTOP | 464 | #ifdef DESKTOP |
466 | #ifdef WIN32 | 465 | #ifdef WIN32 |
467 | setGeometry(100, 150, DeskW, DeskH-30 ); | 466 | setGeometry(100, 150, DeskW, DeskH-30 ); |
468 | #else | 467 | #else |
469 | resize( DeskW, DeskH-30 ); | 468 | resize( DeskW, DeskH-30 ); |
470 | #endif | 469 | #endif |
471 | 470 | ||
472 | #else | 471 | #else |
473 | 472 | ||
474 | #ifdef JPATCH_HDE | 473 | #ifdef JPATCH_HDE |
475 | int DeskS; | 474 | int DeskS; |
476 | if(DeskW > DeskH) | 475 | if(DeskW > DeskH) |
477 | { | 476 | { |
478 | DeskS = DeskW; | 477 | DeskS = DeskW; |
479 | } | 478 | } |
480 | else | 479 | else |
481 | { | 480 | { |
482 | DeskS = DeskH; | 481 | DeskS = DeskH; |
483 | } | 482 | } |
484 | resize( DeskW, DeskH ); | 483 | resize( DeskW, DeskH ); |
485 | setMinimumSize( QSize( DeskS, DeskS ) ); | 484 | setMinimumSize( QSize( DeskS, DeskS ) ); |
486 | setMaximumSize( QSize( DeskS, DeskS ) ); | 485 | setMaximumSize( QSize( DeskS, DeskS ) ); |
487 | #else | 486 | #else |
488 | resize( DeskW, DeskH-30 ); | 487 | resize( DeskW, DeskH-30 ); |
489 | #endif | 488 | #endif |
490 | 489 | ||
491 | #endif | 490 | #endif |
492 | // setCaption( tr( "ZSafe" ) ); | 491 | // setCaption( tr( "ZSafe" ) ); |
493 | 492 | ||
494 | filename = conf->readEntry(APP_KEY+"document"); | 493 | filename = conf->readEntry(APP_KEY+"document"); |
495 | if (filename.isEmpty() || filename.isNull()) | 494 | if (filename.isEmpty() || filename.isNull()) |
496 | { | 495 | { |
497 | 496 | ||
498 | // check if the directory application exists, if not | 497 | // check if the directory application exists, if not |
499 | // create it | 498 | // create it |
500 | // #ifndef WIN32 | 499 | // #ifndef WIN32 |
501 | // QString d1("Documents/application"); | 500 | // QString d1("Documents/application"); |
502 | // #else | 501 | // #else |
503 | QString d1(QDir::homeDirPath() + "/Documents/application"); | 502 | QString d1(QDir::homeDirPath() + "/Documents/application"); |
504 | // #endif | 503 | // #endif |
505 | QDir pd1(d1); | 504 | QDir pd1(d1); |
506 | if (!pd1.exists()) | 505 | if (!pd1.exists()) |
507 | { | 506 | { |
508 | QDir pd1("Documents"); | 507 | QDir pd1("Documents"); |
509 | if (!pd1.mkdir("application", FALSE)) | 508 | if (!pd1.mkdir("application", FALSE)) |
510 | { | 509 | { |
511 | QMessageBox::critical( 0, tr("ZSafe"), | 510 | QMessageBox::critical( 0, tr("ZSafe"), |
512 | #ifdef JPATCH_HDE | 511 | #ifdef JPATCH_HDE |
513 | tr("Can't create directory\n.../Documents/application\n\nZSafe will now exit.")); | 512 | tr("Can't create directory\n.../Documents/application\n\nZSafe will now exit.")); |
514 | #else | 513 | #else |
515 | tr("Can't create directory\n%1\n\nZSafe will now exit.").arg(d1)); | 514 | tr("Can't create directory\n%1\n\nZSafe will now exit.").arg(d1)); |
516 | #endif | 515 | #endif |
517 | exitZs (1); | 516 | exitZs (1); |
518 | } | 517 | } |
519 | } | 518 | } |
520 | QString d2(QDir::homeDirPath() + "/Documents/application/zsafe"); | 519 | QString d2(QDir::homeDirPath() + "/Documents/application/zsafe"); |
521 | QDir pd2(d2); | 520 | QDir pd2(d2); |
522 | if (!pd2.exists()) | 521 | if (!pd2.exists()) |
523 | { | 522 | { |
524 | QDir pd2(QDir::homeDirPath() + "Documents/application"); | 523 | QDir pd2(QDir::homeDirPath() + "Documents/application"); |
525 | if (!pd2.mkdir("zsafe", FALSE)) | 524 | if (!pd2.mkdir("zsafe", FALSE)) |
526 | { | 525 | { |
527 | QMessageBox::critical( 0, tr("ZSafe"), | 526 | QMessageBox::critical( 0, tr("ZSafe"), |
528 | #ifdef JPATCH_HDE | 527 | #ifdef JPATCH_HDE |
529 | tr("Can't create directory\n...//Documents/application/zsafe\n\nZSafe will now exit.")); | 528 | tr("Can't create directory\n...//Documents/application/zsafe\n\nZSafe will now exit.")); |
530 | #else | 529 | #else |
531 | tr("Can't create directory\n%1\n\nZSafe will now exit.").arg(d2)); | 530 | tr("Can't create directory\n%1\n\nZSafe will now exit.").arg(d2)); |
532 | #endif | 531 | #endif |
533 | exitZs (1); | 532 | exitZs (1); |
534 | } | 533 | } |
535 | } | 534 | } |
536 | 535 | ||
537 | 536 | ||
538 | // set the default filename | 537 | // set the default filename |
539 | filename=d2 + "/passwords.zsf"; | 538 | filename=d2 + "/passwords.zsf"; |
540 | 539 | ||
541 | // save the current filename to the config file | 540 | // save the current filename to the config file |
542 | conf->writeEntry(APP_KEY+"document", filename); | 541 | conf->writeEntry(APP_KEY+"document", filename); |
543 | saveConf(); | 542 | saveConf(); |
544 | } | 543 | } |
545 | 544 | ||
546 | //if (filename == "INVALIDPWD") | 545 | //if (filename == "INVALIDPWD") |