author | tille <tille> | 2002-04-27 13:06:45 (UTC) |
---|---|---|
committer | tille <tille> | 2002-04-27 13:06:45 (UTC) |
commit | db90999f6298c1107888f062f2c25cb8817b528a (patch) (unidiff) | |
tree | 020ebe65beb9286f3c63e4329fc3a0f298d34460 | |
parent | e2f3288d468508f2cf7c0a327044963ca4b1b54a (diff) | |
download | opie-db90999f6298c1107888f062f2c25cb8817b528a.zip opie-db90999f6298c1107888f062f2c25cb8817b528a.tar.gz opie-db90999f6298c1107888f062f2c25cb8817b528a.tar.bz2 |
added popup menu to choose inst dest (and more...)
-rw-r--r-- | noncore/unsupported/oipkg/TODO | 3 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/debug.h | 1 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/mainwindow.cpp | 115 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/mainwindow.h | 9 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/opie-oipkg.control | 2 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/package.cpp | 54 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/package.h | 22 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/packagelist.cpp | 46 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/packagelist.h | 8 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/packagelistitem.cpp | 44 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/packagelistitem.h | 8 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/pksettings.cpp | 24 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/pksettings.h | 3 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/pmipkg.cpp | 112 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/pmipkg.h | 12 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/runwindow.ui | 2 | ||||
-rw-r--r-- | noncore/unsupported/oipkg/settings.h | 2 |
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 | ||
6 | extern int debugLevel; | 6 | extern 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) \ |
12 | if ( debugLevel < 3 ) \ | 13 | if ( 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,127 +1,138 @@ | |||
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 | ||
26 | MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f = 0 ) : | 27 | MainWindow::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 | ||
67 | void MainWindow::makeMenu() | 77 | void 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 | ||
@@ -135,223 +146,273 @@ void MainWindow::makeMenu() | |||
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 | ||
185 | MainWindow::~MainWindow() | 204 | MainWindow::~MainWindow() |
186 | { | 205 | { |
187 | } | 206 | } |
188 | 207 | ||
189 | void MainWindow::runIpkg() | 208 | void 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 | ||
195 | void MainWindow::updateList() | 219 | void 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 | ||
206 | void MainWindow::getList() | 230 | void MainWindow::getList() |
207 | { | 231 | { |
208 | packageList.update(); | 232 | packageList.update(); |
209 | displayList(); | 233 | displayList(); |
210 | } | 234 | } |
211 | 235 | ||
212 | void MainWindow::filterList() | 236 | void 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 | ||
219 | void MainWindow::displayList() | 243 | void 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 | ||
232 | void MainWindow::sectionChanged() | 256 | void 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 | ||
248 | void MainWindow::subSectionChanged() | 272 | void 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 | ||
262 | void MainWindow::setSections() | 286 | void MainWindow::setSections() |
263 | { | 287 | { |
264 | section->clear(); | 288 | section->clear(); |
265 | section->insertStringList( packageList.getSections() ); | 289 | section->insertStringList( packageList.getSections() ); |
266 | } | 290 | } |
267 | 291 | ||
268 | void MainWindow::setSubSections() | 292 | void 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 | ||
275 | void MainWindow::showSettings() | 299 | void MainWindow::showSettings() |
276 | { | 300 | { |
277 | if ( settings->showDialog( 0 ) ) | 301 | if ( settings->showDialog( 0 ) ) |
278 | updateList(); | 302 | updateList(); |
279 | } | 303 | } |
280 | void MainWindow::showSettingsSrv() | 304 | void MainWindow::showSettingsSrv() |
281 | { | 305 | { |
282 | if ( settings->showDialog( 1 ) ) | 306 | if ( settings->showDialog( 1 ) ) |
283 | updateList(); | 307 | updateList(); |
284 | } | 308 | } |
285 | void MainWindow::showSettingsDst() | 309 | void MainWindow::showSettingsDst() |
286 | { | 310 | { |
287 | if ( settings->showDialog( 2 ) ) | 311 | if ( settings->showDialog( 2 ) ) |
288 | updateList(); | 312 | updateList(); |
289 | } | 313 | } |
290 | 314 | ||
291 | 315 | ||
292 | void MainWindow::showDetails() | 316 | void 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 | ||
311 | void MainWindow::toggleActivePackage() | 339 | void MainWindow::toggleActivePackage() |
312 | { | 340 | { |
313 | activePackage->toggleProcess(); | 341 | activePackage->toggleProcess(); |
314 | if ( details ) details->close(); | 342 | if ( details ) details->close(); |
315 | } | 343 | } |
316 | 344 | ||
317 | void MainWindow::setCurrent( QListViewItem* p ) | 345 | void 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 | ||
325 | void MainWindow::sectionShow(bool b) | 354 | void 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 | ||
332 | void MainWindow::sectionClose() | 361 | void MainWindow::sectionClose() |
333 | { | 362 | { |
334 | sectionAction->setOn( false ); | 363 | sectionAction->setOn( false ); |
335 | } | 364 | } |
336 | 365 | ||
337 | void MainWindow::findShow(bool b) | 366 | void 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 | ||
344 | void MainWindow::findClose() | 373 | void MainWindow::findClose() |
345 | { | 374 | { |
346 | findAction->setOn( false ); | 375 | findAction->setOn( false ); |
347 | } | 376 | } |
348 | 377 | ||
349 | void MainWindow::rotateUpdateIcon() | 378 | void 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 | |||
388 | void 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 | |||
406 | void MainWindow::changePackageDest( int i ) | ||
407 | { | ||
408 | activePackage->setDest( destsMenu->text(i) ); | ||
409 | activePackage->setOn(); | ||
410 | activePackage->setLink( settings->createLinks() ); | ||
411 | activePackageListItem->displayDetails(); | ||
412 | } | ||
413 | |||
414 | void 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 | ||
14 | class QComboBox; | 14 | class QComboBox; |
15 | class QPEToolBar; | 15 | class QPEToolBar; |
16 | class QLineEdit; | 16 | class QLineEdit; |
17 | class QListView; | 17 | class QListView; |
18 | 18 | class PackageListItem; | |
19 | 19 | ||
20 | class MainWindow : public QMainWindow | 20 | class MainWindow : public QMainWindow |
21 | { | 21 | { |
22 | Q_OBJECT | 22 | Q_OBJECT |
23 | 23 | ||
24 | 24 | ||
25 | public: | 25 | public: |
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 | ||
29 | protected slots: | 29 | protected 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 | ||
40 | public slots: | 40 | public 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 | ||
50 | private: | 53 | private: |
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; |
74 | private slots: | 79 | private 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 @@ | |||
1 | Files: bin/oipkg apps/Settings/oipkg.desktop pics/oipkg/ | 1 | Files: bin/oipkg apps/Settings/oipkg.desktop pics/oipkg/ |
2 | Priority: optional | 2 | Priority: optional |
3 | Section: opie/settings | 3 | Section: opie/settings |
4 | Maintainer: Patrick S. Vogt <tille@almana.ch> | 4 | Maintainer: Patrick S. Vogt <tille@almana.ch> |
5 | Architecture: arm | 5 | Architecture: arm |
6 | Version: $QPE_VERSION-$SUB_VERSION | 6 | Version: $QPE_VERSION-$SUB_VERSION |
7 | Depends: opie-base ($QPE_VERSION) | 7 | Depends: opie-base ($QPE_VERSION), ipkg (>0.9) |
8 | Description: Package Manager | 8 | Description: 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,88 +1,95 @@ | |||
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 | ||
8 | Package::~Package() | 8 | Package::~Package() |
9 | { | 9 | { |
10 | } | 10 | } |
11 | 11 | ||
12 | Package::Package() | 12 | Package::Package( PackageManagerSettings *s ) |
13 | { | 13 | { |
14 | init(s); | ||
15 | } | ||
16 | |||
17 | void 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 | ||
24 | Package::Package( QStringList pack ) | 31 | Package::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 | ||
31 | Package::Package( QString n ) | 38 | Package::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 | ||
38 | Package::Package( Package *pi ) | 45 | Package::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 | ||
46 | void Package::setValue( QString n, QString t ) | 53 | void 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 | { |
@@ -127,137 +134,164 @@ QString Package::desc() | |||
127 | return _desc; | 134 | return _desc; |
128 | } | 135 | } |
129 | 136 | ||
130 | QString Package::shortDesc() | 137 | QString Package::shortDesc() |
131 | { | 138 | { |
132 | return _shortDesc; | 139 | return _shortDesc; |
133 | } | 140 | } |
134 | 141 | ||
135 | QString Package::size() | 142 | QString Package::size() |
136 | { | 143 | { |
137 | return _size; | 144 | return _size; |
138 | } | 145 | } |
139 | 146 | ||
140 | bool Package::toProcess() | 147 | bool Package::toProcess() |
141 | { | 148 | { |
142 | return _toProcess; | 149 | return _toProcess; |
143 | } | 150 | } |
144 | 151 | ||
145 | bool Package::toRemove() | 152 | bool 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 | ||
151 | bool Package::toInstall() | 158 | bool 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 | ||
157 | void Package::toggleProcess() | 164 | void Package::toggleProcess() |
158 | { | 165 | { |
159 | _toProcess = ! _toProcess; | 166 | _toProcess = ! _toProcess; |
160 | } | 167 | } |
161 | 168 | ||
162 | 169 | ||
163 | 170 | ||
164 | void Package::copyValues( Package* pack ) | 171 | void 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 | ||
175 | QString Package::getSection() | 182 | QString Package::section() |
176 | { | 183 | { |
177 | return _section; | 184 | return _section; |
178 | } | 185 | } |
179 | 186 | ||
180 | void Package::setSection( QString s) | 187 | void 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 | ||
193 | QString Package::getSubSection() | 200 | QString Package::subSection() |
194 | { | 201 | { |
195 | return _subsection; | 202 | return _subsection; |
196 | } | 203 | } |
197 | 204 | ||
198 | void Package::parsePackage( QStringList pack ) | 205 | void 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 | ||
217 | QString Package::details() | 224 | QString 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 */ | ||
257 | void Package::processed() | 263 | void 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 | |||
271 | QString Package::dest() | ||
272 | { | ||
273 | if ( installed()||(!installed() && _toProcess) ) | ||
274 | return _dest!=""?_dest:settings->getDestinationName(); | ||
275 | else return ""; | ||
276 | } | ||
277 | |||
278 | void Package::setDest( QString d ) | ||
279 | { | ||
280 | _dest = d; | ||
281 | } | ||
282 | |||
283 | void Package::setOn() | ||
284 | { | ||
285 | _toProcess = true; | ||
286 | } | ||
287 | |||
288 | bool Package::link() | ||
289 | { | ||
290 | if ( _dest == "root" || (!installed() && !_toProcess) ) return false; | ||
291 | return _link; | ||
292 | } | ||
293 | |||
294 | void 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 | |||
11 | class Package //: public QObject | 13 | class 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); | ||
40 | public slots: | 46 | public slots: |
41 | void toggleProcess(); | 47 | void toggleProcess(); |
42 | 48 | ||
43 | private: | 49 | private: |
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 | |||
@@ -25,199 +25,217 @@ PackageList::PackageList() | |||
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 | ||
36 | PackageList::PackageList( PackageManagerSettings* s) | 36 | PackageList::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 | ||
43 | PackageList::~PackageList() | 43 | PackageList::~PackageList() |
44 | { | 44 | { |
45 | } | 45 | } |
46 | 46 | ||
47 | /** Inserts a package into the list */ | 47 | /** Inserts a package into the list */ |
48 | void PackageList::insertPackage( Package* pack ) | 48 | void 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 | ||
64 | void PackageList::filterPackages( QString f ) | 64 | void 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 | ||
85 | Package* PackageList::find( QString n ) | 85 | Package* PackageList::find( QString n ) |
86 | { | 86 | { |
87 | return packageList.find( n ); | 87 | return packageList.find( n ); |
88 | } | 88 | } |
89 | 89 | ||
90 | Package* PackageList::first() | 90 | Package* PackageList::first() |
91 | { | 91 | { |
92 | packageIter.toFirst(); | 92 | packageIter.toFirst(); |
93 | return packageIter.current(); | 93 | return packageIter.current(); |
94 | } | 94 | } |
95 | 95 | ||
96 | Package* PackageList::next() | 96 | Package* PackageList::next() |
97 | { | 97 | { |
98 | ++packageIter; | 98 | ++packageIter; |
99 | return packageIter.current(); | 99 | return packageIter.current(); |
100 | } | 100 | } |
101 | 101 | ||
102 | QStringList PackageList::getSections() | 102 | QStringList PackageList::getSections() |
103 | { | 103 | { |
104 | sections.sort(); | 104 | sections.sort(); |
105 | return sections; | 105 | return sections; |
106 | } | 106 | } |
107 | 107 | ||
108 | QStringList PackageList::getSubSections() | 108 | QStringList 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 | ||
117 | void PackageList::setSection( QString sec ) | 117 | void PackageList::setSection( QString sec ) |
118 | { | 118 | { |
119 | aktSection = sec; | 119 | aktSection = sec; |
120 | } | 120 | } |
121 | 121 | ||
122 | void PackageList::setSubSection( QString ssec ) | 122 | void PackageList::setSubSection( QString ssec ) |
123 | { | 123 | { |
124 | aktSubSection = ssec; | 124 | aktSubSection = ssec; |
125 | } | 125 | } |
126 | 126 | ||
127 | void PackageList::updateSections( Package* pack ) | 127 | void 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 */ |
150 | void PackageList::parseStatus() | 150 | void 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 | ||
160 | void PackageList::parseList() | 163 | void 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 | ||
171 | void PackageList::readFileEntries( QString filename ) | 174 | void 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 | ||
200 | void PackageList::update() | 204 | void 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 | ||
209 | void PackageList::setSettings( PackageManagerSettings *s ) | 213 | void PackageList::setSettings( PackageManagerSettings *s ) |
210 | { | 214 | { |
211 | settings = s; | 215 | settings = s; |
212 | } | 216 | } |
213 | 217 | ||
214 | Package* PackageList::getByName( QString n ) | 218 | Package* PackageList::getByName( QString n ) |
215 | { | 219 | { |
216 | origPackageList[n]; | 220 | origPackageList[n]; |
217 | } | 221 | } |
218 | 222 | ||
219 | void PackageList::clear() | 223 | void PackageList::clear() |
220 | { | 224 | { |
221 | origPackageList.clear(); | 225 | origPackageList.clear(); |
222 | packageList.clear(); | 226 | packageList.clear(); |
223 | } | 227 | } |
228 | |||
229 | void 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 | ||
15 | class PackageList { | 15 | class PackageList //:QObject |
16 | { | ||
17 | // Q_OBJECT | ||
16 | public: | 18 | public: |
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 | ||
35 | public slots: | 37 | public 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 | ||
40 | private: | 42 | private: |
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 | ||
5 | static QPixmap *pm_uninstalled=0; | 8 | static QPixmap *pm_uninstalled=0; |
6 | static QPixmap *pm_installed=0; | 9 | static QPixmap *pm_installed=0; |
7 | static QPixmap *pm_uninstall=0; | 10 | static QPixmap *pm_uninstall=0; |
8 | static QPixmap *pm_install=0; | 11 | static QPixmap *pm_install=0; |
9 | 12 | ||
10 | PackageListItem::PackageListItem(QListView* lv, Package *pi) | 13 | PackageListItem::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 | ||
24 | void PackageListItem::paintCell( QPainter *p, const QColorGroup & cg, | 51 | void 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 | ||
54 | void PackageListItem::paintFocus( QPainter *p, const QColorGroup & cg, | 81 | void 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 | ||
62 | QPixmap PackageListItem::statePixmap() const | 89 | QPixmap 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 | ||
78 | QString PackageListItem::key( int column, bool ascending ) const | 105 | QString 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 | ||
92 | void PackageListItem::setOn( bool b ) | 119 | void 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 | |||
134 | void 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 | |||
12 | class PackageListItem | 14 | class PackageListItem |
13 | : public QCheckListItem | 15 | : public QCheckListItem |
14 | { | 16 | { |
15 | public: | 17 | public: |
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 | ||
26 | private: | 29 | private: |
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 | |||
@@ -424,64 +424,88 @@ void PackageManagerSettings::readSettings() | |||
424 | 424 | ||
425 | void PackageManagerSettings::writeSettings() | 425 | void 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 */ |
431 | bool PackageManagerSettings::showDialog( int i ) | 431 | bool 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 */ |
441 | QString PackageManagerSettings::getDestinationName() | 441 | QString PackageManagerSettings::getDestinationName() |
442 | { | 442 | { |
443 | return activeDestination->currentText(); | 443 | return activeDestination->currentText(); |
444 | } | 444 | } |
445 | /** Returns the link destination */ | 445 | /** Returns the link destination */ |
446 | QString PackageManagerSettings::getLinkDestinationName() | 446 | QString 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 */ |
451 | QString PackageManagerSettings::getDestinationUrl() | 451 | QString 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 */ |
457 | bool PackageManagerSettings::createLinks() | 457 | bool 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 */ |
462 | QStringList PackageManagerSettings::getActiveServers() | 462 | QStringList 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 */ |
473 | QStringList PackageManagerSettings::getDestinationUrls() | 474 | QStringList 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 */ | ||
485 | QString 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 */ | ||
496 | QStringList 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 | |||
483 | void PackageManagerSettings::linkEnabled( bool b ) | 507 | void 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 | ||
8 | class PackageManagerSettings : private PackageManagerSettingsBase | 8 | class PackageManagerSettings : private PackageManagerSettingsBase |
9 | { | 9 | { |
10 | // Q_OBJECT | 10 | // Q_OBJECT |
11 | public: | 11 | public: |
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 | |||
22 | private: | 25 | private: |
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 | ||
37 | public slots: | 40 | public 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 | ||
29 | PmIpkg::PmIpkg( PackageManagerSettings* s, QWidget* p, const char * name, WFlags f ) | 28 | PmIpkg::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 | ||
37 | PmIpkg::~PmIpkg() | 36 | PmIpkg::~PmIpkg() |
38 | { | 37 | { |
39 | } | 38 | } |
40 | 39 | ||
41 | //#define PROC | 40 | //#define PROC |
42 | #define SYSTEM | 41 | #define SYSTEM |
43 | int PmIpkg::runIpkg(const QString& args) | 42 | int 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 | ||
100 | void PmIpkg::makeLinks(QString pack) | 101 | void 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 | ||
127 | void PmIpkg::processLinkDir( QString file, QString dest ) | 130 | void 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 | ||
158 | void PmIpkg::commit( PackageList pl ) | 163 | void 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 | ||
222 | void PmIpkg::doIt() | 213 | void PmIpkg::doIt() |
223 | { | 214 | { |
224 | remove(); | 215 | remove(); |
225 | install(); | 216 | install(); |
226 | } | 217 | } |
227 | 218 | ||
228 | 219 | ||
229 | void PmIpkg::remove() | 220 | void 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 | ||
263 | void PmIpkg::install() | 241 | void 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 | ||
296 | void PmIpkg::linkDestination( const QString msg, const QByteArray dest ) | 261 | void 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 | ||
312 | void PmIpkg::update() | 276 | void 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 | ||
319 | void PmIpkg::out( QString o ) | 283 | void 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 | ||
326 | void PmIpkg::showButtons(bool b) | 290 | void 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 | ||
343 | void PmIpkg::show(bool b) | 307 | void 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 | ||
15 | class Package; | 14 | class Package; |
16 | class PmIpkg : public QObject | 15 | class PmIpkg : public QObject |
17 | { | 16 | { |
18 | Q_OBJECT | 17 | Q_OBJECT |
19 | public: | 18 | public: |
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 | ||
29 | private: | 28 | private: |
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 | ||
48 | public slots: | 40 | public 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,93 +1,93 @@ | |||
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> |
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 | ||
8 | class PackageManagerSettings : public PackageManagerSettingsBase | 8 | class PackageManagerSettings : public PackageManagerSettingsBase |
9 | //class PackageManagerSettings : private PackageManagerSettingsBase | 9 | //class PackageManagerSettings : private PackageManagerSettingsBase |
10 | { | 10 | { |
11 | // Q_OBJECT | 11 | // Q_OBJECT |
12 | public: | 12 | public: |
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 | ||
26 | private: | 24 | private: |
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 | ||
41 | public slots: | 39 | public 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 |