summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/unsupported/oipkg/TODO2
-rw-r--r--noncore/unsupported/oipkg/installdialog.cpp104
-rw-r--r--noncore/unsupported/oipkg/installdialog.h46
-rw-r--r--noncore/unsupported/oipkg/mainwindow.cpp5
-rw-r--r--noncore/unsupported/oipkg/oipkg.pro2
-rw-r--r--noncore/unsupported/oipkg/packagelistremote.cpp2
-rw-r--r--noncore/unsupported/oipkg/pksettings.cpp11
-rw-r--r--noncore/unsupported/oipkg/pksettings.h1
-rw-r--r--noncore/unsupported/oipkg/pmipkg.cpp96
-rw-r--r--noncore/unsupported/oipkg/pmipkg.h7
-rw-r--r--noncore/unsupported/oipkg/settings.h1
11 files changed, 202 insertions, 75 deletions
diff --git a/noncore/unsupported/oipkg/TODO b/noncore/unsupported/oipkg/TODO
index 1aa9e6b..b1ae6e3 100644
--- a/noncore/unsupported/oipkg/TODO
+++ b/noncore/unsupported/oipkg/TODO
@@ -1,14 +1,14 @@
1* Settings Class 1* Settings Class
2* tr() ;) 2* tr() ;)
3* Dialog to display ipkg output live 3* Dialog to display ipkg output live
4* parse "to install" and "to remove" from status 4* parse "to install" and "to remove" from status
5* install local file dialog 5* install local file dialog
6* qcop 6* qcop
7* error handling 7* error handling
8* manage links 8* manage links
9* dependency checking 9* dependency checking
10* create dest if it does not exist 10* create dest if it does not exist
11* allow reinstalling 11* allow reinstalling
12* different types of filters and searches 12* different types of filters and searches
13 i.e. name, desc, files etc 13 i.e. name, desc, files etc
14* get packages from doclnk \ No newline at end of file 14* mark packages from doclnk and ipkgfind installed if installed \ No newline at end of file
diff --git a/noncore/unsupported/oipkg/installdialog.cpp b/noncore/unsupported/oipkg/installdialog.cpp
new file mode 100644
index 0000000..72f436a
--- a/dev/null
+++ b/noncore/unsupported/oipkg/installdialog.cpp
@@ -0,0 +1,104 @@
1/****************************************************************************
2** Form implementation generated from reading ui file 'installdialog.ui'
3**
4** Created: Thu May 2 22:19:02 2002
5** by: The User Interface Compiler (uic)
6**
7** WARNING! All changes made in this file will be lost!
8****************************************************************************/
9#include "installdialog.h"
10
11#include <qcheckbox.h>
12#include <qgroupbox.h>
13#include <qheader.h>
14#include <qlistview.h>
15#include <qpushbutton.h>
16#include <qlayout.h>
17#include <qvariant.h>
18#include <qtooltip.h>
19#include <qwhatsthis.h>
20
21
22InstallDialog::InstallDialog( PackageManagerSettings* s, QWidget* parent, const char* name, bool modal, WFlags fl )
23 : QDialog( parent, name, modal, fl )
24{
25 settings = s;
26 if ( !name )
27 setName( "InstallDialog" );
28 resize( 223, 269 );
29 setCaption( tr( "Install" ) );
30 InstallDialogLayout = new QGridLayout( this );
31 InstallDialogLayout->setSpacing( 2 );
32 InstallDialogLayout->setMargin( 2 );
33
34 ListViewPackages = new PackageListView( this,"listViewPackages",settings );
35
36 InstallDialogLayout->addWidget( ListViewPackages, 0, 0 );
37
38 GroupBoxOptions = new QGroupBox( this, "GroupBoxOptions" );
39 GroupBoxOptions->setTitle( tr( "Ipkg options" ) );
40 GroupBoxOptions->setColumnLayout(0, Qt::Vertical );
41 GroupBoxOptions->layout()->setSpacing( 0 );
42 GroupBoxOptions->layout()->setMargin( 0 );
43 GroupBoxOptionsLayout = new QGridLayout( GroupBoxOptions->layout() );
44 GroupBoxOptionsLayout->setAlignment( Qt::AlignTop );
45 GroupBoxOptionsLayout->setSpacing( 2 );
46 GroupBoxOptionsLayout->setMargin( 2 );
47
48 _force_depends = new QCheckBox( GroupBoxOptions, "_force_depends" );
49 QFont _force_depends_font( _force_depends->font() );
50 _force_depends_font.setPointSize( 8 );
51 _force_depends->setFont( _force_depends_font );
52 _force_depends->setText( tr( "-force-depends" ) );
53 //_force_depends->setChecked( true );
54
55 GroupBoxOptionsLayout->addWidget( _force_depends, 0, 0 );
56
57 _force_reinstall = new QCheckBox( GroupBoxOptions, "_force_reinstall" );
58 QFont _force_reinstall_font( _force_reinstall->font() );
59 _force_reinstall_font.setPointSize( 8 );
60 _force_reinstall->setFont( _force_reinstall_font );
61 _force_reinstall->setText( tr( "-force-reinstall" ) );
62
63 GroupBoxOptionsLayout->addWidget( _force_reinstall, 1, 0 );
64
65 _force_remove = new QCheckBox( GroupBoxOptions, "_force_remove" );
66 QFont _force_remove_font( _force_remove->font() );
67 _force_remove_font.setPointSize( 8 );
68 _force_remove->setFont( _force_remove_font );
69 _force_remove->setText( tr( "-force-removal-of-essential-packages" ) );
70
71 GroupBoxOptionsLayout->addWidget( _force_remove, 2, 0 );
72
73 InstallDialogLayout->addWidget( GroupBoxOptions, 1, 0 );
74}
75
76/*
77 * Destroys the object and frees any allocated resources
78 */
79InstallDialog::~InstallDialog()
80{
81 // no need to delete child widgets, Qt does it all for us
82}
83
84/*
85 * Main event handler. Reimplemented to handle application
86 * font changes
87 */
88bool InstallDialog::event( QEvent* ev )
89{
90 bool ret = QDialog::event( ev );
91 if ( ev->type() == QEvent::ApplicationFontChange ) {
92 QFont _force_depends_font( _force_depends->font() );
93 _force_depends_font.setPointSize( 8 );
94 _force_depends->setFont( _force_depends_font );
95 QFont _force_reinstall_font( _force_reinstall->font() );
96 _force_reinstall_font.setPointSize( 8 );
97 _force_reinstall->setFont( _force_reinstall_font );
98 QFont _force_remove_font( _force_remove->font() );
99 _force_remove_font.setPointSize( 8 );
100 _force_remove->setFont( _force_remove_font );
101 }
102 return ret;
103}
104
diff --git a/noncore/unsupported/oipkg/installdialog.h b/noncore/unsupported/oipkg/installdialog.h
new file mode 100644
index 0000000..f2164ac
--- a/dev/null
+++ b/noncore/unsupported/oipkg/installdialog.h
@@ -0,0 +1,46 @@
1/****************************************************************************
2** Form interface generated from reading ui file 'installdialog.ui'
3**
4** Created: Thu May 2 22:19:01 2002
5** by: The User Interface Compiler (uic)
6**
7** WARNING! All changes made in this file will be lost!
8****************************************************************************/
9#ifndef INSTALLDIALOG_H
10#define INSTALLDIALOG_H
11
12#include "pksettings.h"
13#include "packagelistview.h"
14#include <qvariant.h>
15#include <qdialog.h>
16class QVBoxLayout;
17class QHBoxLayout;
18class QGridLayout;
19class QCheckBox;
20class QGroupBox;
21class QListView;
22class QListViewItem;
23
24class InstallDialog : public QDialog
25{
26 Q_OBJECT
27
28public:
29 InstallDialog( PackageManagerSettings* s, QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 );
30 ~InstallDialog();
31
32 PackageListView* ListViewPackages;
33 QGroupBox* GroupBoxOptions;
34 QCheckBox* _force_depends;
35 QCheckBox* _force_reinstall;
36 QCheckBox* _force_remove;
37
38protected:
39 QGridLayout* InstallDialogLayout;
40 QGridLayout* GroupBoxOptionsLayout;
41 bool event( QEvent* );
42private:
43 PackageManagerSettings* settings;
44};
45
46#endif // INSTALLDIALOG_H
diff --git a/noncore/unsupported/oipkg/mainwindow.cpp b/noncore/unsupported/oipkg/mainwindow.cpp
index b668660..259a789 100644
--- a/noncore/unsupported/oipkg/mainwindow.cpp
+++ b/noncore/unsupported/oipkg/mainwindow.cpp
@@ -47,399 +47,402 @@ MainWindow::MainWindow( QWidget *parent, const char *name, WFlags f = 0 ) :
47 ipkg = new PmIpkg( settings, this ); 47 ipkg = new PmIpkg( settings, this );
48// settings->setIpkg( ipkg ); 48// settings->setIpkg( ipkg );
49 packageListServers.setSettings( settings ); 49 packageListServers.setSettings( settings );
50 packageListSearch.setSettings( settings ); 50 packageListSearch.setSettings( settings );
51 packageListDocLnk.setSettings( settings ); 51 packageListDocLnk.setSettings( settings );
52 packageListServers.update(); 52 packageListServers.update();
53 packageListDocLnk.update(); 53 packageListDocLnk.update();
54 makeMenu(); 54 makeMenu();
55 makeChannel(); 55 makeChannel();
56 //opie is hardcoded default ;) 56 //opie is hardcoded default ;)
57 for (int i=0;i<section->count();i++) 57 for (int i=0;i<section->count();i++)
58 if (section->text(i)=="opie") 58 if (section->text(i)=="opie")
59 section->setCurrentItem(i); 59 section->setCurrentItem(i);
60 sectionChanged(); 60 sectionChanged();
61 61
62 connect( section, SIGNAL(activated(int)), SLOT(sectionChanged()) ); 62 connect( section, SIGNAL(activated(int)), SLOT(sectionChanged()) );
63 connect( subsection, SIGNAL(activated(int)), SLOT(subSectionChanged()) ); 63 connect( subsection, SIGNAL(activated(int)), SLOT(subSectionChanged()) );
64 64
65 connect( settings->removeLinksButton, SIGNAL( clicked()), 65 connect( settings->removeLinksButton, SIGNAL( clicked()),
66 SLOT(removeLinks()) ); 66 SLOT(removeLinks()) );
67 connect( settings->createLinksButton, SIGNAL( clicked()), 67 connect( settings->createLinksButton, SIGNAL( clicked()),
68 SLOT(createLinks()) ); 68 SLOT(createLinks()) );
69 69
70 displayList(); 70 displayList();
71} 71}
72 72
73void MainWindow::makeMenu() 73void MainWindow::makeMenu()
74{ 74{
75 75
76 QPEToolBar *toolBar = new QPEToolBar( this ); 76 QPEToolBar *toolBar = new QPEToolBar( this );
77 QPEMenuBar *menuBar = new QPEMenuBar( toolBar ); 77 QPEMenuBar *menuBar = new QPEMenuBar( toolBar );
78 QPopupMenu *srvMenu = new QPopupMenu( menuBar ); 78 QPopupMenu *srvMenu = new QPopupMenu( menuBar );
79 QPopupMenu *viewMenu = new QPopupMenu( menuBar ); 79 QPopupMenu *viewMenu = new QPopupMenu( menuBar );
80 QPopupMenu *cfgMenu = new QPopupMenu( menuBar ); 80 QPopupMenu *cfgMenu = new QPopupMenu( menuBar );
81 // QPopupMenu *sectMenu = new QPopupMenu( menuBar ); 81 // QPopupMenu *sectMenu = new QPopupMenu( menuBar );
82 82
83 setToolBarsMovable( false ); 83 setToolBarsMovable( false );
84 toolBar->setHorizontalStretchable( true ); 84 toolBar->setHorizontalStretchable( true );
85 menuBar->insertItem( tr( "Package" ), srvMenu ); 85 menuBar->insertItem( tr( "Package" ), srvMenu );
86 menuBar->insertItem( tr( "View" ), viewMenu ); 86 menuBar->insertItem( tr( "View" ), viewMenu );
87 menuBar->insertItem( tr( "Settings" ), cfgMenu ); 87 menuBar->insertItem( tr( "Settings" ), cfgMenu );
88 // menuBar->insertItem( tr( "Sections" ), sectMenu ); 88 // menuBar->insertItem( tr( "Sections" ), sectMenu );
89 89
90 QLabel *spacer = new QLabel( "", toolBar ); 90 QLabel *spacer = new QLabel( "", toolBar );
91 spacer->setBackgroundColor( toolBar->backgroundColor() ); 91 spacer->setBackgroundColor( toolBar->backgroundColor() );
92 toolBar->setStretchableWidget( spacer ); 92 toolBar->setStretchableWidget( spacer );
93 93
94 94
95 runAction = new QAction( tr( "Apply" ), 95 runAction = new QAction( tr( "Apply" ),
96 Resource::loadPixmap( "oipkg/install" ), 96 Resource::loadPixmap( "oipkg/install" ),
97 QString::null, 0, this, 0 ); 97 QString::null, 0, this, 0 );
98 connect( runAction, SIGNAL( activated() ), 98 connect( runAction, SIGNAL( activated() ),
99 this, SLOT( runIpkg() ) ); 99 this, SLOT( runIpkg() ) );
100 runAction->addTo( toolBar ); 100 runAction->addTo( toolBar );
101 runAction->addTo( srvMenu ); 101 runAction->addTo( srvMenu );
102 102
103 srvMenu->insertSeparator (); 103 srvMenu->insertSeparator ();
104 104
105 updateAction = new QAction( tr( "Update" ), 105 updateAction = new QAction( tr( "Update" ),
106 Resource::loadIconSet( "oipkg/update" ), 106 Resource::loadIconSet( "oipkg/update" ),
107 QString::null, 0, this, 0 ); 107 QString::null, 0, this, 0 );
108 connect( updateAction, SIGNAL( activated() ), 108 connect( updateAction, SIGNAL( activated() ),
109 this , SLOT( updateList() ) ); 109 this , SLOT( updateList() ) );
110 updateAction->addTo( toolBar ); 110 updateAction->addTo( toolBar );
111 updateAction->addTo( srvMenu ); 111 updateAction->addTo( srvMenu );
112 112
113 QAction *cfgact; 113 QAction *cfgact;
114 114
115 cfgact = new QAction( tr( "Setups" ), 115 cfgact = new QAction( tr( "Setups" ),
116 QString::null, 0, this, 0 ); 116 QString::null, 0, this, 0 );
117 connect( cfgact, SIGNAL( activated() ), 117 connect( cfgact, SIGNAL( activated() ),
118 SLOT( showSettings() ) ); 118 SLOT( showSettings() ) );
119 cfgact->addTo( cfgMenu ); 119 cfgact->addTo( cfgMenu );
120 120
121 cfgact = new QAction( tr( "Servers" ), 121 cfgact = new QAction( tr( "Servers" ),
122 QString::null, 0, this, 0 ); 122 QString::null, 0, this, 0 );
123 connect( cfgact, SIGNAL( activated() ), 123 connect( cfgact, SIGNAL( activated() ),
124 SLOT( showSettingsSrv() ) ); 124 SLOT( showSettingsSrv() ) );
125 cfgact->addTo( cfgMenu ); 125 cfgact->addTo( cfgMenu );
126 cfgact = new QAction( tr( "Destinations" ), 126 cfgact = new QAction( tr( "Destinations" ),
127 QString::null, 0, this, 0 ); 127 QString::null, 0, this, 0 );
128 connect( cfgact, SIGNAL( activated() ), 128 connect( cfgact, SIGNAL( activated() ),
129 SLOT( showSettingsDst() ) ); 129 SLOT( showSettingsDst() ) );
130 cfgact->addTo( cfgMenu ); 130 cfgact->addTo( cfgMenu );
131 131
132 QAction *a; 132 QAction *a;
133 133
134 // SECTIONS 134 // SECTIONS
135 sectionBar = new QPEToolBar( this ); 135 sectionBar = new QPEToolBar( this );
136 addToolBar( sectionBar, "Section", QMainWindow::Top, TRUE ); 136 addToolBar( sectionBar, "Section", QMainWindow::Top, TRUE );
137 sectionBar->setHorizontalStretchable( true ); 137 sectionBar->setHorizontalStretchable( true );
138 QLabel *label = new QLabel( tr("Section: "), sectionBar ); 138 QLabel *label = new QLabel( tr("Section: "), sectionBar );
139 label->setBackgroundColor( sectionBar->backgroundColor() ); 139 label->setBackgroundColor( sectionBar->backgroundColor() );
140 sectionBar->setStretchableWidget( label ); 140 sectionBar->setStretchableWidget( label );
141 section = new QComboBox( false, sectionBar ); 141 section = new QComboBox( false, sectionBar );
142 label = new QLabel( " / ", sectionBar ); 142 label = new QLabel( " / ", sectionBar );
143 label->setBackgroundColor( sectionBar->backgroundColor() ); 143 label->setBackgroundColor( sectionBar->backgroundColor() );
144 subsection = new QComboBox( false, sectionBar ); 144 subsection = new QComboBox( false, sectionBar );
145 a = new QAction( tr( "Close Section" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 145 a = new QAction( tr( "Close Section" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
146 connect( a, SIGNAL( activated() ), this, SLOT( sectionClose() ) ); 146 connect( a, SIGNAL( activated() ), this, SLOT( sectionClose() ) );
147 a->addTo( sectionBar ); 147 a->addTo( sectionBar );
148 setSections(); 148 setSections();
149 setSubSections(); 149 setSubSections();
150 sectionAction = new QAction( tr( "Sections" ), QString::null, 0, this, 0 ); 150 sectionAction = new QAction( tr( "Sections" ), QString::null, 0, this, 0 );
151 connect( sectionAction, SIGNAL( toggled(bool) ), this, SLOT( sectionShow(bool) ) ); 151 connect( sectionAction, SIGNAL( toggled(bool) ), this, SLOT( sectionShow(bool) ) );
152 sectionAction->setToggleAction( true ); 152 sectionAction->setToggleAction( true );
153 sectionAction->addTo( viewMenu ); 153 sectionAction->addTo( viewMenu );
154 154
155 //FIND 155 //FIND
156 findBar = new QPEToolBar(this); 156 findBar = new QPEToolBar(this);
157 addToolBar( findBar, "Filter", QMainWindow::Top, TRUE ); 157 addToolBar( findBar, "Filter", QMainWindow::Top, TRUE );
158 label = new QLabel( tr("Filter: "), findBar ); 158 label = new QLabel( tr("Filter: "), findBar );
159 label->setBackgroundColor( findBar->backgroundColor() ); 159 label->setBackgroundColor( findBar->backgroundColor() );
160 findBar->setHorizontalStretchable( TRUE ); 160 findBar->setHorizontalStretchable( TRUE );
161 findEdit = new QLineEdit( findBar, "findEdit" ); 161 findEdit = new QLineEdit( findBar, "findEdit" );
162 findBar->setStretchableWidget( findEdit ); 162 findBar->setStretchableWidget( findEdit );
163 connect( findEdit, SIGNAL( textChanged( const QString & ) ), 163 connect( findEdit, SIGNAL( textChanged( const QString & ) ),
164 this, SLOT( displayList() ) ); 164 this, SLOT( displayList() ) );
165 a = new QAction( tr( "Clear Find" ), Resource::loadPixmap( "back" ), QString::null, 0, this, 0 ); 165 a = new QAction( tr( "Clear Find" ), Resource::loadPixmap( "back" ), QString::null, 0, this, 0 );
166 connect( a, SIGNAL( activated() ), findEdit, SLOT( clear() ) ); 166 connect( a, SIGNAL( activated() ), findEdit, SLOT( clear() ) );
167 a->addTo( findBar ); 167 a->addTo( findBar );
168 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 168 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
169 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) ); 169 connect( a, SIGNAL( activated() ), this, SLOT( findClose() ) );
170 a->addTo( findBar ); 170 a->addTo( findBar );
171 findAction = new QAction( tr( "Filter" ), QString::null, 0, this, 0 ); 171 findAction = new QAction( tr( "Filter" ), QString::null, 0, this, 0 );
172 connect( findAction, SIGNAL( toggled(bool) ), this, SLOT( findShow(bool) ) ); 172 connect( findAction, SIGNAL( toggled(bool) ), this, SLOT( findShow(bool) ) );
173 findAction->setToggleAction( true ); 173 findAction->setToggleAction( true );
174 findAction->addTo( viewMenu ); 174 findAction->addTo( viewMenu );
175 175
176 //SEARCH 176 //SEARCH
177 searchBar = new QPEToolBar(this); 177 searchBar = new QPEToolBar(this);
178 addToolBar( searchBar, "Search", QMainWindow::Top, TRUE ); 178 addToolBar( searchBar, "Search", QMainWindow::Top, TRUE );
179 label = new QLabel( tr("ipkgfind: "), searchBar ); 179 label = new QLabel( tr("ipkgfind: "), searchBar );
180 label->setBackgroundColor( searchBar->backgroundColor() ); 180 label->setBackgroundColor( searchBar->backgroundColor() );
181 searchBar->setHorizontalStretchable( TRUE ); 181 searchBar->setHorizontalStretchable( TRUE );
182 searchEdit = new QLineEdit( searchBar, "seachEdit" ); 182 searchEdit = new QLineEdit( searchBar, "seachEdit" );
183 searchBar->setStretchableWidget( searchEdit ); 183 searchBar->setStretchableWidget( searchEdit );
184// connect( searchEdit, SIGNAL( textChanged( const QString & ) ), 184// connect( searchEdit, SIGNAL( textChanged( const QString & ) ),
185// this, SLOT( displayList() ) ); 185// this, SLOT( displayList() ) );
186 a = new QAction( tr( "Clear Search" ), Resource::loadPixmap( "back" ), QString::null, 0, this, 0 ); 186 a = new QAction( tr( "Clear Search" ), Resource::loadPixmap( "back" ), QString::null, 0, this, 0 );
187 connect( a, SIGNAL( activated() ), searchEdit, SLOT( clear() ) ); 187 connect( a, SIGNAL( activated() ), searchEdit, SLOT( clear() ) );
188 a->addTo( searchBar ); 188 a->addTo( searchBar );
189 searchCommit = new QAction( tr( "Do Search" ), Resource::loadPixmap( "find" ), QString::null, 0, this, 0 ); 189 searchCommit = new QAction( tr( "Do Search" ), Resource::loadPixmap( "find" ), QString::null, 0, this, 0 );
190 connect( searchCommit, SIGNAL( activated() ), SLOT( remotePackageQuery() ) ); 190 connect( searchCommit, SIGNAL( activated() ), SLOT( remotePackageQuery() ) );
191 searchCommit->addTo( searchBar ); 191 searchCommit->addTo( searchBar );
192 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 192 a = new QAction( tr( "Close Find" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
193 connect( a, SIGNAL( activated() ), this, SLOT( searchClose() ) ); 193 connect( a, SIGNAL( activated() ), this, SLOT( searchClose() ) );
194 a->addTo( searchBar ); 194 a->addTo( searchBar );
195 searchAction = new QAction( tr( "Search" ), QString::null, 0, this, 0 ); 195 searchAction = new QAction( tr( "Search" ), QString::null, 0, this, 0 );
196 connect( searchAction, SIGNAL( toggled(bool) ), this, SLOT( searchShow(bool) ) ); 196 connect( searchAction, SIGNAL( toggled(bool) ), this, SLOT( searchShow(bool) ) );
197 searchAction->setToggleAction( true ); 197 searchAction->setToggleAction( true );
198 searchAction->addTo( viewMenu ); 198 searchAction->addTo( viewMenu );
199 199
200 //DEST 200 //DEST
201 destBar = new QPEToolBar(this); 201 destBar = new QPEToolBar(this);
202 addToolBar( destBar, "Destination", QMainWindow::Top, TRUE ); 202 addToolBar( destBar, "Destination", QMainWindow::Top, TRUE );
203 label = new QLabel( tr("Destination: "), destBar ); 203 label = new QLabel( tr("Destination: "), destBar );
204 label->setBackgroundColor( destBar->backgroundColor() ); 204 label->setBackgroundColor( destBar->backgroundColor() );
205 destBar->setHorizontalStretchable( TRUE ); 205 destBar->setHorizontalStretchable( TRUE );
206 destination = new QComboBox( false, destBar ); 206 destination = new QComboBox( false, destBar );
207 destination->insertStringList( settings->getDestinationNames() ); 207 destination->insertStringList( settings->getDestinationNames() );
208 setComboName(destination,settings->getDestinationName()); 208 setComboName(destination,settings->getDestinationName());
209 connect( destination, SIGNAL(activated(int)), 209 connect( destination, SIGNAL(activated(int)),
210 settings, SLOT(activeDestinationChange(int)) ); 210 settings, SLOT(activeDestinationChange(int)) );
211 spacer = new QLabel( " ", destBar ); 211 spacer = new QLabel( " ", destBar );
212 spacer->setBackgroundColor( destBar->backgroundColor() ); 212 spacer->setBackgroundColor( destBar->backgroundColor() );
213 CheckBoxLink = new QCheckBox( tr("Link"), destBar); 213 CheckBoxLink = new QCheckBox( tr("Link"), destBar);
214 CheckBoxLink->setBackgroundColor( destBar->backgroundColor() ); 214 CheckBoxLink->setBackgroundColor( destBar->backgroundColor() );
215 CheckBoxLink->setChecked( settings->createLinks() ); 215 CheckBoxLink->setChecked( settings->createLinks() );
216 connect( CheckBoxLink, SIGNAL(toggled(bool)), 216 connect( CheckBoxLink, SIGNAL(toggled(bool)),
217 settings, SLOT(linkEnabled(bool)) ); 217 settings, SLOT(linkEnabled(bool)) );
218 destAction = new QAction( tr( "Destinations" ), QString::null, 0, this, 0 ); 218 destAction = new QAction( tr( "Destinations" ), QString::null, 0, this, 0 );
219 connect( destAction, SIGNAL( toggled(bool) ), SLOT( destShow(bool) ) ); 219 connect( destAction, SIGNAL( toggled(bool) ), SLOT( destShow(bool) ) );
220 a = new QAction( tr( "Close Destinations" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 ); 220 a = new QAction( tr( "Close Destinations" ), Resource::loadPixmap( "close" ), QString::null, 0, this, 0 );
221 connect( a, SIGNAL( activated() ), SLOT( destClose() ) ); 221 connect( a, SIGNAL( activated() ), SLOT( destClose() ) );
222 a->addTo( destBar ); 222 a->addTo( destBar );
223 destBar->setStretchableWidget( CheckBoxLink ); 223 destBar->setStretchableWidget( CheckBoxLink );
224 destAction->setToggleAction( true ); 224 destAction->setToggleAction( true );
225 // destAction->addTo( viewMenu ); 225 // destAction->addTo( viewMenu );
226 226
227 // configure the menus 227 // configure the menus
228 Config cfg( "oipkg", Config::User ); 228 Config cfg( "oipkg", Config::User );
229 cfg.setGroup( "gui" ); 229 cfg.setGroup( "gui" );
230 230
231 findShow( cfg.readBoolEntry( "findBar", true ) ); 231 findShow( cfg.readBoolEntry( "findBar", true ) );
232 searchShow( cfg.readBoolEntry( "searchBar", true ) ); 232 searchShow( cfg.readBoolEntry( "searchBar", true ) );
233 sectionShow( cfg.readBoolEntry( "sectionBar", true ) ); 233 sectionShow( cfg.readBoolEntry( "sectionBar", true ) );
234 destShow( cfg.readBoolEntry( "destBar", false ) ); 234 destShow( cfg.readBoolEntry( "destBar", false ) );
235} 235}
236 236
237MainWindow::~MainWindow() 237MainWindow::~MainWindow()
238{ 238{
239 pvDebug(7,"MainWindow::~MainWindow ");
239 Config cfg( "oipkg", Config::User ); 240 Config cfg( "oipkg", Config::User );
240 cfg.setGroup( "gui" ); 241 cfg.setGroup( "gui" );
241 cfg.writeEntry( "findBar", !findBar->isHidden() ); 242 cfg.writeEntry( "findBar", !findBar->isHidden() );
242 cfg.writeEntry( "searchBar", !searchBar->isHidden() ); 243 cfg.writeEntry( "searchBar", !searchBar->isHidden() );
243 cfg.writeEntry( "sectionBar", !sectionBar->isHidden() ); 244 cfg.writeEntry( "sectionBar", !sectionBar->isHidden() );
244 cfg.writeEntry( "destBar", !destBar->isHidden() ); 245 cfg.writeEntry( "destBar", !destBar->isHidden() );
246 pvDebug(7,"MainWindow::~MainWindow ");
245 247
246} 248}
247 249
248void MainWindow::runIpkg() 250void MainWindow::runIpkg()
249{ 251{
250 packageListServers.allPackages(); 252 packageListServers.allPackages();
251 ipkg->loadList( packageListSearch ); 253 ipkg->loadList( packageListSearch );
252 ipkg->loadList( packageListDocLnk ); 254 ipkg->loadList( packageListDocLnk );
253 ipkg->commit( packageListServers ); 255 ipkg->loadList( packageListServers );
256 ipkg->commit();
254 // ##### If we looked in the list of files, we could send out accurate 257 // ##### If we looked in the list of files, we could send out accurate
255 // ##### messages. But we don't bother yet, and just do an "all". 258 // ##### messages. But we don't bother yet, and just do an "all".
256 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 259 QCopEnvelope e("QPE/System", "linkChanged(QString)");
257 QString lf = QString::null; 260 QString lf = QString::null;
258 e << lf; 261 e << lf;
259 displayList(); 262 displayList();
260} 263}
261 264
262void MainWindow::updateList() 265void MainWindow::updateList()
263{ 266{
264 //wait->show(); 267 //wait->show();
265 QTimer *t = new QTimer( this ); 268 QTimer *t = new QTimer( this );
266 connect( t, SIGNAL(timeout()), SLOT( rotateUpdateIcon() ) ); 269 connect( t, SIGNAL(timeout()), SLOT( rotateUpdateIcon() ) );
267 t->start( 0, false ); 270 t->start( 0, false );
268 packageListServers.clear(); 271 packageListServers.clear();
269 packageListSearch.clear(); 272 packageListSearch.clear();
270 packageListDocLnk.clear(); 273 packageListDocLnk.clear();
271 ipkg->update(); 274 ipkg->update();
272 packageListServers.update(); 275 packageListServers.update();
273 packageListSearch.update(); 276 packageListSearch.update();
274 packageListDocLnk.update(); 277 packageListDocLnk.update();
275 t->stop(); 278 t->stop();
276 // wait->hide(); 279 // wait->hide();
277} 280}
278 281
279void MainWindow::filterList() 282void MainWindow::filterList()
280{ 283{
281 //wait->show(); 284 //wait->show();
282 QString f = ""; 285 QString f = "";
283 if ( findAction->isOn() ) f = findEdit->text(); 286 if ( findAction->isOn() ) f = findEdit->text();
284 packageListServers.filterPackages( f ); 287 packageListServers.filterPackages( f );
285 //wait->hide(); 288 //wait->hide();
286} 289}
287 290
288void MainWindow::displayList() 291void MainWindow::displayList()
289{ 292{
290 //wait->hide(); 293 //wait->hide();
291 filterList(); 294 filterList();
292 listViewPackages->display(); 295 listViewPackages->display();
293} 296}
294 297
295void MainWindow::sectionChanged() 298void MainWindow::sectionChanged()
296{ 299{
297 disconnect( section, SIGNAL( activated(int) ), 300 disconnect( section, SIGNAL( activated(int) ),
298 this, SLOT( sectionChanged() ) ); 301 this, SLOT( sectionChanged() ) );
299 disconnect( subsection, SIGNAL(activated(int) ), 302 disconnect( subsection, SIGNAL(activated(int) ),
300 this, SLOT( subSectionChanged() ) ); 303 this, SLOT( subSectionChanged() ) );
301 subsection->clear(); 304 subsection->clear();
302 packageListServers.setSection( section->currentText() ); 305 packageListServers.setSection( section->currentText() );
303 setSubSections(); 306 setSubSections();
304 connect( section, SIGNAL( activated(int) ), 307 connect( section, SIGNAL( activated(int) ),
305 this, SLOT( sectionChanged() ) ); 308 this, SLOT( sectionChanged() ) );
306 connect( subsection, SIGNAL(activated(int) ), 309 connect( subsection, SIGNAL(activated(int) ),
307 this, SLOT( subSectionChanged() ) ); 310 this, SLOT( subSectionChanged() ) );
308 displayList(); 311 displayList();
309} 312}
310 313
311void MainWindow::subSectionChanged() 314void MainWindow::subSectionChanged()
312{ 315{
313 disconnect( section, SIGNAL( activated(int) ), 316 disconnect( section, SIGNAL( activated(int) ),
314 this, SLOT( sectionChanged() ) ); 317 this, SLOT( sectionChanged() ) );
315 disconnect( subsection, SIGNAL(activated(int) ), 318 disconnect( subsection, SIGNAL(activated(int) ),
316 this, SLOT( subSectionChanged() ) ); 319 this, SLOT( subSectionChanged() ) );
317 packageListServers.setSubSection( subsection->currentText() ); 320 packageListServers.setSubSection( subsection->currentText() );
318 connect( section, SIGNAL( activated(int) ), 321 connect( section, SIGNAL( activated(int) ),
319 this, SLOT( sectionChanged() ) ); 322 this, SLOT( sectionChanged() ) );
320 connect( subsection, SIGNAL(activated(int) ), 323 connect( subsection, SIGNAL(activated(int) ),
321 this, SLOT( subSectionChanged() ) ); 324 this, SLOT( subSectionChanged() ) );
322 displayList(); 325 displayList();
323} 326}
324 327
325void MainWindow::setSections() 328void MainWindow::setSections()
326{ 329{
327 section->clear(); 330 section->clear();
328 section->insertStringList( packageListServers.getSections() ); 331 section->insertStringList( packageListServers.getSections() );
329} 332}
330 333
331void MainWindow::setSubSections() 334void MainWindow::setSubSections()
332{ 335{
333 subsection->clear(); 336 subsection->clear();
334 subsection->insertStringList( packageListServers.getSubSections() ); 337 subsection->insertStringList( packageListServers.getSubSections() );
335} 338}
336 339
337 340
338void MainWindow::showSettings() 341void MainWindow::showSettings()
339{ 342{
340 if ( settings->showDialog( 0 ) ) 343 if ( settings->showDialog( 0 ) )
341 updateList(); 344 updateList();
342} 345}
343void MainWindow::showSettingsSrv() 346void MainWindow::showSettingsSrv()
344{ 347{
345 if ( settings->showDialog( 1 ) ) 348 if ( settings->showDialog( 1 ) )
346 updateList(); 349 updateList();
347} 350}
348void MainWindow::showSettingsDst() 351void MainWindow::showSettingsDst()
349{ 352{
350 if ( settings->showDialog( 2 ) ) 353 if ( settings->showDialog( 2 ) )
351 updateList(); 354 updateList();
352} 355}
353 356
354void MainWindow::sectionShow(bool b) 357void MainWindow::sectionShow(bool b)
355{ 358{
356 if (b) sectionBar->show(); 359 if (b) sectionBar->show();
357 else sectionBar->hide(); 360 else sectionBar->hide();
358 sectionAction->setOn( b ); 361 sectionAction->setOn( b );
359} 362}
360 363
361void MainWindow::sectionClose() 364void MainWindow::sectionClose()
362{ 365{
363 sectionAction->setOn( false ); 366 sectionAction->setOn( false );
364} 367}
365 368
366void MainWindow::findShow(bool b) 369void MainWindow::findShow(bool b)
367{ 370{
368 if (b) findBar->show(); 371 if (b) findBar->show();
369 else findBar->hide(); 372 else findBar->hide();
370 findAction->setOn( b ); 373 findAction->setOn( b );
371} 374}
372 375
373void MainWindow::findClose() 376void MainWindow::findClose()
374{ 377{
375 findAction->setOn( false ); 378 findAction->setOn( false );
376} 379}
377 380
378void MainWindow::searchShow(bool b) 381void MainWindow::searchShow(bool b)
379{ 382{
380 if (b) searchBar->show(); 383 if (b) searchBar->show();
381 else searchBar->hide(); 384 else searchBar->hide();
382 searchAction->setOn( b ); 385 searchAction->setOn( b );
383} 386}
384 387
385void MainWindow::searchClose() 388void MainWindow::searchClose()
386{ 389{
387 searchAction->setOn( false ); 390 searchAction->setOn( false );
388} 391}
389 392
390 393
391void MainWindow::destShow(bool b) 394void MainWindow::destShow(bool b)
392{ 395{
393 if (b) destBar->show(); 396 if (b) destBar->show();
394 else destBar->hide(); 397 else destBar->hide();
395 destAction->setOn( b ); 398 destAction->setOn( b );
396} 399}
397 400
398void MainWindow::destClose() 401void MainWindow::destClose()
399{ 402{
400 destAction->setOn( false ); 403 destAction->setOn( false );
401} 404}
402 405
403void MainWindow::rotateUpdateIcon() 406void MainWindow::rotateUpdateIcon()
404{ 407{
405 pvDebug(2, "MainWindow::rotateUpdateIcon"); 408 pvDebug(2, "MainWindow::rotateUpdateIcon");
406 if ( updateIcon ) 409 if ( updateIcon )
407 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update" ) ); 410 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update" ) );
408 else 411 else
409 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update2" ) ); 412 updateAction->setIconSet( Resource::loadIconSet( "oipkg/update2" ) );
410 updateIcon = !updateIcon; 413 updateIcon = !updateIcon;
411} 414}
412 415
413 416
414void MainWindow::setDocument(const QString &fileName) 417void MainWindow::setDocument(const QString &fileName)
415{ 418{
416 installFile(fileName); 419 installFile(fileName);
417 // ##### If we looked in the list of files, we could send out accurate 420 // ##### If we looked in the list of files, we could send out accurate
418 // ##### messages. But we don't bother yet, and just do an "all". 421 // ##### messages. But we don't bother yet, and just do an "all".
419 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 422 QCopEnvelope e("QPE/System", "linkChanged(QString)");
420 QString lf = QString::null; 423 QString lf = QString::null;
421 e << lf; 424 e << lf;
422 displayList(); 425 displayList();
423} 426}
424 427
425void MainWindow::installFile(const QString &fileName) 428void MainWindow::installFile(const QString &fileName)
426{ 429{
427 pvDebug(3, "MainWindow::installFile "+fileName); 430 pvDebug(3, "MainWindow::installFile "+fileName);
428 if ( !QFile::exists( fileName ) ) return; 431 if ( !QFile::exists( fileName ) ) return;
429 ipkg->installFile( fileName ); 432 ipkg->installFile( fileName );
430 // ##### If we looked in the list of files, we could send out accurate 433 // ##### If we looked in the list of files, we could send out accurate
431 // ##### messages. But we don't bother yet, and just do an "all". 434 // ##### messages. But we don't bother yet, and just do an "all".
432 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 435 QCopEnvelope e("QPE/System", "linkChanged(QString)");
433 QString lf = QString::null; 436 QString lf = QString::null;
434 e << lf; 437 e << lf;
435 displayList(); 438 displayList();
436} 439}
437 440
438void MainWindow::makeChannel() 441void MainWindow::makeChannel()
439 { 442 {
440 channel = new QCopChannel( "QPE/Application/oipkg", this ); 443 channel = new QCopChannel( "QPE/Application/oipkg", this );
441 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), 444 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)),
442 this, SLOT(receive(const QCString&, const QByteArray&)) ); 445 this, SLOT(receive(const QCString&, const QByteArray&)) );
443} 446}
444 447
445 448
diff --git a/noncore/unsupported/oipkg/oipkg.pro b/noncore/unsupported/oipkg/oipkg.pro
index 6ee1963..9e2f5f8 100644
--- a/noncore/unsupported/oipkg/oipkg.pro
+++ b/noncore/unsupported/oipkg/oipkg.pro
@@ -1,34 +1,36 @@
1 DESTDIR = $(OPIEDIR)/bin 1 DESTDIR = $(OPIEDIR)/bin
2 TEMPLATE= app 2 TEMPLATE= app
3 #CONFIG = qt warn_on release 3 #CONFIG = qt warn_on release
4 CONFIG = qt warn_on debug 4 CONFIG = qt warn_on debug
5 HEADERS = mainwindow.h \ 5 HEADERS = mainwindow.h \
6 pksettings.h \ 6 pksettings.h \
7 pmipkg.h \ 7 pmipkg.h \
8 packagelistdoclnk.h \ 8 packagelistdoclnk.h \
9 installdialog.h \
9 utils.h \ 10 utils.h \
10 packagelistitem.h \ 11 packagelistitem.h \
11 packagelistremote.h \ 12 packagelistremote.h \
12 packagelist.h \ 13 packagelist.h \
13 packagelistlocal.h \ 14 packagelistlocal.h \
14 packagelistview.h \ 15 packagelistview.h \
15 package.h 16 package.h
16 SOURCES = main.cpp \ 17 SOURCES = main.cpp \
17 mainwindow.cpp \ 18 mainwindow.cpp \
18 utils.cpp \ 19 utils.cpp \
19 packagelistdoclnk.cpp \ 20 packagelistdoclnk.cpp \
20 packagelistview.cpp \ 21 packagelistview.cpp \
22 installdialog.cpp \
21 packagelistremote.cpp \ 23 packagelistremote.cpp \
22 packagelistlocal.cpp \ 24 packagelistlocal.cpp \
23 pksettings.cpp \ 25 pksettings.cpp \
24 pmipkg.cpp \ 26 pmipkg.cpp \
25 packagelistitem.cpp \ 27 packagelistitem.cpp \
26 packagelist.cpp \ 28 packagelist.cpp \
27 package.cpp 29 package.cpp
28INCLUDEPATH += $(OPIEDIR)/include 30INCLUDEPATH += $(OPIEDIR)/include
29 DEPENDPATH+= $(OPIEDIR)/ioclude 31 DEPENDPATH+= $(OPIEDIR)/ioclude
30LIBS += -lqpe 32LIBS += -lqpe
31 INTERFACES= runwindow.ui \ 33 INTERFACES= runwindow.ui \
32 pksettingsbase.ui 34 pksettingsbase.ui
33 TARGET = oipkg 35 TARGET = oipkg
34 36
diff --git a/noncore/unsupported/oipkg/packagelistremote.cpp b/noncore/unsupported/oipkg/packagelistremote.cpp
index 1ec7292..3c6ede7 100644
--- a/noncore/unsupported/oipkg/packagelistremote.cpp
+++ b/noncore/unsupported/oipkg/packagelistremote.cpp
@@ -1,47 +1,47 @@
1 1
2#include "packagelistremote.h" 2#include "packagelistremote.h"
3 3
4#include <qstring.h> 4#include <qstring.h>
5#include <stdlib.h> 5#include <stdlib.h>
6#include <unistd.h> 6#include <unistd.h>
7 7
8PackageListRemote::PackageListRemote(PackageManagerSettings* s) 8PackageListRemote::PackageListRemote(PackageManagerSettings* s)
9 : PackageList(s) 9 : PackageList(s)
10{ 10{
11 PackageListRemote(); 11 PackageListRemote();
12} 12}
13 13
14PackageListRemote::PackageListRemote() 14PackageListRemote::PackageListRemote()
15 : PackageList() 15 : PackageList()
16{ 16{
17} 17}
18 18
19PackageListRemote::~PackageListRemote() 19PackageListRemote::~PackageListRemote()
20{ 20{
21} 21}
22 22
23void PackageListRemote::query(QString s) 23void PackageListRemote::query(QString s)
24{ 24{
25 searchString = s; 25 searchString = s;
26} 26}
27 27
28void PackageListRemote::update() 28void PackageListRemote::update()
29{ 29{
30 pvDebug(2,"PackageListRemote::update"); 30 pvDebug(2,"PackageListRemote::update");
31 int r=0; 31 int r=0;
32 QString cmd = "wget"; 32 QString cmd = "wget";
33 QString redirect = "/tmp/oipkg.query"; 33 QString redirect = "/tmp/oipkg.query";
34 34
35 // use file for output 35 // use file for output
36 cmd += " --output-document="+redirect; 36 cmd += " --output-document="+redirect;
37//http://ipkgfind.handhelds.org/packages.phtml?format=pda&query=ipkg&searchtype=package&section= 37//http://ipkgfind.handhelds.org/packages.phtml?format=pda&query=ipkg&searchtype=package&section=
38 QString server="http://ipkgfind.handhelds.org/"; 38 QString server="http://ipkgfind.handhelds.org/";
39 cmd += " \""+server+"/packages.phtml"; 39 cmd += " \""+server+"/packages.phtml";
40 cmd += "?format=pda&searchtype=package&section="; 40 cmd += "?format=pda&searchtype=package&section=";
41 cmd += "&query="+searchString; 41 cmd += "&query="+searchString;
42 cmd += "\""; 42 cmd += "\"";
43 43
44 pvDebug(2,"search :"+cmd); 44 pvDebug(4,"search :"+cmd);
45 r = system(cmd.latin1()); 45 r = system(cmd.latin1());
46 readFileEntries( redirect ); 46 readFileEntries( redirect );
47} 47}
diff --git a/noncore/unsupported/oipkg/pksettings.cpp b/noncore/unsupported/oipkg/pksettings.cpp
index 7e2ef10..24c7beb 100644
--- a/noncore/unsupported/oipkg/pksettings.cpp
+++ b/noncore/unsupported/oipkg/pksettings.cpp
@@ -1,397 +1,400 @@
1#include "pksettings.h" 1#include "pksettings.h"
2 2
3#include <qpe/process.h> 3#include <qpe/process.h>
4#include <qpe/resource.h> 4#include <qpe/resource.h>
5#include <qpe/stringutil.h> 5#include <qpe/stringutil.h>
6#include <qpe/qpeapplication.h> 6#include <qpe/qpeapplication.h>
7#include <qpe/qcopenvelope_qws.h> 7#include <qpe/qcopenvelope_qws.h>
8#include <qpe/applnk.h> 8#include <qpe/applnk.h>
9#include <qpe/config.h> 9#include <qpe/config.h>
10 10
11#include <qprogressbar.h> 11#include <qprogressbar.h>
12#include <qcombobox.h> 12#include <qcombobox.h>
13#include <qdict.h> 13#include <qdict.h>
14#include <qfile.h> 14#include <qfile.h>
15#include <qlineedit.h> 15#include <qlineedit.h>
16#include <qpushbutton.h> 16#include <qpushbutton.h>
17#include <qlistview.h> 17#include <qlistview.h>
18#include <qlistbox.h> 18#include <qlistbox.h>
19#include <qcheckbox.h> 19#include <qcheckbox.h>
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21#include <qpainter.h> 21#include <qpainter.h>
22#include <qpixmap.h> 22#include <qpixmap.h>
23#include <qregexp.h> 23#include <qregexp.h>
24#include <qstring.h> 24#include <qstring.h>
25#include <qobject.h> 25#include <qobject.h>
26#include <qtextstream.h> 26#include <qtextstream.h>
27#include <qtextview.h> 27#include <qtextview.h>
28#include <qtoolbutton.h> 28#include <qtoolbutton.h>
29#include <qtabwidget.h> 29#include <qtabwidget.h>
30 30
31#include <stdlib.h> 31#include <stdlib.h>
32#include <unistd.h> 32#include <unistd.h>
33#include "debug.h" 33#include "debug.h"
34//#include "utils.h" 34//#include "utils.h"
35 35
36PackageManagerSettings::PackageManagerSettings( QWidget* parent, const char* name, WFlags fl ) 36PackageManagerSettings::PackageManagerSettings( QWidget* parent, const char* name, WFlags fl )
37 : PackageManagerSettingsBase( parent, name, fl ) 37 : PackageManagerSettingsBase( parent, name, fl )
38{ 38{
39 connect( newserver, SIGNAL(clicked()), this, SLOT(newServer()) ); 39 connect( newserver, SIGNAL(clicked()), this, SLOT(newServer()) );
40 connect( removeserver, SIGNAL(clicked()), this, SLOT(removeServer()) ); 40 connect( removeserver, SIGNAL(clicked()), this, SLOT(removeServer()) );
41 connect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) ); 41 connect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) );
42 connect( newdestination, SIGNAL(clicked()), this, SLOT(newDestination()) ); 42 connect( newdestination, SIGNAL(clicked()), this, SLOT(newDestination()) );
43 connect( removedestination, SIGNAL(clicked()), this, SLOT(removeDestination()) ); 43 connect( removedestination, SIGNAL(clicked()), this, SLOT(removeDestination()) );
44 connect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) ); 44 connect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) );
45 // connect( CheckBoxLink, SIGNAL(toggled(bool)), 45 // connect( CheckBoxLink, SIGNAL(toggled(bool)),
46 // activeLinkDestination, SLOT(setEnabled(bool)) ); 46 // activeLinkDestination, SLOT(setEnabled(bool)) );
47 47
48 connect( settingName, SIGNAL(activated(int)), this, SLOT(installationSettingChange(int)) ); 48 connect( settingName, SIGNAL(activated(int)), this, SLOT(installationSettingChange(int)) );
49 connect( settingName, SIGNAL(textChanged(const QString &)), this, SLOT(installationSettingSetName(const QString &)) ); 49 connect( settingName, SIGNAL(textChanged(const QString &)), this, SLOT(installationSettingSetName(const QString &)) );
50 connect( newsetting, SIGNAL(clicked()), this, SLOT(newInstallationSetting()) ); 50 connect( newsetting, SIGNAL(clicked()), this, SLOT(newInstallationSetting()) );
51 connect( renamesetting, SIGNAL(clicked()), this, SLOT(renameInstallationSetting()) ); 51 connect( renamesetting, SIGNAL(clicked()), this, SLOT(renameInstallationSetting()) );
52 connect( removesetting, SIGNAL(clicked()), this, SLOT(removeInstallationSetting()) ); 52 connect( removesetting, SIGNAL(clicked()), this, SLOT(removeInstallationSetting()) );
53 servername->setEnabled(FALSE); 53 servername->setEnabled(FALSE);
54 serverurl->setEnabled(FALSE); 54 serverurl->setEnabled(FALSE);
55 serverurlDic.setAutoDelete(TRUE); 55 serverurlDic.setAutoDelete(TRUE);
56 destinationname->setEnabled(FALSE); 56 destinationname->setEnabled(FALSE);
57 destinationurl->setEnabled(FALSE); 57 destinationurl->setEnabled(FALSE);
58 destinationurlDic.setAutoDelete(TRUE); 58 destinationurlDic.setAutoDelete(TRUE);
59 readSettings(); 59 readSettings();
60 activeLinkDestination->hide(); 60 activeLinkDestination->hide();
61 serverChanged = false;
61} 62}
62 63
63PackageManagerSettings::~PackageManagerSettings() 64PackageManagerSettings::~PackageManagerSettings()
64{ 65{
65} 66}
66 67
67 68
68void PackageManagerSettings::newServer() 69void PackageManagerSettings::newServer()
69{ 70{
70 int i = servers->count(); 71 int i = servers->count();
71 if ( servername->isEnabled() || serverurl->text().isEmpty() ) { 72 if ( servername->isEnabled() || serverurl->text().isEmpty() ) {
72 serverurlDic.insert(i,new QString("http://")); 73 serverurlDic.insert(i,new QString("http://"));
73 servers->insertItem(tr("New")); 74 servers->insertItem(tr("New"));
74 activeServers->insertItem(tr("New")); 75 activeServers->insertItem(tr("New"));
75 } else { 76 } else {
76 // allows one-level undo 77 // allows one-level undo
77 serverurlDic.insert(i,new QString(serverurl->text())); 78 serverurlDic.insert(i,new QString(serverurl->text()));
78 servers->insertItem(servername->text()); 79 servers->insertItem(servername->text());
79 activeServers->insertItem(servername->text()); 80 activeServers->insertItem(servername->text());
80 } 81 }
81 changed = true; 82 changed = true;
82 servers->setSelected(i,TRUE); 83 servers->setSelected(i,TRUE);
83 editServer(i); 84 editServer(i);
84 changed = true; 85 changed = true;
85} 86}
86 87
87void PackageManagerSettings::newDestination() 88void PackageManagerSettings::newDestination()
88{ 89{
89 int i = destinations->count(); 90 int i = destinations->count();
90 if ( destinationname->isEnabled() || destinationurl->text().isEmpty() ) { 91 if ( destinationname->isEnabled() || destinationurl->text().isEmpty() ) {
91 destinationurlDic.insert(i,new QString("/")); 92 destinationurlDic.insert(i,new QString("/"));
92 destinations->insertItem(tr("New")); 93 destinations->insertItem(tr("New"));
93 activeDestination->insertItem(tr("New")); 94 activeDestination->insertItem(tr("New"));
94 activeLinkDestination->insertItem(tr("New")); 95 activeLinkDestination->insertItem(tr("New"));
95 } else { 96 } else {
96 // allows one-level undo 97 // allows one-level undo
97 destinationurlDic.insert(i,new QString(destinationurl->text())); 98 destinationurlDic.insert(i,new QString(destinationurl->text()));
98 destinations->insertItem(destinationname->text()); 99 destinations->insertItem(destinationname->text());
99 activeDestination->insertItem(destinationname->text()); 100 activeDestination->insertItem(destinationname->text());
100 activeLinkDestination->insertItem(destinationname->text()); 101 activeLinkDestination->insertItem(destinationname->text());
101 } 102 }
102 destinations->setSelected(i,TRUE); 103 destinations->setSelected(i,TRUE);
103 editDestination(i); 104 editDestination(i);
104 changed = true; 105 changed = true;
105} 106}
106 107
107 108
108void PackageManagerSettings::editServer(int i) 109void PackageManagerSettings::editServer(int i)
109{ 110{
110 if ( servername->isEnabled() ) { 111 if ( servername->isEnabled() ) {
111 disconnect( servername, SIGNAL(textChanged(const QString&)), this, SLOT(serverNameChanged(const QString&)) ); 112 disconnect( servername, SIGNAL(textChanged(const QString&)), this, SLOT(serverNameChanged(const QString&)) );
112 disconnect( serverurl, SIGNAL(textChanged(const QString&)), this, SLOT(serverUrlChanged(const QString&)) ); 113 disconnect( serverurl, SIGNAL(textChanged(const QString&)), this, SLOT(serverUrlChanged(const QString&)) );
113 } else { 114 } else {
114 servername->setEnabled(TRUE); 115 servername->setEnabled(TRUE);
115 serverurl->setEnabled(TRUE); 116 serverurl->setEnabled(TRUE);
116 } 117 }
117 118
118 servername->setText( servers->text(i) ); 119 servername->setText( servers->text(i) );
119 serverurl->setText( *serverurlDic[i] ); 120 serverurl->setText( *serverurlDic[i] );
120 121
121 editedserver = i; 122 editedserver = i;
122 123 serverChanged = true;
123 connect( servername, SIGNAL(textChanged(const QString&)), this, SLOT(serverNameChanged(const QString&)) ); 124 connect( servername, SIGNAL(textChanged(const QString&)), this, SLOT(serverNameChanged(const QString&)) );
124 connect( serverurl, SIGNAL(textChanged(const QString&)), this, SLOT(serverUrlChanged(const QString&)) ); 125 connect( serverurl, SIGNAL(textChanged(const QString&)), this, SLOT(serverUrlChanged(const QString&)) );
125 changed = true; 126 changed = true;
126} 127}
127 128
128 129
129void PackageManagerSettings::editDestination(int i) 130void PackageManagerSettings::editDestination(int i)
130{ 131{
131 if ( destinationname->isEnabled() ) { 132 if ( destinationname->isEnabled() ) {
132 disconnect( destinationname, SIGNAL(textChanged(const QString&)), this, SLOT(destNameChanged(const QString&)) ); 133 disconnect( destinationname, SIGNAL(textChanged(const QString&)), this, SLOT(destNameChanged(const QString&)) );
133 disconnect( destinationurl, SIGNAL(textChanged(const QString&)), this, SLOT(destUrlChanged(const QString&)) ); 134 disconnect( destinationurl, SIGNAL(textChanged(const QString&)), this, SLOT(destUrlChanged(const QString&)) );
134 } else { 135 } else {
135 destinationname->setEnabled(TRUE); 136 destinationname->setEnabled(TRUE);
136 destinationurl->setEnabled(TRUE); 137 destinationurl->setEnabled(TRUE);
137 createLinksButton->setEnabled(TRUE); 138 //since it does not work anyway
138 removeLinksButton->setEnabled(TRUE); 139// createLinksButton->setEnabled(TRUE);
140// removeLinksButton->setEnabled(TRUE);
139 } 141 }
140 142
141 destinationname->setText( destinations->text(i) ); 143 destinationname->setText( destinations->text(i) );
142 destinationurl->setText( *destinationurlDic[i] ); 144 destinationurl->setText( *destinationurlDic[i] );
143 145
144 editeddestination = i; 146 editeddestination = i;
145 147
146 connect( destinationname, SIGNAL(textChanged(const QString&)), this, SLOT(destNameChanged(const QString&)) ); 148 connect( destinationname, SIGNAL(textChanged(const QString&)), this, SLOT(destNameChanged(const QString&)) );
147 connect( destinationurl, SIGNAL(textChanged(const QString&)), this, SLOT(destUrlChanged(const QString&)) ); 149 connect( destinationurl, SIGNAL(textChanged(const QString&)), this, SLOT(destUrlChanged(const QString&)) );
148 changed = true; 150 changed = true;
149} 151}
150 152
151void PackageManagerSettings::removeServer() 153void PackageManagerSettings::removeServer()
152{ 154{
153 disconnect( servername, SIGNAL(textChanged(const QString&)), this, SLOT(serverNameChanged(const QString&)) ); 155 disconnect( servername, SIGNAL(textChanged(const QString&)), this, SLOT(serverNameChanged(const QString&)) );
154 disconnect( serverurl, SIGNAL(textChanged(const QString&)), this, SLOT(serverUrlChanged(const QString&)) ); 156 disconnect( serverurl, SIGNAL(textChanged(const QString&)), this, SLOT(serverUrlChanged(const QString&)) );
155 servername->setText(servers->text(editedserver)); 157 servername->setText(servers->text(editedserver));
156 serverurl->setText(*serverurlDic[editedserver]); 158 serverurl->setText(*serverurlDic[editedserver]);
157 disconnect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) ); 159 disconnect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) );
158 servers->removeItem(editedserver); 160 servers->removeItem(editedserver);
159 activeServers->removeItem(editedserver); 161 activeServers->removeItem(editedserver);
160 connect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) ); 162 connect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) );
161 servername->setEnabled(FALSE); 163 servername->setEnabled(FALSE);
162 serverurl->setEnabled(FALSE); 164 serverurl->setEnabled(FALSE);
163 changed = true; 165 changed = true;
164} 166}
165 167
166void PackageManagerSettings::removeDestination() 168void PackageManagerSettings::removeDestination()
167{ 169{
168 disconnect( destinationname, SIGNAL(textChanged(const QString&)), this, SLOT(destNameChanged(const QString&)) ); 170 disconnect( destinationname, SIGNAL(textChanged(const QString&)), this, SLOT(destNameChanged(const QString&)) );
169 disconnect( destinationurl, SIGNAL(textChanged(const QString&)), this, SLOT(destUrlChanged(const QString&)) ); 171 disconnect( destinationurl, SIGNAL(textChanged(const QString&)), this, SLOT(destUrlChanged(const QString&)) );
170 destinationname->setText(destinations->text(editedserver)); 172 destinationname->setText(destinations->text(editedserver));
171 destinationurl->setText(*destinationurlDic[editedserver]); 173 destinationurl->setText(*destinationurlDic[editedserver]);
172 disconnect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) ); 174 disconnect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) );
173 destinations->removeItem(editeddestination); 175 destinations->removeItem(editeddestination);
174 activeDestination->removeItem(editeddestination); 176 activeDestination->removeItem(editeddestination);
175 activeLinkDestination->removeItem(editeddestination); 177 activeLinkDestination->removeItem(editeddestination);
176 connect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) ); 178 connect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) );
177 destinationname->setEnabled(FALSE); 179 destinationname->setEnabled(FALSE);
178 destinationurl->setEnabled(FALSE); 180 destinationurl->setEnabled(FALSE);
179 changed = true; 181 changed = true;
180} 182}
181 183
182void PackageManagerSettings::serverNameChanged(const QString& t) 184void PackageManagerSettings::serverNameChanged(const QString& t)
183{ 185{
184 disconnect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) ); 186 disconnect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) );
185 servers->changeItem( t, editedserver ); 187 servers->changeItem( t, editedserver );
186 activeServers->changeItem( t, editedserver ); 188 activeServers->changeItem( t, editedserver );
187 changed = true;
188 connect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) ); 189 connect( servers, SIGNAL(highlighted(int)), this, SLOT(editServer(int)) );
189 changed = true; 190 changed = true;
191 serverChanged = true;
190} 192}
191 193
192void PackageManagerSettings::destNameChanged(const QString& t) 194void PackageManagerSettings::destNameChanged(const QString& t)
193{ 195{
194 disconnect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) ); 196 disconnect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) );
195 destinations->changeItem( t, editeddestination ); 197 destinations->changeItem( t, editeddestination );
196 activeDestination->changeItem( t, editeddestination ); 198 activeDestination->changeItem( t, editeddestination );
197 activeLinkDestination->changeItem( t, editeddestination ); 199 activeLinkDestination->changeItem( t, editeddestination );
198 connect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) ); 200 connect( destinations, SIGNAL(highlighted(int)), this, SLOT(editDestination(int)) );
199 changed = true; 201 changed = true;
200} 202}
201 203
202void PackageManagerSettings::serverUrlChanged(const QString& t) 204void PackageManagerSettings::serverUrlChanged(const QString& t)
203{ 205{
204 serverurlDic.replace(editedserver, new QString(t)); 206 serverurlDic.replace(editedserver, new QString(t));
205 changed = true; 207 changed = true;
208 serverChanged = true;
206} 209}
207 210
208void PackageManagerSettings::destUrlChanged(const QString& t) 211void PackageManagerSettings::destUrlChanged(const QString& t)
209{ 212{
210 destinationurlDic.replace(editeddestination, new QString(t)); 213 destinationurlDic.replace(editeddestination, new QString(t));
211 changed = true; 214 changed = true;
212} 215}
213 216
214void PackageManagerSettings::writeIpkgConfig(const QString& conffile) 217void PackageManagerSettings::writeIpkgConfig(const QString& conffile)
215{ 218{
216 QFile conf(conffile); 219 QFile conf(conffile);
217 if ( ! conf.open(IO_WriteOnly) ) return; 220 if ( ! conf.open(IO_WriteOnly) ) return;
218 QTextStream s(&conf); 221 QTextStream s(&conf);
219 s << "# Written by qpie Package Manager\n"; 222 s << "# Written by qpie Package Manager\n";
220 for (int i=0; i<(int)activeServers->count(); i++) 223 for (int i=0; i<(int)activeServers->count(); i++)
221 { 224 {
222 QString url = serverurlDic[i] ? *serverurlDic[i] : QString("???"); 225 QString url = serverurlDic[i] ? *serverurlDic[i] : QString("???");
223 if ( !activeServers->isSelected(i) ) 226 if ( !activeServers->isSelected(i) )
224 s << "#"; 227 s << "#";
225 s << "src " << activeServers->text(i) << " " << url << "\n"; 228 s << "src " << activeServers->text(i) << " " << url << "\n";
226 } 229 }
227 for (int i=0; i<(int)destinations->count(); i++) 230 for (int i=0; i<(int)destinations->count(); i++)
228 { 231 {
229 QString url = destinationurlDic[i] ? *destinationurlDic[i] : QString("???"); 232 QString url = destinationurlDic[i] ? *destinationurlDic[i] : QString("???");
230 s << "dest " << destinations->text(i) << " " << url << "\n"; 233 s << "dest " << destinations->text(i) << " " << url << "\n";
231 } 234 }
232 conf.close(); 235 conf.close();
233} 236}
234 237
235 238
236void PackageManagerSettings::readInstallationSettings() 239void PackageManagerSettings::readInstallationSettings()
237{ 240{
238 Config cfg( "oipkg", Config::User ); 241 Config cfg( "oipkg", Config::User );
239 cfg.setGroup( "Settings" ); 242 cfg.setGroup( "Settings" );
240 installationSettingsCount = cfg.readNumEntry( "count", -1 ); 243 installationSettingsCount = cfg.readNumEntry( "count", -1 );
241 currentSetting = cfg.readNumEntry( "current", 0 );// o should be -1 244 currentSetting = cfg.readNumEntry( "current", 0 );// o should be -1
242 245
243 for (int i = 0; i < installationSettingsCount; i++) 246 for (int i = 0; i < installationSettingsCount; i++)
244 { 247 {
245 cfg.setGroup( "Setting_" + QString::number(i) ); 248 cfg.setGroup( "Setting_" + QString::number(i) );
246 settingName->insertItem( cfg.readEntry( "name", "???" ), i ); 249 settingName->insertItem( cfg.readEntry( "name", "???" ), i );
247 }; 250 };
248 readInstallationSetting( currentSetting ); 251 readInstallationSetting( currentSetting );
249} 252}
250 253
251 254
252 255
253/** 256/**
254 * remove from conf file 257 * remove from conf file
255 */ 258 */
256void PackageManagerSettings::removeInstallationSetting() 259void PackageManagerSettings::removeInstallationSetting()
257{ 260{
258 settingName->removeItem( settingName->currentItem() ); 261 settingName->removeItem( settingName->currentItem() );
259 Config cfg( "oipkg", Config::User ); 262 Config cfg( "oipkg", Config::User );
260 cfg.setGroup( "Setting_" + QString::number( installationSettingsCount ) ); 263 cfg.setGroup( "Setting_" + QString::number( installationSettingsCount ) );
261 cfg.clearGroup(); 264 cfg.clearGroup();
262 installationSettingsCount--; 265 installationSettingsCount--;
263 changed = true; 266 changed = true;
264 settingName->setEditable( false ); 267 settingName->setEditable( false );
265} 268}
266 269
267/** 270/**
268 * write to confgile 271 * write to confgile
269 */ 272 */
270void PackageManagerSettings::newInstallationSetting() 273void PackageManagerSettings::newInstallationSetting()
271{ 274{
272 installationSettingsCount++; 275 installationSettingsCount++;
273 settingName->insertItem( "New", installationSettingsCount ); 276 settingName->insertItem( "New", installationSettingsCount );
274 settingName->setCurrentItem( installationSettingsCount ); 277 settingName->setCurrentItem( installationSettingsCount );
275 settingName->setEditable( true ); 278 settingName->setEditable( true );
276 changed = true; 279 changed = true;
277} 280}
278 281
279void PackageManagerSettings::installationSettingChange(int cs) 282void PackageManagerSettings::installationSettingChange(int cs)
280{ 283{
281 writeCurrentInstallationSetting(); 284 writeCurrentInstallationSetting();
282 currentSetting = cs; 285 currentSetting = cs;
283 readInstallationSetting( cs ); 286 readInstallationSetting( cs );
284 changed = true; 287 changed = true;
285} 288}
286 289
287void PackageManagerSettings::writeInstallationSettings() 290void PackageManagerSettings::writeInstallationSettings()
288{ 291{
289 { 292 {
290 Config cfg( "oipkg", Config::User ); 293 Config cfg( "oipkg", Config::User );
291 cfg.setGroup( "Settings" ); 294 cfg.setGroup( "Settings" );
292 cfg.writeEntry( "count", installationSettingsCount ); 295 cfg.writeEntry( "count", installationSettingsCount );
293 cfg.writeEntry( "current", currentSetting ); 296 cfg.writeEntry( "current", currentSetting );
294 } 297 }
295 writeCurrentInstallationSetting(); 298 writeCurrentInstallationSetting();
296} 299}
297 300
298 301
299void PackageManagerSettings::readInstallationSetting(int setting) 302void PackageManagerSettings::readInstallationSetting(int setting)
300{ 303{
301 if ( setting < 0 ) return; 304 if ( setting < 0 ) return;
302 Config cfg( "oipkg", Config::User ); 305 Config cfg( "oipkg", Config::User );
303 cfg.setGroup( "Setting_" + QString::number( setting ) ); 306 cfg.setGroup( "Setting_" + QString::number( setting ) );
304 CheckBoxLink->setChecked( cfg.readBoolEntry( "link", true ) ); 307 CheckBoxLink->setChecked( cfg.readBoolEntry( "link", true ) );
305 QString dest = cfg.readEntry( "dest" ); 308 QString dest = cfg.readEntry( "dest" );
306 QString linkdest = cfg.readEntry( "linkdest" ); 309 QString linkdest = cfg.readEntry( "linkdest" );
307 pvDebug(3, "dest="+dest); 310 pvDebug(3, "dest="+dest);
308 pvDebug(3, "linkdest="+linkdest); 311 pvDebug(3, "linkdest="+linkdest);
309 for ( int i = 0; i < activeDestination->count(); i++) 312 for ( int i = 0; i < activeDestination->count(); i++)
310 { 313 {
311 if ( activeDestination->text( i ) == dest ) 314 if ( activeDestination->text( i ) == dest )
312 activeDestination->setCurrentItem( i ); 315 activeDestination->setCurrentItem( i );
313 if ( activeLinkDestination->text( i ) == linkdest ) 316 if ( activeLinkDestination->text( i ) == linkdest )
314 activeLinkDestination->setCurrentItem( i ); 317 activeLinkDestination->setCurrentItem( i );
315 } 318 }
316} 319}
317 320
318void PackageManagerSettings::writeCurrentInstallationSetting() 321void PackageManagerSettings::writeCurrentInstallationSetting()
319{ 322{
320 Config cfg( "oipkg", Config::User ); 323 Config cfg( "oipkg", Config::User );
321 cfg.setGroup( "Setting_" + QString::number(currentSetting) ); 324 cfg.setGroup( "Setting_" + QString::number(currentSetting) );
322 cfg.writeEntry( "link", CheckBoxLink->isChecked() ); 325 cfg.writeEntry( "link", CheckBoxLink->isChecked() );
323 cfg.writeEntry( "dest", getDestinationName() ); 326 cfg.writeEntry( "dest", getDestinationName() );
324 cfg.writeEntry( "linkdest" , getLinkDestinationName() ); 327 cfg.writeEntry( "linkdest" , getLinkDestinationName() );
325 QStringList sers = getActiveServers(); 328 QStringList sers = getActiveServers();
326 int srvc = 0; 329 int srvc = 0;
327 for ( QStringList::Iterator it = sers.begin(); it != sers.end(); ++it ) { 330 for ( QStringList::Iterator it = sers.begin(); it != sers.end(); ++it ) {
328 cfg.writeEntry( "server_" + QString::number(srvc++), *it ); 331 cfg.writeEntry( "server_" + QString::number(srvc++), *it );
329 } 332 }
330 cfg.writeEntry( "server_count", srvc ); 333 cfg.writeEntry( "server_count", srvc );
331} 334}
332 335
333void PackageManagerSettings::renameInstallationSetting() 336void PackageManagerSettings::renameInstallationSetting()
334{ 337{
335 settingName->setEditable( true ); 338 settingName->setEditable( true );
336 changed = true; 339 changed = true;
337} 340}
338 341
339void PackageManagerSettings::installationSettingSetName(const QString &name) 342void PackageManagerSettings::installationSettingSetName(const QString &name)
340{ 343{
341 settingName->changeItem( name, settingName->currentItem() ); 344 settingName->changeItem( name, settingName->currentItem() );
342 changed = true; 345 changed = true;
343} 346}
344 347
345 348
346bool PackageManagerSettings::readIpkgConfig(const QString& conffile) 349bool PackageManagerSettings::readIpkgConfig(const QString& conffile)
347{ 350{
348 QFile conf(conffile); 351 QFile conf(conffile);
349 changed = false; 352 changed = false;
350 if ( conf.open(IO_ReadOnly) ) { 353 if ( conf.open(IO_ReadOnly) ) {
351 QTextStream s(&conf); 354 QTextStream s(&conf);
352 servers->clear(); 355 servers->clear();
353 activeServers->clear(); 356 activeServers->clear();
354 activeDestination->clear(); 357 activeDestination->clear();
355 activeLinkDestination->clear(); 358 activeLinkDestination->clear();
356 serverurlDic.clear(); 359 serverurlDic.clear();
357 destinationurlDic.clear(); 360 destinationurlDic.clear();
358 ipkg_old=0; 361 ipkg_old=0;
359 int currentserver=0; 362 int currentserver=0;
360 while ( !s.atEnd() ) { 363 while ( !s.atEnd() ) {
361 QString l = s.readLine(); 364 QString l = s.readLine();
362 QStringList token = QStringList::split(' ', l); 365 QStringList token = QStringList::split(' ', l);
363 if ( token[0] == "src" || token[0] == "#src" ) { 366 if ( token[0] == "src" || token[0] == "#src" ) {
364 currentserver=servers->count(); 367 currentserver=servers->count();
365 serverurlDic.insert(servers->count(),new QString(token[2])); 368 serverurlDic.insert(servers->count(),new QString(token[2]));
366 int a = token[0] == "src" ? 1 : 0; 369 int a = token[0] == "src" ? 1 : 0;
367 int i = servers->count(); 370 int i = servers->count();
368 servers->insertItem(token[1]); 371 servers->insertItem(token[1]);
369 activeServers->insertItem( token[1] ); 372 activeServers->insertItem( token[1] );
370 activeServers->setSelected(i,a); 373 activeServers->setSelected(i,a);
371 } else if ( token[0] == "dest" ) { 374 } else if ( token[0] == "dest" ) {
372 currentserver=destinations->count(); 375 currentserver=destinations->count();
373 destinationurlDic.insert(destinations->count(),new QString(token[2])); 376 destinationurlDic.insert(destinations->count(),new QString(token[2]));
374 destinations->insertItem(token[1]); 377 destinations->insertItem(token[1]);
375 activeDestination->insertItem( token[1] ); 378 activeDestination->insertItem( token[1] );
376 activeLinkDestination->insertItem( token[1] ); 379 activeLinkDestination->insertItem( token[1] );
377 380
378 } else if ( token[0] == "option" ) { 381 } else if ( token[0] == "option" ) {
379 // ### somehow need to use the settings from netsetup 382 // ### somehow need to use the settings from netsetup
380 // if ( token[1] == "http_proxy" ) 383 // if ( token[1] == "http_proxy" )
381 // http->setText(token[2]); 384 // http->setText(token[2]);
382 // else if ( token[1] == "ftp_proxy" ) 385 // else if ( token[1] == "ftp_proxy" )
383 // ftp->setText(token[2]); 386 // ftp->setText(token[2]);
384 // else if ( token[1] == "proxy_username" ) 387 // else if ( token[1] == "proxy_username" )
385 // username->setText(token[2]); 388 // username->setText(token[2]);
386 // else if ( token[1] == "proxy_password" ) 389 // else if ( token[1] == "proxy_password" )
387 // password->setText(token[2]); 390 // password->setText(token[2]);
388 } else { 391 } else {
389 // Old style? 392 // Old style?
390 int eq = l.find('='); 393 int eq = l.find('=');
391 if ( eq >= 0 ) { 394 if ( eq >= 0 ) {
392 QString v = l.mid(eq+1).stripWhiteSpace(); 395 QString v = l.mid(eq+1).stripWhiteSpace();
393 if ( v[0] == '"' || v[0] == '\'' ) { 396 if ( v[0] == '"' || v[0] == '\'' ) {
394 int cl=v.find(v[0],1); 397 int cl=v.find(v[0],1);
395 if ( cl >= 0 ) 398 if ( cl >= 0 )
396 v = v.mid(1,cl-1); 399 v = v.mid(1,cl-1);
397 } 400 }
diff --git a/noncore/unsupported/oipkg/pksettings.h b/noncore/unsupported/oipkg/pksettings.h
index 1632d4a..dcc1e3a 100644
--- a/noncore/unsupported/oipkg/pksettings.h
+++ b/noncore/unsupported/oipkg/pksettings.h
@@ -1,74 +1,75 @@
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 "pmipkg.h" 5//#include "pmipkg.h"
6#include <qintdict.h> 6#include <qintdict.h>
7#include <qobject.h> 7#include <qobject.h>
8 8
9 9
10class PackageManagerSettings : public PackageManagerSettingsBase 10class PackageManagerSettings : public PackageManagerSettingsBase
11{ 11{
12 // Q_OBJECT 12 // Q_OBJECT
13public: 13public:
14 PackageManagerSettings( QWidget* , const char* , WFlags ); 14 PackageManagerSettings( QWidget* , const char* , WFlags );
15 ~PackageManagerSettings(); 15 ~PackageManagerSettings();
16 16
17 bool showDialog( int ) ; 17 bool showDialog( int ) ;
18 QString getDestinationUrl(); 18 QString getDestinationUrl();
19 QString getDestinationName(); 19 QString getDestinationName();
20 QString getLinkDestinationName(); 20 QString getLinkDestinationName();
21 bool createLinks(); 21 bool createLinks();
22 QStringList getServers(); 22 QStringList getServers();
23 QStringList getActiveServers(); 23 QStringList getActiveServers();
24 QStringList getDestinationUrls(); 24 QStringList getDestinationUrls();
25 QStringList getDestinationNames(); 25 QStringList getDestinationNames();
26 QString getDestinationUrlByName(QString); 26 QString getDestinationUrlByName(QString);
27 QComboBox* getDestCombo(); 27 QComboBox* getDestCombo();
28// void setIpkg( PmIpkg* ); 28// void setIpkg( PmIpkg* );
29 29
30public slots: 30public slots:
31 void writeInstallationSettings(); 31 void writeInstallationSettings();
32 void readInstallationSettings(); 32 void readInstallationSettings();
33 void writeCurrentInstallationSetting(); 33 void writeCurrentInstallationSetting();
34 void readInstallationSetting(int); 34 void readInstallationSetting(int);
35 void installationSettingSetName(const QString &); 35 void installationSettingSetName(const QString &);
36 void removeLinksToDest(); 36 void removeLinksToDest();
37 void createLinksToDest(); 37 void createLinksToDest();
38 void newServer(); 38 void newServer();
39 void editServer(int); 39 void editServer(int);
40 void removeDestination(); 40 void removeDestination();
41 void newDestination(); 41 void newDestination();
42 void editDestination(int); 42 void editDestination(int);
43 void linkEnabled(bool); 43 void linkEnabled(bool);
44 void removeServer(); 44 void removeServer();
45 void serverNameChanged(const QString&); 45 void serverNameChanged(const QString&);
46 void serverUrlChanged(const QString&); 46 void serverUrlChanged(const QString&);
47 void destNameChanged(const QString&); 47 void destNameChanged(const QString&);
48 void destUrlChanged(const QString&); 48 void destUrlChanged(const QString&);
49 void installationSettingChange(int); 49 void installationSettingChange(int);
50 void newInstallationSetting(); 50 void newInstallationSetting();
51 void removeInstallationSetting(); 51 void removeInstallationSetting();
52 void renameInstallationSetting(); 52 void renameInstallationSetting();
53 void activeServerChanged(); 53 void activeServerChanged();
54signals: 54signals:
55// void doCreateLinks( QString dest ); 55// void doCreateLinks( QString dest );
56// void doRemoveLinks( QString dest ); 56// void doRemoveLinks( QString dest );
57 57
58private: 58private:
59 QIntDict<QString> serverurlDic; 59 QIntDict<QString> serverurlDic;
60 QIntDict<QString> destinationurlDic; 60 QIntDict<QString> destinationurlDic;
61 int ipkg_old; 61 int ipkg_old;
62 int editedserver; 62 int editedserver;
63 int editeddestination; 63 int editeddestination;
64 int currentSetting; 64 int currentSetting;
65 int installationSettingsCount; 65 int installationSettingsCount;
66 bool changed; 66 bool changed;
67 bool serverChanged;
67 68
68 bool readIpkgConfig(const QString&); 69 bool readIpkgConfig(const QString&);
69 void writeIpkgConfig(const QString&); 70 void writeIpkgConfig(const QString&);
70 void writeSettings(); 71 void writeSettings();
71 void readSettings(); 72 void readSettings();
72}; 73};
73 74
74#endif 75#endif
diff --git a/noncore/unsupported/oipkg/pmipkg.cpp b/noncore/unsupported/oipkg/pmipkg.cpp
index be9d6da..fd8279b 100644
--- a/noncore/unsupported/oipkg/pmipkg.cpp
+++ b/noncore/unsupported/oipkg/pmipkg.cpp
@@ -1,449 +1,417 @@
1#include "pmipkg.h" 1#include "pmipkg.h"
2#include "pksettings.h" 2#include "pksettings.h"
3#include "package.h" 3#include "package.h"
4#include "packagelistitem.h" 4#include "packagelistitem.h"
5 5
6#include <qpe/process.h> 6#include <qpe/process.h>
7#include <qpe/resource.h> 7#include <qpe/resource.h>
8#include <qpe/config.h> 8#include <qpe/config.h>
9#include <qpe/stringutil.h> 9#include <qpe/stringutil.h>
10#include <qdir.h> 10#include <qdir.h>
11#include <qfile.h> 11#include <qfile.h>
12#include <qgroupbox.h> 12#include <qgroupbox.h>
13#include <qmultilineedit.h> 13#include <qmultilineedit.h>
14#include <qstring.h> 14#include <qstring.h>
15#include <qcheckbox.h> 15#include <qcheckbox.h>
16#include <qtextstream.h> 16#include <qtextstream.h>
17#include <qtextview.h> 17#include <qtextview.h>
18 18
19#include <qprogressbar.h> 19#include <qprogressbar.h>
20#include <qpushbutton.h> 20#include <qpushbutton.h>
21#include <qlayout.h> 21#include <qlayout.h>
22 22
23#include <stdlib.h> 23#include <stdlib.h>
24#include <unistd.h> 24#include <unistd.h>
25 25
26#include "mainwindow.h" 26#include "mainwindow.h"
27 27
28 28
29PmIpkg::PmIpkg( PackageManagerSettings* s, QWidget* p, const char * name, WFlags f ) 29PmIpkg::PmIpkg( PackageManagerSettings* s, QWidget* p, const char * name, WFlags f )
30 : QObject ( p ) 30 : QObject ( p )
31{ 31{
32 settings = s; 32 settings = s;
33 runwindow = new RunWindow( p, name, true, f ); 33 runwindow = new RunWindow( p, name, true, f );
34} 34}
35 35
36PmIpkg::~PmIpkg() 36PmIpkg::~PmIpkg()
37{ 37{
38} 38}
39 39
40//#define PROC 40//#define PROC
41#define SYSTEM 41#define SYSTEM
42int PmIpkg::runIpkg(const QString& args, const QString& dest ) 42int PmIpkg::runIpkg(const QString& args, const QString& dest )
43{ 43{
44 pvDebug(2,"PmIpkg::runIpkg "+args); 44 pvDebug(2,"PmIpkg::runIpkg "+args);
45 45
46#ifdef PROC 46#ifdef PROC
47 QStringList cmd = "/usr/bin/ipkg "; 47 QStringList cmd = "/usr/bin/ipkg ";
48#endif 48#endif
49#ifdef SYSTEM 49#ifdef SYSTEM
50 QString cmd = "/usr/bin/ipkg "; 50 QString cmd = "/usr/bin/ipkg ";
51#endif 51#endif
52 pvDebug( 3,"PmIpkg::runIpkg got dest="+dest); 52 pvDebug( 3,"PmIpkg::runIpkg got dest="+dest);
53 if ( dest == "" ) 53 if ( dest == "" )
54 cmd += " -dest "+settings->getDestinationName(); 54 cmd += " -dest "+settings->getDestinationName();
55 else 55 else
56 cmd += " -dest "+ dest; 56 cmd += " -dest "+ dest;
57 57
58 cmd += " -force-defaults "; 58 cmd += " -force-defaults ";
59 59
60 if (_force_depends) 60 if (installDialog->_force_depends)
61 { 61 {
62 if (_force_depends->isChecked()) 62 if (installDialog->_force_depends->isChecked())
63 cmd += " -force-depends "; 63 cmd += " -force-depends ";
64 if (_force_reinstall->isChecked()) 64 if (installDialog->_force_reinstall->isChecked())
65 cmd += " -force-reinstall "; 65 cmd += " -force-reinstall ";
66 if (_force_remove->isChecked()) 66 if (installDialog->_force_remove->isChecked())
67 cmd += " -force-removal-of-essential-packages "; 67 cmd += " -force-removal-of-essential-packages ";
68 } 68 }
69 69
70 out( "<hr><br>Starting to "+ args+"<br>\n"); 70 out( "<hr><br>Starting to "+ args+"<br>\n");
71 cmd += args; 71 cmd += args;
72 int r = 0; 72 int r = 0;
73#ifdef PROC 73#ifdef PROC
74 QString o = "start"; 74 QString o = "start";
75 Process *ipkg = new Process( cmd ); 75 Process *ipkg = new Process( cmd );
76 out( "running:<br>\n"+ipkg->arguments().join(" ")+"<br>\n" ); 76 out( "running:<br>\n"+ipkg->arguments().join(" ")+"<br>\n" );
77 QString description; 77 QString description;
78 ipkg->exec("",o); 78 ipkg->exec("",o);
79// out( o ); 79// out( o );
80#endif 80#endif
81#ifdef SYSTEM 81#ifdef SYSTEM
82 out( "running:<br>\n"+cmd+"<br>\n" ); 82 out( "running:<br>\n"+cmd+"<br>\n" );
83 QString redirect = "/tmp/oipkg.pipe"; 83 QString redirect = "/tmp/oipkg.pipe";
84 cmd += " 2>&1 | tee "+redirect+" 2>&1"; 84 cmd += " 2>&1 | tee "+redirect+" 2>&1";
85 pvDebug(2, "running >"+cmd+"<"); 85 pvDebug(2, "running >"+cmd+"<");
86 r = system(cmd.latin1()); 86 r = system(cmd.latin1());
87 QFile f( redirect ); 87 QFile f( redirect );
88 QString line; 88 QString line;
89 QString oldLine; 89 QString oldLine;
90 while ( ! f.open(IO_ReadOnly) ) {}; 90 while ( ! f.open(IO_ReadOnly) ) {};
91 QTextStream t( &f ); 91 QTextStream t( &f );
92 while ( !t.eof() ) 92 while ( !t.eof() )
93 { 93 {
94 line = t.readLine(); 94 line = t.readLine();
95 if ( line != oldLine ) 95 if ( line != oldLine )
96 { 96 {
97 out( line +"<br>" ); 97 out( line +"<br>" );
98 oldLine = line; 98 oldLine = line;
99 } 99 }
100 } 100 }
101 f.close(); 101 f.close();
102 out( "Finished!<br>"); 102 out( "Finished!<br>");
103#endif 103#endif
104 104
105 return r; 105 return r;
106} 106}
107 107
108void PmIpkg::makeLinks(Package *pack) 108void PmIpkg::makeLinks(Package *pack)
109{ 109{
110 pvDebug( 2, "PmIpkg::makeLinks "+ pack->name()); 110 pvDebug( 2, "PmIpkg::makeLinks "+ pack->name());
111 linkPackage( pack->name(), pack->dest() ); 111 linkPackage( pack->name(), pack->dest() );
112} 112}
113 113
114QStringList* PmIpkg::getList( QString packFileName, QString d ) 114QStringList* PmIpkg::getList( QString packFileName, QString d )
115{ 115{
116 QString dest = settings->getDestinationUrlByName( d ); 116 QString dest = settings->getDestinationUrlByName( d );
117 dest = dest==""?d:dest; 117 dest = dest==""?d:dest;
118 if (dest == "/" ) return 0; 118 if (dest == "/" ) return 0;
119 { 119 {
120 Config cfg( "oipkg", Config::User ); 120 Config cfg( "oipkg", Config::User );
121 cfg.setGroup( "Common" ); 121 cfg.setGroup( "Common" );
122 QString statusDir = cfg.readEntry( "statusDir", "" ); 122 QString statusDir = cfg.readEntry( "statusDir", "" );
123 } 123 }
124 packFileName = dest+"/"+statusDir+"/info/"+packFileName+".list"; 124 packFileName = dest+"/"+statusDir+"/info/"+packFileName+".list";
125 QFile f( packFileName ); 125 QFile f( packFileName );
126 if ( ! f.open(IO_ReadOnly) ) 126 if ( ! f.open(IO_ReadOnly) )
127 { 127 {
128 pvDebug(1," Panik! Could not open"); 128 pvDebug(1," Panik! Could not open");
129 out( "<b>Panik!</b> Could not open:<br>"+packFileName ); 129 out( "<b>Panik!</b> Could not open:<br>"+packFileName );
130 return (QStringList*)0; 130 return (QStringList*)0;
131 } 131 }
132 QStringList *fileList = new QStringList(); 132 QStringList *fileList = new QStringList();
133 QTextStream t( &f ); 133 QTextStream t( &f );
134 while ( !t.eof() ) 134 while ( !t.eof() )
135 { 135 {
136 *fileList += t.readLine(); 136 *fileList += t.readLine();
137 } 137 }
138 return fileList; 138 return fileList;
139} 139}
140 140
141void PmIpkg::linkPackage( QString packFileName, QString dest ) 141void PmIpkg::linkPackage( QString packFileName, QString dest )
142{ 142{
143 QStringList *fileList = getList( packFileName, dest ); 143 QStringList *fileList = getList( packFileName, dest );
144 processFileList( fileList, dest ); 144 processFileList( fileList, dest );
145 delete fileList; 145 delete fileList;
146} 146}
147 147
148void PmIpkg::processFileList( QStringList *fileList, QString d ) 148void PmIpkg::processFileList( QStringList *fileList, QString d )
149{ 149{
150 if (!fileList) return; 150 if (!fileList) return;
151 for (uint i=0; i < fileList->count(); i++) 151 for (uint i=0; i < fileList->count(); i++)
152 { 152 {
153 QString dest = settings->getDestinationUrlByName( d ); 153 QString dest = settings->getDestinationUrlByName( d );
154 dest = dest==""?d:dest; 154 dest = dest==""?d:dest;
155 processLinkDir( (*fileList)[i], dest ); 155 processLinkDir( (*fileList)[i], dest );
156 } 156 }
157} 157}
158 158
159 159
160void PmIpkg::processLinkDir( QString file, QString dest ) 160void PmIpkg::processLinkDir( QString file, QString dest )
161{ 161{
162 pvDebug( 4,"PmIpkg::processLinkDir "+file+" to "+ dest); 162 pvDebug( 4,"PmIpkg::processLinkDir "+file+" to "+ dest);
163 if (linkOpp==createLink) pvDebug( 4,"opp: createLink"); 163 if (linkOpp==createLink) pvDebug( 4,"opp: createLink");
164 if (linkOpp==removeLink) pvDebug( 4,"opp: removeLink"); 164 if (linkOpp==removeLink) pvDebug( 4,"opp: removeLink");
165 if ( dest == "???" || dest == "" ) return; 165 if ( dest == "???" || dest == "" ) return;
166 QString destFile = file; 166 QString destFile = file;
167 file = dest+"/"+file; 167 file = dest+"/"+file;
168 if (file == dest) return; 168 if (file == dest) return;
169 QFileInfo fileInfo( file ); 169 QFileInfo fileInfo( file );
170 if ( fileInfo.isDir() ) 170 if ( fileInfo.isDir() )
171 { 171 {
172 pvDebug(4, "process dir "+file); 172 pvDebug(4, "process dir "+file);
173 QDir destDir( destFile ); 173 QDir destDir( destFile );
174 if (linkOpp==createLink) destDir.mkdir( destFile, true ); 174 if (linkOpp==createLink) destDir.mkdir( destFile, true );
175 QDir d( file ); 175 QDir d( file );
176 d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks ); 176// d.setFilter( QDir::Files | QDir::Hidden | QDir::NoSymLinks );
177 const QFileInfoList *list = d.entryInfoList(); 177 const QFileInfoList *list = d.entryInfoList();
178 QFileInfoListIterator it( *list ); 178 QFileInfoListIterator it( *list );
179 QFileInfo *fi; 179 QFileInfo *fi;
180 qDebug( "while %i",list->count());
180 while ( (fi=it.current()) ) 181 while ( (fi=it.current()) )
181 { 182 {
183 pvDebug(4, "processLinkDir "+fi->absFilePath());
182 processLinkDir( fi->absFilePath(), dest ); 184 processLinkDir( fi->absFilePath(), dest );
183 ++it; 185 ++it;
184 } 186 }
185// if (linkOpp==removeLink)
186// {
187 // pvDebug(2,"remove destDir "+ destFile );
188 // destDir.remove( destFile, true );
189// }
190 } else 187 } else
191 if ( fileInfo.isFile() ) 188 if ( fileInfo.isFile() )
192 { 189 {
193 const char *instFile = strdup( (file).ascii() ); 190 const char *instFile = strdup( (file).ascii() );
194 const char *linkFile = strdup( (destFile).ascii()); 191 const char *linkFile = strdup( (destFile).ascii());
195 if( linkOpp==createLink ) 192 if( linkOpp==createLink )
196 { 193 {
197 pvDebug(4, "linking: "+file+" -> "+destFile ); 194 pvDebug(4, "linking: "+file+" -> "+destFile );
198 symlink( instFile, linkFile ); 195 symlink( instFile, linkFile );
199 } 196 }
200 } else { 197 } else {
201 const char *linkFile = strdup( (destFile).ascii()); 198 const char *linkFile = strdup( (destFile).ascii());
202 if( linkOpp==removeLink ) 199 if( linkOpp==removeLink )
203 { 200 {
204 pvDebug(4,"removing "+destFile+" no "+file);
205 QFileInfo toRemoveLink( destFile ); 201 QFileInfo toRemoveLink( destFile );
206 if ( !QFile::exists( file ) && toRemoveLink.isSymLink() ) 202 if ( !QFile::exists( file ) && toRemoveLink.isSymLink() )
203 {
204 pvDebug(4,"removing "+destFile+" no "+file);
207 unlink( linkFile ); 205 unlink( linkFile );
206 }
208 } 207 }
209 } 208 }
210} 209}
211 210
212void PmIpkg::loadList( PackageList pl ) 211void PmIpkg::loadList( PackageList pl )
213 { 212 {
214 for( Package *pack = pl.first();pack ; (pack = pl.next()) ) 213 for( Package *pack = pl.first();pack ; (pack = pl.next()) )
215 { 214 {
216 if ( pack && (pack->name() != "") && pack) 215 if ( pack && (pack->name() != "") && pack)
217 { 216 {
218 if ( pack->toInstall() ) 217 if ( pack->toInstall() )
219 to_install.append( pack ); 218 to_install.append( pack );
220 if ( pack->toRemove() ) 219 if ( pack->toRemove() )
221 to_remove.append( pack ); 220 to_remove.append( pack );
222 } 221 }
223 } 222 }
224} 223}
225 224
226void PmIpkg::commit( PackageList pl ) 225void PmIpkg::commit()
227 { 226 {
228 int sizecount = 0; 227 int sizecount = 0;
229// QString rem="<b>"+tr("To remove:")+"</b><br>\n";
230// QString inst="<b>"+tr("To install:")+"</b><br>\n";
231 loadList(pl);
232 for (uint i=0; i < to_remove.count(); i++) 228 for (uint i=0; i < to_remove.count(); i++)
233 sizecount += 1; 229 sizecount += 1;
234 for (uint i=0; i < to_install.count(); i++) 230 for (uint i=0; i < to_install.count(); i++)
235 sizecount += to_install.at(i)->size().toInt(); 231 sizecount += to_install.at(i)->size().toInt();
236 runwindow->progress->setTotalSteps(sizecount); 232 runwindow->progress->setTotalSteps(sizecount);
237 startDialog(); 233 startDialog();
238} 234}
239 235
240void PmIpkg::startDialog() 236void PmIpkg::startDialog()
241{ 237{
242 installDialog = new QDialog(0,0,true); 238 installDialog = new InstallDialog(settings,0,0,true);
243 QGridLayout *RunWindowLayout = new QGridLayout( installDialog ); 239 QCheckListItem *toRemoveItem;
244 RunWindowLayout->setSpacing( 2 ); 240 toRemoveItem= new QCheckListItem( installDialog->ListViewPackages, QObject::tr("To remove") );
245 RunWindowLayout->setMargin( 2 ); 241 toRemoveItem->setOpen( true );
246 242 for (Package *it=to_remove.first(); it != 0; it=to_remove.next() )
247 PackageListView *plv = new PackageListView(installDialog, "install",settings); 243 {
248 plv->setSizePolicy(QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Expanding, plv->sizePolicy().mayShrinkVertically()) ); 244 toRemoveItem->insertItem( new PackageListItem(installDialog->ListViewPackages, it,settings) );
249 RunWindowLayout->addWidget( plv, 1, 0 ); 245 }
250 QCheckListItem *toRemoveItem; 246 QCheckListItem *toInstallItem;
251 toRemoveItem= new QCheckListItem( plv, QObject::tr("To remove") ); 247 toInstallItem = new QCheckListItem( installDialog->ListViewPackages, QObject::tr("To install") );
252 toRemoveItem->setOpen( true ); 248 toInstallItem->setOpen( true );
253 for (Package *it=to_remove.first(); it != 0; it=to_remove.next() ) 249 for (Package *it=to_install.first(); it != 0; it=to_install.next() )
254 { 250 {
255 toRemoveItem->insertItem( new PackageListItem(plv, it,settings) ); 251 toInstallItem->insertItem( new PackageListItem(installDialog->ListViewPackages, it,settings) );
256 } 252 }
257 QCheckListItem *toInstallItem;
258 toInstallItem = new QCheckListItem( plv, QObject::tr("To install") );
259 toInstallItem->setOpen( true );
260 for (Package *it=to_install.first(); it != 0; it=to_install.next() )
261 {
262 toInstallItem->insertItem( new PackageListItem(plv, it,settings) );
263 }
264
265 QGroupBox *GroupBox1 = new QGroupBox( installDialog, "Ipkg" );
266 GroupBox1->setSizePolicy( QSizePolicy( (QSizePolicy::SizeType)3, (QSizePolicy::SizeType)3, GroupBox1->sizePolicy().mayShrinkVertically() ) );
267 GroupBox1->setTitle( tr( "Ipkg options" ) );
268 GroupBox1->setColumnLayout(0, Qt::Vertical );
269 GroupBox1->layout()->setSpacing( 0 );
270 GroupBox1->layout()->setMargin( 0 );
271 QGridLayout *GroupBox1Layout = new QGridLayout( GroupBox1->layout() );
272 GroupBox1Layout->setAlignment( Qt::AlignTop );
273 GroupBox1Layout->setSpacing( 3 );
274 GroupBox1Layout->setMargin( 3 );
275 _force_depends = new QCheckBox( GroupBox1, "_force_depends" );
276 _force_depends->setText( tr( "-force-depends" ) );
277 _force_depends->setAutoResize( TRUE );
278 _force_depends->setChecked(true);
279 GroupBox1Layout->addWidget( _force_depends, 0, 0 );
280 _force_reinstall = new QCheckBox( GroupBox1, "_force_reinstall" );
281 _force_reinstall->setText( tr( "-force-reinstall" ) );
282 _force_reinstall->setAutoResize( TRUE );
283 GroupBox1Layout->addWidget( _force_reinstall, 1, 0 );
284 _force_remove = new QCheckBox( GroupBox1, "_force_remove" );
285 _force_remove->setText( tr( "-force-removal-of-essential-packages" ) );
286 _force_remove->setAutoResize( TRUE );
287 GroupBox1Layout->addWidget( _force_remove, 1, 0 );
288 RunWindowLayout->addWidget( GroupBox1 , 3, 0 );
289 installDialog->showMaximized(); 253 installDialog->showMaximized();
290 if ( installDialog->exec() ) doIt(); 254 if ( installDialog->exec() ) doIt();
291 installDialog->close(); 255 installDialog->close();
292 out(tr("<b>All done.</b>")); 256 out(tr("<b>All done.</b>"));
257 to_install.clear();
293} 258}
294 259
295void PmIpkg::doIt() 260void PmIpkg::doIt()
296{ 261{
297 show( true ); 262 show( true );
298 remove(); 263 remove();
299 install(); 264 install();
300} 265}
301 266
302 267
303void PmIpkg::remove() 268void PmIpkg::remove()
304{ 269{
305 if ( to_remove.count() == 0 ) return; 270 if ( to_remove.count() == 0 ) return;
306 271
307 out("<b>"+tr("Removing")+"<br>"+tr("please wait")+"</b><br><hr>"); 272 out("<b>"+tr("Removing")+"<br>"+tr("please wait")+"</b><br><hr>");
308 273
309 QStringList *fileList; 274 QStringList *fileList;
310 for (Package *it=to_remove.first(); it != 0; it=to_remove.next() ) 275 for (Package *it=to_remove.first(); it != 0; it=to_remove.next() )
311 { 276 {
312 if ( it->link() )fileList = getList( it->name(), it->dest() ); 277 if ( it->link() )fileList = getList( it->name(), it->dest() );
313 if ( runIpkg("remove " + it->name(), it->dest() ) == 0) 278 if ( runIpkg("remove " + it->name(), it->dest() ) == 0)
314 { 279 {
315 runwindow->progress->setProgress( 1 + runwindow->progress->progress() ); 280 runwindow->progress->setProgress( 1 + runwindow->progress->progress() );
316 linkOpp = removeLink; 281 linkOpp = removeLink;
317 if ( it->link() ) 282 if ( it->link() )
318 { 283 {
319 out( "<br>removing links<br>" ); 284 out( "<br>removing links<br>" );
320 out( "for package "+it->name()+" in "+it->dest()+"<br>" ); 285 out( "for package "+it->name()+" in "+it->dest()+"<br>" );
321 processFileList( fileList, it->dest() ); 286 processFileList( fileList, it->dest() );
322 } 287 }
323 it->processed(); 288 it->processed();
324 // to_install.take( it ); 289 // to_install.take( it );
325 out("<br><hr>"); 290 out("<br><hr>");
326 }else{ 291 }else{
327 out("<b>"+tr("Error while removing")+"</b><hr>"+it->name()); 292 out("<b>"+tr("Error while removing")+"</b><hr>"+it->name());
328 } 293 }
329 if ( it->link() )delete fileList; 294 if ( it->link() )delete fileList;
330 } 295 }
331 out("<br>"); 296 out("<br>");
332} 297}
333 298
334 299
335void PmIpkg::install() 300void PmIpkg::install()
336{ 301{
337 if ( to_install.count() == 0 ) return; 302 if ( to_install.count() == 0 ) return;
338 out("<b>"+tr("Installing")+"<br>"+tr("please wait")+"</b><br>"); 303 out("<b>"+tr("Installing")+"<br>"+tr("please wait")+"</b><br>");
339 for (Package *it=to_install.first(); it != 0; it=to_install.next() ) 304 for (Package *it=to_install.first(); it != 0; it=to_install.next() )
340 { 305 {
341 306
342 if ( runIpkg("install " + it->installName(), it->dest() ) == 0 ) 307 if ( runIpkg("install " + it->installName(), it->dest() ) == 0 )
343 { 308 {
344 runwindow->progress->setProgress( it->size().toInt() + runwindow->progress->progress()); 309 runwindow->progress->setProgress( it->size().toInt() + runwindow->progress->progress());
345 linkOpp = createLink; 310 linkOpp = createLink;
346 if ( it->link() ) 311 if ( it->link() )
347 { 312 {
348 out( "<br>creating links<br>" ); 313 out( "<br>creating links<br>" );
349 out( "for package "+it->name()+" in "+it->dest()+"<br>" ); 314 out( "for package "+it->name()+" in "+it->dest()+"<br>" );
350 makeLinks( it ); 315 makeLinks( it );
351 } 316 }
352 it->processed(); 317 it->processed();
353 // to_install.take( it->name() ); 318 // to_install.take( it->name() );
354 out("<br><hr>"); 319 out("<br><hr>");
355 }else{ 320 }else{
356 out("<b>"+tr("Error while installing")+"</b><hr>"+it->name()); 321 out("<b>"+tr("Error while installing")+"</b><hr>"+it->name());
357 } 322 }
358 } 323 }
359 out("<br>"); 324 out("<br>");
325 to_install.clear();
360} 326}
361 327
362void PmIpkg::createLinks( const QString &dest ) 328void PmIpkg::createLinks( const QString &dest )
363{ 329{
364 pvDebug(2,"PmIpkg::createLinks "+dest); 330 pvDebug(2,"PmIpkg::createLinks "+dest);
365 linkOpp=createLink; 331 linkOpp=createLink;
366 QString url = settings->getDestinationUrlByName( dest ); 332 QString url = settings->getDestinationUrlByName( dest );
367 url = url==""?dest:url; 333 url = url==""?dest:url;
368 processLinkDir( "/", url ); 334 processLinkDir( "/opt", url );
335 processLinkDir( "/usr", url );
369} 336}
370 337
371void PmIpkg::removeLinks( const QString &dest ) 338void PmIpkg::removeLinks( const QString &dest )
372{ 339{
373 pvDebug(2,"PmIpkg::removeLinks "+dest); 340 pvDebug(2,"PmIpkg::removeLinks "+dest);
374 linkOpp=removeLink; 341 linkOpp=removeLink;
375 QString url = settings->getDestinationUrlByName( dest ); 342 QString url = settings->getDestinationUrlByName( dest );
376 url = url==""?dest:url; 343 url = url==""?dest:url;
377 processLinkDir( "/", url ); 344 processLinkDir( "/opt", url );
345 processLinkDir( "/usr", url );
378} 346}
379 347
380void PmIpkg::update() 348void PmIpkg::update()
381{ 349{
382 show( false ); 350 show( false );
383 runIpkg( "update" ); 351 runIpkg( "update" );
384 runwindow->close(); 352 runwindow->close();
385} 353}
386 354
387void PmIpkg::out( QString o ) 355void PmIpkg::out( QString o )
388{ 356{
389 runwindow->outPut->append(o); 357 runwindow->outPut->append(o);
390 //runwindow->outPut->setCursorPosition(0, runwindow->outPut->contentsHeight()); 358 //runwindow->outPut->setCursorPosition(0, runwindow->outPut->contentsHeight());
391 //runwindow->outPut->setText( runwindow->outPut->text()+o ); 359 //runwindow->outPut->setText( runwindow->outPut->text()+o );
392 runwindow->outPut->setContentsPos(0, runwindow->outPut->contentsHeight()); 360 runwindow->outPut->setContentsPos(0, runwindow->outPut->contentsHeight());
393} 361}
394 362
395 363
396void PmIpkg::showButtons(bool b) 364void PmIpkg::showButtons(bool b)
397{ 365{
398 if ( b ) 366 if ( b )
399 { 367 {
400 runwindow->cancelButton->hide(); 368 runwindow->cancelButton->hide();
401 runwindow->doItButton->hide(); 369 runwindow->doItButton->hide();
402 runwindow->removeButton->hide(); 370 runwindow->removeButton->hide();
403 runwindow->installButton->hide(); 371 runwindow->installButton->hide();
404 }else{ 372 }else{
405 runwindow->cancelButton->show(); 373 runwindow->cancelButton->show();
406 runwindow->doItButton->show(); 374 runwindow->doItButton->show();
407 runwindow->removeButton->show(); 375 runwindow->removeButton->show();
408 runwindow->installButton->show(); 376 runwindow->installButton->show();
409 377
410 } 378 }
411} 379}
412 380
413void PmIpkg::show(bool b) 381void PmIpkg::show(bool b)
414{ 382{
415 if (!runwindow->isVisible()) 383 if (!runwindow->isVisible())
416 runwindow->showMaximized(); 384 runwindow->showMaximized();
417 showButtons(b); 385 showButtons(b);
418 if ( !b ) 386 if ( !b )
419 runwindow->progress->hide(); 387 runwindow->progress->hide();
420 else 388 else
421 runwindow->progress->show(); 389 runwindow->progress->show();
422} 390}
423 391
424void PmIpkg::installFile(const QString &fileName, const QString &dest) 392void PmIpkg::installFile(const QString &fileName, const QString &dest)
425{ 393{
426 394
427 to_install.clear(); 395 to_install.clear();
428 to_remove.clear(); 396 to_remove.clear();
429 pvDebug( 2,"PmIpkg::installFile "+ fileName); 397 pvDebug( 2,"PmIpkg::installFile "+ fileName);
430 Package *p = new Package(fileName,settings); 398 Package *p = new Package(fileName,settings);
431 if ( dest!="") p->setDest( dest ); 399 if ( dest!="") p->setDest( dest );
432 to_install.append( p ); 400 to_install.append( p );
433 startDialog(); 401 startDialog();
434 delete p; 402 delete p;
435} 403}
436 404
437void PmIpkg::removeFile(const QString &fileName, const QString &dest) 405void PmIpkg::removeFile(const QString &fileName, const QString &dest)
438{ 406{
439 407
440 to_install.clear(); 408 to_install.clear();
441 to_remove.clear(); 409 to_remove.clear();
442 pvDebug( 2,"PmIpkg::removeFile "+ fileName); 410 pvDebug( 2,"PmIpkg::removeFile "+ fileName);
443 Package *p = new Package(fileName,settings); 411 Package *p = new Package(fileName,settings);
444 if ( dest!="") p->setDest( dest ); 412 if ( dest!="") p->setDest( dest );
445 to_remove.append( p ); 413 to_remove.append( p );
446 startDialog(); 414 startDialog();
447 delete p; 415 delete p;
448} 416}
449 417
diff --git a/noncore/unsupported/oipkg/pmipkg.h b/noncore/unsupported/oipkg/pmipkg.h
index 3799969..d2490e8 100644
--- a/noncore/unsupported/oipkg/pmipkg.h
+++ b/noncore/unsupported/oipkg/pmipkg.h
@@ -1,65 +1,64 @@
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 "installdialog.h"
12#include "debug.h" 13#include "debug.h"
13 14
14#define createLink 0 15#define createLink 0
15#define removeLink 1 16#define removeLink 1
16 17
17class Package; 18class Package;
18class PmIpkg : public QObject 19class PmIpkg : public QObject
19{ 20{
20 Q_OBJECT 21 Q_OBJECT
21public: 22public:
22 PmIpkg( PackageManagerSettings* , QWidget* p=0, const char * name=0, WFlags f=0 ); 23 PmIpkg( PackageManagerSettings* , QWidget* p=0, const char * name=0, WFlags f=0 );
23 ~PmIpkg(); 24 ~PmIpkg();
24 25
25 int linkOpp; 26 int linkOpp;
26 void loadList( PackageList ); 27 void loadList( PackageList );
27 void commit( PackageList ); 28 void commit();
28 void update(); 29 void update();
29 void showButtons(bool b=true); 30 void showButtons(bool b=true);
30 void show( bool buttons=true ); 31 void show( bool buttons=true );
31 32
32public slots: 33public slots:
33 void doIt(); 34 void doIt();
34 void install(); 35 void install();
35 void remove(); 36 void remove();
36 void installFile(const QString &fileName, const QString &dest=""); 37 void installFile(const QString &fileName, const QString &dest="");
37 void removeFile(const QString &fileName, const QString &dest=""); 38 void removeFile(const QString &fileName, const QString &dest="");
38 void createLinks( const QString &dest ); 39 void createLinks( const QString &dest );
39 void removeLinks( const QString &dest ); 40 void removeLinks( const QString &dest );
40 41
41private: 42private:
42 //int sizecount;
43 PackageManagerSettings* settings; 43 PackageManagerSettings* settings;
44 RunWindow *runwindow; 44 RunWindow *runwindow;
45 QDialog *installDialog; 45 InstallDialog *installDialog;
46 QList<Package> to_remove; 46 QList<Package> to_remove;
47 QList<Package> to_install; 47 QList<Package> to_install;
48// bool runwindowopen;
49 QString fileNameToInstall; 48 QString fileNameToInstall;
50 QCheckBox *_force_reinstall; 49 QCheckBox *_force_reinstall;
51 QCheckBox *_force_remove; 50 QCheckBox *_force_remove;
52 QCheckBox *_force_depends; 51 QCheckBox *_force_depends;
53 void startDialog(); 52 void startDialog();
54 void makeLinks(Package*); 53 void makeLinks(Package*);
55 void linkPackage( QString, QString ); 54 void linkPackage( QString, QString );
56 void processLinkDir( QString , QString ); 55 void processLinkDir( QString , QString );
57 int runIpkg(const QString& args, const QString& dest="" ); 56 int runIpkg(const QString& args, const QString& dest="" );
58 void out( QString ); 57 void out( QString );
59 QStringList* getList( QString, QString ); 58 QStringList* getList( QString, QString );
60 void processFileList( QStringList*, QString ); 59 void processFileList( QStringList*, QString );
61 60
62 61
63}; 62};
64 63
65#endif 64#endif
diff --git a/noncore/unsupported/oipkg/settings.h b/noncore/unsupported/oipkg/settings.h
index bab7a4f..f01cb69 100644
--- a/noncore/unsupported/oipkg/settings.h
+++ b/noncore/unsupported/oipkg/settings.h
@@ -1,66 +1,67 @@
1#ifndef PACKAGEMANAGERSETTINGS_H 1#ifndef PACKAGEMANAGERSETTINGS_H
2#define PACKAGEMANAGERSETTINGS_H 2#define PACKAGEMANAGERSETTINGS_H
3 3
4#include "pksettingsbase.h" 4#include "pksettingsbase.h"
5#include <qintdict.h> 5#include <qintdict.h>
6 6
7 7
8class PackageManagerSettings : public PackageManagerSettingsBase 8class PackageManagerSettings : public PackageManagerSettingsBase
9//class PackageManagerSettings : private PackageManagerSettingsBase 9//class PackageManagerSettings : private PackageManagerSettingsBase
10{ 10{
11 // Q_OBJECT 11 // Q_OBJECT
12public: 12public:
13 PackageManagerSettings( QWidget* , const char* , WFlags ); 13 PackageManagerSettings( QWidget* , const char* , WFlags );
14 ~PackageManagerSettings(); 14 ~PackageManagerSettings();
15 15
16 bool showDialog( int ) ; 16 bool showDialog( int ) ;
17 QString getDestinationUrl(); 17 QString getDestinationUrl();
18 QString getDestinationName(); 18 QString getDestinationName();
19 QString getLinkDestinationName(); 19 QString getLinkDestinationName();
20 bool createLinks(); 20 bool createLinks();
21 QStringList getActiveServers(); 21 QStringList getActiveServers();
22 QStringList getDestinationUrls(); 22 QStringList getDestinationUrls();
23 23
24public slots: /** No descriptions */ 24public slots: /** No descriptions */
25 void createLinks(); 25 void createLinks();
26 void removeLinks(); 26 void removeLinks();
27 void writeInstallationSettings(); 27 void writeInstallationSettings();
28 void readInstallationSettings(); 28 void readInstallationSettings();
29 void writeCurrentInstallationSetting(); 29 void writeCurrentInstallationSetting();
30 void readInstallationSetting(int); 30 void readInstallationSetting(int);
31 void installationSettingSetName(const QString &); 31 void installationSettingSetName(const QString &);
32 void activeDestinationChange(int) 32 void activeDestinationChange(int)
33 void newServer(); 33 void newServer();
34 void editServer(int); 34 void editServer(int);
35 void removeDestination(); 35 void removeDestination();
36 void newDestination(); 36 void newDestination();
37 void editDestination(int); 37 void editDestination(int);
38 void linkEnabled(bool); 38 void linkEnabled(bool);
39 void removeServer(); 39 void removeServer();
40 void serverNameChanged(const QString&); 40 void serverNameChanged(const QString&);
41 void serverUrlChanged(const QString&); 41 void serverUrlChanged(const QString&);
42 void destNameChanged(const QString&); 42 void destNameChanged(const QString&);
43 void destUrlChanged(const QString&); 43 void destUrlChanged(const QString&);
44 void installationSettingChange(int); 44 void installationSettingChange(int);
45 void newInstallationSetting(); 45 void newInstallationSetting();
46 void removeInstallationSetting(); 46 void removeInstallationSetting();
47 void renameInstallationSetting(); 47 void renameInstallationSetting();
48 48
49private: 49private:
50 QIntDict<QString> serverurlDic; 50 QIntDict<QString> serverurlDic;
51 QIntDict<QString> destinationurlDic; 51 QIntDict<QString> destinationurlDic;
52 int ipkg_old; 52 int ipkg_old;
53 int editedserver; 53 int editedserver;
54 int editeddestination; 54 int editeddestination;
55 int currentSetting; 55 int currentSetting;
56 int installationSettingsCount; 56 int installationSettingsCount;
57 bool changed; 57 bool changed;
58 bool serverChanged;
58 59
59 bool readIpkgConfig(const QString&); 60 bool readIpkgConfig(const QString&);
60 void writeIpkgConfig(const QString&); 61 void writeIpkgConfig(const QString&);
61 void writeSettings(); 62 void writeSettings();
62 void readSettings(); 63 void readSettings();
63}; 64};
64 65
65#endif 66#endif
66 67