author | llornkcor <llornkcor> | 2004-09-18 09:05:57 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2004-09-18 09:05:57 (UTC) |
commit | eaf09b9b6e1abbe36e814a8e4da315ac8d96bd63 (patch) (unidiff) | |
tree | ee914747ae2494d50716ab3cda866613d4eb134c | |
parent | 5096f9bd9f1a06e5238e2206eee195c43a2bdb6b (diff) | |
download | opie-eaf09b9b6e1abbe36e814a8e4da315ac8d96bd63.zip opie-eaf09b9b6e1abbe36e814a8e4da315ac8d96bd63.tar.gz opie-eaf09b9b6e1abbe36e814a8e4da315ac8d96bd63.tar.bz2 |
fix stuff, including #1404
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.cpp | 88 | ||||
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.h | 3 | ||||
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.pro | 2 | ||||
-rw-r--r-- | noncore/apps/advancedfm/advancedfmMenu.cpp | 20 |
4 files changed, 71 insertions, 42 deletions
diff --git a/noncore/apps/advancedfm/advancedfm.cpp b/noncore/apps/advancedfm/advancedfm.cpp index afb44f5..b4461cb 100644 --- a/noncore/apps/advancedfm/advancedfm.cpp +++ b/noncore/apps/advancedfm/advancedfm.cpp | |||
@@ -1,146 +1,164 @@ | |||
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 <opie2/odebug.h> | ||
15 | #include <qpe/qpeapplication.h> | 16 | #include <qpe/qpeapplication.h> |
16 | #include <qpe/config.h> | 17 | #include <qpe/config.h> |
17 | #include <qpe/mimetype.h> | 18 | #include <qpe/mimetype.h> |
18 | #include <qpe/applnk.h> | 19 | #include <qpe/applnk.h> |
19 | #include <qpe/resource.h> | 20 | #include <qpe/resource.h> |
20 | #include <qpe/menubutton.h> | 21 | #include <qpe/menubutton.h> |
21 | 22 | ||
22 | #include <qcombobox.h> | 23 | #include <qcombobox.h> |
23 | #include <qpopupmenu.h> | 24 | #include <qpopupmenu.h> |
24 | #include <qlistview.h> | 25 | #include <qlistview.h> |
25 | #include <qmessagebox.h> | 26 | #include <qmessagebox.h> |
26 | #include <qlineedit.h> | 27 | #include <qlineedit.h> |
27 | 28 | ||
28 | 29 | ||
29 | #include <sys/stat.h> | 30 | #include <sys/stat.h> |
30 | #include <time.h> | 31 | #include <time.h> |
31 | #include <dirent.h> | 32 | #include <dirent.h> |
32 | #include <fcntl.h> | 33 | #include <fcntl.h> |
33 | #include <sys/vfs.h> | 34 | #include <sys/vfs.h> |
34 | #include <mntent.h> | 35 | #include <mntent.h> |
35 | 36 | ||
36 | using namespace Opie::Ui; | 37 | using namespace Opie::Ui; |
37 | 38 | ||
38 | AdvancedFm::AdvancedFm(QWidget *,const char*, WFlags ) | 39 | AdvancedFm::AdvancedFm(QWidget *,const char*, WFlags ) |
39 | : QMainWindow( ) { | 40 | : QMainWindow( ) { |
40 | init(); | 41 | init(); |
41 | renameBox = 0; | 42 | renameBox = 0; |
42 | 43 | ||
43 | unknownXpm = Resource::loadImage( "UnknownDocument" ).smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); | 44 | unknownXpm = Resource::loadImage( "UnknownDocument" ).smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); |
44 | 45 | ||
45 | initConnections(); | 46 | initConnections(); |
46 | whichTab=1; | 47 | |
47 | rePopulate(); | 48 | whichTab = 1; |
48 | currentPathCombo->setFocus(); | 49 | populateView(); |
49 | channel = new QCopChannel( "QPE/Application/advancedfm", this ); | 50 | // rePopulate(); |
50 | connect( channel, SIGNAL(received(const QCString&,const QByteArray&)), | 51 | // currentPathCombo->setFocus(); |
51 | this, SLOT( qcopReceive(const QCString&,const QByteArray&)) ); | 52 | channel = new QCopChannel( "QPE/Application/advancedfm", this ); |
53 | connect( channel, SIGNAL(received(const QCString&,const QByteArray&)), | ||
54 | this, SLOT( qcopReceive(const QCString&,const QByteArray&)) ); | ||
55 | |||
56 | // if( CurrentView() == Local_View) | ||
57 | // qDebug("LOCAL VIEW"); | ||
58 | // else | ||
59 | // qDebug("REMOTE VIEW"); | ||
60 | switchToLocalTab(); | ||
52 | } | 61 | } |
53 | 62 | ||
54 | AdvancedFm::~AdvancedFm() { | 63 | AdvancedFm::~AdvancedFm() { |
55 | } | 64 | } |
56 | 65 | ||
57 | 66 | ||
58 | void AdvancedFm::cleanUp() { | 67 | void AdvancedFm::cleanUp() { |
59 | QString sfile=QDir::homeDirPath(); | 68 | QString sfile=QDir::homeDirPath(); |
60 | if(sfile.right(1) != "/") | 69 | if(sfile.right(1) != "/") |
61 | sfile+="/._temp"; | 70 | sfile+="/._temp"; |
62 | else | 71 | else |
63 | sfile+="._temp"; | 72 | sfile+="._temp"; |
64 | QFile file( sfile); | 73 | QFile file( sfile); |
65 | if(file.exists()) | 74 | if(file.exists()) |
66 | file.remove(); | 75 | file.remove(); |
67 | } | 76 | } |
68 | 77 | ||
69 | void AdvancedFm::tabChanged(QWidget *) { | 78 | void AdvancedFm::tabChanged(QWidget *wd) { |
70 | // owarn << "tab changed" << oendl; | 79 | if(wd == tab) |
71 | QString path = CurrentDir()->canonicalPath(); | 80 | odebug << "LOCAL VIEW SHOWN"<< oendl; |
81 | else if(wd == tab_2) | ||
82 | odebug<< "REMOTE VIEW SHOWN"<< oendl; | ||
83 | |||
84 | QString path = CurrentDir()->canonicalPath(); | ||
72 | currentPathCombo->lineEdit()->setText( path ); | 85 | currentPathCombo->lineEdit()->setText( path ); |
73 | 86 | ||
74 | if(whichTab == 1) { | 87 | if ( TabWidget->currentWidget() == tab) { |
88 | // if(whichTab == 1) { | ||
75 | viewMenu->setItemChecked(viewMenu->idAt(0), true); | 89 | viewMenu->setItemChecked(viewMenu->idAt(0), true); |
76 | viewMenu->setItemChecked(viewMenu->idAt(1), false); | 90 | viewMenu->setItemChecked(viewMenu->idAt(1), false); |
77 | } else { | 91 | } else { |
78 | viewMenu->setItemChecked(viewMenu->idAt(0), false); | 92 | viewMenu->setItemChecked(viewMenu->idAt(0), false); |
79 | viewMenu->setItemChecked(viewMenu->idAt(1), true); | 93 | viewMenu->setItemChecked(viewMenu->idAt(1), true); |
80 | } | 94 | } |
81 | 95 | ||
82 | QString fs= getFileSystemType( (const QString &) path); | 96 | QString fs= getFileSystemType( (const QString &) path); |
83 | 97 | ||
84 | setCaption(tr("AdvancedFm :: ")+fs+" :: " | 98 | setCaption(tr("AdvancedFm :: ")+fs+" :: " |
85 | +checkDiskSpace( (const QString &) path )+ tr(" kB free") ); | 99 | +checkDiskSpace( (const QString &) path )+ tr(" kB free") ); |
86 | chdir( path.latin1()); | 100 | chdir( path.latin1()); |
101 | if( wd == Local_View) { | ||
102 | Remote_View->clearFocus(); | ||
103 | } else { | ||
104 | Local_View->clearFocus(); | ||
105 | } | ||
106 | |||
87 | } | 107 | } |
88 | 108 | ||
89 | 109 | ||
90 | void AdvancedFm::populateView() { | 110 | void AdvancedFm::populateView() { |
91 | 111 | ||
92 | // owarn << "PopulateView" << oendl; | ||
93 | QPixmap pm; | 112 | QPixmap pm; |
94 | QListView *thisView = CurrentView(); | 113 | QListView *thisView = CurrentView(); |
95 | QDir *thisDir = CurrentDir(); | 114 | QDir *thisDir = CurrentDir(); |
96 | QString path = thisDir->canonicalPath(); | 115 | QString path = thisDir->canonicalPath(); |
97 | 116 | ||
98 | //owarn << "path is "+path << oendl; | ||
99 | thisView->clear(); | 117 | thisView->clear(); |
100 | thisDir->setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); | 118 | thisDir->setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); |
101 | thisDir->setMatchAllDirs(TRUE); | 119 | thisDir->setMatchAllDirs(TRUE); |
102 | thisDir->setNameFilter(filterStr); | 120 | thisDir->setNameFilter(filterStr); |
103 | QString fileL, fileS, fileDate; | 121 | QString fileL, fileS, fileDate; |
104 | QString fs= getFileSystemType((const QString &) path); | 122 | QString fs= getFileSystemType((const QString &) path); |
105 | setCaption(tr("AdvancedFm :: ")+fs+" :: " | 123 | setCaption(tr("AdvancedFm :: ")+fs+" :: " |
106 | +checkDiskSpace((const QString &) path)+ tr(" kB free") ); | 124 | +checkDiskSpace((const QString &) path)+ tr(" kB free") ); |
107 | bool isDir=FALSE; | 125 | bool isDir=FALSE; |
108 | const QFileInfoList *list = thisDir->entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); | 126 | const QFileInfoList *list = thisDir->entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); |
109 | QFileInfoListIterator it(*list); | 127 | QFileInfoListIterator it(*list); |
110 | QFileInfo *fi; | 128 | QFileInfo *fi; |
111 | while ( (fi=it.current()) ) { | 129 | while ( (fi=it.current()) ) { |
112 | if (fi->isSymLink() ) { | 130 | if (fi->isSymLink() ) { |
113 | QString symLink=fi->readLink(); | 131 | QString symLink=fi->readLink(); |
114 | QFileInfo sym( symLink); | 132 | QFileInfo sym( symLink); |
115 | fileS.sprintf( "%10i", sym.size() ); | 133 | fileS.sprintf( "%10i", sym.size() ); |
116 | fileL = fi->fileName() +" -> " + sym.filePath().data(); | 134 | fileL = fi->fileName() +" -> " + sym.filePath().data(); |
117 | fileDate = sym.lastModified().toString(); | 135 | fileDate = sym.lastModified().toString(); |
118 | } else { | 136 | } else { |
119 | fileS.sprintf( "%10i", fi->size() ); | 137 | fileS.sprintf( "%10i", fi->size() ); |
120 | fileL = fi->fileName(); | 138 | fileL = fi->fileName(); |
121 | fileDate= fi->lastModified().toString(); | 139 | fileDate= fi->lastModified().toString(); |
122 | if( QDir(QDir::cleanDirPath( path +"/"+fileL)).exists() ) { | 140 | if( QDir(QDir::cleanDirPath( path +"/"+fileL)).exists() ) { |
123 | // if(fileL == "..") | 141 | // if(fileL == "..") |
124 | fileL += "/"; | 142 | fileL += "/"; |
125 | isDir=TRUE; | 143 | isDir=TRUE; |
126 | } | 144 | } |
127 | } | 145 | } |
128 | QFileInfo fileInfo( path + "/" + fileL); | 146 | QFileInfo fileInfo( path + "/" + fileL); |
129 | 147 | ||
130 | if(fileL !="./" && fi->exists()) { | 148 | if(fileL !="./" && fi->exists()) { |
131 | item = new QListViewItem( thisView, fileL, fileS , fileDate); | 149 | item = new QListViewItem( thisView, fileL, fileS , fileDate); |
132 | 150 | ||
133 | if(isDir || fileL.find("/",0,TRUE) != -1) { | 151 | if(isDir || fileL.find("/",0,TRUE) != -1) { |
134 | 152 | ||
135 | if( !QDir( fi->filePath() ).isReadable()) //is directory | 153 | if( !QDir( fi->filePath() ).isReadable()) //is directory |
136 | pm = Resource::loadPixmap( "lockedfolder" ); | 154 | pm = Resource::loadPixmap( "lockedfolder" ); |
137 | else | 155 | else |
138 | pm= Resource::loadPixmap( "folder" ); | 156 | pm= Resource::loadPixmap( "folder" ); |
139 | } | 157 | } |
140 | else if ( fs == "vfat" && fileInfo.filePath().contains("/bin") ) { | 158 | else if ( fs == "vfat" && fileInfo.filePath().contains("/bin") ) { |
141 | pm = Resource::loadPixmap( "exec"); | 159 | pm = Resource::loadPixmap( "exec"); |
142 | } | 160 | } |
143 | else if( (fileInfo.permission( QFileInfo::ExeUser) | 161 | else if( (fileInfo.permission( QFileInfo::ExeUser) |
144 | | fileInfo.permission( QFileInfo::ExeGroup) | 162 | | fileInfo.permission( QFileInfo::ExeGroup) |
145 | | fileInfo.permission( QFileInfo::ExeOther)) && fs != "vfat" ) { | 163 | | fileInfo.permission( QFileInfo::ExeOther)) && fs != "vfat" ) { |
146 | pm = Resource::loadPixmap( "exec"); | 164 | pm = Resource::loadPixmap( "exec"); |
@@ -170,172 +188,180 @@ void AdvancedFm::populateView() { | |||
170 | isDir=FALSE; | 188 | isDir=FALSE; |
171 | ++it; | 189 | ++it; |
172 | } | 190 | } |
173 | 191 | ||
174 | if( path.find("dev",0,TRUE) != -1) { | 192 | if( path.find("dev",0,TRUE) != -1) { |
175 | struct stat buf; | 193 | struct stat buf; |
176 | dev_t devT; | 194 | dev_t devT; |
177 | DIR *dir; | 195 | DIR *dir; |
178 | struct dirent *mydirent; | 196 | struct dirent *mydirent; |
179 | 197 | ||
180 | if((dir = opendir( path.latin1())) != NULL) | 198 | if((dir = opendir( path.latin1())) != NULL) |
181 | while ((mydirent = readdir(dir)) != NULL) { | 199 | while ((mydirent = readdir(dir)) != NULL) { |
182 | lstat( mydirent->d_name, &buf); | 200 | lstat( mydirent->d_name, &buf); |
183 | // odebug << mydirent->d_name << oendl; | 201 | // odebug << mydirent->d_name << oendl; |
184 | fileL.sprintf("%s", mydirent->d_name); | 202 | fileL.sprintf("%s", mydirent->d_name); |
185 | devT = buf.st_dev; | 203 | devT = buf.st_dev; |
186 | fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); | 204 | fileS.sprintf("%d, %d", (int) ( devT >>8) &0xFF, (int)devT &0xFF); |
187 | fileDate.sprintf("%s", ctime( &buf.st_mtime)); | 205 | fileDate.sprintf("%s", ctime( &buf.st_mtime)); |
188 | if( fileL.find(".") == -1 ) { | 206 | if( fileL.find(".") == -1 ) { |
189 | item= new QListViewItem( thisView, fileL, fileS, fileDate); | 207 | item= new QListViewItem( thisView, fileL, fileS, fileDate); |
190 | pm = unknownXpm; | 208 | pm = unknownXpm; |
191 | item->setPixmap( 0,pm); | 209 | item->setPixmap( 0,pm); |
192 | } | 210 | } |
193 | } | 211 | } |
194 | 212 | ||
195 | closedir(dir); | 213 | closedir(dir); |
196 | } | 214 | } |
197 | 215 | ||
198 | thisView->setSorting( 3,FALSE); | 216 | thisView->setSorting( 3,FALSE); |
199 | fillCombo( (const QString &) path ); | 217 | fillCombo( (const QString &) path ); |
200 | } | 218 | } |
201 | 219 | ||
202 | void AdvancedFm::rePopulate() { | 220 | void AdvancedFm::rePopulate() { |
203 | populateView(); | 221 | populateView(); |
204 | setOtherTabCurrent(); | 222 | setOtherTabCurrent(); |
205 | populateView(); | 223 | populateView(); |
206 | 224 | ||
207 | // int tmpTab = whichTab; | 225 | // int tmpTab = whichTab; |
208 | // // odebug << "" << tmpTab << "" << oendl; | 226 | // // odebug << "" << tmpTab << "" << oendl; |
209 | 227 | ||
210 | // for(int i =1; i < 3; i++) { | 228 | // for(int i =1; i < 3; i++) { |
211 | // TabWidget->setCurrentWidget(i - 1); | 229 | // TabWidget->setCurrentWidget(i - 1); |
212 | // populateView(); | 230 | // populateView(); |
213 | // } | 231 | // } |
214 | // TabWidget->setCurrentWidget( tmpTab - 1); | 232 | // TabWidget->setCurrentWidget( tmpTab - 1); |
215 | } | 233 | } |
216 | 234 | ||
217 | void AdvancedFm::ListClicked(QListViewItem *selectedItem) { | 235 | void AdvancedFm::ListClicked(QListViewItem *selectedItem) { |
218 | //owarn << "listclicked" << oendl; | 236 | if ( TabWidget->currentWidget() == tab) |
219 | if(selectedItem) { | 237 | qDebug("XXXXXXXXXXXXXXXXXXXXXXXX ListClicked local"); |
238 | else | ||
239 | qDebug("XXXXXXXXXXXXXXXXXXXXXXXX ListClicked remote"); | ||
240 | |||
241 | |||
242 | if(selectedItem) { | ||
220 | QString strItem=selectedItem->text(0); | 243 | QString strItem=selectedItem->text(0); |
221 | // owarn << strItem << oendl; | 244 | // owarn << strItem << oendl; |
222 | QString strSize=selectedItem->text(1); | 245 | QString strSize=selectedItem->text(1); |
223 | strSize=strSize.stripWhiteSpace(); | 246 | strSize=strSize.stripWhiteSpace(); |
224 | bool isDirectory = false; | 247 | bool isDirectory = false; |
225 | QString strItem2; | 248 | QString strItem2; |
226 | 249 | ||
227 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 ) {//if symlink | 250 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 ) {//if symlink |
228 | strItem2 = dealWithSymName((const QString&)strItem); | 251 | strItem2 = dealWithSymName((const QString&)strItem); |
229 | if(QDir(strItem2).exists() ) | 252 | if(QDir(strItem2).exists() ) |
230 | strItem = strItem2; | 253 | strItem = strItem2; |
231 | } | 254 | } |
232 | 255 | ||
233 | if( strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) { | 256 | if( strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) { |
234 | 257 | ||
235 | if(QDir(strItem).exists()) | 258 | if(QDir(strItem).exists()) |
236 | isDirectory = true; | 259 | isDirectory = true; |
237 | } | 260 | } |
238 | 261 | ||
239 | if( isDirectory ) { | 262 | if( isDirectory ) { |
240 | CurrentDir()->cd( strItem, TRUE); | 263 | CurrentDir()->cd( strItem, TRUE); |
241 | populateView(); | 264 | populateView(); |
242 | CurrentView()->ensureItemVisible( CurrentView()->firstChild()); | 265 | CurrentView()->ensureItemVisible( CurrentView()->firstChild()); |
243 | } | 266 | } |
244 | chdir( strItem.latin1()); | 267 | chdir( strItem.latin1()); |
245 | } | 268 | } |
246 | } | 269 | } |
247 | 270 | ||
248 | void AdvancedFm::ListPressed( int mouse, QListViewItem *item, const QPoint& , int ) { | 271 | void AdvancedFm::ListPressed( int mouse, QListViewItem *item, const QPoint& , int ) { |
249 | dealWithSchmooSchmaa( item->listView()); | 272 | Q_UNUSED(item); |
250 | switch (mouse) { | 273 | switch (mouse) { |
251 | case 1: | 274 | case 1: |
252 | { | 275 | { |
253 | if(renameBox != 0 ) { | 276 | if(renameBox != 0 ) { |
254 | cancelRename(); | 277 | cancelRename(); |
255 | } | 278 | } |
256 | } | 279 | } |
257 | break; | 280 | break; |
281 | // case 2: | ||
282 | // menuTimer.start( 50, TRUE ); | ||
283 | // break; | ||
258 | }; | 284 | }; |
259 | } | 285 | } |
260 | 286 | ||
261 | 287 | ||
262 | void AdvancedFm::switchToLocalTab() { | 288 | void AdvancedFm::switchToLocalTab() { |
263 | //owarn << "switch to local view" << oendl; | ||
264 | TabWidget->setCurrentWidget(0); | 289 | TabWidget->setCurrentWidget(0); |
265 | Local_View->setFocus(); | 290 | Local_View->setFocus(); |
291 | |||
266 | } | 292 | } |
267 | 293 | ||
268 | void AdvancedFm::switchToRemoteTab() { | 294 | void AdvancedFm::switchToRemoteTab() { |
269 | //owarn << "switch to local view" << oendl; | ||
270 | TabWidget->setCurrentWidget(1); | 295 | TabWidget->setCurrentWidget(1); |
271 | Remote_View->setFocus(); | 296 | Remote_View->setFocus(); |
272 | } | 297 | } |
273 | 298 | ||
274 | void AdvancedFm::readConfig() { | 299 | void AdvancedFm::readConfig() { |
275 | Config cfg("AdvancedFm"); | 300 | Config cfg("AdvancedFm"); |
276 | } | 301 | } |
277 | 302 | ||
278 | void AdvancedFm::writeConfig() { | 303 | void AdvancedFm::writeConfig() { |
279 | Config cfg("AdvancedFm"); | 304 | Config cfg("AdvancedFm"); |
280 | } | 305 | } |
281 | 306 | ||
282 | void AdvancedFm::currentPathComboChanged() { | 307 | void AdvancedFm::currentPathComboChanged() { |
283 | if(QDir( currentPathCombo->lineEdit()->text()).exists()) { | 308 | if(QDir( currentPathCombo->lineEdit()->text()).exists()) { |
284 | CurrentDir()->setPath( currentPathCombo->lineEdit()->text() ); | 309 | CurrentDir()->setPath( currentPathCombo->lineEdit()->text() ); |
285 | populateView(); | 310 | populateView(); |
286 | } else { | 311 | } else { |
287 | QMessageBox::message(tr("Note"),tr("That directory does not exist")); | 312 | QMessageBox::message(tr("Note"),tr("That directory does not exist")); |
288 | } | 313 | } |
289 | } | 314 | } |
290 | 315 | ||
291 | void AdvancedFm::fillCombo(const QString ¤tPath) { | 316 | void AdvancedFm::fillCombo(const QString ¤tPath) { |
292 | 317 | ||
293 | if ( whichTab == 1) { | 318 | if ( TabWidget->currentWidget() == tab) { |
319 | // if ( whichTab == 1) { | ||
294 | currentPathCombo->lineEdit()->setText( currentPath); | 320 | currentPathCombo->lineEdit()->setText( currentPath); |
295 | if( localDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { | 321 | if( localDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { |
296 | currentPathCombo->clear(); | 322 | currentPathCombo->clear(); |
297 | localDirPathStringList.prepend( currentPath ); | 323 | localDirPathStringList.prepend( currentPath ); |
298 | currentPathCombo->insertStringList( localDirPathStringList,-1); | 324 | currentPathCombo->insertStringList( localDirPathStringList,-1); |
299 | } | 325 | } |
300 | } else { | 326 | } else { |
301 | currentPathCombo->lineEdit()->setText( currentPath); | 327 | currentPathCombo->lineEdit()->setText( currentPath); |
302 | if( remoteDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { | 328 | if( remoteDirPathStringList.grep( currentPath,TRUE).isEmpty() ) { |
303 | currentPathCombo->clear(); | 329 | currentPathCombo->clear(); |
304 | remoteDirPathStringList.prepend( currentPath ); | 330 | remoteDirPathStringList.prepend( currentPath ); |
305 | currentPathCombo->insertStringList( remoteDirPathStringList,-1); | 331 | currentPathCombo->insertStringList( remoteDirPathStringList,-1); |
306 | } | 332 | } |
307 | } | 333 | } |
308 | } | 334 | } |
309 | 335 | ||
310 | void AdvancedFm::currentPathComboActivated(const QString & currentPath) { | 336 | void AdvancedFm::currentPathComboActivated(const QString & currentPath) { |
311 | chdir( currentPath.latin1() ); | 337 | chdir( currentPath.latin1() ); |
312 | CurrentDir()->cd( currentPath, TRUE); | 338 | CurrentDir()->cd( currentPath, TRUE); |
313 | populateView(); | 339 | populateView(); |
314 | update(); | 340 | update(); |
315 | } | 341 | } |
316 | 342 | ||
317 | QStringList AdvancedFm::getPath() { | 343 | QStringList AdvancedFm::getPath() { |
318 | QStringList strList; | 344 | QStringList strList; |
319 | QListView *thisView=CurrentView(); | 345 | QListView *thisView=CurrentView(); |
320 | QList<QListViewItem> * getSelectedItems( QListView * thisView ); | 346 | QList<QListViewItem> * getSelectedItems( QListView * thisView ); |
321 | QListViewItemIterator it( thisView ); | 347 | QListViewItemIterator it( thisView ); |
322 | for ( ; it.current(); ++it ) { | 348 | for ( ; it.current(); ++it ) { |
323 | if ( it.current()->isSelected() ) { | 349 | if ( it.current()->isSelected() ) { |
324 | strList << it.current()->text(0); | 350 | strList << it.current()->text(0); |
325 | // odebug << it.current()->text(0) << oendl; | 351 | // odebug << it.current()->text(0) << oendl; |
326 | } | 352 | } |
327 | } | 353 | } |
328 | return strList; | 354 | return strList; |
329 | } | 355 | } |
330 | 356 | ||
331 | void AdvancedFm::homeButtonPushed() { | 357 | void AdvancedFm::homeButtonPushed() { |
332 | QString current = QDir::homeDirPath(); | 358 | QString current = QDir::homeDirPath(); |
333 | chdir( current.latin1() ); | 359 | chdir( current.latin1() ); |
334 | CurrentDir()->cd( current, TRUE); | 360 | CurrentDir()->cd( current, TRUE); |
335 | populateView(); | 361 | populateView(); |
336 | update(); | 362 | update(); |
337 | } | 363 | } |
338 | 364 | ||
339 | void AdvancedFm::docButtonPushed() { | 365 | void AdvancedFm::docButtonPushed() { |
340 | QString current = QPEApplication::documentDir(); | 366 | QString current = QPEApplication::documentDir(); |
341 | chdir( current.latin1() ); | 367 | chdir( current.latin1() ); |
@@ -712,161 +738,161 @@ void AdvancedFm::removeCustomDir() { | |||
712 | QMessageBox::message(tr( "AdvancedFm" ), | 738 | QMessageBox::message(tr( "AdvancedFm" ), |
713 | tr("Cannot remove current directory\nfrom bookmarks.\nIt is not bookmarked!")); | 739 | tr("Cannot remove current directory\nfrom bookmarks.\nIt is not bookmarked!")); |
714 | } else { | 740 | } else { |
715 | for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { | 741 | for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { |
716 | if((*it) != dir) { | 742 | if((*it) != dir) { |
717 | //current item is not our current dir, so add it to temp list | 743 | //current item is not our current dir, so add it to temp list |
718 | list2 <<(*it); | 744 | list2 <<(*it); |
719 | } else { | 745 | } else { |
720 | // customDirMenu->removeItem( ramble); | 746 | // customDirMenu->removeItem( ramble); |
721 | menuButton->remove( ramble); | 747 | menuButton->remove( ramble); |
722 | 748 | ||
723 | } | 749 | } |
724 | ramble++; | 750 | ramble++; |
725 | // ramble--; | 751 | // ramble--; |
726 | } | 752 | } |
727 | 753 | ||
728 | cfg.writeEntry("CustomDir", list2, ','); | 754 | cfg.writeEntry("CustomDir", list2, ','); |
729 | cfg.write(); | 755 | cfg.write(); |
730 | } | 756 | } |
731 | // customDirsToMenu(); | 757 | // customDirsToMenu(); |
732 | 758 | ||
733 | } | 759 | } |
734 | 760 | ||
735 | void AdvancedFm::gotoCustomDir(const QString &dir) { | 761 | void AdvancedFm::gotoCustomDir(const QString &dir) { |
736 | // odebug << "gotoCustomDir(const QString &dir) " +dir << oendl; | 762 | // odebug << "gotoCustomDir(const QString &dir) " +dir << oendl; |
737 | // QString curDir = dir; | 763 | // QString curDir = dir; |
738 | // QDir *thisDir = CurrentDir(); | 764 | // QDir *thisDir = CurrentDir(); |
739 | // if( curDir.isEmpty()) { | 765 | // if( curDir.isEmpty()) { |
740 | // } | 766 | // } |
741 | if( dir == s_addBookmark) { | 767 | if( dir == s_addBookmark) { |
742 | addCustomDir(); | 768 | addCustomDir(); |
743 | } | 769 | } |
744 | if( dir == s_removeBookmark) { | 770 | if( dir == s_removeBookmark) { |
745 | removeCustomDir( ); | 771 | removeCustomDir( ); |
746 | } else { | 772 | } else { |
747 | gotoDirectory( dir); | 773 | gotoDirectory( dir); |
748 | // if(QDir( curDir).exists() ) | 774 | // if(QDir( curDir).exists() ) |
749 | // { | 775 | // { |
750 | // thisDir->setPath( curDir ); | 776 | // thisDir->setPath( curDir ); |
751 | // chdir( curDir.latin1() ); | 777 | // chdir( curDir.latin1() ); |
752 | // thisDir->cd( curDir, TRUE); | 778 | // thisDir->cd( curDir, TRUE); |
753 | // populateView(); | 779 | // populateView(); |
754 | // } | 780 | // } |
755 | } | 781 | } |
756 | } | 782 | } |
757 | 783 | ||
758 | QDir *AdvancedFm::CurrentDir() { | 784 | QDir *AdvancedFm::CurrentDir() { |
759 | 785 | ||
786 | if ( TabWidget->currentWidget() == tab) | ||
787 | qDebug("CurrentTab is Local"); | ||
788 | else | ||
789 | qDebug("CurrentTab is Remote"); | ||
790 | |||
760 | if ( whichTab == 1) { | 791 | if ( whichTab == 1) { |
761 | return ¤tDir; | 792 | return ¤tDir; |
762 | } else { | 793 | } else { |
763 | return ¤tRemoteDir; | 794 | return ¤tRemoteDir; |
764 | } | 795 | } |
765 | } | 796 | } |
766 | 797 | ||
767 | QDir *AdvancedFm::OtherDir() { | 798 | QDir *AdvancedFm::OtherDir() { |
799 | // if ( TabWidget->currentWidget() == tab) { | ||
768 | if ( whichTab == 1) { | 800 | if ( whichTab == 1) { |
769 | return ¤tRemoteDir; | 801 | return ¤tRemoteDir; |
770 | } else { | 802 | } else { |
771 | return ¤tDir; | 803 | return ¤tDir; |
772 | } | 804 | } |
773 | } | 805 | } |
774 | 806 | ||
775 | QListView * AdvancedFm::CurrentView() { | 807 | QListView * AdvancedFm::CurrentView() { |
808 | if ( TabWidget->currentWidget() == tab) | ||
809 | odebug << "CurrentView local" << oendl; | ||
810 | |||
811 | // if ( TabWidget->currentWidget() == tab) { | ||
776 | if ( whichTab == 1) { | 812 | if ( whichTab == 1) { |
777 | // owarn << "CurrentView Tab 1" << oendl; | ||
778 | return Local_View; | 813 | return Local_View; |
779 | } else { | 814 | } else { |
780 | // owarn << "CurrentView Tab 2" << oendl; | 815 | // owarn << "CurrentView Tab 2" << oendl; |
781 | return Remote_View; | 816 | return Remote_View; |
782 | } | 817 | } |
783 | } | 818 | } |
784 | 819 | ||
785 | QListView * AdvancedFm::OtherView() { | 820 | QListView * AdvancedFm::OtherView() { |
786 | if ( whichTab == 1) | 821 | if ( whichTab == 1) |
787 | return Remote_View; | 822 | return Remote_View; |
788 | else | 823 | else |
789 | return Local_View; | 824 | return Local_View; |
790 | } | 825 | } |
791 | 826 | ||
792 | void AdvancedFm::setOtherTabCurrent() { | 827 | void AdvancedFm::setOtherTabCurrent() { |
793 | // owarn << "setOtherTabCurrent() " << whichTab << "" << oendl; | 828 | qDebug("setOtherTabCurrent() %d",whichTab); |
794 | if ( whichTab == 1) { | 829 | if ( whichTab == 1) { |
795 | TabWidget->setCurrentWidget(1); | 830 | TabWidget->setCurrentWidget(1); |
796 | } else { | 831 | } else { |
797 | TabWidget->setCurrentWidget(0); | 832 | TabWidget->setCurrentWidget(0); |
798 | } | 833 | } |
799 | OtherView()->setFocus(); | 834 | OtherView()->setFocus(); |
800 | OtherView()->setSelected( CurrentView()->firstChild(), true); | 835 | OtherView()->setSelected( CurrentView()->firstChild(), true); |
801 | } | 836 | } |
802 | 837 | ||
803 | void AdvancedFm::qcopReceive(const QCString &msg, const QByteArray &data) { | 838 | void AdvancedFm::qcopReceive(const QCString &msg, const QByteArray &data) { |
804 | // odebug << "qcop message "+msg << oendl; | 839 | // odebug << "qcop message "+msg << oendl; |
805 | QDataStream stream ( data, IO_ReadOnly ); | 840 | QDataStream stream ( data, IO_ReadOnly ); |
806 | if ( msg == "openDirectory(QString)" ) { | 841 | if ( msg == "openDirectory(QString)" ) { |
807 | // odebug << "received" << oendl; | 842 | // odebug << "received" << oendl; |
808 | QString file; | 843 | QString file; |
809 | stream >> file; | 844 | stream >> file; |
810 | gotoDirectory( (const QString &) file); | 845 | gotoDirectory( (const QString &) file); |
811 | } | 846 | } |
812 | } | 847 | } |
813 | 848 | ||
814 | void AdvancedFm::setDocument(const QString &file) { | 849 | void AdvancedFm::setDocument(const QString &file) { |
815 | gotoDirectory( file); | 850 | gotoDirectory( file); |
816 | 851 | ||
817 | } | 852 | } |
818 | 853 | ||
819 | void AdvancedFm::gotoDirectory(const QString &file) { | 854 | void AdvancedFm::gotoDirectory(const QString &file) { |
820 | // owarn << "goto dir "+file << oendl; | 855 | qDebug("goto dir "+file); |
821 | QString curDir = file; | 856 | QString curDir = file; |
822 | QDir *thisDir = CurrentDir(); | 857 | QDir *thisDir = CurrentDir(); |
823 | if(QDir( curDir).exists() ) { | 858 | if(QDir( curDir).exists() ) { |
824 | thisDir->setPath( curDir ); | 859 | thisDir->setPath( curDir ); |
825 | chdir( curDir.latin1() ); | 860 | chdir( curDir.latin1() ); |
826 | thisDir->cd( curDir, TRUE); | 861 | thisDir->cd( curDir, TRUE); |
827 | populateView(); | 862 | populateView(); |
828 | } | 863 | } |
829 | else if(QFileInfo(curDir).exists()) { | 864 | else if(QFileInfo(curDir).exists()) { |
830 | QFileInfo fileInfo(curDir); | 865 | QFileInfo fileInfo(curDir); |
831 | curDir=fileInfo.dirPath(); | 866 | curDir=fileInfo.dirPath(); |
832 | if(QDir( curDir).exists() ) { | 867 | if(QDir( curDir).exists() ) { |
833 | thisDir->setPath( curDir ); | 868 | thisDir->setPath( curDir ); |
834 | chdir( curDir.latin1() ); | 869 | chdir( curDir.latin1() ); |
835 | thisDir->cd( curDir, TRUE); | 870 | thisDir->cd( curDir, TRUE); |
836 | populateView(); | 871 | populateView(); |
837 | } | 872 | } |
838 | findFile(file); | 873 | findFile(file); |
839 | } | 874 | } |
840 | 875 | ||
841 | } | 876 | } |
842 | 877 | ||
843 | void AdvancedFm::findFile(const QString &fileName) { | 878 | void AdvancedFm::findFile(const QString &fileName) { |
844 | QFileInfo fi(fileName); | 879 | QFileInfo fi(fileName); |
845 | QListView *thisView = CurrentView(); | 880 | QListView *thisView = CurrentView(); |
846 | QListViewItemIterator it( thisView ); | 881 | QListViewItemIterator it( thisView ); |
847 | for ( ; it.current(); ++it ) { | 882 | for ( ; it.current(); ++it ) { |
848 | if(it.current()->text(0) == fi.fileName()) { | 883 | if(it.current()->text(0) == fi.fileName()) { |
849 | it.current()->setSelected(true); | 884 | it.current()->setSelected(true); |
850 | thisView->ensureItemVisible(it.current()); | 885 | thisView->ensureItemVisible(it.current()); |
851 | } | 886 | } |
852 | } | 887 | } |
853 | } | 888 | } |
854 | 889 | ||
855 | void AdvancedFm::slotSwitchMenu(int ) { | 890 | void AdvancedFm::slotSwitchMenu(int ) { |
856 | // odebug << "Switch " << item << "" << oendl; | 891 | // odebug << "Switch " << item << "" << oendl; |
857 | // viewMenu->setItemChecked(item, true); | 892 | // viewMenu->setItemChecked(item, true); |
858 | } | 893 | } |
859 | 894 | ||
860 | void AdvancedFm::dealWithSchmooSchmaa(QWidget *w) { | ||
861 | tabChanged( w); | ||
862 | if( w == Local_View) { | ||
863 | Remote_View->clearFocus(); | ||
864 | } else { | ||
865 | Local_View->clearFocus(); | ||
866 | } | ||
867 | } | ||
868 | |||
869 | void AdvancedFm::navigateToSelected() { | 895 | void AdvancedFm::navigateToSelected() { |
870 | if( !CurrentView()->currentItem()) return; | 896 | if( !CurrentView()->currentItem()) return; |
871 | doDirChange(); | 897 | doDirChange(); |
872 | } | 898 | } |
diff --git a/noncore/apps/advancedfm/advancedfm.h b/noncore/apps/advancedfm/advancedfm.h index effda0b..e596977 100644 --- a/noncore/apps/advancedfm/advancedfm.h +++ b/noncore/apps/advancedfm/advancedfm.h | |||
@@ -84,102 +84,103 @@ protected slots: | |||
84 | void doProperties(); | 84 | void doProperties(); |
85 | void runCommand(); | 85 | void runCommand(); |
86 | void runCommandStd(); | 86 | void runCommandStd(); |
87 | QStringList getPath(); | 87 | QStringList getPath(); |
88 | void mkSym(); | 88 | void mkSym(); |
89 | void switchToLocalTab(); | 89 | void switchToLocalTab(); |
90 | void switchToRemoteTab(); | 90 | void switchToRemoteTab(); |
91 | 91 | ||
92 | protected: | 92 | protected: |
93 | 93 | ||
94 | Opie::Ui::OSplitter *TabWidget; | 94 | Opie::Ui::OSplitter *TabWidget; |
95 | QCopChannel * channel; | 95 | QCopChannel * channel; |
96 | QPixmap unknownXpm; | 96 | QPixmap unknownXpm; |
97 | int whichTab; | 97 | int whichTab; |
98 | // QTabWidget *TabWidget; | 98 | // QTabWidget *TabWidget; |
99 | QWidget *tab, *tab_2, *tab_3; | 99 | QWidget *tab, *tab_2, *tab_3; |
100 | QListView *Local_View, *Remote_View; | 100 | QListView *Local_View, *Remote_View; |
101 | 101 | ||
102 | QLineEdit *currentPathEdit; | 102 | QLineEdit *currentPathEdit; |
103 | QPopupMenu *fileMenu, *localMenu, *remoteMenu, *viewMenu /*, *customDirMenu*/; | 103 | QPopupMenu *fileMenu, *localMenu, *remoteMenu, *viewMenu /*, *customDirMenu*/; |
104 | QToolButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; | 104 | QToolButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; |
105 | // QPushButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; | 105 | // QPushButton *homeButton, *docButton, *cdUpButton, *sdButton, *cfButton, *qpeDirButton; |
106 | QDir currentDir, currentRemoteDir; | 106 | QDir currentDir, currentRemoteDir; |
107 | QComboBox *currentPathCombo; | 107 | QComboBox *currentPathCombo; |
108 | QString filterStr, s_addBookmark, s_removeBookmark; | 108 | QString filterStr, s_addBookmark, s_removeBookmark; |
109 | QListViewItem * item; | 109 | QListViewItem * item; |
110 | bool b; | 110 | bool b; |
111 | QStringList fileSystemTypeList, fsList; | 111 | QStringList fileSystemTypeList, fsList; |
112 | int currentServerConfig; | 112 | int currentServerConfig; |
113 | bool zaurusDevice; | 113 | bool zaurusDevice; |
114 | QGridLayout *tabLayout, *tabLayout_2, *tabLayout_3; | 114 | QGridLayout *tabLayout, *tabLayout_2, *tabLayout_3; |
115 | QStringList remoteDirPathStringList, localDirPathStringList; | 115 | QStringList remoteDirPathStringList, localDirPathStringList; |
116 | QLineEdit *renameBox; | 116 | QLineEdit *renameBox; |
117 | 117 | ||
118 | void init(); | 118 | void init(); |
119 | void initConnections(); | 119 | void initConnections(); |
120 | void keyReleaseEvent( QKeyEvent *); | 120 | void keyReleaseEvent( QKeyEvent *); |
121 | void keyPressEvent( QKeyEvent *); | 121 | void keyPressEvent( QKeyEvent *); |
122 | QString getFileSystemType(const QString &); | 122 | QString getFileSystemType(const QString &); |
123 | QString getDiskSpace(const QString &); | 123 | QString getDiskSpace(const QString &); |
124 | void parsetab(const QString &fileName); | 124 | void parsetab(const QString &fileName); |
125 | QString checkDiskSpace(const QString &); | 125 | QString checkDiskSpace(const QString &); |
126 | QString dealWithSymName(const QString &); | 126 | QString dealWithSymName(const QString &); |
127 | QDir *CurrentDir(); | 127 | QDir *CurrentDir(); |
128 | QDir *OtherDir(); | 128 | QDir *OtherDir(); |
129 | QListView *CurrentView(); | 129 | QListView *CurrentView(); |
130 | QListView *OtherView(); | 130 | QListView *OtherView(); |
131 | void setOtherTabCurrent(); | 131 | void setOtherTabCurrent(); |
132 | void dealWithSchmooSchmaa(QWidget *); | ||
133 | 132 | ||
134 | protected slots: | 133 | protected slots: |
134 | |||
135 | void openSearch(); | 135 | void openSearch(); |
136 | void dirMenuSelected(int); | 136 | void dirMenuSelected(int); |
137 | void showFileMenu(); | 137 | void showFileMenu(); |
138 | void homeButtonPushed(); | 138 | void homeButtonPushed(); |
139 | void docButtonPushed(); | 139 | void docButtonPushed(); |
140 | void SDButtonPushed(); | 140 | void SDButtonPushed(); |
141 | void CFButtonPushed(); | 141 | void CFButtonPushed(); |
142 | void QPEButtonPushed(); | 142 | void QPEButtonPushed(); |
143 | void upDir(); | 143 | void upDir(); |
144 | void currentPathComboChanged(); | 144 | void currentPathComboChanged(); |
145 | void copy(); | 145 | void copy(); |
146 | void copyAs(); | 146 | void copyAs(); |
147 | void copySameDir(); | 147 | void copySameDir(); |
148 | void currentPathComboActivated(const QString &); | 148 | void currentPathComboActivated(const QString &); |
149 | void fillCombo(const QString &); | 149 | void fillCombo(const QString &); |
150 | bool copyFile( const QString & , const QString & ); | 150 | bool copyFile( const QString & , const QString & ); |
151 | void move(); | 151 | void move(); |
152 | void fileStatus(); | 152 | void fileStatus(); |
153 | void doAbout(); | 153 | void doAbout(); |
154 | void doBeam(); | 154 | void doBeam(); |
155 | void fileBeamFinished( Ir *); | 155 | void fileBeamFinished( Ir *); |
156 | bool copyDirectory( const QString & , const QString & ); | 156 | bool copyDirectory( const QString & , const QString & ); |
157 | // void navigateToSelected(); | 157 | // void navigateToSelected(); |
158 | bool moveDirectory( const QString & , const QString & ); | 158 | bool moveDirectory( const QString & , const QString & ); |
159 | |||
159 | // void slotSwitchtoLocal(int); | 160 | // void slotSwitchtoLocal(int); |
160 | 161 | ||
161 | private: | 162 | private: |
162 | MenuButton *menuButton; | 163 | MenuButton *menuButton; |
163 | QString oldName; | 164 | QString oldName; |
164 | void startProcess(const QString &); | 165 | void startProcess(const QString &); |
165 | bool eventFilter( QObject * , QEvent * ); | 166 | bool eventFilter( QObject * , QEvent * ); |
166 | void cancelRename(); | 167 | void cancelRename(); |
167 | void doRename(QListView *); | 168 | void doRename(QListView *); |
168 | void okRename(); | 169 | void okRename(); |
169 | void customDirsToMenu(); | 170 | void customDirsToMenu(); |
170 | void addCustomDir(); | 171 | void addCustomDir(); |
171 | void removeCustomDir(); | 172 | void removeCustomDir(); |
172 | void gotoDirectory(const QString &); | 173 | void gotoDirectory(const QString &); |
173 | void navigateToSelected(); | 174 | void navigateToSelected(); |
174 | void findFile(const QString &); | 175 | void findFile(const QString &); |
175 | 176 | ||
176 | private slots: | 177 | private slots: |
177 | void processEnded(Opie::Core::OProcess *); | 178 | void processEnded(Opie::Core::OProcess *); |
178 | void oprocessStderr(Opie::Core::OProcess *, char *, int); | 179 | void oprocessStderr(Opie::Core::OProcess *, char *, int); |
179 | void gotoCustomDir(const QString &); | 180 | void gotoCustomDir(const QString &); |
180 | void qcopReceive(const QCString&, const QByteArray&); | 181 | void qcopReceive(const QCString&, const QByteArray&); |
181 | void setDocument(const QString &); | 182 | void setDocument(const QString &); |
182 | 183 | ||
183 | }; | 184 | }; |
184 | 185 | ||
185 | #endif // ADVANCEDFM_H | 186 | #endif // ADVANCEDFM_H |
diff --git a/noncore/apps/advancedfm/advancedfm.pro b/noncore/apps/advancedfm/advancedfm.pro index f1c518e..0644edb 100644 --- a/noncore/apps/advancedfm/advancedfm.pro +++ b/noncore/apps/advancedfm/advancedfm.pro | |||
@@ -1,15 +1,15 @@ | |||
1 | TEMPLATE = app | 1 | TEMPLATE = app |
2 | CONFIG += qt warn_on quick-app | 2 | CONFIG += qt warn_on quick-app |
3 | HEADERS = advancedfm.h filePermissions.h output.h | 3 | HEADERS = advancedfm.h filePermissions.h output.h |
4 | SOURCES = advancedfm.cpp advancedfmData.cpp advancedfmMenu.cpp filePermissions.cpp output.cpp main.cpp | 4 | SOURCES = advancedfm.cpp advancedfmData.cpp advancedfmMenu.cpp filePermissions.cpp output.cpp main.cpp |
5 | TARGET = advancedfm | 5 | TARGET = advancedfm |
6 | INCLUDEPATH += $(OPIEDIR)/include | 6 | INCLUDEPATH += $(OPIEDIR)/include |
7 | DEPENDPATH += $(OPIEDIR)/include | 7 | DEPENDPATH += $(OPIEDIR)/include |
8 | LIBS += -lqpe -lopiecore2 -lopieui2 | 8 | LIBS += -lqpe -lqte -lopiecore2 -lopieui2 |
9 | 9 | ||
10 | !contains(CONFIG,quick-app) { | 10 | !contains(CONFIG,quick-app) { |
11 | DESTDIR = $(OPIEDIR)/bin | 11 | DESTDIR = $(OPIEDIR)/bin |
12 | DEFINES += NOQUICKLAUNCH | 12 | DEFINES += NOQUICKLAUNCH |
13 | } | 13 | } |
14 | 14 | ||
15 | include ( $(OPIEDIR)/include.pro ) | 15 | include ( $(OPIEDIR)/include.pro ) |
diff --git a/noncore/apps/advancedfm/advancedfmMenu.cpp b/noncore/apps/advancedfm/advancedfmMenu.cpp index 4628170..8d04c68 100644 --- a/noncore/apps/advancedfm/advancedfmMenu.cpp +++ b/noncore/apps/advancedfm/advancedfmMenu.cpp | |||
@@ -289,142 +289,143 @@ void AdvancedFm::copy() { | |||
289 | { | 289 | { |
290 | case 0: | 290 | case 0: |
291 | doMsg=false; | 291 | doMsg=false; |
292 | break; | 292 | break; |
293 | case 1: | 293 | case 1: |
294 | return; | 294 | return; |
295 | break; | 295 | break; |
296 | }; | 296 | }; |
297 | } | 297 | } |
298 | 298 | ||
299 | QString curFile, item, destFile; | 299 | QString curFile, item, destFile; |
300 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 300 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
301 | item=(*it); | 301 | item=(*it); |
302 | if(item.find("->",0,TRUE)) //symlink | 302 | if(item.find("->",0,TRUE)) //symlink |
303 | item = item.left(item.find("->",0,TRUE)); | 303 | item = item.left(item.find("->",0,TRUE)); |
304 | 304 | ||
305 | curFile = thisDir->canonicalPath()+"/"+ item; | 305 | curFile = thisDir->canonicalPath()+"/"+ item; |
306 | destFile = thatDir->canonicalPath()+"/"+ item; | 306 | destFile = thatDir->canonicalPath()+"/"+ item; |
307 | 307 | ||
308 | // odebug << "Destination file is "+destFile << oendl; | 308 | // odebug << "Destination file is "+destFile << oendl; |
309 | // odebug << "CurrentFile file is " + curFile << oendl; | 309 | // odebug << "CurrentFile file is " + curFile << oendl; |
310 | 310 | ||
311 | QFile f(destFile); | 311 | QFile f(destFile); |
312 | if( f.exists()) { | 312 | if( f.exists()) { |
313 | if(doMsg) { | 313 | if(doMsg) { |
314 | switch ( QMessageBox::warning(this,tr("File Exists!"), | 314 | switch ( QMessageBox::warning(this,tr("File Exists!"), |
315 | tr("%1 exists. Ok to overwrite?").arg( item ), | 315 | tr("%1 exists. Ok to overwrite?").arg( item ), |
316 | tr("Yes"),tr("No"),0,0,1) ) { | 316 | tr("Yes"),tr("No"),0,0,1) ) { |
317 | case 1: | 317 | case 1: |
318 | return; | 318 | return; |
319 | break; | 319 | break; |
320 | }; | 320 | }; |
321 | } | 321 | } |
322 | f.remove(); | 322 | f.remove(); |
323 | } | 323 | } |
324 | 324 | ||
325 | if( !copyFile( curFile, destFile) ) { | 325 | if( !copyFile( curFile, destFile) ) { |
326 | QMessageBox::message("AdvancedFm", | 326 | QMessageBox::message("AdvancedFm", |
327 | tr( "Could not copy %1 to %2").arg( curFile ).arg( destFile ) ); | 327 | tr( "Could not copy %1 to %2").arg( curFile ).arg( destFile ) ); |
328 | return; | 328 | return; |
329 | } | 329 | } |
330 | } | 330 | } |
331 | setOtherTabCurrent(); | 331 | setOtherTabCurrent(); |
332 | rePopulate(); | 332 | rePopulate(); |
333 | } | 333 | } |
334 | } | 334 | } |
335 | 335 | ||
336 | void AdvancedFm::copyAs() { | 336 | void AdvancedFm::copyAs() { |
337 | qApp->processEvents(); | ||
338 | 337 | ||
339 | QStringList curFileList = getPath(); | 338 | QStringList curFileList = getPath(); |
340 | QString curFile, item; | 339 | QString curFile, item; |
341 | InputDialog *fileDlg; | 340 | InputDialog *fileDlg; |
342 | 341 | ||
343 | QDir *thisDir = CurrentDir(); | 342 | QDir *thisDir = CurrentDir(); |
344 | QDir *thatDir = OtherDir(); | 343 | QDir *thatDir = OtherDir(); |
345 | 344 | ||
346 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 345 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
347 | QString destFile; | 346 | QString destFile; |
348 | item=(*it); | 347 | item=(*it); |
349 | curFile = thisDir->canonicalPath()+"/"+(*it); | 348 | curFile = thisDir->canonicalPath()+"/"+(*it); |
350 | fileDlg = new InputDialog( this, tr("Copy "+curFile+" As"), TRUE, 0); | 349 | fileDlg = new InputDialog( this, tr("Copy "+curFile+" As"), TRUE, 0); |
351 | 350 | ||
352 | fileDlg->setInputText((const QString &) destFile ); | 351 | fileDlg->setInputText((const QString &) destFile ); |
353 | fileDlg->exec(); | 352 | fileDlg->exec(); |
354 | 353 | ||
355 | if( fileDlg->result() == 1 ) { | 354 | if( fileDlg->result() == 1 ) { |
356 | QString filename = fileDlg->LineEdit1->text(); | 355 | QString filename = fileDlg->LineEdit1->text(); |
357 | destFile = thatDir->canonicalPath()+"/"+filename; | 356 | destFile = thatDir->canonicalPath()+"/"+filename; |
358 | 357 | ||
359 | QFile f( destFile); | 358 | QFile f( destFile); |
360 | if( f.exists()) { | 359 | if( f.exists()) { |
361 | switch (QMessageBox::warning(this,tr("File Exists!"), | 360 | switch (QMessageBox::warning(this,tr("File Exists!"), |
362 | item+tr("\nexists. Ok to overwrite?"), | 361 | item+tr("\nexists. Ok to overwrite?"), |
363 | tr("Yes"),tr("No"),0,0,1) ) { | 362 | tr("Yes"),tr("No"),0,0,1) ) { |
364 | case 0: | 363 | case 0: |
365 | f.remove(); | 364 | f.remove(); |
366 | break; | 365 | break; |
367 | case 1: | 366 | case 1: |
368 | return; | 367 | return; |
369 | break; | 368 | break; |
370 | }; | 369 | }; |
371 | } | 370 | } |
372 | if( !copyFile( curFile, destFile) ) { | 371 | if( !copyFile( curFile, destFile) ) { |
373 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") | 372 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") |
374 | +curFile +tr("to\n")+destFile); | 373 | +curFile +tr("to\n")+destFile); |
375 | return; | 374 | return; |
376 | } | 375 | } |
377 | } | 376 | } |
378 | delete fileDlg; | 377 | delete fileDlg; |
379 | 378 | ||
380 | } | 379 | } |
381 | rePopulate(); | 380 | rePopulate(); |
382 | setOtherTabCurrent(); | 381 | setOtherTabCurrent(); |
382 | qApp->processEvents(); | ||
383 | |||
383 | } | 384 | } |
384 | 385 | ||
385 | void AdvancedFm::copySameDir() { | 386 | void AdvancedFm::copySameDir() { |
386 | qApp->processEvents(); | 387 | qApp->processEvents(); |
387 | QStringList curFileList = getPath(); | 388 | QStringList curFileList = getPath(); |
388 | QString curFile, item, destFile; | 389 | QString curFile, item, destFile; |
389 | InputDialog *fileDlg; | 390 | InputDialog *fileDlg; |
390 | 391 | ||
391 | QDir *thisDir = CurrentDir(); | 392 | QDir *thisDir = CurrentDir(); |
392 | 393 | ||
393 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 394 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
394 | item=(*it); | 395 | item=(*it); |
395 | curFile = thisDir->canonicalPath()+"/"+ item; | 396 | curFile = thisDir->canonicalPath()+"/"+ item; |
396 | 397 | ||
397 | fileDlg = new InputDialog(this,tr("Copy ")+curFile+tr(" As"),TRUE, 0); | 398 | fileDlg = new InputDialog(this,tr("Copy ")+curFile+tr(" As"),TRUE, 0); |
398 | fileDlg->setInputText((const QString &) destFile ); | 399 | fileDlg->setInputText((const QString &) destFile ); |
399 | fileDlg->exec(); | 400 | fileDlg->exec(); |
400 | 401 | ||
401 | if( fileDlg->result() == 1 ) { | 402 | if( fileDlg->result() == 1 ) { |
402 | 403 | ||
403 | QString filename = fileDlg->LineEdit1->text(); | 404 | QString filename = fileDlg->LineEdit1->text(); |
404 | destFile = thisDir->canonicalPath()+"/"+filename; | 405 | destFile = thisDir->canonicalPath()+"/"+filename; |
405 | 406 | ||
406 | QFile f(destFile); | 407 | QFile f(destFile); |
407 | if( f.exists()) { | 408 | if( f.exists()) { |
408 | switch (QMessageBox::warning(this,tr("Delete"), | 409 | switch (QMessageBox::warning(this,tr("Delete"), |
409 | destFile+tr(" already exists.\nDo you really want to delete it?"), | 410 | destFile+tr(" already exists.\nDo you really want to delete it?"), |
410 | tr("Yes"),tr("No"),0,0,1) ) { | 411 | tr("Yes"),tr("No"),0,0,1) ) { |
411 | case 0: | 412 | case 0: |
412 | 413 | ||
413 | f.remove(); | 414 | f.remove(); |
414 | break; | 415 | break; |
415 | case 1: | 416 | case 1: |
416 | return; | 417 | return; |
417 | break; | 418 | break; |
418 | }; | 419 | }; |
419 | } | 420 | } |
420 | if(!copyFile( curFile,destFile) ) { | 421 | if(!copyFile( curFile,destFile) ) { |
421 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") | 422 | QMessageBox::message("AdvancedFm",tr("Could not copy\n") |
422 | +curFile +tr("to\n")+destFile); | 423 | +curFile +tr("to\n")+destFile); |
423 | return; | 424 | return; |
424 | } | 425 | } |
425 | 426 | ||
426 | // odebug << "copy "+curFile+" as "+destFile << oendl; | 427 | // odebug << "copy "+curFile+" as "+destFile << oendl; |
427 | } | 428 | } |
428 | delete fileDlg; | 429 | delete fileDlg; |
429 | } | 430 | } |
430 | rePopulate(); | 431 | rePopulate(); |
@@ -708,102 +709,103 @@ void AdvancedFm::startProcess(const QString & cmd) { | |||
708 | OProcess *process; | 709 | OProcess *process; |
709 | process = new OProcess(); | 710 | process = new OProcess(); |
710 | connect(process, SIGNAL(processExited(Opie::Core::OProcess*)), | 711 | connect(process, SIGNAL(processExited(Opie::Core::OProcess*)), |
711 | this, SLOT( processEnded(Opie::Core::OProcess*))); | 712 | this, SLOT( processEnded(Opie::Core::OProcess*))); |
712 | 713 | ||
713 | connect(process, SIGNAL( receivedStderr(Opie::Core::OProcess*,char*,int)), | 714 | connect(process, SIGNAL( receivedStderr(Opie::Core::OProcess*,char*,int)), |
714 | this, SLOT( oprocessStderr(Opie::Core::OProcess*,char*,int))); | 715 | this, SLOT( oprocessStderr(Opie::Core::OProcess*,char*,int))); |
715 | 716 | ||
716 | command << "/bin/sh"; | 717 | command << "/bin/sh"; |
717 | command << "-c"; | 718 | command << "-c"; |
718 | command << cmd.latin1(); | 719 | command << cmd.latin1(); |
719 | *process << command; | 720 | *process << command; |
720 | if(!process->start(OProcess::NotifyOnExit, OProcess::All) ) | 721 | if(!process->start(OProcess::NotifyOnExit, OProcess::All) ) |
721 | odebug << "could not start process" << oendl; | 722 | odebug << "could not start process" << oendl; |
722 | } | 723 | } |
723 | 724 | ||
724 | void AdvancedFm::processEnded(OProcess *) { | 725 | void AdvancedFm::processEnded(OProcess *) { |
725 | rePopulate(); | 726 | rePopulate(); |
726 | } | 727 | } |
727 | 728 | ||
728 | void AdvancedFm::oprocessStderr(OProcess*, char *buffer, int ) { | 729 | void AdvancedFm::oprocessStderr(OProcess*, char *buffer, int ) { |
729 | // owarn << "received stderrt " << buflen << " bytes" << oendl; | 730 | // owarn << "received stderrt " << buflen << " bytes" << oendl; |
730 | 731 | ||
731 | QString lineStr = buffer; | 732 | QString lineStr = buffer; |
732 | QMessageBox::warning( this, tr("Error"), lineStr ,tr("Ok") ); | 733 | QMessageBox::warning( this, tr("Error"), lineStr ,tr("Ok") ); |
733 | } | 734 | } |
734 | 735 | ||
735 | bool AdvancedFm::eventFilter( QObject * o, QEvent * e ) { | 736 | bool AdvancedFm::eventFilter( QObject * o, QEvent * e ) { |
736 | if ( o->inherits( "QLineEdit" ) ) { | 737 | if ( o->inherits( "QLineEdit" ) ) { |
737 | if ( e->type() == QEvent::KeyPress ) { | 738 | if ( e->type() == QEvent::KeyPress ) { |
738 | QKeyEvent *ke = (QKeyEvent*)e; | 739 | QKeyEvent *ke = (QKeyEvent*)e; |
739 | if ( ke->key() == Key_Return || | 740 | if ( ke->key() == Key_Return || |
740 | ke->key() == Key_Enter ) { | 741 | ke->key() == Key_Enter ) { |
741 | okRename(); | 742 | okRename(); |
742 | return true; | 743 | return true; |
743 | } | 744 | } |
744 | else if ( ke->key() == Key_Escape ) { | 745 | else if ( ke->key() == Key_Escape ) { |
745 | cancelRename(); | 746 | cancelRename(); |
746 | return true; | 747 | return true; |
747 | } | 748 | } |
748 | } | 749 | } |
749 | else if ( e->type() == QEvent::FocusOut ) { | 750 | else if ( e->type() == QEvent::FocusOut ) { |
750 | cancelRename(); | 751 | cancelRename(); |
751 | return true; | 752 | return true; |
752 | } | 753 | } |
753 | } | 754 | } |
754 | if ( o->inherits( "QListView" ) ) { | 755 | if ( o->inherits( "QListView" ) ) { |
755 | if ( e->type() == QEvent::FocusIn ) { | 756 | if ( e->type() == QEvent::FocusIn ) { |
756 | if( o == Local_View) { //keep track of which view | 757 | if( o == Local_View) { //keep track of which view |
757 | whichTab=1; | 758 | qDebug("local view"); |
758 | } | 759 | whichTab = 1; |
759 | else { | 760 | } else { |
760 | whichTab=2; | 761 | whichTab = 2; |
761 | } | 762 | qDebug("remote view"); |
763 | } | ||
762 | } | 764 | } |
763 | OtherView()->setSelected( OtherView()->currentItem(), FALSE );//make sure there's correct selection | 765 | OtherView()->setSelected( OtherView()->currentItem(), FALSE );//make sure there's correct selection |
764 | } | 766 | } |
765 | 767 | ||
766 | return QWidget::eventFilter( o, e ); | 768 | return QWidget::eventFilter( o, e ); |
767 | } | 769 | } |
768 | 770 | ||
769 | 771 | ||
770 | void AdvancedFm::cancelRename() { | 772 | void AdvancedFm::cancelRename() { |
771 | // odebug << "cancel rename" << oendl; | 773 | // odebug << "cancel rename" << oendl; |
772 | QListView * view; | 774 | QListView * view; |
773 | view = CurrentView(); | 775 | view = CurrentView(); |
774 | 776 | ||
775 | bool resetFocus = view->viewport()->focusProxy() == renameBox; | 777 | bool resetFocus = view->viewport()->focusProxy() == renameBox; |
776 | delete renameBox; | 778 | delete renameBox; |
777 | renameBox = 0; | 779 | renameBox = 0; |
778 | if ( resetFocus ) { | 780 | if ( resetFocus ) { |
779 | view->viewport()->setFocusProxy( view); | 781 | view->viewport()->setFocusProxy( view); |
780 | view->setFocus(); | 782 | view->setFocus(); |
781 | } | 783 | } |
782 | } | 784 | } |
783 | 785 | ||
784 | void AdvancedFm::doRename(QListView * view) { | 786 | void AdvancedFm::doRename(QListView * view) { |
785 | if( !CurrentView()->currentItem()) return; | 787 | if( !CurrentView()->currentItem()) return; |
786 | 788 | ||
787 | QRect r = view->itemRect( view->currentItem( )); | 789 | QRect r = view->itemRect( view->currentItem( )); |
788 | r = QRect( view->viewportToContents( r.topLeft() ), r.size() ); | 790 | r = QRect( view->viewportToContents( r.topLeft() ), r.size() ); |
789 | r.setX( view->contentsX() ); | 791 | r.setX( view->contentsX() ); |
790 | 792 | ||
791 | if ( r.width() > view->visibleWidth() ) | 793 | if ( r.width() > view->visibleWidth() ) |
792 | r.setWidth( view->visibleWidth() ); | 794 | r.setWidth( view->visibleWidth() ); |
793 | 795 | ||
794 | renameBox = new QLineEdit( view->viewport(), "qt_renamebox" ); | 796 | renameBox = new QLineEdit( view->viewport(), "qt_renamebox" ); |
795 | renameBox->setFrame(true); | 797 | renameBox->setFrame(true); |
796 | 798 | ||
797 | renameBox->setText( view->currentItem()->text(0) ); | 799 | renameBox->setText( view->currentItem()->text(0) ); |
798 | 800 | ||
799 | renameBox->selectAll(); | 801 | renameBox->selectAll(); |
800 | renameBox->installEventFilter( this ); | 802 | renameBox->installEventFilter( this ); |
801 | 803 | ||
802 | view->addChild( renameBox, r.x(), r.y() ); | 804 | view->addChild( renameBox, r.x(), r.y() ); |
803 | 805 | ||
804 | renameBox->resize( r.size() ); | 806 | renameBox->resize( r.size() ); |
805 | 807 | ||
806 | view->viewport()->setFocusProxy( renameBox ); | 808 | view->viewport()->setFocusProxy( renameBox ); |
807 | 809 | ||
808 | renameBox->setFocus(); | 810 | renameBox->setFocus(); |
809 | renameBox->show(); | 811 | renameBox->show(); |