summaryrefslogtreecommitdiff
authortille <tille>2002-04-27 13:06:45 (UTC)
committer tille <tille>2002-04-27 13:06:45 (UTC)
commitdb90999f6298c1107888f062f2c25cb8817b528a (patch) (unidiff)
tree020ebe65beb9286f3c63e4329fc3a0f298d34460
parente2f3288d468508f2cf7c0a327044963ca4b1b54a (diff)
downloadopie-db90999f6298c1107888f062f2c25cb8817b528a.zip
opie-db90999f6298c1107888f062f2c25cb8817b528a.tar.gz
opie-db90999f6298c1107888f062f2c25cb8817b528a.tar.bz2
added popup menu to choose inst dest (and more...)
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/unsupported/oipkg/TODO3
-rw-r--r--noncore/unsupported/oipkg/debug.h1
-rw-r--r--noncore/unsupported/oipkg/mainwindow.cpp115
-rw-r--r--noncore/unsupported/oipkg/mainwindow.h9
-rw-r--r--noncore/unsupported/oipkg/opie-oipkg.control2
-rw-r--r--noncore/unsupported/oipkg/package.cpp54
-rw-r--r--noncore/unsupported/oipkg/package.h22
-rw-r--r--noncore/unsupported/oipkg/packagelist.cpp46
-rw-r--r--noncore/unsupported/oipkg/packagelist.h8
-rw-r--r--noncore/unsupported/oipkg/packagelistitem.cpp44
-rw-r--r--noncore/unsupported/oipkg/packagelistitem.h8
-rw-r--r--noncore/unsupported/oipkg/pksettings.cpp24
-rw-r--r--noncore/unsupported/oipkg/pksettings.h3
-rw-r--r--noncore/unsupported/oipkg/pmipkg.cpp112
-rw-r--r--noncore/unsupported/oipkg/pmipkg.h12
-rw-r--r--noncore/unsupported/oipkg/runwindow.ui2
-rw-r--r--noncore/unsupported/oipkg/settings.h2
17 files changed, 312 insertions, 155 deletions
diff --git a/noncore/unsupported/oipkg/TODO b/noncore/unsupported/oipkg/TODO
index c53ca93..744cba4 100644
--- a/noncore/unsupported/oipkg/TODO
+++ b/noncore/unsupported/oipkg/TODO
@@ -1,11 +1,8 @@
1* search
2* Settings Class 1* Settings Class
3* make oipkg determine dest of "to remove" apps
4* tr() ;) 2* tr() ;)
5* Dialog to display ipkg output live 3* Dialog to display ipkg output live
6* parse "to install" and "to remove" from status 4* parse "to install" and "to remove" from status
7* install local file 5* install local file
8* install to dest with click on packet
9* qcop 6* qcop
10* error handling 7* error handling
11* manage links 8* manage links
diff --git a/noncore/unsupported/oipkg/debug.h b/noncore/unsupported/oipkg/debug.h
index c53e36c..e73b9b2 100644
--- a/noncore/unsupported/oipkg/debug.h
+++ b/noncore/unsupported/oipkg/debug.h
@@ -1,20 +1,21 @@
1#ifndef _DEBUG_H_ 1#ifndef _DEBUG_H_
2#define _DEBUG_H_ 2#define _DEBUG_H_
3 3
4#include <stdio.h> 4#include <stdio.h>
5 5
6extern int debugLevel; 6extern int debugLevel;
7 7
8#define HACK 8#define HACK
9 9
10#define NEWLAYOUT
10 11
11#define pvDebug(I, S) \ 12#define pvDebug(I, S) \
12if ( debugLevel < 3 ) \ 13if ( debugLevel < 3 ) \
13{ \ 14{ \
14 if ( I <= debugLevel ) qDebug(S);\ 15 if ( I <= debugLevel ) qDebug(S);\
15}else{\ 16}else{\
16 if ( I <= debugLevel ) \ 17 if ( I <= debugLevel ) \
17 printf("# %s \t\t(Level: %i)\n",QString(S).latin1(),I);\ 18 printf("# %s \t\t(Level: %i)\n",QString(S).latin1(),I);\
18} 19}
19 20
20#endif \ No newline at end of file 21#endif \ No newline at end of file
diff --git a/noncore/unsupported/oipkg/mainwindow.cpp b/noncore/unsupported/oipkg/mainwindow.cpp
index c803ca0..25ca889 100644
--- a/noncore/unsupported/oipkg/mainwindow.cpp
+++ b/noncore/unsupported/oipkg/mainwindow.cpp
@@ -1,357 +1,418 @@
1// adadpted form qpe/qipkg 1// adadpted form qpe/qipkg
2 2
3 3
4#include "mainwindow.h" 4#include "mainwindow.h"
5 5
6#include <qpe/qpemenubar.h> 6#include <qpe/qpemenubar.h>
7#include <qpe/qpemessagebox.h> 7#include <qpe/qpemessagebox.h>
8#include <qpe/resource.h> 8#include <qpe/resource.h>
9#include <qpe/qpetoolbar.h> 9#include <qpe/qpetoolbar.h>
10#include <qpe/qcopenvelope_qws.h>
10#include <qaction.h> 11#include <qaction.h>
11#include <qmessagebox.h> 12#include <qmessagebox.h>
12#include <qpopupmenu.h> 13#include <qpopupmenu.h>
13#include <qtoolbutton.h> 14#include <qtoolbutton.h>
14#include <qstring.h> 15#include <qstring.h>
15#include <qlabel.h> 16#include <qlabel.h>
16#include <qlistview.h> 17#include <qlistview.h>
17#include <qtextview.h> 18#include <qtextview.h>
18#include <qlineedit.h> 19#include <qlineedit.h>
19#include <qtabwidget.h> 20#include <qtabwidget.h>
20#include <qcombobox.h> 21#include <qcombobox.h>
21#include <qlayout.h> 22#include <qlayout.h>
22 23
23#include "pksettingsbase.h" 24#include "pksettingsbase.h"
24#include "packagelistitem.h" 25#include "packagelistitem.h"
25 26
26MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f = 0 ) : 27MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f = 0 ) :
27 QMainWindow( parent, name, f ) 28 QMainWindow( parent, name, f )
28 { 29 {
29 setCaption( tr("Package Manager") ); 30 setCaption( tr("Package Manager") );
30 31
31 listViewPackages = new QListView( this,0,0 ); 32 listViewPackages = new QListView( this,0,0 );
33 listViewPackages->setSelectionMode(QListView::NoSelection);
32 setCentralWidget( listViewPackages ); 34 setCentralWidget( listViewPackages );
33 35
34 makeMenu(); 36 makeMenu();
35 37#ifdef NEWLAYOUT
38 listViewPackages->addColumn( tr("Package") );
39 listViewPackages->setRootIsDecorated( true );
40#endif
41#ifndef NEWLAYOUT
36 QFontMetrics fm = fontMetrics(); 42 QFontMetrics fm = fontMetrics();
37 int wlw = width()*2; 43 int wlw = width()*2;
38 int w0 = fm.width(tr("Package"))+30; 44 int w0 = fm.width(tr("Package"))+30;
39 // int w0 = fm.width(tr("Package"))+30; 45 // int w0 = fm.width(tr("Package"))+30;
40 int w2 = fm.width("00000")+4; 46 int w2 = fm.width("00000")+4;
41 int w1 = wlw-w2-w0-20; 47 int w1 = wlw-w2-w0-24;
42 listViewPackages->addColumn( tr("Package"), w0 ); 48 listViewPackages->addColumn( tr("Package"), w0 );
43 listViewPackages->addColumn( tr("Description"), w1 ); 49 listViewPackages->addColumn( tr("Description"), w1 );
44 listViewPackages->addColumn( tr("Size"), w2 ); 50 listViewPackages->addColumn( tr("Size"), w2 );
45 listViewPackages->setColumnWidthMode(0,QListView::Manual); 51 listViewPackages->setColumnWidthMode(0,QListView::Manual);
46 listViewPackages->setColumnWidthMode(1,QListView::Manual); 52 listViewPackages->setColumnWidthMode(1,QListView::Manual);
47 listViewPackages->setColumnWidthMode(2,QListView::Manual); 53 listViewPackages->setColumnWidthMode(2,QListView::Manual);
48 listViewPackages->setSelectionMode( QListView::Multi ); 54 listViewPackages->setSelectionMode( QListView::Multi );
49 55#endif
50 connect( section, SIGNAL( activated(int) ), 56 connect( section, SIGNAL( activated(int) ),
51 this, SLOT( sectionChanged() ) ); 57 this, SLOT( sectionChanged() ) );
52 connect( subsection, SIGNAL(activated(int) ), 58 connect( subsection, SIGNAL(activated(int) ),
53 this, SLOT( subSectionChanged() ) ); 59 this, SLOT( subSectionChanged() ) );
54 connect( listViewPackages, SIGNAL( pressed( QListViewItem* ) ), 60 connect( listViewPackages, SIGNAL( pressed( QListViewItem* ) ),
55 this, SLOT( setCurrent( QListViewItem* ) ) ); 61 this, SLOT( setCurrent( QListViewItem* ) ) );
56 62 connect( listViewPackages, SIGNAL( clicked( QListViewItem* ) ),
63 this, SLOT( stopTimer( QListViewItem* ) ) );
64
65 popupMenu = new QPopupMenu( this );
66
57 settings = new PackageManagerSettings(this,0,TRUE); 67 settings = new PackageManagerSettings(this,0,TRUE);
58 68
59 ipkg = new PmIpkg( settings, this ); 69 ipkg = new PmIpkg( settings, this );
60 packageList.setSettings( settings ); 70 packageList.setSettings( settings );
61 getList(); 71 getList();
62 setSections(); 72 setSections();
63 setSubSections(); 73 setSubSections();
64 displayList(); 74 displayList();
65} 75}
66 76
67void MainWindow::makeMenu() 77void MainWindow::makeMenu()
68{ 78{
69 79
70 QPEToolBar *toolBar = new QPEToolBar( this ); 80 QPEToolBar *toolBar = new QPEToolBar( this );
71 QPEMenuBar *menuBar = new QPEMenuBar( toolBar ); 81 QPEMenuBar *menuBar = new QPEMenuBar( toolBar );
72 QPopupMenu *srvMenu = new QPopupMenu( menuBar ); 82 QPopupMenu *srvMenu = new QPopupMenu( menuBar );
73 QPopupMenu *viewMenu = new QPopupMenu( menuBar ); 83 QPopupMenu *viewMenu = new QPopupMenu( menuBar );
74 QPopupMenu *cfgMenu = new QPopupMenu( menuBar ); 84 QPopupMenu *cfgMenu = new QPopupMenu( menuBar );
75 // QPopupMenu *sectMenu = new QPopupMenu( menuBar ); 85 // QPopupMenu *sectMenu = new QPopupMenu( menuBar );
76 86
77 popupMenu = new QPopupMenu( this ); 87 popupMenu = new QPopupMenu( this );
78 88 destsMenu = new QPopupMenu( popupMenu );
79 contextMenu = new QPopupMenu( this ); 89 popupTimer = new QTimer( this );
90 connect( popupTimer, SIGNAL(timeout()), this, SLOT(showPopup()) );
80 91
81 setToolBarsMovable( false ); 92 setToolBarsMovable( false );
82 toolBar->setHorizontalStretchable( true ); 93 toolBar->setHorizontalStretchable( true );
83 menuBar->insertItem( tr( "Package" ), srvMenu ); 94 menuBar->insertItem( tr( "Package" ), srvMenu );
84 menuBar->insertItem( tr( "View" ), viewMenu ); 95 menuBar->insertItem( tr( "View" ), viewMenu );
85 menuBar->insertItem( tr( "Settings" ), cfgMenu ); 96 menuBar->insertItem( tr( "Settings" ), cfgMenu );
86 // menuBar->insertItem( tr( "Sections" ), sectMenu ); 97 // menuBar->insertItem( tr( "Sections" ), sectMenu );
87 98
88 QLabel *spacer = new QLabel( "", toolBar ); 99 QLabel *spacer = new QLabel( "", toolBar );
89 spacer->setBackgroundColor( toolBar->backgroundColor() ); 100 spacer->setBackgroundColor( toolBar->backgroundColor() );
90 toolBar->setStretchableWidget( spacer ); 101 toolBar->setStretchableWidget( spacer );
91 102
92 103
93 runAction = new QAction( tr( "Apply" ), 104 runAction = new QAction( tr( "Apply" ),
94 Resource::loadPixmap( "oipkg/install" ), 105 Resource::loadPixmap( "oipkg/install" ),
95 QString::null, 0, this, 0 ); 106 QString::null, 0, this, 0 );
96 connect( runAction, SIGNAL( activated() ), 107 connect( runAction, SIGNAL( activated() ),
97 this, SLOT( runIpkg() ) ); 108 this, SLOT( runIpkg() ) );
98 runAction->addTo( toolBar ); 109 runAction->addTo( toolBar );
99 runAction->addTo( srvMenu ); 110 runAction->addTo( srvMenu );
100 111
101 srvMenu->insertSeparator (); 112 srvMenu->insertSeparator ();
102 113
103 updateAction = new QAction( tr( "Update" ), 114 updateAction = new QAction( tr( "Update" ),
104 Resource::loadIconSet( "oipkg/update" ), 115 Resource::loadIconSet( "oipkg/update" ),
105 QString::null, 0, this, 0 ); 116 QString::null, 0, this, 0 );
106 connect( updateAction, SIGNAL( activated() ), 117 connect( updateAction, SIGNAL( activated() ),
107 this , SLOT( updateList() ) ); 118 this , SLOT( updateList() ) );
108 updateAction->addTo( toolBar ); 119 updateAction->addTo( toolBar );
109 updateAction->addTo( srvMenu ); 120 updateAction->addTo( srvMenu );
110 121
111 detailsAction = new QAction( tr( "Details" ), 122 detailsAction = new QAction( tr( "Details" ),
112 Resource::loadIconSet( "find" ), 123 Resource::loadIconSet( "find" ),
113 QString::null, 0, this, 0 ); 124 QString::null, 0, this, 0 );
114 connect( detailsAction, SIGNAL( activated() ), 125 connect( detailsAction, SIGNAL( activated() ),
115 this , SLOT( showDetails() ) ); 126 this , SLOT( showDetails() ) );
116 detailsAction->addTo( toolBar ); 127 detailsAction->addTo( toolBar );
117 detailsAction->addTo( srvMenu ); 128 detailsAction->addTo( srvMenu );
118 129
119 QAction *cfgact; 130 QAction *cfgact;
120 131
121 cfgact = new QAction( tr( "Setups" ), 132 cfgact = new QAction( tr( "Setups" ),
122 // Resource::loadIconSet( "" ), 133 // Resource::loadIconSet( "" ),
123 QString::null, 0, this, 0 ); 134 QString::null, 0, this, 0 );
124 connect( cfgact, SIGNAL( activated() ), 135 connect( cfgact, SIGNAL( activated() ),
125 SLOT( showSettings() ) ); 136 SLOT( showSettings() ) );
126 cfgact->addTo( cfgMenu ); 137 cfgact->addTo( cfgMenu );
127 138
128 cfgact = new QAction( tr( "Servers" ), 139 cfgact = new QAction( tr( "Servers" ),
129 // Resource::loadIconSet( "" ), 140 // Resource::loadIconSet( "" ),
130 QString::null, 0, this, 0 ); 141 QString::null, 0, this, 0 );
131 connect( cfgact, SIGNAL( activated() ), 142 connect( cfgact, SIGNAL( activated() ),
132 SLOT( showSettingsSrv() ) ); 143 SLOT( showSettingsSrv() ) );
133 cfgact->addTo( cfgMenu ); 144 cfgact->addTo( cfgMenu );
134 cfgact = new QAction( tr( "Destinations" ), 145 cfgact = new QAction( tr( "Destinations" ),
135 //Resource::loadIconSet( "" ), 146 //Resource::loadIconSet( "" ),
136 QString::null, 0, this, 0 ); 147 QString::null, 0, this, 0 );
137 connect( cfgact, SIGNAL( activated() ), 148 connect( cfgact, SIGNAL( activated() ),
138 SLOT( showSettingsDst() ) ); 149 SLOT( showSettingsDst() ) );
139 cfgact->addTo( cfgMenu ); 150 cfgact->addTo( cfgMenu );
140 151
141 QAction *a; 152 QAction *a;
142 153
143 sectionBar = new QPEToolBar( this ); 154 sectionBar = new QPEToolBar( this );
144 addToolBar( sectionBar, "Section", QMainWindow::Top, TRUE ); 155 addToolBar( sectionBar, "Section", QMainWindow::Top, TRUE );
145 sectionBar->setHorizontalStretchable( true ); 156 sectionBar->setHorizontalStretchable( true );
146 QLabel *label = new QLabel( tr("Section: "), sectionBar ); 157 QLabel *label = new QLabel( tr("Section: "), sectionBar );
147 label->setBackgroundColor( sectionBar->backgroundColor() ); 158 label->setBackgroundColor( sectionBar->backgroundColor() );
148 sectionBar->setStretchableWidget( label ); 159 sectionBar->setStretchableWidget( label );
149 section = new QComboBox( false, sectionBar ); 160 section = new QComboBox( false, sectionBar );
150// section->setBackgroundMode( PaletteBackground ); 161// section->setBackgroundMode( PaletteBackground );
151 label = new QLabel( " / ", sectionBar ); 162 label = new QLabel( " / ", sectionBar );
152 label->setBackgroundColor( sectionBar->backgroundColor() ); 163 label->setBackgroundColor( sectionBar->backgroundColor() );
153 subsection = new QComboBox( false, sectionBar ); 164 subsection = new QComboBox( false, sectionBar );
154 165
155 a = new QAction( tr( "Close Section" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 166 a = new QAction( tr( "Close Section" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
156 connect( a, SIGNAL( activated() ), this, SLOT( sectionClose() ) ); 167 connect( a, SIGNAL( activated() ), this, SLOT( sectionClose() ) );
157 a->addTo( sectionBar ); 168 a->addTo( sectionBar );
158 169
159 sectionAction = new QAction( tr( "Sections" ), QString::null, 0, this, 0 ); 170 sectionAction = new QAction( tr( "Sections" ), QString::null, 0, this, 0 );
160 connect( sectionAction, SIGNAL( toggled(bool) ), this, SLOT( sectionShow(bool) ) ); 171 connect( sectionAction, SIGNAL( toggled(bool) ), this, SLOT( sectionShow(bool) ) );
161 sectionAction->setToggleAction( true ); 172 sectionAction->setToggleAction( true );
162 sectionAction->setOn( true ); 173 sectionAction->setOn( true );
163 sectionAction->addTo( viewMenu ); 174 sectionAction->addTo( viewMenu );
164 175
165 findBar = new QPEToolBar(this); 176 findBar = new QPEToolBar(this);
166 addToolBar( findBar, "Search", QMainWindow::Top, TRUE ); 177 addToolBar( findBar, "Search", QMainWindow::Top, TRUE );
167 label = new QLabel( tr("Filter: "), findBar ); 178 label = new QLabel( tr("Filter: "), findBar );
168 label->setBackgroundColor( findBar->backgroundColor() ); 179 label->setBackgroundColor( findBar->backgroundColor() );
169 findBar->setHorizontalStretchable( TRUE ); 180 findBar->setHorizontalStretchable( TRUE );
170 findEdit = new QLineEdit( findBar, "findEdit" ); 181 findEdit = new QLineEdit( findBar, "findEdit" );
171 findBar->setStretchableWidget( findEdit ); 182 findBar->setStretchableWidget( findEdit );
172 connect( findEdit, SIGNAL( textChanged( const QString & ) ), 183 connect( findEdit, SIGNAL( textChanged( const QString & ) ),
173 this, SLOT( displayList() ) ); 184 this, SLOT( displayList() ) );
174 185
175 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 186 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
176 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) ); 187 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) );
177 a->addTo( findBar ); 188 a->addTo( findBar );
178 findAction = new QAction( tr( "Find" ), QString::null, 0, this, 0 ); 189 findAction = new QAction( tr( "Find" ), QString::null, 0, this, 0 );
179 connect( findAction, SIGNAL( toggled(bool) ), this, SLOT( findShow(bool) ) ); 190 connect( findAction, SIGNAL( toggled(bool) ), this, SLOT( findShow(bool) ) );
180 findAction->setToggleAction( true ); 191 findAction->setToggleAction( true );
181 findAction->setOn( true ); 192 findAction->setOn( true );
182 findAction->addTo( viewMenu ); 193 findAction->addTo( viewMenu );
194
195 #ifdef NEW
196 Config cfg( "oipkg", Config::User );
197 cfg.setGroup( "Setting_" + QString::number( setting ) );
198 CheckBoxLink->setChecked( cfg.readBoolEntry( "link", false ) );
199 findShow(bool b)
200 sectionShow(bool b)
201 #endif
183} 202}
184 203
185MainWindow::~MainWindow() 204MainWindow::~MainWindow()
186{ 205{
187} 206}
188 207
189void MainWindow::runIpkg() 208void MainWindow::runIpkg()
190{ 209{
191 ipkg->commit( packageList ); 210 ipkg->commit( packageList );
192// updateList(); //to remove 211 // ##### If we looked in the list of files, we could send out accurate
212 // ##### messages. But we don't bother yet, and just do an "all".
213 QCopEnvelope e("QPE/System", "linkChanged(QString)");
214 QString lf = QString::null;
215 e << lf;
216 displayList();
193} 217}
194 218
195void MainWindow::updateList() 219void MainWindow::updateList()
196{ 220{
197 QTimer *t = new QTimer( this ); 221 QTimer *t = new QTimer( this );
198 connect( t, SIGNAL(timeout()), SLOT( rotateUpdateIcon() ) ); 222 connect( t, SIGNAL(timeout()), SLOT( rotateUpdateIcon() ) );
199 t->start( 0, false ); 223 t->start( 0, false );
200 packageList.clear(); 224 packageList.clear();
201 ipkg->update(); 225 ipkg->update();
202 getList(); 226 getList();
203 t->stop(); 227 t->stop();
204} 228}
205 229
206void MainWindow::getList() 230void MainWindow::getList()
207{ 231{
208 packageList.update(); 232 packageList.update();
209 displayList(); 233 displayList();
210} 234}
211 235
212void MainWindow::filterList() 236void MainWindow::filterList()
213{ 237{
214 QString f = ""; 238 QString f = "";
215 if ( findAction->isOn() ) f = findEdit->text(); 239 if ( findAction->isOn() ) f = findEdit->text();
216 packageList.filterPackages( f ); 240 packageList.filterPackages( f );
217} 241}
218 242
219void MainWindow::displayList() 243void MainWindow::displayList()
220{ 244{
221 filterList(); 245 filterList();
222 listViewPackages->clear(); 246 listViewPackages->clear();
223 Package *pack = packageList.first(); 247 Package *pack = packageList.first();
224 while( pack ) 248 while( pack )
225 { 249 {
226 if ( pack && (pack->name() != "") ) 250 if ( pack && (pack->name() != "") )
227 listViewPackages->insertItem( new PackageListItem( listViewPackages, pack ) ); 251 listViewPackages->insertItem( new PackageListItem( listViewPackages, pack, settings ) );
228 pack = packageList.next(); 252 pack = packageList.next();
229 } 253 }
230} 254}
231 255
232void MainWindow::sectionChanged() 256void MainWindow::sectionChanged()
233{ 257{
234 disconnect( section, SIGNAL( activated(int) ), 258 disconnect( section, SIGNAL( activated(int) ),
235 this, SLOT( sectionChanged() ) ); 259 this, SLOT( sectionChanged() ) );
236 disconnect( subsection, SIGNAL(activated(int) ), 260 disconnect( subsection, SIGNAL(activated(int) ),
237 this, SLOT( subSectionChanged() ) ); 261 this, SLOT( subSectionChanged() ) );
238 subsection->clear(); 262 subsection->clear();
239 packageList.setSection( section->currentText() ); 263 packageList.setSection( section->currentText() );
240 setSubSections(); 264 setSubSections();
241 connect( section, SIGNAL( activated(int) ), 265 connect( section, SIGNAL( activated(int) ),
242 this, SLOT( sectionChanged() ) ); 266 this, SLOT( sectionChanged() ) );
243 connect( subsection, SIGNAL(activated(int) ), 267 connect( subsection, SIGNAL(activated(int) ),
244 this, SLOT( subSectionChanged() ) ); 268 this, SLOT( subSectionChanged() ) );
245 displayList(); 269 displayList();
246} 270}
247 271
248void MainWindow::subSectionChanged() 272void MainWindow::subSectionChanged()
249{ 273{
250 disconnect( section, SIGNAL( activated(int) ), 274 disconnect( section, SIGNAL( activated(int) ),
251 this, SLOT( sectionChanged() ) ); 275 this, SLOT( sectionChanged() ) );
252 disconnect( subsection, SIGNAL(activated(int) ), 276 disconnect( subsection, SIGNAL(activated(int) ),
253 this, SLOT( subSectionChanged() ) ); 277 this, SLOT( subSectionChanged() ) );
254 packageList.setSubSection( subsection->currentText() ); 278 packageList.setSubSection( subsection->currentText() );
255 connect( section, SIGNAL( activated(int) ), 279 connect( section, SIGNAL( activated(int) ),
256 this, SLOT( sectionChanged() ) ); 280 this, SLOT( sectionChanged() ) );
257 connect( subsection, SIGNAL(activated(int) ), 281 connect( subsection, SIGNAL(activated(int) ),
258 this, SLOT( subSectionChanged() ) ); 282 this, SLOT( subSectionChanged() ) );
259 displayList(); 283 displayList();
260} 284}
261 285
262void MainWindow::setSections() 286void MainWindow::setSections()
263{ 287{
264 section->clear(); 288 section->clear();
265 section->insertStringList( packageList.getSections() ); 289 section->insertStringList( packageList.getSections() );
266} 290}
267 291
268void MainWindow::setSubSections() 292void MainWindow::setSubSections()
269{ 293{
270 subsection->clear(); 294 subsection->clear();
271 subsection->insertStringList( packageList.getSubSections() ); 295 subsection->insertStringList( packageList.getSubSections() );
272} 296}
273 297
274 298
275void MainWindow::showSettings() 299void MainWindow::showSettings()
276{ 300{
277 if ( settings->showDialog( 0 ) ) 301 if ( settings->showDialog( 0 ) )
278 updateList(); 302 updateList();
279} 303}
280void MainWindow::showSettingsSrv() 304void MainWindow::showSettingsSrv()
281{ 305{
282 if ( settings->showDialog( 1 ) ) 306 if ( settings->showDialog( 1 ) )
283 updateList(); 307 updateList();
284} 308}
285void MainWindow::showSettingsDst() 309void MainWindow::showSettingsDst()
286{ 310{
287 if ( settings->showDialog( 2 ) ) 311 if ( settings->showDialog( 2 ) )
288 updateList(); 312 updateList();
289} 313}
290 314
291 315
292void MainWindow::showDetails() 316void MainWindow::showDetails()
293{ 317{
294 if ( activePackage ) return;
295 if ( details ) 318 if ( details )
296 { 319 {
297 details = new PackageDetails( this ); 320 details = new PackageDetails( this );
298 connect( details->install, SIGNAL(clicked()), SLOT( toggleActivePackage() ) ); 321 connect( details->install, SIGNAL(clicked()), SLOT( toggleActivePackage() ) );
299 connect( details->remove, SIGNAL(clicked()), SLOT( toggleActivePackage() ) ); 322 connect( details->remove, SIGNAL(clicked()), SLOT( toggleActivePackage() ) );
300 connect( details->ignore, SIGNAL(clicked()), details, SLOT(close())); 323 connect( details->ignore, SIGNAL(clicked()), details, SLOT(close()));
301 details->description->setTextFormat(RichText); 324 details->description->setTextFormat(RichText);
302 } 325 }
303 326 if ( !activePackage )
304 details->setCaption("Package: " + activePackage->name()); 327 {
305 details->description->setText(activePackage->details() ); 328 details->description->setText(tr("no package selected"));
306 details->install->setEnabled(!activePackage->installed()); 329 details->description->setText(tr("errmm...<br>...not working?"));
307 details->remove->setEnabled(activePackage->installed()); 330 }else{
331 details->setCaption("Package: " + activePackage->name());
332 details->description->setText(activePackage->details() );
333 details->install->setEnabled(!activePackage->installed());
334 details->remove->setEnabled(activePackage->installed());
335 }
308 details->showMaximized(); 336 details->showMaximized();
309} 337}
310 338
311void MainWindow::toggleActivePackage() 339void MainWindow::toggleActivePackage()
312{ 340{
313 activePackage->toggleProcess(); 341 activePackage->toggleProcess();
314 if ( details ) details->close(); 342 if ( details ) details->close();
315} 343}
316 344
317void MainWindow::setCurrent( QListViewItem* p ) 345void MainWindow::setCurrent( QListViewItem* p )
318{ 346{
319 pvDebug(2, "MainWindow::setCurrent "); 347 if ( !p ) return;
320 return; 348 activePackageListItem = (PackageListItem*)p;
321 pvDebug(2, "name "+((Package*)p)->name()); 349 activePackage = activePackageListItem->getPackage();
322 activePackage = (Package*)p; 350 pvDebug(5, "start timer");
351 popupTimer->start( 750, true );
323} 352}
324 353
325void MainWindow::sectionShow(bool b) 354void MainWindow::sectionShow(bool b)
326{ 355{
327 if (b) sectionBar->show(); 356 if (b) sectionBar->show();
328 else sectionBar->hide(); 357 else sectionBar->hide();
329 sectionAction->setOn( b ); 358 sectionAction->setOn( b );
330} 359}
331 360
332void MainWindow::sectionClose() 361void MainWindow::sectionClose()
333{ 362{
334 sectionAction->setOn( false ); 363 sectionAction->setOn( false );
335} 364}
336 365
337void MainWindow::findShow(bool b) 366void MainWindow::findShow(bool b)
338{ 367{
339 if (b) findBar->show(); 368 if (b) findBar->show();
340 else findBar->hide(); 369 else findBar->hide();
341 findAction->setOn( b ); 370 findAction->setOn( b );
342} 371}
343 372
344void MainWindow::findClose() 373void MainWindow::findClose()
345{ 374{
346 findAction->setOn( false ); 375 findAction->setOn( false );
347} 376}
348 377
349void MainWindow::rotateUpdateIcon() 378void MainWindow::rotateUpdateIcon()
350{ 379{
351 pvDebug(2, "MainWindow::rotateUpdateIcon"); 380 pvDebug(2, "MainWindow::rotateUpdateIcon");
352 if ( updateIcon ) 381 if ( updateIcon )
353 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update" ) ); 382 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update" ) );
354 else 383 else
355 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update2" ) ); 384 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update2" ) );
356 updateIcon = !updateIcon; 385 updateIcon = !updateIcon;
357} 386}
387
388void MainWindow::showPopup()
389{
390 popupMenu->clear();
391 destsMenu->clear();
392
393 QAction *popupAction;
394 popupMenu->insertItem( tr("Install to"), destsMenu );
395 QStringList dests = settings->getDestinationNames();
396 for (uint i = 0; i < dests.count(); i++ )
397 {
398 popupAction = new QAction( dests[i], QString::null, 0, this, 0 );
399 popupAction->addTo( destsMenu );
400 }
401 connect( destsMenu, SIGNAL( activated( int ) ),
402 this, SLOT( changePackageDest( int ) ) );
403 popupMenu->popup( QCursor::pos() );
404}
405
406void MainWindow::changePackageDest( int i )
407{
408 activePackage->setDest( destsMenu->text(i) );
409 activePackage->setOn();
410 activePackage->setLink( settings->createLinks() );
411 activePackageListItem->displayDetails();
412}
413
414void MainWindow::stopTimer( QListViewItem* )
415{
416 pvDebug( 5, "stop timer" );
417 popupTimer->stop();
418}
diff --git a/noncore/unsupported/oipkg/mainwindow.h b/noncore/unsupported/oipkg/mainwindow.h
index 892d5e8..adc5e78 100644
--- a/noncore/unsupported/oipkg/mainwindow.h
+++ b/noncore/unsupported/oipkg/mainwindow.h
@@ -1,78 +1,83 @@
1#ifndef MAINWINDOW_H 1#ifndef MAINWINDOW_H
2#define MAINWINDOW_H 2#define MAINWINDOW_H
3 3
4#include <qmainwindow.h> 4#include <qmainwindow.h>
5#include <qaction.h> 5#include <qaction.h>
6#include <qtimer.h> 6#include <qtimer.h>
7#include <qpopupmenu.h> 7#include <qpopupmenu.h>
8 8
9#include "packagelist.h" 9#include "packagelist.h"
10#include "pmipkg.h" 10#include "pmipkg.h"
11#include "pksettings.h" 11#include "pksettings.h"
12#include "pkdesc.h" 12#include "pkdesc.h"
13 13
14class QComboBox; 14class QComboBox;
15class QPEToolBar; 15class QPEToolBar;
16class QLineEdit; 16class QLineEdit;
17class QListView; 17class QListView;
18 18class PackageListItem;
19 19
20class MainWindow : public QMainWindow 20class MainWindow : public QMainWindow
21{ 21{
22 Q_OBJECT 22 Q_OBJECT
23 23
24 24
25public: 25public:
26 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags f = 0 ); 26 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags f = 0 );
27 ~MainWindow(); 27 ~MainWindow();
28 28
29protected slots: 29protected slots:
30 void runIpkg(); 30 void runIpkg();
31 void getList(); 31 void getList();
32 void updateList(); 32 void updateList();
33 void displayList(); 33 void displayList();
34 void subSectionChanged(); 34 void subSectionChanged();
35 void sectionChanged(); 35 void sectionChanged();
36 void showSettings(); 36 void showSettings();
37 void showSettingsSrv(); 37 void showSettingsSrv();
38 void showSettingsDst(); 38 void showSettingsDst();
39 39
40public slots: 40public slots:
41 void showDetails(); 41 void showDetails();
42 void toggleActivePackage(); 42 void toggleActivePackage();
43 void setCurrent( QListViewItem* ); 43 void setCurrent( QListViewItem* );
44 void sectionClose(); 44 void sectionClose();
45 void sectionShow(bool); 45 void sectionShow(bool);
46 void findClose(); 46 void findClose();
47 void findShow(bool); 47 void findShow(bool);
48 void filterList(); 48 void filterList();
49 void showPopup();
50 void changePackageDest( int );
51 void stopTimer( QListViewItem* );
49 52
50private: 53private:
51 void makeMenu(); 54 void makeMenu();
52 void setSections(); 55 void setSections();
53 void setSubSections(); 56 void setSubSections();
54 57
55 PmIpkg* ipkg; 58 PmIpkg* ipkg;
56 PackageManagerSettings *settings; 59 PackageManagerSettings *settings;
57 PackageDetails* details; 60 PackageDetails* details;
58 PackageList packageList; 61 PackageList packageList;
59 Package *activePackage; 62 Package *activePackage;
63 PackageListItem *activePackageListItem;
60 QAction *runAction; 64 QAction *runAction;
61 QAction *detailsAction; 65 QAction *detailsAction;
62 QAction *updateAction; 66 QAction *updateAction;
63 QAction *findAction; 67 QAction *findAction;
64 QAction *sectionAction; 68 QAction *sectionAction;
65 QListView *listViewPackages; 69 QListView *listViewPackages;
66 QPopupMenu *contextMenu;
67 QPEToolBar *findBar; 70 QPEToolBar *findBar;
68 QLineEdit *findEdit; 71 QLineEdit *findEdit;
69 QPEToolBar *sectionBar; 72 QPEToolBar *sectionBar;
70 QComboBox *section; 73 QComboBox *section;
71 QComboBox *subsection; 74 QComboBox *subsection;
75 QTimer *popupTimer;
72 QPopupMenu *popupMenu; 76 QPopupMenu *popupMenu;
77 QPopupMenu *destsMenu;
73 bool updateIcon; 78 bool updateIcon;
74private slots: 79private slots:
75 void rotateUpdateIcon(); 80 void rotateUpdateIcon();
76}; 81};
77 82
78#endif 83#endif
diff --git a/noncore/unsupported/oipkg/opie-oipkg.control b/noncore/unsupported/oipkg/opie-oipkg.control
index 89cc0b4..2ffec71 100644
--- a/noncore/unsupported/oipkg/opie-oipkg.control
+++ b/noncore/unsupported/oipkg/opie-oipkg.control
@@ -1,9 +1,9 @@
1Files: bin/oipkg apps/Settings/oipkg.desktop pics/oipkg/ 1Files: bin/oipkg apps/Settings/oipkg.desktop pics/oipkg/
2Priority: optional 2Priority: optional
3Section: opie/settings 3Section: opie/settings
4Maintainer: Patrick S. Vogt <tille@almana.ch> 4Maintainer: Patrick S. Vogt <tille@almana.ch>
5Architecture: arm 5Architecture: arm
6Version: $QPE_VERSION-$SUB_VERSION 6Version: $QPE_VERSION-$SUB_VERSION
7Depends: opie-base ($QPE_VERSION) 7Depends: opie-base ($QPE_VERSION), ipkg (>0.9)
8Description: Package Manager 8Description: Package Manager
9 A GUI front-end to ipkg for the Opie environment. 9 A GUI front-end to ipkg for the Opie environment.
diff --git a/noncore/unsupported/oipkg/package.cpp b/noncore/unsupported/oipkg/package.cpp
index 1705f78..9f602b5 100644
--- a/noncore/unsupported/oipkg/package.cpp
+++ b/noncore/unsupported/oipkg/package.cpp
@@ -1,263 +1,297 @@
1#include "package.h" 1#include "package.h"
2 2
3#include <qpe/process.h> 3#include <qpe/process.h>
4#include <qpe/stringutil.h> 4#include <qpe/stringutil.h>
5 5
6#include "debug.h" 6#include "debug.h"
7 7
8Package::~Package() 8Package::~Package()
9{ 9{
10} 10}
11 11
12Package::Package() 12Package::Package( PackageManagerSettings *s )
13{ 13{
14 init(s);
15}
16
17void Package::init( PackageManagerSettings *s )
18{
19 settings = s;
14 _size = ""; 20 _size = "";
15 _section = ""; 21 _section = "";
16 _subsection = ""; 22 _subsection = "";
17 _shortDesc = ""; 23 _shortDesc = "";
18 _desc = ""; 24 _desc = "";
19 _name = ""; 25 _name = "";
20 _toProcess = false; 26 _toProcess = false;
21 _status = ""; 27 _status = "";
28 _dest = "";
22} 29}
23 30
24Package::Package( QStringList pack ) 31Package::Package( QStringList pack, PackageManagerSettings *s )
25 { 32 {
26 Package(); 33 init(s);
27 parsePackage( pack ); 34 parsePackage( pack );
28 _toProcess = false; 35 _toProcess = false;
29} 36}
30 37
31Package::Package( QString n ) 38Package::Package( QString n, PackageManagerSettings *s )
32 { 39 {
33 Package(); 40 init(s);
34 _name = QString( n ); 41 _name = QString( n );
35 _toProcess = false; 42 _toProcess = false;
36} 43}
37 44
38Package::Package( Package *pi ) 45Package::Package( Package *pi )
39{ 46{
40 Package(); 47 init(pi->settings);
41 copyValues( pi ); 48 copyValues( pi );
42 _toProcess = false; 49 _toProcess = false;
43} 50}
44 51
45 52
46void Package::setValue( QString n, QString t ) 53void Package::setValue( QString n, QString t )
47{ 54{
48 if ( n == "Status" && installed() ) return; 55 if ( n == "Status" && installed() ) return;
49 if ( n == "Package" ) 56 if ( n == "Package" )
50 { 57 {
51 _name = QString( t ); 58 _name = QString( t );
52 } 59 }
53 if ( n == "Installed-Size" ) 60 if ( n == "Installed-Size" )
54 { 61 {
55 _size = t; 62 _size = t;
56 } 63 }
57 if ( n == "Priority") 64 if ( n == "Priority")
58 { 65 {
59 66
60 } 67 }
61 if ( n == "Section") 68 if ( n == "Section")
62 { 69 {
63 setSection( t ); 70 setSection( t );
64 } 71 }
65 if ( n == "Maintainer") 72 if ( n == "Maintainer")
66 { 73 {
67 74
68 } 75 }
69 if ( n == "Architecture") 76 if ( n == "Architecture")
70 { 77 {
71 78
72 } 79 }
73 if ( n == "Version") 80 if ( n == "Version")
74 { 81 {
75 82
76 } 83 }
77 if ( n == "Pre-Depends") 84 if ( n == "Pre-Depends")
78 { 85 {
79 86
80 } 87 }
81 if ( n == "Depends") 88 if ( n == "Depends")
82 { 89 {
83 90
84 }else if ( n == "Filename") 91 }else if ( n == "Filename")
85 { 92 {
86 93
87 }else if ( n == "Size") 94 }else if ( n == "Size")
88 { 95 {
89 96
90 }else if ( n == "MD5Sum") 97 }else if ( n == "MD5Sum")
91 { 98 {
92 99
93 } 100 }
94 if ( n == "Description") 101 if ( n == "Description")
95 { 102 {
96 setDesc( t ); 103 setDesc( t );
97 } 104 }
98 if ( n == "Status") 105 if ( n == "Status")
99 { 106 {
100 if ( installed() ) return; 107 if ( installed() ) return;
101 _status = t; 108 _status = t;
102 } 109 }
103 if ( t == "Essential") 110 if ( t == "Essential")
104 { 111 {
105 112
106 } 113 }
107}; 114};
108 115
109QString Package::name() 116QString Package::name()
110{ 117{
111 return _name; 118 return _name;
112} 119}
113 120
114bool Package::installed() 121bool Package::installed()
115{ 122{
116 return _status.contains("installed"); 123 return _status.contains("installed");
117} 124}
118 125
119void Package::setDesc( QString s ) 126void Package::setDesc( QString s )
120{ 127{
121 _desc = s; 128 _desc = s;
122 _shortDesc = s.left( s.find("\n") ); 129 _shortDesc = s.left( s.find("\n") );
123} 130}
124 131
125QString Package::desc() 132QString Package::desc()
126{ 133{
127 return _desc; 134 return _desc;
128} 135}
129 136
130QString Package::shortDesc() 137QString Package::shortDesc()
131{ 138{
132 return _shortDesc; 139 return _shortDesc;
133} 140}
134 141
135QString Package::size() 142QString Package::size()
136{ 143{
137 return _size; 144 return _size;
138} 145}
139 146
140bool Package::toProcess() 147bool Package::toProcess()
141{ 148{
142 return _toProcess; 149 return _toProcess;
143} 150}
144 151
145bool Package::toRemove() 152bool Package::toRemove()
146{ 153{
147 if ( _toProcess && installed() ) return true; 154 if ( _toProcess && installed() ) return true;
148 else return false; 155 else return false;
149} 156}
150 157
151bool Package::toInstall() 158bool Package::toInstall()
152{ 159{
153 if ( _toProcess && !installed() ) return true; 160 if ( _toProcess && !installed() ) return true;
154 else return false; 161 else return false;
155} 162}
156 163
157void Package::toggleProcess() 164void Package::toggleProcess()
158{ 165{
159 _toProcess = ! _toProcess; 166 _toProcess = ! _toProcess;
160} 167}
161 168
162 169
163 170
164void Package::copyValues( Package* pack ) 171void Package::copyValues( Package* pack )
165{ 172{
166 if (_size.isEmpty() && !pack->_size.isEmpty()) _size = QString( pack->_size ); 173 if (_size.isEmpty() && !pack->_size.isEmpty()) _size = QString( pack->_size );
167 if (_section.isEmpty() && !pack->_section.isEmpty()) _section = QString( pack->_section ); 174 if (_section.isEmpty() && !pack->_section.isEmpty()) _section = QString( pack->_section );
168 if (_subsection.isEmpty()&& !pack->_subsection.isEmpty()) _subsection = QString( pack->_subsection ); 175 if (_subsection.isEmpty()&& !pack->_subsection.isEmpty()) _subsection = QString( pack->_subsection );
169 if (_shortDesc.isEmpty() && !pack->_shortDesc.isEmpty()) _shortDesc = QString( pack->_shortDesc ); 176 if (_shortDesc.isEmpty() && !pack->_shortDesc.isEmpty()) _shortDesc = QString( pack->_shortDesc );
170 if (_desc.isEmpty() && !pack->_desc.isEmpty()) _desc = QString( pack->_desc ); 177 if (_desc.isEmpty() && !pack->_desc.isEmpty()) _desc = QString( pack->_desc );
171 if (_name.isEmpty() && !pack->_name.isEmpty()) _name = QString( pack->_name ); 178 if (_name.isEmpty() && !pack->_name.isEmpty()) _name = QString( pack->_name );
172 if (!installed() && _status.isEmpty() && !pack->_status.isEmpty()) _status = QString( pack->_status ); 179 if (!installed() && _status.isEmpty() && !pack->_status.isEmpty()) _status = QString( pack->_status );
173} 180}
174 181
175QString Package::getSection() 182QString Package::section()
176{ 183{
177 return _section; 184 return _section;
178} 185}
179 186
180void Package::setSection( QString s) 187void Package::setSection( QString s)
181{ 188{
182 int i = s.find("/"); 189 int i = s.find("/");
183 if ( i > 0 ) 190 if ( i > 0 )
184 { 191 {
185 _section = s.left(i); 192 _section = s.left(i);
186 _subsection = s.mid(i+1); 193 _subsection = s.mid(i+1);
187 }else{ 194 }else{
188 _section = s; 195 _section = s;
189 _subsection = ""; 196 _subsection = "";
190 } 197 }
191} 198}
192 199
193QString Package::getSubSection() 200QString Package::subSection()
194{ 201{
195 return _subsection; 202 return _subsection;
196} 203}
197 204
198void Package::parsePackage( QStringList pack ) 205void Package::parsePackage( QStringList pack )
199{ 206{
200 if ( pack.isEmpty() ) return; 207 if ( pack.isEmpty() ) return;
201 int count = pack.count(); 208 int count = pack.count();
202 for( int i = 0; i < count; i++ ) 209 for( int i = 0; i < count; i++ )
203 { 210 {
204 QString line = pack[i]; 211 QString line = pack[i];
205 int sep = line.find( QRegExp(":[\t ]+") ); 212 int sep = line.find( QRegExp(":[\t ]+") );
206 if ( sep >= 0 ) 213 if ( sep >= 0 )
207 { 214 {
208 QString tag = line.left(sep); 215 QString tag = line.left(sep);
209 QString value = line.mid(sep+2).simplifyWhiteSpace(); 216 QString value = line.mid(sep+2).simplifyWhiteSpace();
210 setValue( tag, value ); 217 setValue( tag, value );
211 }else{ 218 }else{
212 } 219 }
213 } 220 }
214 return; 221 return;
215} 222}
216 223
217QString Package::details() 224QString Package::details()
218{ 225{
219 QString status; 226 QString status;
220 Process ipkg_status(QStringList() << "ipkg" << "info" << name() ); 227 Process ipkg_status(QStringList() << "ipkg" << "info" << name() );
221 QString description; 228 QString description;
222 if ( ipkg_status.exec("",status) ) 229 if ( ipkg_status.exec("",status) )
223 { 230 {
224 QStringList lines = QStringList::split('\n',status,TRUE); 231 QStringList lines = QStringList::split('\n',status,TRUE);
225 for (QStringList::Iterator it = lines.begin(); it!=lines.end(); ++it) { 232 for (QStringList::Iterator it = lines.begin(); it!=lines.end(); ++it) {
226 QString line = *it; 233 QString line = *it;
227 if ( line == " ." ) 234 if ( line == " ." )
228 { 235 {
229 description.append("<p>"); 236 description.append("<p>");
230 } else 237 } else
231 if ( line[0] == ' ' || line[0] == '\t' ) 238 if ( line[0] == ' ' || line[0] == '\t' )
232 { 239 {
233 // continuation 240 // continuation
234 description.append(" "); 241 description.append(" ");
235 description.append(Qtopia::escapeString(line)); 242 description.append(Qtopia::escapeString(line));
236 } else { 243 } else {
237 int sep = line.find(QRegExp(":[\t ]+")); 244 int sep = line.find(QRegExp(":[\t ]+"));
238 if ( sep >= 0 ) 245 if ( sep >= 0 )
239 { 246 {
240 QString tag = line.left(sep); 247 QString tag = line.left(sep);
241 description.append("<br>"); 248 description.append("<br>");
242 description.append("<b>"); 249 description.append("<b>");
243 description.append(Qtopia::escapeString(tag)); 250 description.append(Qtopia::escapeString(tag));
244 description.append(":</b> "); 251 description.append(":</b> ");
245 description.append(Qtopia::escapeString(line.mid(sep+2))); 252 description.append(Qtopia::escapeString(line.mid(sep+2)));
246 } else { 253 } else {
247 description.append(" "); 254 description.append(" ");
248 description.append(Qtopia::escapeString(line)); 255 description.append(Qtopia::escapeString(line));
249 } 256 }
250 } 257 }
251 } 258 }
252 } 259 }
253 return description; 260 return description;
254} 261}
255 262
256/** No descriptions */
257void Package::processed() 263void Package::processed()
258{ 264{
259 _toProcess = false; 265 _toProcess = false;
260 //hack, but we're mot writing status anyway... 266 //hack, but we're not writing status anyway...
261 if ( installed() ) _status = "install"; 267 if ( installed() ) _status = "install";
262 else _status = "installed"; 268 else _status = "installed";
263} 269}
270
271QString Package::dest()
272{
273 if ( installed()||(!installed() && _toProcess) )
274 return _dest!=""?_dest:settings->getDestinationName();
275 else return "";
276}
277
278void Package::setDest( QString d )
279{
280 _dest = d;
281}
282
283void Package::setOn()
284{
285 _toProcess = true;
286}
287
288bool Package::link()
289{
290 if ( _dest == "root" || (!installed() && !_toProcess) ) return false;
291 return _link;
292}
293
294void Package::setLink(bool b)
295{
296 _link = b;
297}
diff --git a/noncore/unsupported/oipkg/package.h b/noncore/unsupported/oipkg/package.h
index cf2af75..6c292ed 100644
--- a/noncore/unsupported/oipkg/package.h
+++ b/noncore/unsupported/oipkg/package.h
@@ -1,56 +1,66 @@
1#ifndef PK_ITEM_H 1#ifndef PK_ITEM_H
2#define PK_ITEM_H 2#define PK_ITEM_H
3 3
4#include <qstring.h> 4#include <qstring.h>
5#include <qlistview.h> 5#include <qlistview.h>
6#include <qpainter.h> 6#include <qpainter.h>
7#include <qpixmap.h> 7#include <qpixmap.h>
8#include <qdict.h> 8#include <qdict.h>
9#include <qobject.h> 9#include <qobject.h>
10 10
11#include "pksettings.h"
12
11class Package //: public QObject 13class Package //: public QObject
12{ 14{
13 //Q_OBJECT 15 //Q_OBJECT
14 public: 16 public:
15 Package(); 17 Package(PackageManagerSettings *);
16 ~Package(); 18 ~Package();
17 Package( QStringList ); 19 Package( QStringList, PackageManagerSettings * );
18 Package( QString ); 20 Package( QString, PackageManagerSettings * );
19 Package( Package* ); 21 Package( Package* );
20 22
21 void setValue( QString, QString ); 23 void setValue( QString, QString );
22 void copyValues( Package* ); 24 void copyValues( Package* );
23 25
24 QString name() ; 26 QString name() ;
25 bool installed(); 27 bool installed();
26 28
27 void setDesc( QString ); 29 void setDesc( QString );
28 QString shortDesc(); 30 QString shortDesc();
29 QString desc(); 31 QString desc();
30 QString size(); 32 QString size();
31 void setSection( QString ); 33 void setSection( QString );
32 QString getSection(); 34 QString section();
33 QString getSubSection(); 35 QString subSection();
34 QString details(); 36 QString details();
35 bool toProcess(); 37 bool toProcess();
36 bool toInstall(); 38 bool toInstall();
37 bool toRemove(); 39 bool toRemove();
38 /** No descriptions */
39 void processed(); 40 void processed();
41 QString dest();
42 void setDest( QString d );
43 void setOn();
44 bool link();
45 void setLink(bool);
40public slots: 46public slots:
41 void toggleProcess(); 47 void toggleProcess();
42 48
43private: 49private:
50 PackageManagerSettings *settings;
44 QString _name; 51 QString _name;
45 bool _toProcess; 52 bool _toProcess;
53 bool _link;
46 QString _status; 54 QString _status;
47 QString _size; 55 QString _size;
48 QString _section; 56 QString _section;
49 QString _subsection; 57 QString _subsection;
50 QString _shortDesc; 58 QString _shortDesc;
51 QString _desc; 59 QString _desc;
60 QString _dest;
52 void parsePackage( QStringList ); 61 void parsePackage( QStringList );
62 void init(PackageManagerSettings *);
53}; 63};
54 64
55 65
56#endif 66#endif
diff --git a/noncore/unsupported/oipkg/packagelist.cpp b/noncore/unsupported/oipkg/packagelist.cpp
index 944bb83..035ec81 100644
--- a/noncore/unsupported/oipkg/packagelist.cpp
+++ b/noncore/unsupported/oipkg/packagelist.cpp
@@ -1,223 +1,241 @@
1#include "packagelist.h" 1#include "packagelist.h"
2 2
3#include <assert.h> 3#include <assert.h>
4#include <qfile.h> 4#include <qfile.h>
5#include <qfileinfo.h> 5#include <qfileinfo.h>
6#include <qtextstream.h> 6#include <qtextstream.h>
7#include <qpe/config.h> 7#include <qpe/config.h>
8 8
9#include "debug.h" 9#include "debug.h"
10 10
11PackageList::PackageList() 11PackageList::PackageList()
12 : packageIter( packageList ) 12 : packageIter( packageList )
13{ 13{
14 empty=true; 14 empty=true;
15 { 15 {
16 Config cfg( "oipkg", Config::User ); 16 Config cfg( "oipkg", Config::User );
17 cfg.setGroup( "Common" ); 17 cfg.setGroup( "Common" );
18 statusDir = cfg.readEntry( "statusDir", "" ); 18 statusDir = cfg.readEntry( "statusDir", "" );
19 listsDir = cfg.readEntry( "listsDir", "" ); 19 listsDir = cfg.readEntry( "listsDir", "" );
20 if ( statusDir=="" || ! QFileInfo(statusDir+"/status").isFile() ) 20 if ( statusDir=="" || ! QFileInfo(statusDir+"/status").isFile() )
21 { 21 {
22 statusDir="/usr/lib/ipkg/"; 22 statusDir="/usr/lib/ipkg/";
23 listsDir="/usr/lib/ipkg/lists/"; 23 listsDir="/usr/lib/ipkg/lists/";
24 cfg.writeEntry( "statusDir", statusDir ); 24 cfg.writeEntry( "statusDir", statusDir );
25 cfg.writeEntry( "listsDir", listsDir ); 25 cfg.writeEntry( "listsDir", listsDir );
26 } 26 }
27 } 27 }
28 sections << "All"; 28 sections << "All";
29 subSections.insert("All", new QStringList() ); 29 subSections.insert("All", new QStringList() );
30 QStringList *ss = subSections["All"]; 30 QStringList *ss = subSections["All"];
31 *ss << "All"; 31 *ss << "All";
32 aktSection = "All"; 32 aktSection = "All";
33 aktSubSection = "All"; 33 aktSubSection = "All";
34} 34}
35 35
36PackageList::PackageList( PackageManagerSettings* s) 36PackageList::PackageList( PackageManagerSettings* s)
37 : packageIter( packageList ) 37 : packageIter( packageList )
38{ 38{
39 settings = s; 39 settings = s;
40 PackageList(); 40 PackageList();
41} 41}
42 42
43PackageList::~PackageList() 43PackageList::~PackageList()
44{ 44{
45} 45}
46 46
47/** Inserts a package into the list */ 47/** Inserts a package into the list */
48void PackageList::insertPackage( Package* pack ) 48void PackageList::insertPackage( Package* pack )
49{ 49{
50 Package* p = packageList.find( pack->name() ); 50 Package* p = packageList.find( pack->name() );
51 if ( p ) 51 if ( p )
52 { 52 {
53 p->copyValues( pack ); 53 p->copyValues( pack );
54 delete pack; 54 delete pack;
55 pack = p; 55 pack = p;
56 }else{ 56 }else{
57 packageList.insert( pack->name(), pack ); 57 packageList.insert( pack->name(), pack );
58 origPackageList.insert( pack->name(), pack ); 58 origPackageList.insert( pack->name(), pack );
59 empty=false; 59 empty=false;
60 }; 60 };
61 updateSections( pack ); 61 updateSections( pack );
62} 62}
63 63
64void PackageList::filterPackages( QString f ) 64void PackageList::filterPackages( QString f )
65 { 65 {
66 packageList.clear(); 66 packageList.clear();
67 QDictIterator<Package> filterIter( origPackageList ); 67 QDictIterator<Package> filterIter( origPackageList );
68 filterIter.toFirst(); 68 filterIter.toFirst();
69 Package *pack= filterIter.current() ; 69 Package *pack= filterIter.current() ;
70 while ( pack ) 70 while ( pack )
71 { 71 {
72 if ( 72 if (
73 ((aktSection=="All")||(pack->getSection()==aktSection)) && 73 ((aktSection=="All")||(pack->section()==aktSection)) &&
74 ((aktSubSection=="All")||(pack->getSubSection()==aktSubSection)) && 74 ((aktSubSection=="All")||(pack->subSection()==aktSubSection)) &&
75 pack->name().contains( f ) 75 pack->name().contains( f )
76 ) 76 )
77 { 77 {
78 packageList.insert( pack->name(), pack ); 78 packageList.insert( pack->name(), pack );
79 } 79 }
80 ++filterIter; 80 ++filterIter;
81 pack = filterIter.current(); 81 pack = filterIter.current();
82 } 82 }
83} 83}
84 84
85Package* PackageList::find( QString n ) 85Package* PackageList::find( QString n )
86{ 86{
87 return packageList.find( n ); 87 return packageList.find( n );
88} 88}
89 89
90Package* PackageList::first() 90Package* PackageList::first()
91 { 91 {
92 packageIter.toFirst(); 92 packageIter.toFirst();
93 return packageIter.current(); 93 return packageIter.current();
94} 94}
95 95
96Package* PackageList::next() 96Package* PackageList::next()
97{ 97{
98 ++packageIter; 98 ++packageIter;
99 return packageIter.current(); 99 return packageIter.current();
100} 100}
101 101
102QStringList PackageList::getSections() 102QStringList PackageList::getSections()
103{ 103{
104 sections.sort(); 104 sections.sort();
105 return sections; 105 return sections;
106} 106}
107 107
108QStringList PackageList::getSubSections() 108QStringList PackageList::getSubSections()
109{ 109{
110 QStringList ss; 110 QStringList ss;
111 if ( !subSections[aktSection] ) return ss; 111 if ( !subSections[aktSection] ) return ss;
112 ss = *subSections[aktSection]; 112 ss = *subSections[aktSection];
113 ss.sort(); 113 ss.sort();
114 return ss; 114 return ss;
115} 115}
116 116
117void PackageList::setSection( QString sec ) 117void PackageList::setSection( QString sec )
118{ 118{
119 aktSection = sec; 119 aktSection = sec;
120} 120}
121 121
122void PackageList::setSubSection( QString ssec ) 122void PackageList::setSubSection( QString ssec )
123{ 123{
124 aktSubSection = ssec; 124 aktSubSection = ssec;
125} 125}
126 126
127void PackageList::updateSections( Package* pack ) 127void PackageList::updateSections( Package* pack )
128{ 128{
129 QString s = pack->getSection(); 129 QString s = pack->section();
130 if ( s.isEmpty() || s == "") return; 130 if ( s.isEmpty() || s == "") return;
131 if ( sections.contains(s) ) return; 131 if ( sections.contains(s) ) return;
132 sections += s; 132 sections += s;
133 QString ss = pack->getSubSection(); 133 QString ss = pack->subSection();
134 if ( ss.isEmpty() || ss == "" ) return; 134 if ( ss.isEmpty() || ss == "" ) return;
135 if ( !subSections[s] ) { 135 if ( !subSections[s] ) {
136 subSections.insert( s, new QStringList() ); 136 subSections.insert( s, new QStringList() );
137 QStringList *subsecs = subSections[s]; 137 QStringList *subsecs = subSections[s];
138 *subsecs += "All"; 138 *subsecs += "All";
139 } 139 }
140 QStringList *subsecs = subSections[s]; 140 QStringList *subsecs = subSections[s];
141 *subsecs += ss; 141 *subsecs += ss;
142 if ( !subSections["All"] ) subSections.insert( "All", new QStringList() ); 142 if ( !subSections["All"] ) subSections.insert( "All", new QStringList() );
143 subsecs = subSections["All"]; 143 subsecs = subSections["All"];
144 *subsecs += ss; 144 *subsecs += ss;
145} 145}
146 146
147 147
148 148
149/** No descriptions */ 149/** No descriptions */
150void PackageList::parseStatus() 150void PackageList::parseStatus()
151{ 151{
152 QStringList dests = settings->getDestinationUrls(); 152 QStringList dests = settings->getDestinationUrls();
153 for ( QStringList::Iterator it = dests.begin(); it != dests.end(); ++it ) 153 QStringList destnames = settings->getDestinationNames();
154 QStringList::Iterator name = destnames.begin();
155 for ( QStringList::Iterator dir = dests.begin(); dir != dests.end(); ++dir )
154 { 156 {
155 pvDebug( 2,"Status Dir: "+*it+statusDir+"/status"); 157 pvDebug( 2,"Status: "+*dir+statusDir+"/status");
156 readFileEntries( *it+statusDir+"/status" ); 158 readFileEntries( *dir+statusDir+"/status", *name );
159 ++name;
157 }; 160 };
158} 161}
159 162
160void PackageList::parseList() 163void PackageList::parseList()
161{ 164{
162 QStringList srvs = settings->getActiveServers(); 165 QStringList srvs = settings->getActiveServers();
163 166
164 for ( QStringList::Iterator it = srvs.begin(); it != srvs.end(); ++it ) 167 for ( QStringList::Iterator it = srvs.begin(); it != srvs.end(); ++it )
165 { 168 {
166 pvDebug( 2, "List Dir: "+listsDir+"/"+*it); 169 pvDebug( 2, "List: "+listsDir+"/"+*it);
167 readFileEntries( listsDir+"/"+*it ); 170 readFileEntries( listsDir+"/"+*it, "" );
168 } 171 }
169} 172}
170 173
171void PackageList::readFileEntries( QString filename ) 174void PackageList::readFileEntries( QString filename, QString dest )
172 { 175 {
173 QStringList packEntry; 176 QStringList packEntry;
174 QFile f( filename ); 177 QFile f( filename );
175 if ( !f.open(IO_ReadOnly) ) return; 178 if ( !f.open(IO_ReadOnly) ) return;
176 QTextStream *statusStream = new QTextStream( &f ); 179 QTextStream *statusStream = new QTextStream( &f );
177 while ( !statusStream ->eof() ) 180 while ( !statusStream ->eof() )
178 { 181 {
179 QString line = statusStream->readLine(); 182 QString line = statusStream->readLine();
180 if ( line.find(QRegExp("[\n\t ]*")) || line == "" ) 183 if ( line.find(QRegExp("[\n\t ]*")) || line == "" )
181 { 184 {
182 //end of package 185 //end of package
183 if ( ! packEntry.isEmpty() ) 186 if ( ! packEntry.isEmpty() )
184 { 187 {
185 Package *p = new Package( packEntry ); 188 Package *p = new Package( packEntry, settings );
189 p->setDest( dest );
186 if ( p ) 190 if ( p )
187 { 191 {
188 insertPackage( p ); 192 insertPackage( p );
189 packEntry.clear(); 193 packEntry.clear();
190 } 194 }
191 } 195 }
192 }else{ 196 }else{
193 packEntry << line; 197 packEntry << line;
194 }; 198 };
195 } 199 }
196 return; 200 return;
197} 201}
198 202
199 203
200void PackageList::update() 204void PackageList::update()
201{ 205{
202 pvDebug( 3, "parseStatus"); 206 pvDebug( 2, "parseStatus");
203 parseStatus(); 207 parseStatus();
204 pvDebug( 3, "parseList"); 208 pvDebug( 2, "parseList");
205 parseList(); 209 parseList();
206 pvDebug( 3, "finished parsing"); 210 pvDebug( 2, "finished parsing");
207} 211}
208 212
209void PackageList::setSettings( PackageManagerSettings *s ) 213void PackageList::setSettings( PackageManagerSettings *s )
210{ 214{
211 settings = s; 215 settings = s;
212} 216}
213 217
214Package* PackageList::getByName( QString n ) 218Package* PackageList::getByName( QString n )
215{ 219{
216 origPackageList[n]; 220 origPackageList[n];
217} 221}
218 222
219void PackageList::clear() 223void PackageList::clear()
220{ 224{
221 origPackageList.clear(); 225 origPackageList.clear();
222 packageList.clear(); 226 packageList.clear();
223} 227}
228
229void PackageList::allPackages()
230{
231 packageList.clear();
232 QDictIterator<Package> filterIter( origPackageList );
233 filterIter.toFirst();
234 Package *pack= filterIter.current() ;
235 while ( pack )
236 {
237 packageList.insert( pack->name(), pack );
238 ++filterIter;
239 pack = filterIter.current();
240 }
241}
diff --git a/noncore/unsupported/oipkg/packagelist.h b/noncore/unsupported/oipkg/packagelist.h
index 4ce97af..7c326ca 100644
--- a/noncore/unsupported/oipkg/packagelist.h
+++ b/noncore/unsupported/oipkg/packagelist.h
@@ -1,68 +1,70 @@
1#ifndef PACKAGELIST_H 1#ifndef PACKAGELIST_H
2#define PACKAGELIST_H 2#define PACKAGELIST_H
3 3
4#include <qdict.h> 4#include <qdict.h>
5#include "package.h" 5#include "package.h"
6#include "pksettings.h" 6#include "pksettings.h"
7#include "debug.h" 7#include "debug.h"
8 8
9#define HACK 9#define HACK
10#ifdef HACK 10#ifdef HACK
11 static QString listsDir="/usr/lib/ipkg/"; 11 static QString listsDir="/usr/lib/ipkg/";
12 static QString statusDir="/usr/lib/ipkg/"; 12 static QString statusDir="/usr/lib/ipkg/";
13#endif 13#endif
14 14
15class PackageList { 15class PackageList //:QObject
16{
17 // Q_OBJECT
16public: 18public:
17 //static QString all = QObject::tr("All"); 19 //static QString all = QObject::tr("All");
18 20
19 PackageList(); 21 PackageList();
20 PackageList( PackageManagerSettings* ); 22 PackageList( PackageManagerSettings* );
21 ~PackageList(); 23 ~PackageList();
22 void insertPackage( Package* ); 24 void insertPackage( Package* );
23 Package* find( QString ); 25 Package* find( QString );
24 Package* next(); 26 Package* next();
25 Package* first(); 27 Package* first();
26 28
27 QStringList getSections(); 29 QStringList getSections();
28 QStringList getSubSections(); 30 QStringList getSubSections();
29 void setSettings( PackageManagerSettings* ); 31 void setSettings( PackageManagerSettings* );
30 void filterPackages( QString ); 32 void filterPackages( QString );
31 Package* getByName( QString ); 33 Package* getByName( QString );
32 /** No descriptions */
33 void clear(); 34 void clear();
35 void allPackages();
34 36
35public slots: 37public slots:
36 void setSection(QString); 38 void setSection(QString);
37 void setSubSection(QString); 39 void setSubSection(QString);
38 void update(); 40 void update();
39 41
40private: 42private:
41 int currentPackage; 43 int currentPackage;
42 int packageCount; 44 int packageCount;
43 45
44 PackageManagerSettings *settings; 46 PackageManagerSettings *settings;
45 QDict<Package> packageList; 47 QDict<Package> packageList;
46 QDict<Package> origPackageList; 48 QDict<Package> origPackageList;
47 QDictIterator<Package> packageIter; 49 QDictIterator<Package> packageIter;
48 50
49 bool empty; 51 bool empty;
50#ifndef HACK 52#ifndef HACK
51 QString listsDir; 53 QString listsDir;
52 QString statusDir; 54 QString statusDir;
53#endif 55#endif
54 QString aktSection; 56 QString aktSection;
55 QString aktSubSection; 57 QString aktSubSection;
56 QStringList sections; 58 QStringList sections;
57 QDict<QStringList> subSections; 59 QDict<QStringList> subSections;
58 QDict<bool> sectionsDict; 60 QDict<bool> sectionsDict;
59 61
60 62
61 void updateSections( Package* ); 63 void updateSections( Package* );
62 void parseStatus(); 64 void parseStatus();
63 void parseList(); 65 void parseList();
64 void readFileEntries( QString ); 66 void readFileEntries( QString file, QString dest );
65}; 67};
66 68
67 69
68#endif 70#endif
diff --git a/noncore/unsupported/oipkg/packagelistitem.cpp b/noncore/unsupported/oipkg/packagelistitem.cpp
index 5d08bb1..149ba35 100644
--- a/noncore/unsupported/oipkg/packagelistitem.cpp
+++ b/noncore/unsupported/oipkg/packagelistitem.cpp
@@ -1,97 +1,139 @@
1#include "packagelistitem.h" 1#include "packagelistitem.h"
2 2
3#include <qpe/resource.h> 3#include <qpe/resource.h>
4#include <qobject.h>
5
6#include "debug.h"
4 7
5static QPixmap *pm_uninstalled=0; 8static QPixmap *pm_uninstalled=0;
6static QPixmap *pm_installed=0; 9static QPixmap *pm_installed=0;
7static QPixmap *pm_uninstall=0; 10static QPixmap *pm_uninstall=0;
8static QPixmap *pm_install=0; 11static QPixmap *pm_install=0;
9 12
10PackageListItem::PackageListItem(QListView* lv, Package *pi) 13PackageListItem::PackageListItem(QListView* lv, Package *pi, PackageManagerSettings *s)
11 :QCheckListItem(lv,pi->name(),CheckBox) 14 :QCheckListItem(lv,pi->name(),CheckBox)
12{ 15{
13 package = pi; 16 package = pi;
17 settings = s;
18 setExpandable( true );
19 QCheckListItem *item;
20#ifndef NEWLAYOUT
21 item = new QCheckListItem( this, QObject::tr("Name") );
22 item->setText(1,pi->name());
23 item = new QCheckListItem( this, QObject::tr("Description") );
24 item->setText(1,pi->desc()+"\ntest multi\nline");
25 item = new QCheckListItem( this, QObject::tr("Size") );
26 item->setText(1,pi->size());
27 item = new QCheckListItem( this, QObject::tr("Destination") );
28 item->setText(1,pi->getDest());
29#endif
30#ifdef NEWLAYOUT
31 item = new QCheckListItem( this, QObject::tr("Name: ")+pi->name() );
32 item = new QCheckListItem( this, QObject::tr("Description: ")+pi->desc() );
33 item = new QCheckListItem( this, QObject::tr("Size: ")+pi->size() );
34 destItem = new QCheckListItem( this, "" );
35 linkItem = new QCheckListItem( this, "" );
36 displayDetails();
37#endif
38
14 if (!pm_uninstalled) { 39 if (!pm_uninstalled) {
15 pm_uninstalled = new QPixmap(Resource::loadPixmap("oipkg/uninstalled")); 40 pm_uninstalled = new QPixmap(Resource::loadPixmap("oipkg/uninstalled"));
16 pm_installed = new QPixmap(Resource::loadPixmap("oipkg/installed")); 41 pm_installed = new QPixmap(Resource::loadPixmap("oipkg/installed"));
17 pm_install = new QPixmap(Resource::loadPixmap("oipkg/install")); 42 pm_install = new QPixmap(Resource::loadPixmap("oipkg/install"));
18 pm_uninstall = new QPixmap(Resource::loadPixmap("oipkg/uninstall")); 43 pm_uninstall = new QPixmap(Resource::loadPixmap("oipkg/uninstall"));
19 } 44 }
45#ifndef NEWLAYOUT
20 setText(1, package->shortDesc() ); 46 setText(1, package->shortDesc() );
21 setText(2, package->size() ); 47 setText(2, package->size() );
48#endif
22} 49}
23 50
24void PackageListItem::paintCell( QPainter *p, const QColorGroup & cg, 51void PackageListItem::paintCell( QPainter *p, const QColorGroup & cg,
25 int column, int width, int alignment ) 52 int column, int width, int alignment )
26{ 53{
27 if ( !p ) 54 if ( !p )
28 return; 55 return;
29 56
30 p->fillRect( 0, 0, width, height(), 57 p->fillRect( 0, 0, width, height(),
31 isSelected()? cg.highlight() : cg.base() ); 58 isSelected()? cg.highlight() : cg.base() );
32 59
33 if ( column != 0 ) { 60 if ( column != 0 ) {
34 // The rest is text 61 // The rest is text
35 QListViewItem::paintCell( p, cg, column, width, alignment ); 62 QListViewItem::paintCell( p, cg, column, width, alignment );
36 return; 63 return;
37 } 64 }
38 65
39 QListView *lv = listView(); 66 QListView *lv = listView();
40 if ( !lv ) 67 if ( !lv )
41 return; 68 return;
42 int marg = lv->itemMargin(); 69 int marg = lv->itemMargin();
43 int r = marg; 70 int r = marg;
44 71
45 QPixmap pm = statePixmap(); 72 QPixmap pm = statePixmap();
46 p->drawPixmap(marg,(height()-pm.height())/2,pm); 73 p->drawPixmap(marg,(height()-pm.height())/2,pm);
47 r += pm.width()+1; 74 r += pm.width()+1;
48 75
49 p->translate( r, 0 ); 76 p->translate( r, 0 );
50 QListViewItem::paintCell( p, cg, column, width - r, alignment ); 77 QListViewItem::paintCell( p, cg, column, width - r, alignment );
51} 78}
52 79
53 80
54void PackageListItem::paintFocus( QPainter *p, const QColorGroup & cg, 81void PackageListItem::paintFocus( QPainter *p, const QColorGroup & cg,
55 const QRect & r ) 82 const QRect & r )
56{ 83{
57 // Skip QCheckListItem 84 // Skip QCheckListItem
58 // (makes you wonder what we're getting from QCheckListItem) 85 // (makes you wonder what we're getting from QCheckListItem)
59 QListViewItem::paintFocus(p,cg,r); 86 QListViewItem::paintFocus(p,cg,r);
60} 87}
61 88
62QPixmap PackageListItem::statePixmap() const 89QPixmap PackageListItem::statePixmap() const
63{ 90{
64 bool installed = package->installed(); 91 bool installed = package->installed();
65 if ( !package->toProcess() ) { 92 if ( !package->toProcess() ) {
66 if ( !installed ) 93 if ( !installed )
67 return *pm_uninstalled; 94 return *pm_uninstalled;
68 else 95 else
69 return *pm_installed; 96 return *pm_installed;
70 } else { 97 } else {
71 if ( !installed ) 98 if ( !installed )
72 return *pm_install; 99 return *pm_install;
73 else 100 else
74 return *pm_uninstall; 101 return *pm_uninstall;
75 } 102 }
76} 103}
77 104
78QString PackageListItem::key( int column, bool ascending ) const 105QString PackageListItem::key( int column, bool ascending ) const
79{ 106{
80 if ( column == 2 ) { 107 if ( column == 2 ) {
81 QString t = text(2); 108 QString t = text(2);
82 double bytes=t.toDouble(); 109 double bytes=t.toDouble();
83 if ( t.contains('M') ) bytes*=1024*1024; 110 if ( t.contains('M') ) bytes*=1024*1024;
84 else if ( t.contains('K') || t.contains('k') ) bytes*=1024; 111 else if ( t.contains('K') || t.contains('k') ) bytes*=1024;
85 if ( !ascending ) bytes=999999999-bytes; 112 if ( !ascending ) bytes=999999999-bytes;
86 return QString().sprintf("%09d",(int)bytes); 113 return QString().sprintf("%09d",(int)bytes);
87 } else { 114 } else {
88 return QListViewItem::key(column,ascending); 115 return QListViewItem::key(column,ascending);
89 } 116 }
90} 117}
91 118
92void PackageListItem::setOn( bool b ) 119void PackageListItem::setOn( bool b )
93{ 120{
94 QCheckListItem::setOn( b ); 121 QCheckListItem::setOn( b );
95 package->toggleProcess(); 122 package->toggleProcess();
123// if ( b )
124// {
125// if ((package->dest()).isEmpty)
126 // package->setDest( settings->getDestinationName() );
127// }else{
128// package->setDest( QObject::tr("not installed"));
129// }
130 package->setLink( settings->createLinks() );
131 displayDetails();
132}
133
134void PackageListItem::displayDetails()
135{
136 linkItem->setText( 0, QObject::tr("Link: ")+QString(package->link()?QObject::tr("Yes"):QObject::tr("No")) );
137 destItem->setText( 0, QObject::tr("Destination: ")+package->dest() );
96 repaint(); 138 repaint();
97} 139}
diff --git a/noncore/unsupported/oipkg/packagelistitem.h b/noncore/unsupported/oipkg/packagelistitem.h
index 6983e58..f695432 100644
--- a/noncore/unsupported/oipkg/packagelistitem.h
+++ b/noncore/unsupported/oipkg/packagelistitem.h
@@ -1,31 +1,37 @@
1#ifndef PK_LISTITEM_H 1#ifndef PK_LISTITEM_H
2#define PK_LISTITEM_H 2#define PK_LISTITEM_H
3 3
4#include "package.h" 4#include "package.h"
5 5
6#include <qstring.h> 6#include <qstring.h>
7#include <qlistview.h> 7#include <qlistview.h>
8#include <qpainter.h> 8#include <qpainter.h>
9#include <qpixmap.h> 9#include <qpixmap.h>
10#include <qdict.h> 10#include <qdict.h>
11 11
12#include "pksettings.h"
13
12class PackageListItem 14class PackageListItem
13: public QCheckListItem 15: public QCheckListItem
14{ 16{
15public: 17public:
16 PackageListItem(QListView*, Package* ); 18 PackageListItem(QListView*, Package*, PackageManagerSettings*);
17 void paintCell( QPainter*, const QColorGroup&, int, int, int ); 19 void paintCell( QPainter*, const QColorGroup&, int, int, int );
18 void paintFocus( QPainter*, const QColorGroup&, const QRect& ); 20 void paintFocus( QPainter*, const QColorGroup&, const QRect& );
19 QPixmap statePixmap() const; 21 QPixmap statePixmap() const;
20 QString key( int, bool ) const; 22 QString key( int, bool ) const;
21 Package* getPackage() { return package; } ; 23 Package* getPackage() { return package; } ;
22 QString getName() { return package->name(); } ; 24 QString getName() { return package->name(); } ;
23 bool isInstalled(){ return package->installed(); }; 25 bool isInstalled(){ return package->installed(); };
24 virtual void setOn ( bool ); 26 virtual void setOn ( bool );
27 void displayDetails();
25 28
26private: 29private:
30 QCheckListItem *destItem;
31 QCheckListItem *linkItem;
32 PackageManagerSettings *settings;
27 Package *package; 33 Package *package;
28}; 34};
29 35
30 36
31#endif 37#endif
diff --git a/noncore/unsupported/oipkg/pksettings.cpp b/noncore/unsupported/oipkg/pksettings.cpp
index 32224b5..f84a9c4 100644
--- a/noncore/unsupported/oipkg/pksettings.cpp
+++ b/noncore/unsupported/oipkg/pksettings.cpp
@@ -216,272 +216,296 @@ void PackageManagerSettings::writeIpkgConfig(const QString& conffile)
216 conf.close(); 216 conf.close();
217} 217}
218 218
219 219
220void PackageManagerSettings::readInstallationSettings() 220void PackageManagerSettings::readInstallationSettings()
221{ 221{
222 Config cfg( "oipkg", Config::User ); 222 Config cfg( "oipkg", Config::User );
223 cfg.setGroup( "Settings" ); 223 cfg.setGroup( "Settings" );
224 installationSettingsCount = cfg.readNumEntry( "count", -1 ); 224 installationSettingsCount = cfg.readNumEntry( "count", -1 );
225 currentSetting = cfg.readNumEntry( "current", 0 );// o should be -1 225 currentSetting = cfg.readNumEntry( "current", 0 );// o should be -1
226 226
227 for (int i = 0; i < installationSettingsCount; i++) 227 for (int i = 0; i < installationSettingsCount; i++)
228 { 228 {
229 cfg.setGroup( "Setting_" + QString::number(i) ); 229 cfg.setGroup( "Setting_" + QString::number(i) );
230 settingName->insertItem( cfg.readEntry( "name", "???" ), i ); 230 settingName->insertItem( cfg.readEntry( "name", "???" ), i );
231 }; 231 };
232 readInstallationSetting( currentSetting ); 232 readInstallationSetting( currentSetting );
233} 233}
234 234
235 235
236 236
237/** 237/**
238 * remove from conf file 238 * remove from conf file
239 */ 239 */
240void PackageManagerSettings::removeInstallationSetting() 240void PackageManagerSettings::removeInstallationSetting()
241{ 241{
242 settingName->removeItem( settingName->currentItem() ); 242 settingName->removeItem( settingName->currentItem() );
243 Config cfg( "oipkg", Config::User ); 243 Config cfg( "oipkg", Config::User );
244 cfg.setGroup( "Setting_" + QString::number( installationSettingsCount ) ); 244 cfg.setGroup( "Setting_" + QString::number( installationSettingsCount ) );
245 cfg.clearGroup(); 245 cfg.clearGroup();
246 installationSettingsCount--; 246 installationSettingsCount--;
247 changed = true; 247 changed = true;
248 settingName->setEditable( false ); 248 settingName->setEditable( false );
249} 249}
250 250
251/** 251/**
252 * write to confgile 252 * write to confgile
253 */ 253 */
254void PackageManagerSettings::newInstallationSetting() 254void PackageManagerSettings::newInstallationSetting()
255{ 255{
256 installationSettingsCount++; 256 installationSettingsCount++;
257 settingName->insertItem( "New", installationSettingsCount ); 257 settingName->insertItem( "New", installationSettingsCount );
258 settingName->setCurrentItem( installationSettingsCount ); 258 settingName->setCurrentItem( installationSettingsCount );
259 settingName->setEditable( true ); 259 settingName->setEditable( true );
260 changed = true; 260 changed = true;
261} 261}
262 262
263void PackageManagerSettings::installationSettingChange(int cs) 263void PackageManagerSettings::installationSettingChange(int cs)
264{ 264{
265 writeCurrentInstallationSetting(); 265 writeCurrentInstallationSetting();
266 currentSetting = cs; 266 currentSetting = cs;
267 readInstallationSetting( cs ); 267 readInstallationSetting( cs );
268} 268}
269 269
270void PackageManagerSettings::writeInstallationSettings() 270void PackageManagerSettings::writeInstallationSettings()
271{ 271{
272 if ( ! changed ) return ; 272 if ( ! changed ) return ;
273 { 273 {
274 Config cfg( "oipkg", Config::User ); 274 Config cfg( "oipkg", Config::User );
275 cfg.setGroup( "Settings" ); 275 cfg.setGroup( "Settings" );
276 cfg.writeEntry( "count", installationSettingsCount ); 276 cfg.writeEntry( "count", installationSettingsCount );
277 cfg.writeEntry( "current", currentSetting ); 277 cfg.writeEntry( "current", currentSetting );
278 } 278 }
279 writeCurrentInstallationSetting(); 279 writeCurrentInstallationSetting();
280} 280}
281 281
282 282
283void PackageManagerSettings::readInstallationSetting(int setting) 283void PackageManagerSettings::readInstallationSetting(int setting)
284{ 284{
285 if ( setting < 0 ) return; 285 if ( setting < 0 ) return;
286 Config cfg( "oipkg", Config::User ); 286 Config cfg( "oipkg", Config::User );
287 cfg.setGroup( "Setting_" + QString::number( setting ) ); 287 cfg.setGroup( "Setting_" + QString::number( setting ) );
288 CheckBoxLink->setChecked( cfg.readBoolEntry( "link", false ) ); 288 CheckBoxLink->setChecked( cfg.readBoolEntry( "link", false ) );
289 QString dest = cfg.readEntry( "dest" ); 289 QString dest = cfg.readEntry( "dest" );
290 QString linkdest = cfg.readEntry( "linkdest" ); 290 QString linkdest = cfg.readEntry( "linkdest" );
291 pvDebug(3, "dest="+dest); 291 pvDebug(3, "dest="+dest);
292 pvDebug(3, "linkdest="+linkdest); 292 pvDebug(3, "linkdest="+linkdest);
293 293
294 for ( int i = 0; i < activeDestination->count(); i++) 294 for ( int i = 0; i < activeDestination->count(); i++)
295 { 295 {
296 if ( activeDestination->text( i ) == dest ) 296 if ( activeDestination->text( i ) == dest )
297 activeDestination->setCurrentItem( i ); 297 activeDestination->setCurrentItem( i );
298 if ( activeLinkDestination->text( i ) == linkdest ) 298 if ( activeLinkDestination->text( i ) == linkdest )
299 activeLinkDestination->setCurrentItem( i ); 299 activeLinkDestination->setCurrentItem( i );
300 } 300 }
301} 301}
302 302
303void PackageManagerSettings::writeCurrentInstallationSetting() 303void PackageManagerSettings::writeCurrentInstallationSetting()
304{ 304{
305 Config cfg( "oipkg", Config::User ); 305 Config cfg( "oipkg", Config::User );
306 changed = false; 306 changed = false;
307 cfg.setGroup( "Setting_" + QString::number(currentSetting) ); 307 cfg.setGroup( "Setting_" + QString::number(currentSetting) );
308 cfg.writeEntry( "link", CheckBoxLink->isChecked() ); 308 cfg.writeEntry( "link", CheckBoxLink->isChecked() );
309 cfg.writeEntry( "dest", getDestinationName() ); 309 cfg.writeEntry( "dest", getDestinationName() );
310 cfg.writeEntry( "linkdest" , getLinkDestinationName() ); 310 cfg.writeEntry( "linkdest" , getLinkDestinationName() );
311 QStringList sers = getActiveServers(); 311 QStringList sers = getActiveServers();
312 int srvc = 0; 312 int srvc = 0;
313 for ( QStringList::Iterator it = sers.begin(); it != sers.end(); ++it ) { 313 for ( QStringList::Iterator it = sers.begin(); it != sers.end(); ++it ) {
314 cfg.writeEntry( "server_" + QString::number(srvc++), *it ); 314 cfg.writeEntry( "server_" + QString::number(srvc++), *it );
315 } 315 }
316 cfg.writeEntry( "server_count", srvc ); 316 cfg.writeEntry( "server_count", srvc );
317} 317}
318 318
319void PackageManagerSettings::renameInstallationSetting() 319void PackageManagerSettings::renameInstallationSetting()
320{ 320{
321 settingName->setEditable( true ); 321 settingName->setEditable( true );
322 changed = true; 322 changed = true;
323} 323}
324 324
325void PackageManagerSettings::installationSettingSetName(const QString &name) 325void PackageManagerSettings::installationSettingSetName(const QString &name)
326{ 326{
327 settingName->changeItem( name, settingName->currentItem() ); 327 settingName->changeItem( name, settingName->currentItem() );
328 changed = true; 328 changed = true;
329} 329}
330 330
331 331
332bool PackageManagerSettings::readIpkgConfig(const QString& conffile) 332bool PackageManagerSettings::readIpkgConfig(const QString& conffile)
333{ 333{
334 QFile conf(conffile); 334 QFile conf(conffile);
335 if ( conf.open(IO_ReadOnly) ) { 335 if ( conf.open(IO_ReadOnly) ) {
336 QTextStream s(&conf); 336 QTextStream s(&conf);
337 servers->clear(); 337 servers->clear();
338 activeServers->clear(); 338 activeServers->clear();
339 activeDestination->clear(); 339 activeDestination->clear();
340 activeLinkDestination->clear(); 340 activeLinkDestination->clear();
341 serverurlDic.clear(); 341 serverurlDic.clear();
342 destinationurlDic.clear(); 342 destinationurlDic.clear();
343 ipkg_old=0; 343 ipkg_old=0;
344 int currentserver=0; 344 int currentserver=0;
345 while ( !s.atEnd() ) { 345 while ( !s.atEnd() ) {
346 QString l = s.readLine(); 346 QString l = s.readLine();
347 QStringList token = QStringList::split(' ', l); 347 QStringList token = QStringList::split(' ', l);
348 if ( token[0] == "src" || token[0] == "#src" ) { 348 if ( token[0] == "src" || token[0] == "#src" ) {
349 currentserver=servers->count(); 349 currentserver=servers->count();
350 serverurlDic.insert(servers->count(),new QString(token[2])); 350 serverurlDic.insert(servers->count(),new QString(token[2]));
351 int a = token[0] == "src" ? 1 : 0; 351 int a = token[0] == "src" ? 1 : 0;
352 int i = servers->count(); 352 int i = servers->count();
353 servers->insertItem(token[1]); 353 servers->insertItem(token[1]);
354 activeServers->insertItem( token[1] ); 354 activeServers->insertItem( token[1] );
355 activeServers->setSelected(i,a); 355 activeServers->setSelected(i,a);
356 } else if ( token[0] == "dest" ) { 356 } else if ( token[0] == "dest" ) {
357 currentserver=destinations->count(); 357 currentserver=destinations->count();
358 destinationurlDic.insert(destinations->count(),new QString(token[2])); 358 destinationurlDic.insert(destinations->count(),new QString(token[2]));
359 destinations->insertItem(token[1]); 359 destinations->insertItem(token[1]);
360 activeDestination->insertItem( token[1] ); 360 activeDestination->insertItem( token[1] );
361 activeLinkDestination->insertItem( token[1] ); 361 activeLinkDestination->insertItem( token[1] );
362 362
363 } else if ( token[0] == "option" ) { 363 } else if ( token[0] == "option" ) {
364 // ### somehow need to use the settings from netsetup 364 // ### somehow need to use the settings from netsetup
365 // if ( token[1] == "http_proxy" ) 365 // if ( token[1] == "http_proxy" )
366 // http->setText(token[2]); 366 // http->setText(token[2]);
367 // else if ( token[1] == "ftp_proxy" ) 367 // else if ( token[1] == "ftp_proxy" )
368 // ftp->setText(token[2]); 368 // ftp->setText(token[2]);
369 // else if ( token[1] == "proxy_username" ) 369 // else if ( token[1] == "proxy_username" )
370 // username->setText(token[2]); 370 // username->setText(token[2]);
371 // else if ( token[1] == "proxy_password" ) 371 // else if ( token[1] == "proxy_password" )
372 // password->setText(token[2]); 372 // password->setText(token[2]);
373 } else { 373 } else {
374 // Old style? 374 // Old style?
375 int eq = l.find('='); 375 int eq = l.find('=');
376 if ( eq >= 0 ) { 376 if ( eq >= 0 ) {
377 QString v = l.mid(eq+1).stripWhiteSpace(); 377 QString v = l.mid(eq+1).stripWhiteSpace();
378 if ( v[0] == '"' || v[0] == '\'' ) { 378 if ( v[0] == '"' || v[0] == '\'' ) {
379 int cl=v.find(v[0],1); 379 int cl=v.find(v[0],1);
380 if ( cl >= 0 ) 380 if ( cl >= 0 )
381 v = v.mid(1,cl-1); 381 v = v.mid(1,cl-1);
382 } 382 }
383 if ( l.left(12) == "IPKG_SOURCE=" ) { 383 if ( l.left(12) == "IPKG_SOURCE=" ) {
384 ipkg_old=1; 384 ipkg_old=1;
385 currentserver=servers->count(); 385 currentserver=servers->count();
386 serverurlDic.insert(servers->count(),new QString(v)); 386 serverurlDic.insert(servers->count(),new QString(v));
387 servers->insertItem(v); 387 servers->insertItem(v);
388 } else if ( l.left(13) == "#IPKG_SOURCE=" ) { 388 } else if ( l.left(13) == "#IPKG_SOURCE=" ) {
389 serverurlDic.insert(servers->count(),new QString(v)); 389 serverurlDic.insert(servers->count(),new QString(v));
390 servers->insertItem(v); 390 servers->insertItem(v);
391 } else if ( l.left(10) == "IPKG_ROOT=" ) { 391 } else if ( l.left(10) == "IPKG_ROOT=" ) {
392 // ### no UI 392 // ### no UI
393 // } else if ( l.left(20) == "IPKG_PROXY_USERNAME=" ) { 393 // } else if ( l.left(20) == "IPKG_PROXY_USERNAME=" ) {
394 // username->setText(v); 394 // username->setText(v);
395 // } else if ( l.left(20) == "IPKG_PROXY_PASSWORD=" ) { 395 // } else if ( l.left(20) == "IPKG_PROXY_PASSWORD=" ) {
396 // password->setText(v); 396 // password->setText(v);
397 // } else if ( l.left(16) == "IPKG_PROXY_HTTP=" ) { 397 // } else if ( l.left(16) == "IPKG_PROXY_HTTP=" ) {
398 // http->setText(v); 398 // http->setText(v);
399 // } else if ( l.left(16) == "IPKG_PROXY_FTP=" ) { 399 // } else if ( l.left(16) == "IPKG_PROXY_FTP=" ) {
400 // ftp->setText(v); 400 // ftp->setText(v);
401 } 401 }
402 } 402 }
403 } 403 }
404 } 404 }
405 if ( ipkg_old ) { 405 if ( ipkg_old ) {
406 servers->setSelectionMode(QListBox::Single); 406 servers->setSelectionMode(QListBox::Single);
407 servers->setSelected(currentserver,TRUE); 407 servers->setSelected(currentserver,TRUE);
408 } 408 }
409 return TRUE; 409 return TRUE;
410 } else { 410 } else {
411 return FALSE; 411 return FALSE;
412 } 412 }
413} 413}
414 414
415 415
416/** 416/**
417 * read from config file(s) 417 * read from config file(s)
418 */ 418 */
419void PackageManagerSettings::readSettings() 419void PackageManagerSettings::readSettings()
420{ 420{
421 readIpkgConfig("/etc/ipkg.conf"); 421 readIpkgConfig("/etc/ipkg.conf");
422 readInstallationSettings(); 422 readInstallationSettings();
423} 423}
424 424
425void PackageManagerSettings::writeSettings() 425void PackageManagerSettings::writeSettings()
426{ 426{
427 writeIpkgConfig("/etc/ipkg.conf"); 427 writeIpkgConfig("/etc/ipkg.conf");
428 writeInstallationSettings(); 428 writeInstallationSettings();
429} 429}
430/** shows the setting dialog */ 430/** shows the setting dialog */
431bool PackageManagerSettings::showDialog( int i ) 431bool PackageManagerSettings::showDialog( int i )
432{ 432{
433 TabWidget->setCurrentPage( i ); 433 TabWidget->setCurrentPage( i );
434 showMaximized(); 434 showMaximized();
435 bool ret = exec(); 435 bool ret = exec();
436 if ( ret ) writeSettings(); 436 if ( ret ) writeSettings();
437 else readSettings(); 437 else readSettings();
438 return ret; 438 return ret;
439} 439}
440/** Returns the installation destination */ 440/** Returns the installation destination */
441QString PackageManagerSettings::getDestinationName() 441QString PackageManagerSettings::getDestinationName()
442{ 442{
443 return activeDestination->currentText(); 443 return activeDestination->currentText();
444} 444}
445/** Returns the link destination */ 445/** Returns the link destination */
446QString PackageManagerSettings::getLinkDestinationName() 446QString PackageManagerSettings::getLinkDestinationName()
447{ 447{
448 return activeLinkDestination->currentText(); 448 return activeLinkDestination->currentText();
449} 449}
450/** Returns the URL of the active destination */ 450/** Returns the URL of the active destination */
451QString PackageManagerSettings::getDestinationUrl() 451QString PackageManagerSettings::getDestinationUrl()
452{ 452{
453 int dnr = activeDestination->currentItem(); 453 int dnr = activeDestination->currentItem();
454 return *destinationurlDic.find(dnr); 454 return *destinationurlDic.find(dnr);
455} 455}
456/** Should oipkg create links form install destination to link destination */ 456/** Should oipkg create links form install destination to link destination */
457bool PackageManagerSettings::createLinks() 457bool PackageManagerSettings::createLinks()
458{ 458{
459 return CheckBoxLink->isChecked(); 459 return CheckBoxLink->isChecked();
460} 460}
461/** get the servers that are active */ 461/** get the servers that are active */
462QStringList PackageManagerSettings::getActiveServers() 462QStringList PackageManagerSettings::getActiveServers()
463{ 463{
464 QStringList sl; 464 QStringList sl;
465 for (int i=0; i<(int)activeServers->count(); i++) 465 for (int i=0; i<(int)activeServers->count(); i++)
466 { 466 {
467 if ( activeServers->isSelected(i) ) 467 if ( activeServers->isSelected(i) )
468 sl += activeServers->text(i); 468 sl += activeServers->text(i);
469 } 469 }
470 return sl; 470 return sl;
471} 471}
472
472/** returns the destination listed in ipkg.conf */ 473/** returns the destination listed in ipkg.conf */
473QStringList PackageManagerSettings::getDestinationUrls() 474QStringList PackageManagerSettings::getDestinationUrls()
474{ 475{
475 QStringList sl; 476 QStringList sl;
476 for (int i=0; i<(int)destinations->count(); i++) 477 for (int i=0; i<(int)destinations->count(); i++)
477 { 478 {
478 sl += *destinationurlDic[i]; 479 sl += *destinationurlDic[i];
479 } 480 }
480 return sl; 481 return sl;
481} 482}
482 483
484/** returns the destination listed in ipkg.conf */
485QString PackageManagerSettings::getDestinationUrlByName(QString n)
486{
487 QStringList sl;
488 for (int i=0; i<(int)destinations->count(); i++)
489 {
490 if ( n == destinations->text(i)) return*destinationurlDic[i];
491 }
492 return "";
493}
494
495/** returns the destination listed in ipkg.conf */
496QStringList PackageManagerSettings::getDestinationNames()
497{
498 QStringList sl;
499 for (int i=0; i<(int)destinations->count(); i++)
500 {
501 sl += destinations->text(i);
502 }
503 return sl;
504}
505
506
483void PackageManagerSettings::linkEnabled( bool b ) 507void PackageManagerSettings::linkEnabled( bool b )
484{ 508{
485 changed = true; 509 changed = true;
486 activeLinkDestination->setEnabled( b ); 510 activeLinkDestination->setEnabled( b );
487} 511}
diff --git a/noncore/unsupported/oipkg/pksettings.h b/noncore/unsupported/oipkg/pksettings.h
index 2982f1c..11ba55c 100644
--- a/noncore/unsupported/oipkg/pksettings.h
+++ b/noncore/unsupported/oipkg/pksettings.h
@@ -1,61 +1,64 @@
1#ifndef PACKAGEMANAGERSETTINGS_H 1#ifndef PACKAGEMANAGERSETTINGS_H
2#define PACKAGEMANAGERSETTINGS_H 2#define PACKAGEMANAGERSETTINGS_H
3 3
4#include "pksettingsbase.h" 4#include "pksettingsbase.h"
5#include <qintdict.h> 5#include <qintdict.h>
6 6
7 7
8class PackageManagerSettings : private PackageManagerSettingsBase 8class PackageManagerSettings : private PackageManagerSettingsBase
9{ 9{
10 // Q_OBJECT 10 // Q_OBJECT
11public: 11public:
12 PackageManagerSettings( QWidget* , const char* , WFlags ); 12 PackageManagerSettings( QWidget* , const char* , WFlags );
13 ~PackageManagerSettings(); 13 ~PackageManagerSettings();
14 14
15 bool showDialog( int ) ; 15 bool showDialog( int ) ;
16 QString getDestinationUrl(); 16 QString getDestinationUrl();
17 QString getDestinationName(); 17 QString getDestinationName();
18 QString getLinkDestinationName(); 18 QString getLinkDestinationName();
19 bool createLinks(); 19 bool createLinks();
20 QStringList getActiveServers(); 20 QStringList getActiveServers();
21 QStringList getDestinationUrls(); 21 QStringList getDestinationUrls();
22 QStringList getDestinationNames();
23 QString getDestinationUrlByName(QString);
24
22private: 25private:
23 QIntDict<QString> serverurlDic; 26 QIntDict<QString> serverurlDic;
24 QIntDict<QString> destinationurlDic; 27 QIntDict<QString> destinationurlDic;
25 int ipkg_old; 28 int ipkg_old;
26 int editedserver; 29 int editedserver;
27 int editeddestination; 30 int editeddestination;
28 int currentSetting; 31 int currentSetting;
29 int installationSettingsCount; 32 int installationSettingsCount;
30 bool changed; 33 bool changed;
31 34
32 bool readIpkgConfig(const QString&); 35 bool readIpkgConfig(const QString&);
33 void writeIpkgConfig(const QString&); 36 void writeIpkgConfig(const QString&);
34 void writeSettings(); 37 void writeSettings();
35 void readSettings(); 38 void readSettings();
36 39
37public slots: 40public slots:
38 void writeInstallationSettings(); 41 void writeInstallationSettings();
39 void readInstallationSettings(); 42 void readInstallationSettings();
40 void writeCurrentInstallationSetting(); 43 void writeCurrentInstallationSetting();
41 void readInstallationSetting(int); 44 void readInstallationSetting(int);
42 void installationSettingSetName(const QString &); 45 void installationSettingSetName(const QString &);
43 46
44 void newServer(); 47 void newServer();
45 void editServer(int); 48 void editServer(int);
46 void removeDestination(); 49 void removeDestination();
47 void newDestination(); 50 void newDestination();
48 void editDestination(int); 51 void editDestination(int);
49 void linkEnabled(bool); 52 void linkEnabled(bool);
50 void removeServer(); 53 void removeServer();
51 void serverNameChanged(const QString&); 54 void serverNameChanged(const QString&);
52 void serverUrlChanged(const QString&); 55 void serverUrlChanged(const QString&);
53 void destNameChanged(const QString&); 56 void destNameChanged(const QString&);
54 void destUrlChanged(const QString&); 57 void destUrlChanged(const QString&);
55 void installationSettingChange(int); 58 void installationSettingChange(int);
56 void newInstallationSetting(); 59 void newInstallationSetting();
57 void removeInstallationSetting(); 60 void removeInstallationSetting();
58 void renameInstallationSetting(); 61 void renameInstallationSetting();
59}; 62};
60 63
61#endif 64#endif
diff --git a/noncore/unsupported/oipkg/pmipkg.cpp b/noncore/unsupported/oipkg/pmipkg.cpp
index eae73ad..3b31b4d 100644
--- a/noncore/unsupported/oipkg/pmipkg.cpp
+++ b/noncore/unsupported/oipkg/pmipkg.cpp
@@ -1,352 +1,316 @@
1#include "pmipkg.h" 1#include "pmipkg.h"
2#include "pkdesc.h" 2#include "pkdesc.h"
3#include "pksettings.h" 3#include "pksettings.h"
4#include "package.h" 4#include "package.h"
5#include "packagelistitem.h" 5#include "packagelistitem.h"
6 6
7#include <qpe/process.h> 7#include <qpe/process.h>
8#include <qpe/resource.h> 8#include <qpe/resource.h>
9#include <qpe/config.h> 9#include <qpe/config.h>
10#include <qpe/stringutil.h> 10#include <qpe/stringutil.h>
11#include <qpe/qcopenvelope_qws.h>
12#include <qdir.h> 11#include <qdir.h>
13#include <qfile.h> 12#include <qfile.h>
14#include <qmultilineedit.h> 13#include <qmultilineedit.h>
15#include <qstring.h> 14#include <qstring.h>
16#include <qtextstream.h> 15#include <qtextstream.h>
17#include <qtextview.h> 16#include <qtextview.h>
18 17
19#include <qprogressbar.h> 18#include <qprogressbar.h>
20#include <qpushbutton.h> 19#include <qpushbutton.h>
21#include <qlayout.h> 20#include <qlayout.h>
22 21
23#include <stdlib.h> 22#include <stdlib.h>
24#include <unistd.h> 23#include <unistd.h>
25 24
26#include "mainwindow.h" 25#include "mainwindow.h"
27 26
28 27
29PmIpkg::PmIpkg( PackageManagerSettings* s, QWidget* p, const char * name, WFlags f ) 28PmIpkg::PmIpkg( PackageManagerSettings* s, QWidget* p, const char * name, WFlags f )
30 : QObject ( p ) 29 : QObject ( p )
31{ 30{
32 settings = s; 31 settings = s;
33 runwindowopen = false; 32 runwindowopen = false;
34 runwindow = new RunWindow( p, name, true, f ); 33 runwindow = new RunWindow( p, name, true, f );
35} 34}
36 35
37PmIpkg::~PmIpkg() 36PmIpkg::~PmIpkg()
38{ 37{
39} 38}
40 39
41//#define PROC 40//#define PROC
42#define SYSTEM 41#define SYSTEM
43int PmIpkg::runIpkg(const QString& args) 42int PmIpkg::runIpkg(const QString& args, const QString& dest )
44{ 43{
45 pvDebug(2,"PmIpkg::runIpkg "+args); 44 pvDebug(2,"PmIpkg::runIpkg "+args);
46 45
47 //to make script ipkg happy
48 pvDebug(2, "cd "+settings->getDestinationUrl()+"/tmp/ipkg");
49 if (!QDir::setCurrent(settings->getDestinationUrl()+"/tmp/ipkg"))
50 {
51 QDir instDir = QDir(settings->getDestinationUrl()+"/tmp/ipkg");
52 instDir.mkdir(settings->getDestinationUrl()+"/tmp/ipkg");
53 }
54#ifdef PROC 46#ifdef PROC
55 QStringList cmd = "/usr/bin/ipkg "; 47 QStringList cmd = "/usr/bin/ipkg ";
56#endif 48#endif
57#ifdef SYSTEM 49#ifdef SYSTEM
58 QString cmd = "/usr/bin/ipkg "; 50 QString cmd = "/usr/bin/ipkg ";
59#endif 51#endif
60 cmd += " -dest "+settings->getDestinationName(); 52 pvDebug( 3,"PmIpkg::runIpkg got dest="+dest);
53 if ( dest == "" )
54 cmd += " -dest "+settings->getDestinationName();
55 else
56 cmd += " -dest "+ dest;
57
61 cmd += " -force-defaults "; 58 cmd += " -force-defaults ";
62 59
63 out( "<hr><br>Starting to "+ args+"<br>\n"); 60 out( "<hr><br>Starting to "+ args+"<br>\n");
64 cmd += args; 61 cmd += args;
65 out( "running:<br>\n"+cmd+"<br>\n" );
66 int r = 0; 62 int r = 0;
67#ifdef PROC 63#ifdef PROC
68 QString o = "start"; 64 QString o = "start";
69 Process ipkg( cmd ); 65 Process *ipkg = new Process( "ls");//cmd );
66 out( "running:<br>\n"+ipkg->arguments().join(" ")+"<br>\n" );
70 QString description; 67 QString description;
71 ipkg.exec("",o); 68 ipkg->exec("",o);
72 out( o ); 69// out( o );
73#endif 70#endif
74#ifdef SYSTEM 71#ifdef SYSTEM
72 out( "running:<br>\n"+cmd+"<br>\n" );
75 QString redirect = "/tmp/oipkg.pipe"; 73 QString redirect = "/tmp/oipkg.pipe";
76 cmd += " | tee "+redirect+" 2>&1"; 74 cmd += " | tee "+redirect+" 2>&1";
77 pvDebug(2, "running >"+cmd+"<"); 75 pvDebug(2, "running >"+cmd+"<");
78 r = system(cmd.latin1()); 76 r = system(cmd.latin1());
79 QFile f( redirect ); 77 QFile f( redirect );
80 QString line; 78 QString line;
81 QString oldLine; 79 QString oldLine;
82 while ( ! f.open(IO_ReadOnly) ) {}; 80 while ( ! f.open(IO_ReadOnly) ) {};
83 { 81 // {
84 QTextStream t( &f ); 82 QTextStream t( &f );
85 // QString fp; 83 // QString fp;
86 while ( !t.eof() ) 84 while ( !t.eof() )
87 { 85 {
88 line = t.readLine(); 86 line = t.readLine();
89 if ( line != oldLine ) out( line +"<br>" ); 87 if ( line != oldLine )
90 oldLine = line; 88 {
89 out( line +"<br>" );
90 oldLine = line;
91 }
91 } 92 }
92 } 93// }
93 f.close(); 94 f.close();
94 out( "Finished!<br>"); 95 out( "Finished!<br>");
95#endif 96#endif
96 97
97 return r; 98 return r;
98} 99}
99 100
100void PmIpkg::makeLinks(QString pack) 101void PmIpkg::makeLinks(Package *pack)
101{ 102{
102 pvDebug( 2, "PmIpkg::makeLinks "+ pack); 103 pvDebug( 2, "PmIpkg::makeLinks "+ pack->name());
104 QString dest = settings->getDestinationUrlByName( pack->dest() );
105 if (dest == "/" ) return;
103 out( "<br>creating links<br>" ); 106 out( "<br>creating links<br>" );
104 QString dest = settings->getDestinationUrl(); 107 out("for package "+pack->name()+" in "+dest+"<br>");
105 out("for package "+pack+" in "+dest+"<br>");
106 { 108 {
107 Config cfg( "oipkg", Config::User ); 109 Config cfg( "oipkg", Config::User );
108 cfg.setGroup( "Common" ); 110 cfg.setGroup( "Common" );
109 QString statusDir = cfg.readEntry( "statusDir", "" ); 111 QString statusDir = cfg.readEntry( "statusDir", "" );
110 } 112 }
111 QString fn = dest+"/"+statusDir+"/info/"+pack+".list"; 113 QString fn = dest+"/"+statusDir+"/info/"+pack->name()+".list";
112 QFile f( fn ); 114 QFile f( fn );
113 if ( ! f.open(IO_ReadOnly) ) 115 if ( ! f.open(IO_ReadOnly) )
114 { 116 {
115 out( "<b>Panik!</b> Could not open:<br>"+fn ); 117 out( "<b>Panik!</b> Could not open:<br>"+fn );
118 return;
116 }; 119 };
117 QTextStream t( &f ); 120 QTextStream t( &f );
118 QString fp; 121 QString fp;
119 while ( !t.eof() ) 122 while ( !t.eof() )
120 { 123 {
121 fp = t.readLine(); 124 fp = t.readLine();
122 processLinkDir( fp, dest ); 125 processLinkDir( fp, dest );
123 } 126 }
124 f.close(); 127 f.close();
125} 128}
126 129
127void PmIpkg::processLinkDir( QString file, QString dest ) 130void PmIpkg::processLinkDir( QString file, QString dest )
128{ 131{
132 if ( dest == "???" ) return;
129 QString destFile = file; 133 QString destFile = file;
130 file = dest+"/"+file; 134 file = dest+"/"+file;
135 if (file == dest) return;
131 QFileInfo fileInfo( file ); 136 QFileInfo fileInfo( file );
132 if ( fileInfo.isDir() ) 137 if ( fileInfo.isDir() )
133 { 138 {
134 QDir destDir( destFile ); 139 QDir destDir( destFile );
135 destDir.mkdir( destFile, true ); 140 destDir.mkdir( destFile, true );
136 QDir d( file ); 141 QDir d( file );
137 d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks ); 142 d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks );
138 const QFileInfoList *list = d.entryInfoList(); 143 const QFileInfoList *list = d.entryInfoList();
139 QFileInfoListIterator it( *list ); 144 QFileInfoListIterator it( *list );
140 QFileInfo *fi; 145 QFileInfo *fi;
141 while ( (fi=it.current()) ) 146 while ( (fi=it.current()) )
142 { 147 {
143 // out( "<b>"+fi->absFilePath()+"</b>" ); 148 // out( "<b>"+fi->absFilePath()+"</b>" );
144 processLinkDir( fi->absFilePath(), dest ); 149 processLinkDir( fi->absFilePath(), dest );
145 ++it; 150 ++it;
146 } 151 }
147 } else 152 } else
148 if ( fileInfo.isFile() ) 153 if ( fileInfo.isFile() )
149 { 154 {
150 const char *instFile = strdup( (file).ascii() ); 155 const char *instFile = strdup( (file).ascii() );
151 const char *linkFile = strdup( (destFile).ascii()); 156 const char *linkFile = strdup( (destFile).ascii());
152// out( "linking: "+file+" -> "+destFile ); 157// out( "linking: "+file+" -> "+destFile );
153 qDebug( "linking: %s -> %s", instFile, linkFile ); 158 qDebug( "linking: %s -> %s", instFile, linkFile );
154 symlink( instFile, linkFile ); 159 symlink( instFile, linkFile );
155 } 160 }
156} 161}
157 162
158void PmIpkg::commit( PackageList pl ) 163void PmIpkg::commit( PackageList pl )
159 { 164 {
160 show( false ); 165 show( false );
161 runwindow->outPut->setText(""); 166 runwindow->outPut->setText("");
162 out( "<h1>"+tr("Todo")+"</h1>\n"); 167 out( "<h1>"+tr("Todo")+"</h1>\n");
163 168
164 to_install.clear(); 169 to_install.clear();
165 to_remove.clear(); 170 to_remove.clear();
166 int sizecount = 0; 171 int sizecount = 0;
167 QString rem="<b>To remove:</b><br>\n"; 172 QString rem="<b>To remove:</b><br>\n";
168 QString inst="<b>To install:</b><br>\n";; 173 QString inst="<b>To install:</b><br>\n";;
174 pl.allPackages();
169 for( Package *pack = pl.first();pack ; (pack = pl.next()) ) 175 for( Package *pack = pl.first();pack ; (pack = pl.next()) )
170 { 176 {
171 if ( pack && (pack->name() != "") && pack) 177 if ( pack && (pack->name() != "") && pack)
172 { 178 {
173 if ( pack->toInstall() ) 179 if ( pack->toInstall() )
174 { 180 {
175 #ifndef NEWLIST
176 to_install.append( pack->name() );
177 #endif
178 #ifdef NEWLIST
179 to_install.append( pack ); 181 to_install.append( pack );
180 sizecount += pack->size().toInt(); 182 sizecount += pack->size().toInt();
181 #endif 183 inst += pack->name()+"\t(on "+pack->dest()+")<br>";
182 inst += pack->name()+"<br>";
183 } 184 }
184 if ( pack->toRemove() ) 185 if ( pack->toRemove() )
185 { 186 {
186 #ifndef NEWLIST
187 to_remove.append( pack->name() );
188 #endif
189 #ifdef NEWLIST
190 to_remove.append( pack ); 187 to_remove.append( pack );
191 sizecount += 1; 188 sizecount += 1;
192 #endif
193 rem += pack->name()+"<br>"; 189 rem += pack->name()+"<br>";
194 } 190 }
195 } 191 }
196 } 192 }
197 193
198 out("<p>"+inst+"</p>"+"<p>"+rem+"</p><hl>"); 194 out("<p>"+inst+"</p>"+"<p>"+rem+"</p><hl>");
199 195
200 qDebug("to remove=%i; to install=%i",to_remove.count(),to_install.count()); 196 qDebug("to remove=%i; to install=%i",to_remove.count(),to_install.count());
201 197
202 runwindow->progress->setTotalSteps( sizecount ); 198 runwindow->progress->setTotalSteps( sizecount );
203 199
204 connect( runwindow->doItButton, SIGNAL( clicked() ), 200 connect( runwindow->doItButton, SIGNAL( clicked() ),
205 SLOT( doIt() ) ); 201 SLOT( doIt() ) );
206 connect( runwindow->installButton, SIGNAL( clicked() ), 202 connect( runwindow->installButton, SIGNAL( clicked() ),
207 this, SLOT( install() ) ); 203 this, SLOT( install() ) );
208 connect( runwindow->removeButton, SIGNAL( clicked() ), 204 connect( runwindow->removeButton, SIGNAL( clicked() ),
209 this, SLOT( remove() ) ); 205 this, SLOT( remove() ) );
210 connect( runwindow->cancelButton, SIGNAL( clicked() ), 206 connect( runwindow->cancelButton, SIGNAL( clicked() ),
211 runwindow, SLOT( close() ) ); 207 runwindow, SLOT( close() ) );
212 208
213 runwindow->exec(); 209 runwindow->exec();
214 // ##### If we looked in the list of files, we could send out accurate
215 // ##### messages. But we don't bother yet, and just do an "all".
216 QCopEnvelope e("QPE/System", "linkChanged(QString)");
217 QString lf = QString::null;
218 e << lf;
219 return; 210 return;
220} 211}
221 212
222void PmIpkg::doIt() 213void PmIpkg::doIt()
223{ 214{
224 remove(); 215 remove();
225 install(); 216 install();
226} 217}
227 218
228 219
229void PmIpkg::remove() 220void PmIpkg::remove()
230{ 221{
231 if ( to_remove.count() == 0 ) return; 222 if ( to_remove.count() == 0 ) return;
232 show( true ); 223 show( true );
233 224
234 out("<hr><hr><b>"+tr("Removing")+"<br>"+tr("please wait")+"</b><br>"); 225 out("<hr><hr><b>"+tr("Removing")+"<br>"+tr("please wait")+"</b><br>");
235 226
236 #ifndef NEWLIST
237 for (QStringList::ConstIterator it=to_remove.begin(); it!=to_remove.end(); ++it)
238 {
239 if ( runIpkg("remove " + *it) == 0)
240 {
241
242 }else{
243 out("<b>"+tr("Error while removing")+"</b>"+*it);
244 }
245 }
246#endif
247 #ifdef NEWLIST
248 for (Package *it=to_remove.first(); it != 0; it=to_remove.next() ) 227 for (Package *it=to_remove.first(); it != 0; it=to_remove.next() )
249 { 228 {
250 if ( runIpkg("remove " + it->name()) == 0) 229 if ( runIpkg("remove " + it->name()) == 0)
251 { 230 {
252 runwindow->progress->setProgress( it->size().toInt() + runwindow->progress->progress()); 231 runwindow->progress->setProgress( it->size().toInt() + runwindow->progress->progress());
253 it->processed(); 232 it->processed();
254 runwindow->progress->setProgress( 1 ); 233 runwindow->progress->setProgress( 1 );
255 }else{ 234 }else{
256 out("<b>"+tr("Error while removing")+"</b>"+it->name()); 235 out("<b>"+tr("Error while removing")+"</b>"+it->name());
257 } 236 }
258 } 237 }
259#endif
260} 238}
261 239
262 240
263void PmIpkg::install() 241void PmIpkg::install()
264{ 242{
265 if ( to_install.count() == 0 ) return; 243 if ( to_install.count() == 0 ) return;
266 show( true ); 244 show( true );
267 out("<hr><hr><b>"+tr("Installing")+"<br>"+tr("please wait")+"</b><br>"); 245 out("<hr><hr><b>"+tr("Installing")+"<br>"+tr("please wait")+"</b><br>");
268 #ifndef NEWLIST 246 for (Package *it=to_install.first(); it != 0; it=to_install.next() )
269 for (QStringList::ConstIterator it=to_install.begin(); it!=to_install.end(); ++it)
270 {
271 if ( runIpkg("install " + *it) == 0 )
272 {
273 if ( settings->createLinks() )
274 makeLinks( *it );
275 }else{
276 out("<b>"+tr("Error while installing")+"</b>"+*it);
277 }
278 }
279#endif
280 #ifdef NEWLIST
281 for (Package *it=to_install.first(); it != 0; it=to_install.next() )
282 { 247 {
283 if ( runIpkg("install " + it->name()) == 0 ) 248
249 if ( runIpkg("install " + it->name(), it->dest() ) == 0 )
284 { 250 {
285 runwindow->progress->setProgress( it->size().toInt() + runwindow->progress->progress()); 251 runwindow->progress->setProgress( it->size().toInt() + runwindow->progress->progress());
286 if ( settings->createLinks() ) 252 if ( it->link() )
287 makeLinks( it->name() ); 253 makeLinks( it );
288 it->processed(); 254 it->processed();
289 }else{ 255 }else{
290 out("<b>"+tr("Error while installing")+"</b>"+it->name()); 256 out("<b>"+tr("Error while installing")+"</b>"+it->name());
291 } 257 }
292 } 258 }
293#endif
294} 259}
295 260
296void PmIpkg::linkDestination( const QString msg, const QByteArray dest ) 261void PmIpkg::linkDestination( const QString msg, const QByteArray dest )
297// add 3rd package parameter
298{ 262{
299 qDebug("msg="+msg+" -- "+QString(dest) ); 263 qDebug("msg="+msg+" -- "+QString(dest) );
300// QDir d( src ); 264// QDir d( src );
301// d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks ); 265// d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks );
302//// if (! d.exists() ) return; 266//// if (! d.exists() ) return;
303// const QFileInfoList *list = d.entryInfoList(); 267// const QFileInfoList *list = d.entryInfoList();
304// QFileInfoListIterator it( *list ); 268// QFileInfoListIterator it( *list );
305// QFileInfo *fi; 269// QFileInfo *fi;
306// while ( (fi=it.current()) ) { 270// while ( (fi=it.current()) ) {
307 // processLinkDir( fi->absFilePath(), dest ); 271 // processLinkDir( fi->absFilePath(), dest );
308// ++it; 272// ++it;
309// } 273// }
310} 274}
311 275
312void PmIpkg::update() 276void PmIpkg::update()
313{ 277{
314 show( false ); 278 show( false );
315 runIpkg( "update" ); 279 runIpkg( "update" );
316 runwindow->close(); 280 runwindow->close();
317} 281}
318 282
319void PmIpkg::out( QString o ) 283void PmIpkg::out( QString o )
320{ 284{
321 runwindow->outPut->setText( runwindow->outPut->text()+o ); 285 runwindow->outPut->setText( runwindow->outPut->text()+o );
322 runwindow->outPut->setContentsPos(0, runwindow->outPut->contentsHeight()); 286 runwindow->outPut->setContentsPos(0, runwindow->outPut->contentsHeight());
323} 287}
324 288
325 289
326void PmIpkg::showButtons(bool b) 290void PmIpkg::showButtons(bool b)
327{ 291{
328 if ( b ) 292 if ( b )
329 { 293 {
330 runwindow->cancelButton->hide(); 294 runwindow->cancelButton->hide();
331 runwindow->doItButton->hide(); 295 runwindow->doItButton->hide();
332 runwindow->removeButton->hide(); 296 runwindow->removeButton->hide();
333 runwindow->installButton->hide(); 297 runwindow->installButton->hide();
334 }else{ 298 }else{
335 runwindow->cancelButton->show(); 299 runwindow->cancelButton->show();
336 runwindow->doItButton->show(); 300 runwindow->doItButton->show();
337 runwindow->removeButton->show(); 301 runwindow->removeButton->show();
338 runwindow->installButton->show(); 302 runwindow->installButton->show();
339 303
340 } 304 }
341} 305}
342 306
343void PmIpkg::show(bool b) 307void PmIpkg::show(bool b)
344{ 308{
345 if (!runwindow->isVisible()) 309 if (!runwindow->isVisible())
346 runwindow->showMaximized(); 310 runwindow->showMaximized();
347 showButtons(b); 311 showButtons(b);
348 //if ( b ) 312 if ( b )
349 runwindow->progress->hide(); 313 runwindow->progress->hide();
350// else 314 else
351 // runwindow->progress->show(); 315 runwindow->progress->show();
352} 316}
diff --git a/noncore/unsupported/oipkg/pmipkg.h b/noncore/unsupported/oipkg/pmipkg.h
index 2692017..c57adb7 100644
--- a/noncore/unsupported/oipkg/pmipkg.h
+++ b/noncore/unsupported/oipkg/pmipkg.h
@@ -1,55 +1,47 @@
1#ifndef PMIPKG_H 1#ifndef PMIPKG_H
2#define PMIPKG_H 2#define PMIPKG_H
3 3
4 4
5#include <qobject.h> 5#include <qobject.h>
6#include <qlist.h> 6#include <qlist.h>
7#include <qstring.h> 7#include <qstring.h>
8#include <qwidget.h> 8#include <qwidget.h>
9#include "pksettings.h" 9#include "pksettings.h"
10#include "runwindow.h" 10#include "runwindow.h"
11#include "packagelist.h" 11#include "packagelist.h"
12#include "debug.h" 12#include "debug.h"
13 13
14//#define NEWLIST
15class Package; 14class Package;
16class PmIpkg : public QObject 15class PmIpkg : public QObject
17{ 16{
18 Q_OBJECT 17 Q_OBJECT
19public: 18public:
20 PmIpkg( PackageManagerSettings* , QWidget* p=0, const char * name=0, WFlags f=0 ); 19 PmIpkg( PackageManagerSettings* , QWidget* p=0, const char * name=0, WFlags f=0 );
21 ~PmIpkg(); 20 ~PmIpkg();
22 21
23 void commit( PackageList ); 22 void commit( PackageList );
24 void update(); 23 void update();
25 PackageList* getPackageList(); 24 PackageList* getPackageList();
26 void showButtons(bool b=true); 25 void showButtons(bool b=true);
27 void show( bool buttons=true ); 26 void show( bool buttons=true );
28 27
29private: 28private:
30 PackageManagerSettings* settings; 29 PackageManagerSettings* settings;
31 RunWindow *runwindow; 30 RunWindow *runwindow;
32#ifndef NEWLIST
33 QStringList to_remove;
34 QStringList to_install;
35#endif
36#ifdef NEWLIST
37 QList<Package> to_remove; 31 QList<Package> to_remove;
38 QList<Package> to_install; 32 QList<Package> to_install;
39#endif
40 bool runwindowopen; 33 bool runwindowopen;
41 34
42 void makeLinks(QString); 35 void makeLinks(Package*);
43 void processLinkDir( QString, QString ); 36 void processLinkDir( QString, QString );
44 37 int runIpkg(const QString& args, const QString& dest="" );
45 int runIpkg(const QString& args);
46 void out( QString ); 38 void out( QString );
47 39
48public slots: 40public slots:
49 void doIt(); 41 void doIt();
50 void install(); 42 void install();
51 void remove(); 43 void remove();
52 void linkDestination( const QString, const QByteArray ); 44 void linkDestination( const QString, const QByteArray );
53}; 45};
54 46
55#endif 47#endif
diff --git a/noncore/unsupported/oipkg/runwindow.ui b/noncore/unsupported/oipkg/runwindow.ui
index 5359fe2..52da408 100644
--- a/noncore/unsupported/oipkg/runwindow.ui
+++ b/noncore/unsupported/oipkg/runwindow.ui
@@ -1,171 +1,171 @@
1<!DOCTYPE UI><UI> 1<!DOCTYPE UI><UI>
2<class>RunWindow</class> 2<class>RunWindow</class>
3<widget> 3<widget>
4 <class>QDialog</class> 4 <class>QDialog</class>
5 <property stdset="1"> 5 <property stdset="1">
6 <name>name</name> 6 <name>name</name>
7 <cstring>RunWindow</cstring> 7 <cstring>RunWindow</cstring>
8 </property> 8 </property>
9 <property stdset="1"> 9 <property stdset="1">
10 <name>geometry</name> 10 <name>geometry</name>
11 <rect> 11 <rect>
12 <x>0</x> 12 <x>0</x>
13 <y>0</y> 13 <y>0</y>
14 <width>344</width> 14 <width>344</width>
15 <height>291</height> 15 <height>291</height>
16 </rect> 16 </rect>
17 </property> 17 </property>
18 <property stdset="1"> 18 <property stdset="1">
19 <name>caption</name> 19 <name>caption</name>
20 <string>running...</string> 20 <string>running...</string>
21 </property> 21 </property>
22 <property> 22 <property>
23 <name>layoutMargin</name> 23 <name>layoutMargin</name>
24 </property> 24 </property>
25 <property> 25 <property>
26 <name>layoutSpacing</name> 26 <name>layoutSpacing</name>
27 </property> 27 </property>
28 <grid> 28 <grid>
29 <property stdset="1"> 29 <property stdset="1">
30 <name>margin</name> 30 <name>margin</name>
31 <number>2</number> 31 <number>2</number>
32 </property> 32 </property>
33 <property stdset="1"> 33 <property stdset="1">
34 <name>spacing</name> 34 <name>spacing</name>
35 <number>2</number> 35 <number>2</number>
36 </property> 36 </property>
37 <widget row="0" column="0" > 37 <widget row="0" column="0" >
38 <class>QProgressBar</class> 38 <class>QProgressBar</class>
39 <property stdset="1"> 39 <property stdset="1">
40 <name>name</name> 40 <name>name</name>
41 <cstring>progress</cstring> 41 <cstring>progress</cstring>
42 </property> 42 </property>
43 <property stdset="1"> 43 <property stdset="1">
44 <name>progress</name> 44 <name>progress</name>
45 <number>42</number> 45 <number>0</number>
46 </property> 46 </property>
47 </widget> 47 </widget>
48 <widget row="1" column="0" > 48 <widget row="1" column="0" >
49 <class>QTextView</class> 49 <class>QTextView</class>
50 <property stdset="1"> 50 <property stdset="1">
51 <name>name</name> 51 <name>name</name>
52 <cstring>outPut</cstring> 52 <cstring>outPut</cstring>
53 </property> 53 </property>
54 <property stdset="1"> 54 <property stdset="1">
55 <name>font</name> 55 <name>font</name>
56 <font> 56 <font>
57 <pointsize>6</pointsize> 57 <pointsize>6</pointsize>
58 </font> 58 </font>
59 </property> 59 </property>
60 </widget> 60 </widget>
61 <widget row="2" column="0" > 61 <widget row="2" column="0" >
62 <class>QLayoutWidget</class> 62 <class>QLayoutWidget</class>
63 <property stdset="1"> 63 <property stdset="1">
64 <name>name</name> 64 <name>name</name>
65 <cstring>buttons</cstring> 65 <cstring>buttons</cstring>
66 </property> 66 </property>
67 <hbox> 67 <hbox>
68 <property stdset="1"> 68 <property stdset="1">
69 <name>margin</name> 69 <name>margin</name>
70 <number>0</number> 70 <number>0</number>
71 </property> 71 </property>
72 <property stdset="1"> 72 <property stdset="1">
73 <name>spacing</name> 73 <name>spacing</name>
74 <number>6</number> 74 <number>6</number>
75 </property> 75 </property>
76 <widget> 76 <widget>
77 <class>QPushButton</class> 77 <class>QPushButton</class>
78 <property stdset="1"> 78 <property stdset="1">
79 <name>name</name> 79 <name>name</name>
80 <cstring>doItButton</cstring> 80 <cstring>doItButton</cstring>
81 </property> 81 </property>
82 <property stdset="1"> 82 <property stdset="1">
83 <name>sizePolicy</name> 83 <name>sizePolicy</name>
84 <sizepolicy> 84 <sizepolicy>
85 <hsizetype>0</hsizetype> 85 <hsizetype>0</hsizetype>
86 <vsizetype>0</vsizetype> 86 <vsizetype>0</vsizetype>
87 </sizepolicy> 87 </sizepolicy>
88 </property> 88 </property>
89 <property stdset="1"> 89 <property stdset="1">
90 <name>font</name> 90 <name>font</name>
91 <font> 91 <font>
92 <pointsize>8</pointsize> 92 <pointsize>8</pointsize>
93 </font> 93 </font>
94 </property> 94 </property>
95 <property stdset="1"> 95 <property stdset="1">
96 <name>text</name> 96 <name>text</name>
97 <string>Do all </string> 97 <string>Do all </string>
98 </property> 98 </property>
99 <property stdset="1"> 99 <property stdset="1">
100 <name>autoResize</name> 100 <name>autoResize</name>
101 <bool>true</bool> 101 <bool>true</bool>
102 </property> 102 </property>
103 </widget> 103 </widget>
104 <widget> 104 <widget>
105 <class>QPushButton</class> 105 <class>QPushButton</class>
106 <property stdset="1"> 106 <property stdset="1">
107 <name>name</name> 107 <name>name</name>
108 <cstring>installButton</cstring> 108 <cstring>installButton</cstring>
109 </property> 109 </property>
110 <property stdset="1"> 110 <property stdset="1">
111 <name>font</name> 111 <name>font</name>
112 <font> 112 <font>
113 <pointsize>8</pointsize> 113 <pointsize>8</pointsize>
114 </font> 114 </font>
115 </property> 115 </property>
116 <property stdset="1"> 116 <property stdset="1">
117 <name>text</name> 117 <name>text</name>
118 <string>Install</string> 118 <string>Install</string>
119 </property> 119 </property>
120 <property stdset="1"> 120 <property stdset="1">
121 <name>autoResize</name> 121 <name>autoResize</name>
122 <bool>true</bool> 122 <bool>true</bool>
123 </property> 123 </property>
124 </widget> 124 </widget>
125 <widget> 125 <widget>
126 <class>QPushButton</class> 126 <class>QPushButton</class>
127 <property stdset="1"> 127 <property stdset="1">
128 <name>name</name> 128 <name>name</name>
129 <cstring>removeButton</cstring> 129 <cstring>removeButton</cstring>
130 </property> 130 </property>
131 <property stdset="1"> 131 <property stdset="1">
132 <name>font</name> 132 <name>font</name>
133 <font> 133 <font>
134 <pointsize>7</pointsize> 134 <pointsize>7</pointsize>
135 </font> 135 </font>
136 </property> 136 </property>
137 <property stdset="1"> 137 <property stdset="1">
138 <name>text</name> 138 <name>text</name>
139 <string>Remove</string> 139 <string>Remove</string>
140 </property> 140 </property>
141 <property stdset="1"> 141 <property stdset="1">
142 <name>autoResize</name> 142 <name>autoResize</name>
143 <bool>true</bool> 143 <bool>true</bool>
144 </property> 144 </property>
145 </widget> 145 </widget>
146 <widget> 146 <widget>
147 <class>QPushButton</class> 147 <class>QPushButton</class>
148 <property stdset="1"> 148 <property stdset="1">
149 <name>name</name> 149 <name>name</name>
150 <cstring>cancelButton</cstring> 150 <cstring>cancelButton</cstring>
151 </property> 151 </property>
152 <property stdset="1"> 152 <property stdset="1">
153 <name>font</name> 153 <name>font</name>
154 <font> 154 <font>
155 <pointsize>8</pointsize> 155 <pointsize>8</pointsize>
156 </font> 156 </font>
157 </property> 157 </property>
158 <property stdset="1"> 158 <property stdset="1">
159 <name>text</name> 159 <name>text</name>
160 <string>Cancel</string> 160 <string>Cancel</string>
161 </property> 161 </property>
162 <property stdset="1"> 162 <property stdset="1">
163 <name>autoResize</name> 163 <name>autoResize</name>
164 <bool>true</bool> 164 <bool>true</bool>
165 </property> 165 </property>
166 </widget> 166 </widget>
167 </hbox> 167 </hbox>
168 </widget> 168 </widget>
169 </grid> 169 </grid>
170</widget> 170</widget>
171</UI> 171</UI>
diff --git a/noncore/unsupported/oipkg/settings.h b/noncore/unsupported/oipkg/settings.h
index 5df522b..cf6e614 100644
--- a/noncore/unsupported/oipkg/settings.h
+++ b/noncore/unsupported/oipkg/settings.h
@@ -1,65 +1,63 @@
1#ifndef PACKAGEMANAGERSETTINGS_H 1#ifndef PACKAGEMANAGERSETTINGS_H
2#define PACKAGEMANAGERSETTINGS_H 2#define PACKAGEMANAGERSETTINGS_H
3 3
4#include "pksettingsbase.h" 4#include "pksettingsbase.h"
5#include <qintdict.h> 5#include <qintdict.h>
6 6
7 7
8class PackageManagerSettings : public PackageManagerSettingsBase 8class PackageManagerSettings : public PackageManagerSettingsBase
9//class PackageManagerSettings : private PackageManagerSettingsBase 9//class PackageManagerSettings : private PackageManagerSettingsBase
10{ 10{
11 // Q_OBJECT 11 // Q_OBJECT
12public: 12public:
13 PackageManagerSettings( QWidget* , const char* , WFlags ); 13 PackageManagerSettings( QWidget* , const char* , WFlags );
14 ~PackageManagerSettings(); 14 ~PackageManagerSettings();
15 15
16 bool showDialog( int ) ; 16 bool showDialog( int ) ;
17 QString getDestinationUrl(); 17 QString getDestinationUrl();
18 QString getDestinationName(); 18 QString getDestinationName();
19 QString getLinkDestinationName(); 19 QString getLinkDestinationName();
20 bool createLinks(); 20 bool createLinks();
21 QStringList getActiveServers(); 21 QStringList getActiveServers();
22 QStringList getDestinationUrls(); 22 QStringList getDestinationUrls();
23 /** No descriptions */
24 QComboBox getActiveDestinationCombo();
25 23
26private: 24private:
27 QIntDict<QString> serverurlDic; 25 QIntDict<QString> serverurlDic;
28 QIntDict<QString> destinationurlDic; 26 QIntDict<QString> destinationurlDic;
29 int ipkg_old; 27 int ipkg_old;
30 int editedserver; 28 int editedserver;
31 int editeddestination; 29 int editeddestination;
32 int currentSetting; 30 int currentSetting;
33 int installationSettingsCount; 31 int installationSettingsCount;
34 bool changed; 32 bool changed;
35 33
36 bool readIpkgConfig(const QString&); 34 bool readIpkgConfig(const QString&);
37 void writeIpkgConfig(const QString&); 35 void writeIpkgConfig(const QString&);
38 void writeSettings(); 36 void writeSettings();
39 void readSettings(); 37 void readSettings();
40 38
41public slots: 39public slots:
42 void writeInstallationSettings(); 40 void writeInstallationSettings();
43 void readInstallationSettings(); 41 void readInstallationSettings();
44 void writeCurrentInstallationSetting(); 42 void writeCurrentInstallationSetting();
45 void readInstallationSetting(int); 43 void readInstallationSetting(int);
46 void installationSettingSetName(const QString &); 44 void installationSettingSetName(const QString &);
47 45
48 void newServer(); 46 void newServer();
49 void editServer(int); 47 void editServer(int);
50 void removeDestination(); 48 void removeDestination();
51 void newDestination(); 49 void newDestination();
52 void editDestination(int); 50 void editDestination(int);
53 void linkEnabled(bool); 51 void linkEnabled(bool);
54 void removeServer(); 52 void removeServer();
55 void serverNameChanged(const QString&); 53 void serverNameChanged(const QString&);
56 void serverUrlChanged(const QString&); 54 void serverUrlChanged(const QString&);
57 void destNameChanged(const QString&); 55 void destNameChanged(const QString&);
58 void destUrlChanged(const QString&); 56 void destUrlChanged(const QString&);
59 void installationSettingChange(int); 57 void installationSettingChange(int);
60 void newInstallationSetting(); 58 void newInstallationSetting();
61 void removeInstallationSetting(); 59 void removeInstallationSetting();
62 void renameInstallationSetting(); 60 void renameInstallationSetting();
63}; 61};
64 62
65#endif 63#endif