summaryrefslogtreecommitdiff
authorbenmeyer <benmeyer>2002-10-24 20:20:12 (UTC)
committer benmeyer <benmeyer>2002-10-24 20:20:12 (UTC)
commit57c34f2f0b35ab13e7618ba77480c9b28b83885a (patch) (unidiff)
tree406fc6016ccea8d9d77a3b251361d11828e7afbc
parent013b5a78262099a55de8e7228436f2c00660e6b1 (diff)
downloadopie-57c34f2f0b35ab13e7618ba77480c9b28b83885a.zip
opie-57c34f2f0b35ab13e7618ba77480c9b28b83885a.tar.gz
opie-57c34f2f0b35ab13e7618ba77480c9b28b83885a.tar.bz2
Fix segfault
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/networksetup/interfacesetupimp.cpp2
-rw-r--r--noncore/net/networksetup/interfacesetupimp.h2
-rw-r--r--noncore/net/networksetup/mainwindowimp.cpp13
-rw-r--r--noncore/net/networksetup/networksetup.pro6
-rw-r--r--noncore/net/networksetup/wlan/wlan.pro6
-rw-r--r--noncore/net/networksetup/wlan/wlanimp.cpp9
-rw-r--r--noncore/net/networksetup/wlan/wlanimp.h3
-rw-r--r--noncore/net/networksetup/wlan/wlanmodule.cpp7
-rw-r--r--noncore/settings/networksettings/interfacesetupimp.cpp2
-rw-r--r--noncore/settings/networksettings/interfacesetupimp.h2
-rw-r--r--noncore/settings/networksettings/mainwindowimp.cpp13
-rw-r--r--noncore/settings/networksettings/networksetup.pro6
-rw-r--r--noncore/settings/networksettings/wlan/wlan.pro6
-rw-r--r--noncore/settings/networksettings/wlan/wlanimp.cpp9
-rw-r--r--noncore/settings/networksettings/wlan/wlanimp.h3
-rw-r--r--noncore/settings/networksettings/wlan/wlanmodule.cpp7
16 files changed, 38 insertions, 58 deletions
diff --git a/noncore/net/networksetup/interfacesetupimp.cpp b/noncore/net/networksetup/interfacesetupimp.cpp
index 1327726..a8731a9 100644
--- a/noncore/net/networksetup/interfacesetupimp.cpp
+++ b/noncore/net/networksetup/interfacesetupimp.cpp
@@ -1,147 +1,147 @@
1#include "interfacesetupimp.h" 1#include "interfacesetupimp.h"
2#include "interface.h" 2#include "interface.h"
3#include "interfaces.h" 3#include "interfaces.h"
4 4
5#include <qcombobox.h> 5#include <qcombobox.h>
6#include <qcheckbox.h> 6#include <qcheckbox.h>
7#include <qlineedit.h> 7#include <qlineedit.h>
8#include <qspinbox.h> 8#include <qspinbox.h>
9#include <qgroupbox.h> 9#include <qgroupbox.h>
10#include <qlabel.h> 10#include <qlabel.h>
11 11
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13 13
14#include <assert.h> 14#include <assert.h>
15 15
16#define DNSSCRIPT "interfacednsscript" 16#define DNSSCRIPT "interfacednsscript"
17 17
18/** 18/**
19 * Constuctor. Set up the connection and load the first profile. 19 * Constuctor. Set up the connection and load the first profile.
20 */ 20 */
21InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl) : InterfaceSetup(parent, name, modal, fl){ 21InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl) : InterfaceSetup(parent, name, modal, fl){
22 assert(i); 22 assert(i);
23 interface = i; 23 interface = i;
24 interfaces = new Interfaces(); 24 interfaces = new Interfaces();
25 bool error = false; 25 bool error = false;
26 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){ 26 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){
27 staticGroupBox->hide(); 27 staticGroupBox->hide();
28 dhcpCheckBox->hide(); 28 dhcpCheckBox->hide();
29 leaseTime->hide(); 29 leaseTime->hide();
30 leaseHoursLabel->hide(); 30 leaseHoursLabel->hide();
31 } 31 }
32} 32}
33 33
34/** 34/**
35 * Save the current settings, then write out the interfaces file and close. 35 * Save the current settings, then write out the interfaces file and close.
36 */ 36 */
37void InterfaceSetupImp::accept(){ 37void InterfaceSetupImp::accept(){
38 if(!saveSettings()) 38 if(!saveSettings())
39 return; 39 return;
40 interfaces->write(); 40 interfaces->write();
41 close(true); 41 QDialog::accept();
42} 42}
43 43
44/** 44/**
45 * Save the settings for the current Interface. 45 * Save the settings for the current Interface.
46 * @return bool true if successfull, false otherwise 46 * @return bool true if successfull, false otherwise
47 */ 47 */
48bool InterfaceSetupImp::saveSettings(){ 48bool InterfaceSetupImp::saveSettings(){
49 // eh can't really do anything about it other then return. :-D 49 // eh can't really do anything about it other then return. :-D
50 if(!interfaces->isInterfaceSet()) 50 if(!interfaces->isInterfaceSet())
51 return true; 51 return true;
52 52
53 bool error = false; 53 bool error = false;
54 // Loopback case 54 // Loopback case
55 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){ 55 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){
56 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked()); 56 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked());
57 return true; 57 return true;
58 } 58 }
59 59
60 if(!dhcpCheckBox->isChecked() && (ipAddressEdit->text().isEmpty() || subnetMaskEdit->text().isEmpty() || firstDNSLineEdit->text().isEmpty())){ 60 if(!dhcpCheckBox->isChecked() && (ipAddressEdit->text().isEmpty() || subnetMaskEdit->text().isEmpty() || firstDNSLineEdit->text().isEmpty())){
61 QMessageBox::information(this, "Empy Fields.", "Please fill in address, subnet,\n gateway and the first dns entries.", "Ok"); 61 QMessageBox::information(this, "Empy Fields.", "Please fill in address, subnet,\n gateway and the first dns entries.", "Ok");
62 return false; 62 return false;
63 } 63 }
64 interfaces->removeAllInterfaceOptions(); 64 interfaces->removeAllInterfaceOptions();
65 65
66 // DHCP 66 // DHCP
67 if(dhcpCheckBox->isChecked()){ 67 if(dhcpCheckBox->isChecked()){
68 interfaces->setInterfaceMethod(INTERFACES_METHOD_DHCP); 68 interfaces->setInterfaceMethod(INTERFACES_METHOD_DHCP);
69 interfaces->setInterfaceOption("leasehours", QString("%1").arg(leaseTime->value())); 69 interfaces->setInterfaceOption("leasehours", QString("%1").arg(leaseTime->value()));
70 interfaces->setInterfaceOption("leasetime", QString("%1").arg(leaseTime->value()*60*60)); 70 interfaces->setInterfaceOption("leasetime", QString("%1").arg(leaseTime->value()*60*60));
71 } 71 }
72 else{ 72 else{
73 interfaces->setInterfaceMethod("static"); 73 interfaces->setInterfaceMethod("static");
74 interfaces->setInterfaceOption("address", ipAddressEdit->text()); 74 interfaces->setInterfaceOption("address", ipAddressEdit->text());
75 interfaces->setInterfaceOption("netmask", subnetMaskEdit->text()); 75 interfaces->setInterfaceOption("netmask", subnetMaskEdit->text());
76 interfaces->setInterfaceOption("gateway", gatewayEdit->text()); 76 interfaces->setInterfaceOption("gateway", gatewayEdit->text());
77 QString dns = firstDNSLineEdit->text() + " " + secondDNSLineEdit->text(); 77 QString dns = firstDNSLineEdit->text() + " " + secondDNSLineEdit->text();
78 interfaces->setInterfaceOption("up "DNSSCRIPT" add ", dns); 78 interfaces->setInterfaceOption("up "DNSSCRIPT" add ", dns);
79 interfaces->setInterfaceOption("down "DNSSCRIPT" remove ", dns); 79 interfaces->setInterfaceOption("down "DNSSCRIPT" remove ", dns);
80 } 80 }
81 81
82 // IP Information 82 // IP Information
83 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked()); 83 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked());
84 return true; 84 return true;
85} 85}
86 86
87/** 87/**
88 * The Profile has changed. 88 * The Profile has changed.
89 * @profile the new profile. 89 * @profile the new profile.
90 */ 90 */
91void InterfaceSetupImp::setProfile(const QString &profile){ 91void InterfaceSetupImp::setProfile(const QString &profile){
92 QString newInterfaceName = interface->getInterfaceName(); 92 QString newInterfaceName = interface->getInterfaceName();
93 if(profile.length() > 0) 93 if(profile.length() > 0)
94 newInterfaceName += "_" + profile; 94 newInterfaceName += "_" + profile;
95 // See if we have to make a interface. 95 // See if we have to make a interface.
96 if(!interfaces->setInterface(newInterfaceName)){ 96 if(!interfaces->setInterface(newInterfaceName)){
97 // Add making for this new interface if need too 97 // Add making for this new interface if need too
98 if(profile != ""){ 98 if(profile != ""){
99 interfaces->copyInterface(interface->getInterfaceName(), newInterfaceName); 99 interfaces->copyInterface(interface->getInterfaceName(), newInterfaceName);
100 if(!interfaces->setMapping(interface->getInterfaceName())){ 100 if(!interfaces->setMapping(interface->getInterfaceName())){
101 interfaces->addMapping(interface->getInterfaceName()); 101 interfaces->addMapping(interface->getInterfaceName());
102 if(!interfaces->setMapping(interface->getInterfaceName())){ 102 if(!interfaces->setMapping(interface->getInterfaceName())){
103 qDebug("InterfaceSetupImp: Added Mapping, but still can't set."); 103 qDebug("InterfaceSetupImp: Added Mapping, but still can't set.");
104 return; 104 return;
105 } 105 }
106 } 106 }
107 interfaces->setMap("map", newInterfaceName); 107 interfaces->setMap("map", newInterfaceName);
108 interfaces->setScript("getprofile.sh"); 108 interfaces->setScript("getprofile.sh");
109 } 109 }
110 else{ 110 else{
111 interfaces->addInterface(newInterfaceName, INTERFACES_FAMILY_INET, INTERFACES_METHOD_DHCP); 111 interfaces->addInterface(newInterfaceName, INTERFACES_FAMILY_INET, INTERFACES_METHOD_DHCP);
112 if(!interfaces->setInterface(newInterfaceName)){ 112 if(!interfaces->setInterface(newInterfaceName)){
113 qDebug("InterfaceSetupImp: Added interface, but still can't set."); 113 qDebug("InterfaceSetupImp: Added interface, but still can't set.");
114 return; 114 return;
115 } 115 }
116 } 116 }
117 } 117 }
118 118
119 // We must have a valid interface to get this far so read some settings. 119 // We must have a valid interface to get this far so read some settings.
120 120
121 // DHCP 121 // DHCP
122 bool error = false; 122 bool error = false;
123 if(interfaces->getInterfaceMethod(error) == INTERFACES_METHOD_DHCP) 123 if(interfaces->getInterfaceMethod(error) == INTERFACES_METHOD_DHCP)
124 dhcpCheckBox->setChecked(true); 124 dhcpCheckBox->setChecked(true);
125 else 125 else
126 dhcpCheckBox->setChecked(false); 126 dhcpCheckBox->setChecked(false);
127 leaseTime->setValue(interfaces->getInterfaceOption("leasehours", error).toInt()); 127 leaseTime->setValue(interfaces->getInterfaceOption("leasehours", error).toInt());
128 if(error) 128 if(error)
129 leaseTime->setValue(interfaces->getInterfaceOption("leasetime", error).toInt()/60/60); 129 leaseTime->setValue(interfaces->getInterfaceOption("leasetime", error).toInt()/60/60);
130 if(error) 130 if(error)
131 leaseTime->setValue(24); 131 leaseTime->setValue(24);
132 132
133 // IP Information 133 // IP Information
134 autoStart->setChecked(interfaces->isAuto(interface->getInterfaceName())); 134 autoStart->setChecked(interfaces->isAuto(interface->getInterfaceName()));
135 QString dns = interfaces->getInterfaceOption("up interfacednsscript add", error); 135 QString dns = interfaces->getInterfaceOption("up interfacednsscript add", error);
136 if(dns.contains(" ")){ 136 if(dns.contains(" ")){
137 firstDNSLineEdit->setText(dns.mid(0, dns.find(" "))); 137 firstDNSLineEdit->setText(dns.mid(0, dns.find(" ")));
138 secondDNSLineEdit->setText(dns.mid(dns.find(" ")+1, dns.length())); 138 secondDNSLineEdit->setText(dns.mid(dns.find(" ")+1, dns.length()));
139 } 139 }
140 ipAddressEdit->setText(interfaces->getInterfaceOption("address", error)); 140 ipAddressEdit->setText(interfaces->getInterfaceOption("address", error));
141 subnetMaskEdit->setText(interfaces->getInterfaceOption("netmask", error)); 141 subnetMaskEdit->setText(interfaces->getInterfaceOption("netmask", error));
142 gatewayEdit->setText(interfaces->getInterfaceOption("gateway", error)); 142 gatewayEdit->setText(interfaces->getInterfaceOption("gateway", error));
143} 143}
144 144
145 145
146// interfacesetup.cpp 146// interfacesetup.cpp
147 147
diff --git a/noncore/net/networksetup/interfacesetupimp.h b/noncore/net/networksetup/interfacesetupimp.h
index 7df0d46..a0bec32 100644
--- a/noncore/net/networksetup/interfacesetupimp.h
+++ b/noncore/net/networksetup/interfacesetupimp.h
@@ -1,31 +1,31 @@
1#ifndef INTERFACESETUPIMP_H 1#ifndef INTERFACESETUPIMP_H
2#define INTERFACESETUPIMP_H 2#define INTERFACESETUPIMP_H
3 3
4#include "interfacesetup.h" 4#include "interfacesetup.h"
5 5
6class Interface; 6class Interface;
7class Interfaces; 7class Interfaces;
8 8
9class InterfaceSetupImp : public InterfaceSetup { 9class InterfaceSetupImp : public InterfaceSetup {
10 Q_OBJECT 10 Q_OBJECT
11 11
12public: 12public:
13 InterfaceSetupImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, bool modal = FALSE, WFlags fl = 0); 13 InterfaceSetupImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, bool modal = FALSE, WFlags fl = 0);
14 14
15protected slots: 15protected slots:
16 void accept(); 16 void accept();
17 17
18public slots: 18public slots:
19 void setProfile(const QString &profile); 19 void setProfile(const QString &profile);
20 20
21private: 21private:
22 bool saveSettings(); 22 bool saveSettings();
23 Interfaces *interfaces; 23 Interfaces *interfaces;
24 Interface *interface; 24 Interface *interface;
25 25
26}; 26};
27 27
28#endif 28#endif
29 29
30// interfacesetupimp.h 30// interfacesetupimp.h
31 31
diff --git a/noncore/net/networksetup/mainwindowimp.cpp b/noncore/net/networksetup/mainwindowimp.cpp
index c86acdc..4a088cb 100644
--- a/noncore/net/networksetup/mainwindowimp.cpp
+++ b/noncore/net/networksetup/mainwindowimp.cpp
@@ -1,514 +1,513 @@
1#include "mainwindowimp.h" 1#include "mainwindowimp.h"
2#include "addconnectionimp.h" 2#include "addconnectionimp.h"
3#include "interfaceinformationimp.h" 3#include "interfaceinformationimp.h"
4#include "interfacesetupimp.h" 4#include "interfacesetupimp.h"
5#include "interfaces.h" 5#include "interfaces.h"
6 6
7#include "module.h" 7#include "module.h"
8 8
9#include "kprocess.h" 9#include "kprocess.h"
10 10
11#include <qpushbutton.h> 11#include <qpushbutton.h>
12#include <qtabwidget.h> 12#include <qtabwidget.h>
13#include <qlistbox.h> 13#include <qlistbox.h>
14#include <qlineedit.h> 14#include <qlineedit.h>
15#include <qlistview.h> 15#include <qlistview.h>
16#include <qheader.h> 16#include <qheader.h>
17#include <qlabel.h> 17#include <qlabel.h>
18 18
19#include <qmainwindow.h> 19#include <qmainwindow.h>
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21 21
22#include <qpe/config.h> 22#include <qpe/config.h>
23#include <qpe/qlibrary.h> 23#include <qpe/qlibrary.h>
24#include <qpe/resource.h> 24#include <qpe/resource.h>
25#include <qpe/qpeapplication.h> 25#include <qpe/qpeapplication.h>
26 26
27#include <qlist.h> 27#include <qlist.h>
28#include <qdir.h> 28#include <qdir.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qtextstream.h> 30#include <qtextstream.h>
31 31
32#define TEMP_ALL "/tmp/ifconfig-a" 32#define TEMP_ALL "/tmp/ifconfig-a"
33#define TEMP_UP "/tmp/ifconfig" 33#define TEMP_UP "/tmp/ifconfig"
34 34
35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" 35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme"
36 36
37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){ 37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){
38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); 38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked()));
39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); 39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked()));
40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); 40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked()));
41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); 41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked()));
42 42
43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile())); 43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile()));
44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile())); 44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile()));
45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile())); 45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile()));
46 46
47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&))); 47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&)));
48 // Load connections. 48 // Load connections.
49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup"); 49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup");
50 getInterfaceList(); 50 getInterfaceList();
51 connectionList->header()->hide(); 51 connectionList->header()->hide();
52 52
53 53
54 Config cfg("NetworkSetup"); 54 Config cfg("NetworkSetup");
55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); 55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All"));
56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
57 profilesList->insertItem((*it)); 57 profilesList->insertItem((*it));
58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); 58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All"));
59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); 59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false);
60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); 60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME);
61 61
62 QFile file(scheme); 62 QFile file(scheme);
63 if ( file.open(IO_ReadOnly) ) { // file opened successfully 63 if ( file.open(IO_ReadOnly) ) { // file opened successfully
64 QTextStream stream( &file ); // use a text stream 64 QTextStream stream( &file ); // use a text stream
65 while ( !stream.eof() ) { // until end of file... 65 while ( !stream.eof() ) { // until end of file...
66 QString line = stream.readLine(); // line of text excluding '\n' 66 QString line = stream.readLine(); // line of text excluding '\n'
67 if(line.contains("SCHEME")){ 67 if(line.contains("SCHEME")){
68 line = line.mid(7, line.length()); 68 line = line.mid(7, line.length());
69 currentProfileLabel->setText(line); 69 currentProfileLabel->setText(line);
70 break; 70 break;
71 } 71 }
72 } 72 }
73 file.close(); 73 file.close();
74 } 74 }
75} 75}
76 76
77/** 77/**
78 * Deconstructor. Save profiles. Delete loaded libraries. 78 * Deconstructor. Save profiles. Delete loaded libraries.
79 */ 79 */
80MainWindowImp::~MainWindowImp(){ 80MainWindowImp::~MainWindowImp(){
81 qDebug("start Saving mainwindow"); 81 qDebug("Deleting main window");
82 // Save profiles. 82 // Save profiles.
83 Config cfg("NetworkSetup"); 83 Config cfg("NetworkSetup");
84 cfg.setGroup("General"); 84 cfg.setGroup("General");
85 cfg.writeEntry("Profiles", profiles.join(" ")); 85 cfg.writeEntry("Profiles", profiles.join(" "));
86 86
87 // Delete all interfaces that don't have owners. 87 // Delete all interfaces that don't have owners.
88 QMap<Interface*, QListViewItem*>::Iterator iIt; 88 QMap<Interface*, QListViewItem*>::Iterator iIt;
89 for( iIt = items.begin(); iIt != items.end(); ++iIt ){ 89 for( iIt = items.begin(); iIt != items.end(); ++iIt ){
90 if(iIt.key()->getModuleOwner() == NULL) 90 if(iIt.key()->getModuleOwner() == NULL)
91 delete iIt.key(); 91 delete iIt.key();
92 } 92 }
93 93
94 // Delete Modules and Libraries 94 // Delete Modules and Libraries
95 QMap<Module*, QLibrary*>::Iterator it; 95 QMap<Module*, QLibrary*>::Iterator it;
96 for( it = libraries.begin(); it != libraries.end(); ++it ){ 96 for( it = libraries.begin(); it != libraries.end(); ++it ){
97 delete it.key(); 97 delete it.key();
98 delete it.data(); 98 //delete it.data();
99 } 99 }
100 qDebug("done Saving mainwindow"); 100 qDebug("Done deleting main window");
101} 101}
102 102
103/** 103/**
104 * Load all modules that are found in the path 104 * Load all modules that are found in the path
105 * @param path a directory that is scaned for any plugins that can be loaded 105 * @param path a directory that is scaned for any plugins that can be loaded
106 * and attempts to load them 106 * and attempts to load them
107 */ 107 */
108void MainWindowImp::loadModules(QString path){ 108void MainWindowImp::loadModules(QString path){
109 //qDebug(path.latin1()); 109 //qDebug(path.latin1());
110 QDir d(path); 110 QDir d(path);
111 if(!d.exists()) 111 if(!d.exists())
112 return; 112 return;
113 113
114 // Don't want sym links 114 // Don't want sym links
115 d.setFilter( QDir::Files | QDir::NoSymLinks ); 115 d.setFilter( QDir::Files | QDir::NoSymLinks );
116 const QFileInfoList *list = d.entryInfoList(); 116 const QFileInfoList *list = d.entryInfoList();
117 QFileInfoListIterator it( *list ); 117 QFileInfoListIterator it( *list );
118 QFileInfo *fi; 118 QFileInfo *fi;
119 while ( (fi=it.current()) ) { 119 while ( (fi=it.current()) ) {
120 if(fi->fileName().contains(".so")){ 120 if(fi->fileName().contains(".so")){
121 loadPlugin(path + "/" + fi->fileName()); 121 loadPlugin(path + "/" + fi->fileName());
122 } 122 }
123 ++it; 123 ++it;
124 } 124 }
125} 125}
126 126
127/** 127/**
128 * Attempt to load a function and resolve a function. 128 * Attempt to load a function and resolve a function.
129 * @param pluginFileName - the name of the file in which to attempt to load 129 * @param pluginFileName - the name of the file in which to attempt to load
130 * @param resolveString - function pointer to resolve 130 * @param resolveString - function pointer to resolve
131 * @return pointer to the function with name resolveString or NULL 131 * @return pointer to the function with name resolveString or NULL
132 */ 132 */
133Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){ 133Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){
134 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1()); 134 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1());
135 QLibrary *lib = new QLibrary(pluginFileName); 135 QLibrary *lib = new QLibrary(pluginFileName);
136 void *functionPointer = lib->resolve(resolveString); 136 void *functionPointer = lib->resolve(resolveString);
137 if( !functionPointer ){ 137 if( !functionPointer ){
138 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1()); 138 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1());
139 delete lib; 139 delete lib;
140 return NULL; 140 return NULL;
141 } 141 }
142 142
143 // Try to get an object. 143 // Try to get an object.
144 Module *object = ((Module* (*)()) functionPointer)(); 144 Module *object = ((Module* (*)()) functionPointer)();
145 if(object == NULL){ 145 if(object == NULL){
146 qDebug("MainWindowImp: Couldn't create object, but did load library!"); 146 qDebug("MainWindowImp: Couldn't create object, but did load library!");
147 delete lib; 147 delete lib;
148 return NULL; 148 return NULL;
149 } 149 }
150 150
151 // Store for deletion later 151 // Store for deletion later
152 libraries.insert(object, lib); 152 libraries.insert(object, lib);
153 return object; 153 return object;
154} 154}
155 155
156/** 156/**
157 * The Add button was clicked. Bring up the add dialog and if OK is hit 157 * The Add button was clicked. Bring up the add dialog and if OK is hit
158 * load the plugin and append it to the list 158 * load the plugin and append it to the list
159 */ 159 */
160void MainWindowImp::addClicked(){ 160void MainWindowImp::addClicked(){
161 QMap<Module*, QLibrary*>::Iterator it; 161 QMap<Module*, QLibrary*>::Iterator it;
162 QMap<QString, QString> list; 162 QMap<QString, QString> list;
163 QMap<QString, Module*> newInterfaceOwners; 163 QMap<QString, Module*> newInterfaceOwners;
164 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port"); 164 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port");
165 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port"); 165 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port");
166 for( it = libraries.begin(); it != libraries.end(); ++it ){ 166 for( it = libraries.begin(); it != libraries.end(); ++it ){
167 if(it.key()){ 167 if(it.key()){
168 (it.key())->possibleNewInterfaces(list); 168 (it.key())->possibleNewInterfaces(list);
169 } 169 }
170 } 170 }
171 // See if the list has anything that we can add. 171 // See if the list has anything that we can add.
172 if(list.count() == 0){ 172 if(list.count() == 0){
173 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok"); 173 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok");
174 return; 174 return;
175 } 175 }
176 AddConnectionImp addNewConnection(this, "AddConnectionImp", true); 176 AddConnectionImp addNewConnection(this, "AddConnectionImp", true);
177 addNewConnection.addConnections(list); 177 addNewConnection.addConnections(list);
178 addNewConnection.showMaximized(); 178 addNewConnection.showMaximized();
179 if(QDialog::Accepted == addNewConnection.exec()){ 179 if(QDialog::Accepted == addNewConnection.exec()){
180 QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); 180 QListViewItem *item = addNewConnection.registeredServicesList->currentItem();
181 if(!item) 181 if(!item)
182 return; 182 return;
183 183
184 for( it = libraries.begin(); it != libraries.end(); ++it ){ 184 for( it = libraries.begin(); it != libraries.end(); ++it ){
185 if(it.key()){ 185 if(it.key()){
186 Interface *i = (it.key())->addNewInterface(item->text(0)); 186 Interface *i = (it.key())->addNewInterface(item->text(0));
187 if(i){ 187 if(i){
188 interfaceNames.insert(i->getInterfaceName(), i); 188 interfaceNames.insert(i->getInterfaceName(), i);
189 updateInterface(i); 189 updateInterface(i);
190 } 190 }
191 } 191 }
192 } 192 }
193 } 193 }
194} 194}
195 195
196/** 196/**
197 * Prompt the user to see if they really want to do this. 197 * Prompt the user to see if they really want to do this.
198 * If they do then remove from the list and unload. 198 * If they do then remove from the list and unload.
199 */ 199 */
200void MainWindowImp::removeClicked(){ 200void MainWindowImp::removeClicked(){
201 QListViewItem *item = connectionList->currentItem(); 201 QListViewItem *item = connectionList->currentItem();
202 if(!item) { 202 if(!item) {
203 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok"); 203 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok");
204 return; 204 return;
205 } 205 }
206 206
207 Interface *i = interfaceItems[item]; 207 Interface *i = interfaceItems[item];
208 if(i->getModuleOwner() == NULL){ 208 if(i->getModuleOwner() == NULL){
209 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok"); 209 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok");
210 } 210 }
211 else{ 211 else{
212 if(!i->getModuleOwner()->remove(i)) 212 if(!i->getModuleOwner()->remove(i))
213 QMessageBox::information(this, "Error", "Unable to remove.", "Ok"); 213 QMessageBox::information(this, "Error", "Unable to remove.", "Ok");
214 else{ 214 else{
215 QMessageBox::information(this, "Success", "Interface was removed.", "Ok"); 215 QMessageBox::information(this, "Success", "Interface was removed.", "Ok");
216 // TODO memory managment.... 216 // TODO memory managment....
217 // who deletes the interface? 217 // who deletes the interface?
218 } 218 }
219 } 219 }
220} 220}
221 221
222/** 222/**
223 * Pull up the configure about the currently selected interface. 223 * Pull up the configure about the currently selected interface.
224 * Report an error if no interface is selected. 224 * Report an error if no interface is selected.
225 * If the interface has a module owner then request its configure with a empty 225 * If the interface has a module owner then request its configure with a empty
226 * tab. If tab is !NULL then append the interfaces setup widget to it. 226 * tab. If tab is !NULL then append the interfaces setup widget to it.
227 */ 227 */
228void MainWindowImp::configureClicked(){ 228void MainWindowImp::configureClicked(){
229 QListViewItem *item = connectionList->currentItem(); 229 QListViewItem *item = connectionList->currentItem();
230 if(!item){ 230 if(!item){
231 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok); 231 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok);
232 return; 232 return;
233 } 233 }
234 234
235 QString currentProfile = currentProfileLabel->text(); 235 QString currentProfile = currentProfileLabel->text();
236 if(profilesList->count() <= 1 || currentProfile == "All"){ 236 if(profilesList->count() <= 1 || currentProfile == "All"){
237 currentProfile = ""; 237 currentProfile = "";
238 } 238 }
239 239
240 Interface *i = interfaceItems[item]; 240 Interface *i = interfaceItems[item];
241 if(i->getModuleOwner()){ 241 if(i->getModuleOwner()){
242 i->getModuleOwner()->setProfile(currentProfile); 242 i->getModuleOwner()->setProfile(currentProfile);
243 QTabWidget *tabWidget = NULL; 243 QTabWidget *tabWidget = NULL;
244 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget); 244 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget);
245 if(moduleConfigure != NULL){ 245 if(moduleConfigure != NULL){
246 if(tabWidget != NULL){ 246 if(tabWidget != NULL){
247 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, true); 247 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, false, Qt::WDestructiveClose);
248 configure->setProfile(currentProfile); 248 configure->setProfile(currentProfile);
249 tabWidget->insertTab(configure, "TCP/IP"); 249 tabWidget->insertTab(configure, "TCP/IP");
250
251 } 250 }
252 moduleConfigure->showMaximized(); 251 moduleConfigure->showMaximized();
253 moduleConfigure->show(); 252 moduleConfigure->show();
254 return; 253 return;
255 } 254 }
256 } 255 }
257 256
258 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, true); 257 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, false, Qt::WDestructiveClose);
259 configure->setProfile(currentProfile); 258 configure->setProfile(currentProfile);
260 configure->showMaximized(); 259 configure->showMaximized();
261 configure->show(); 260 configure->show();
262} 261}
263 262
264/** 263/**
265 * Pull up the information about the currently selected interface. 264 * Pull up the information about the currently selected interface.
266 * Report an error if no interface is selected. 265 * Report an error if no interface is selected.
267 * If the interface has a module owner then request its configure with a empty 266 * If the interface has a module owner then request its configure with a empty
268 * tab. If tab is !NULL then append the interfaces setup widget to it. 267 * tab. If tab is !NULL then append the interfaces setup widget to it.
269 */ 268 */
270void MainWindowImp::informationClicked(){ 269void MainWindowImp::informationClicked(){
271 QListViewItem *item = connectionList->currentItem(); 270 QListViewItem *item = connectionList->currentItem();
272 if(!item){ 271 if(!item){
273 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); 272 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok);
274 return; 273 return;
275 } 274 }
276 275
277 Interface *i = interfaceItems[item]; 276 Interface *i = interfaceItems[item];
278 if(!i->isAttached()){ 277 if(!i->isAttached()){
279 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok); 278 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok);
280 return; 279 return;
281 } 280 }
282 281
283 QStringList list; 282 QStringList list;
284 for(uint i = 0; i < profilesList->count(); i++){ 283 for(uint i = 0; i < profilesList->count(); i++){
285 list.append(profilesList->text(i)); 284 list.append(profilesList->text(i));
286 } 285 }
287 286
288 if(i->getModuleOwner()){ 287 if(i->getModuleOwner()){
289 QTabWidget *tabWidget = NULL; 288 QTabWidget *tabWidget = NULL;
290 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget); 289 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget);
291 if(moduleInformation != NULL){ 290 if(moduleInformation != NULL){
292 if(tabWidget != NULL){ 291 if(tabWidget != NULL){
293 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true); 292 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true);
294 tabWidget->insertTab(information, "TCP/IP"); 293 tabWidget->insertTab(information, "TCP/IP");
295 } 294 }
296 moduleInformation->showMaximized(); 295 moduleInformation->showMaximized();
297 moduleInformation->show(); 296 moduleInformation->show();
298 return; 297 return;
299 } 298 }
300 } 299 }
301 300
302 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true); 301 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true);
303 information->showMaximized(); 302 information->showMaximized();
304 information->show(); 303 information->show();
305} 304}
306 305
307/** 306/**
308 * Aquire the list of active interfaces from ifconfig 307 * Aquire the list of active interfaces from ifconfig
309 * Call ifconfig and ifconfig -a 308 * Call ifconfig and ifconfig -a
310 */ 309 */
311void MainWindowImp::getInterfaceList(){ 310void MainWindowImp::getInterfaceList(){
312 KShellProcess *processAll = new KShellProcess(); 311 KShellProcess *processAll = new KShellProcess();
313 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL; 312 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL;
314 connect(processAll, SIGNAL(processExited(KProcess *)), 313 connect(processAll, SIGNAL(processExited(KProcess *)),
315 this, SLOT(jobDone(KProcess *))); 314 this, SLOT(jobDone(KProcess *)));
316 threads.insert(processAll, TEMP_ALL); 315 threads.insert(processAll, TEMP_ALL);
317 316
318 KShellProcess *process = new KShellProcess(); 317 KShellProcess *process = new KShellProcess();
319 *process << "/sbin/ifconfig" << " > " TEMP_UP; 318 *process << "/sbin/ifconfig" << " > " TEMP_UP;
320 connect(process, SIGNAL(processExited(KProcess *)), 319 connect(process, SIGNAL(processExited(KProcess *)),
321 this, SLOT(jobDone(KProcess *))); 320 this, SLOT(jobDone(KProcess *)));
322 threads.insert(process, TEMP_UP); 321 threads.insert(process, TEMP_UP);
323 322
324 processAll->start(KShellProcess::NotifyOnExit); 323 processAll->start(KShellProcess::NotifyOnExit);
325 process->start(KShellProcess::NotifyOnExit); 324 process->start(KShellProcess::NotifyOnExit);
326} 325}
327 326
328void MainWindowImp::jobDone(KProcess *process){ 327void MainWindowImp::jobDone(KProcess *process){
329 QString fileName = threads[process]; 328 QString fileName = threads[process];
330 threads.remove(process); 329 threads.remove(process);
331 delete process; 330 delete process;
332 331
333 QFile file(fileName); 332 QFile file(fileName);
334 if (!file.open(IO_ReadOnly)){ 333 if (!file.open(IO_ReadOnly)){
335 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1()); 334 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1());
336 return; 335 return;
337 } 336 }
338 337
339 QTextStream stream( &file ); 338 QTextStream stream( &file );
340 QString line; 339 QString line;
341 while ( !stream.eof() ) { 340 while ( !stream.eof() ) {
342 line = stream.readLine(); 341 line = stream.readLine();
343 int space = line.find(" "); 342 int space = line.find(" ");
344 if(space > 1){ 343 if(space > 1){
345 // We have found an interface 344 // We have found an interface
346 QString interfaceName = line.mid(0, space); 345 QString interfaceName = line.mid(0, space);
347 Interface *i; 346 Interface *i;
348 // We have found an interface 347 // We have found an interface
349 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1()); 348 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1());
350 // See if we already have it 349 // See if we already have it
351 if(interfaceNames.find(interfaceName) == interfaceNames.end()){ 350 if(interfaceNames.find(interfaceName) == interfaceNames.end()){
352 if(fileName == TEMP_ALL) 351 if(fileName == TEMP_ALL)
353 i = new Interface(this, interfaceName, false); 352 i = new Interface(this, interfaceName, false);
354 else 353 else
355 i = new Interface(this, interfaceName, true); 354 i = new Interface(this, interfaceName, true);
356 i->setAttached(true); 355 i->setAttached(true);
357 356
358 QString hardName = "Ethernet"; 357 QString hardName = "Ethernet";
359 int hardwareName = line.find("Link encap:"); 358 int hardwareName = line.find("Link encap:");
360 int macAddress = line.find("HWaddr"); 359 int macAddress = line.find("HWaddr");
361 if(macAddress == -1) 360 if(macAddress == -1)
362 macAddress = line.length(); 361 macAddress = line.length();
363 if(hardwareName != -1) 362 if(hardwareName != -1)
364 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) ); 363 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) );
365 364
366 interfaceNames.insert(i->getInterfaceName(), i); 365 interfaceNames.insert(i->getInterfaceName(), i);
367 updateInterface(i); 366 updateInterface(i);
368 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 367 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
369 } 368 }
370 // It was an interface we already had. 369 // It was an interface we already had.
371 else{ 370 else{
372 if(fileName != TEMP_ALL) 371 if(fileName != TEMP_ALL)
373 (interfaceNames[interfaceName])->setStatus(true); 372 (interfaceNames[interfaceName])->setStatus(true);
374 } 373 }
375 } 374 }
376 } 375 }
377 file.close(); 376 file.close();
378 QFile::remove(fileName); 377 QFile::remove(fileName);
379 378
380 if(threads.count() == 0){ 379 if(threads.count() == 0){
381 Interfaces i; 380 Interfaces i;
382 QStringList list = i.getInterfaceList(); 381 QStringList list = i.getInterfaceList();
383 QMap<QString, Interface*>::Iterator it; 382 QMap<QString, Interface*>::Iterator it;
384 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) { 383 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) {
385 bool found = false; 384 bool found = false;
386 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){ 385 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){
387 if(it.key() == (*ni)) 386 if(it.key() == (*ni))
388 found = true; 387 found = true;
389 } 388 }
390 if(!found){ 389 if(!found){
391 if(!(*ni).contains("_")){ 390 if(!(*ni).contains("_")){
392 Interface *i = new Interface(this, *ni, false); 391 Interface *i = new Interface(this, *ni, false);
393 i->setAttached(false); 392 i->setAttached(false);
394 i->setHardwareName("Disconnected"); 393 i->setHardwareName("Disconnected");
395 interfaceNames.insert(i->getInterfaceName(), i); 394 interfaceNames.insert(i->getInterfaceName(), i);
396 updateInterface(i); 395 updateInterface(i);
397 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 396 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
398 } 397 }
399 } 398 }
400 } 399 }
401 } 400 }
402} 401}
403 402
404/** 403/**
405 * Update this interface. If no QListViewItem exists create one. 404 * Update this interface. If no QListViewItem exists create one.
406 * @param Interface* pointer to the interface that needs to be updated. 405 * @param Interface* pointer to the interface that needs to be updated.
407 */ 406 */
408void MainWindowImp::updateInterface(Interface *i){ 407void MainWindowImp::updateInterface(Interface *i){
409 if(!advancedUserMode){ 408 if(!advancedUserMode){
410 if(i->getInterfaceName() == "lo") 409 if(i->getInterfaceName() == "lo")
411 return; 410 return;
412 } 411 }
413 412
414 QListViewItem *item = NULL; 413 QListViewItem *item = NULL;
415 414
416 // Find the interface, making it if needed. 415 // Find the interface, making it if needed.
417 if(items.find(i) == items.end()){ 416 if(items.find(i) == items.end()){
418 item = new QListViewItem(connectionList, "", "", ""); 417 item = new QListViewItem(connectionList, "", "", "");
419 // See if you can't find a module owner for this interface 418 // See if you can't find a module owner for this interface
420 QMap<Module*, QLibrary*>::Iterator it; 419 QMap<Module*, QLibrary*>::Iterator it;
421 for( it = libraries.begin(); it != libraries.end(); ++it ){ 420 for( it = libraries.begin(); it != libraries.end(); ++it ){
422 if(it.key()->isOwner(i)) 421 if(it.key()->isOwner(i))
423 i->setModuleOwner(it.key()); 422 i->setModuleOwner(it.key());
424 } 423 }
425 items.insert(i, item); 424 items.insert(i, item);
426 interfaceItems.insert(item, i); 425 interfaceItems.insert(item, i);
427 } 426 }
428 else 427 else
429 item = items[i]; 428 item = items[i];
430 429
431 // Update the icons and information 430 // Update the icons and information
432 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down"))); 431 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down")));
433 432
434 QString typeName = "lan"; 433 QString typeName = "lan";
435 if(i->getHardwareName().contains("Local Loopback")) 434 if(i->getHardwareName().contains("Local Loopback"))
436 typeName = "lo"; 435 typeName = "lo";
437 if(i->getInterfaceName().contains("irda")) 436 if(i->getInterfaceName().contains("irda"))
438 typeName = "irda"; 437 typeName = "irda";
439 if(i->getInterfaceName().contains("wlan")) 438 if(i->getInterfaceName().contains("wlan"))
440 typeName = "wlan"; 439 typeName = "wlan";
441 if(i->getInterfaceName().contains("usb")) 440 if(i->getInterfaceName().contains("usb"))
442 typeName = "usb"; 441 typeName = "usb";
443 442
444 if(!i->isAttached()) 443 if(!i->isAttached())
445 typeName = "connect_no"; 444 typeName = "connect_no";
446 // Actually try to use the Module 445 // Actually try to use the Module
447 if(i->getModuleOwner() != NULL) 446 if(i->getModuleOwner() != NULL)
448 typeName = i->getModuleOwner()->getPixmapName(i); 447 typeName = i->getModuleOwner()->getPixmapName(i);
449 448
450 item->setPixmap(1, (Resource::loadPixmap(typeName))); 449 item->setPixmap(1, (Resource::loadPixmap(typeName)));
451 item->setText(2, i->getHardwareName()); 450 item->setText(2, i->getHardwareName());
452 item->setText(3, QString("(%1)").arg(i->getInterfaceName())); 451 item->setText(3, QString("(%1)").arg(i->getInterfaceName()));
453 item->setText(4, (i->getStatus()) ? i->getIp() : QString("")); 452 item->setText(4, (i->getStatus()) ? i->getIp() : QString(""));
454} 453}
455 454
456void MainWindowImp::newProfileChanged(const QString& newText){ 455void MainWindowImp::newProfileChanged(const QString& newText){
457 if(newText.length() > 0) 456 if(newText.length() > 0)
458 newProfileButton->setEnabled(true); 457 newProfileButton->setEnabled(true);
459 else 458 else
460 newProfileButton->setEnabled(false); 459 newProfileButton->setEnabled(false);
461} 460}
462 461
463/** 462/**
464 * Adds a new profile to the list of profiles. 463 * Adds a new profile to the list of profiles.
465 * Don't add profiles that already exists. 464 * Don't add profiles that already exists.
466 * Appends to the list and QStringList 465 * Appends to the list and QStringList
467 */ 466 */
468void MainWindowImp::addProfile(){ 467void MainWindowImp::addProfile(){
469 QString newProfileName = newProfile->text(); 468 QString newProfileName = newProfile->text();
470 if(profiles.grep(newProfileName).count() > 0){ 469 if(profiles.grep(newProfileName).count() > 0){
471 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok"); 470 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok");
472 return; 471 return;
473 } 472 }
474 profiles.append(newProfileName); 473 profiles.append(newProfileName);
475 profilesList->insertItem(newProfileName); 474 profilesList->insertItem(newProfileName);
476} 475}
477 476
478/** 477/**
479 * Removes the currently selected profile in the combo. 478 * Removes the currently selected profile in the combo.
480 * Doesn't delete if there are less then 2 profiles. 479 * Doesn't delete if there are less then 2 profiles.
481 */ 480 */
482void MainWindowImp::removeProfile(){ 481void MainWindowImp::removeProfile(){
483 if(profilesList->count() <= 1){ 482 if(profilesList->count() <= 1){
484 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok"); 483 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok");
485 return; 484 return;
486 } 485 }
487 QString profileToRemove = profilesList->currentText(); 486 QString profileToRemove = profilesList->currentText();
488 if(profileToRemove == "All"){ 487 if(profileToRemove == "All"){
489 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok"); 488 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok");
490 return; 489 return;
491 } 490 }
492 // Can't remove the curent profile 491 // Can't remove the curent profile
493 if(profileToRemove == currentProfileLabel->text()){ 492 if(profileToRemove == currentProfileLabel->text()){
494 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok"); 493 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok");
495 return; 494 return;
496 495
497 } 496 }
498 497
499 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){ 498 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){
500 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), "")); 499 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), ""));
501 profilesList->clear(); 500 profilesList->clear();
502 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 501 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
503 profilesList->insertItem((*it)); 502 profilesList->insertItem((*it));
504 503
505 // Remove any interface settings and mappings. 504 // Remove any interface settings and mappings.
506 Interfaces interfaces; 505 Interfaces interfaces;
507 // Go through them one by one 506 // Go through them one by one
508 QMap<Interface*, QListViewItem*>::Iterator it; 507 QMap<Interface*, QListViewItem*>::Iterator it;
509 for( it = items.begin(); it != items.end(); ++it ){ 508 for( it = items.begin(); it != items.end(); ++it ){
510 QString interfaceName = it.key()->getInterfaceName(); 509 QString interfaceName = it.key()->getInterfaceName();
511 qDebug(interfaceName.latin1()); 510 qDebug(interfaceName.latin1());
512 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){ 511 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){
513 interfaces.removeInterface(); 512 interfaces.removeInterface();
514 if(interfaces.setMapping(interfaceName)){ 513 if(interfaces.setMapping(interfaceName)){
diff --git a/noncore/net/networksetup/networksetup.pro b/noncore/net/networksetup/networksetup.pro
index f09db93..7299cc6 100644
--- a/noncore/net/networksetup/networksetup.pro
+++ b/noncore/net/networksetup/networksetup.pro
@@ -1,11 +1,11 @@
1 DESTDIR = $(OPIEDIR)/bin 1 #DESTDIR = $(OPIEDIR)/bin
2 TEMPLATE= app 2 TEMPLATE= app
3 #CONFIG = qt warn_on debug 3 CONFIG = qt warn_on debug
4 CONFIG = qt warn_on release 4 #CONFIG = qt warn_on release
5 HEADERS = mainwindowimp.h addconnectionimp.h interface.h interfaceinformationimp.h interfacesetupimp.h interfaces.h defaultmodule.h kprocctrl.h module.h kprocess.h 5 HEADERS = mainwindowimp.h addconnectionimp.h interface.h interfaceinformationimp.h interfacesetupimp.h interfaces.h defaultmodule.h kprocctrl.h module.h kprocess.h
6 SOURCES = main.cpp mainwindowimp.cpp addconnectionimp.cpp interface.cpp interfaceinformationimp.cpp interfacesetupimp.cpp kprocctrl.cpp kprocess.cpp interfaces.cpp 6 SOURCES = main.cpp mainwindowimp.cpp addconnectionimp.cpp interface.cpp interfaceinformationimp.cpp interfacesetupimp.cpp kprocctrl.cpp kprocess.cpp interfaces.cpp
7 INCLUDEPATH+= $(OPIEDIR)/include 7 INCLUDEPATH+= $(OPIEDIR)/include
8 DEPENDPATH+= $(OPIEDIR)/include 8 DEPENDPATH+= $(OPIEDIR)/include
9LIBS += -lqpe 9LIBS += -lqpe
10 INTERFACES= mainwindow.ui addconnection.ui interfaceinformation.ui interfaceadvanced.ui interfacesetup.ui 10 INTERFACES= mainwindow.ui addconnection.ui interfaceinformation.ui interfaceadvanced.ui interfacesetup.ui
11 TARGET = networksetup 11 TARGET = networksetup
diff --git a/noncore/net/networksetup/wlan/wlan.pro b/noncore/net/networksetup/wlan/wlan.pro
index 432a096..814a0b4 100644
--- a/noncore/net/networksetup/wlan/wlan.pro
+++ b/noncore/net/networksetup/wlan/wlan.pro
@@ -1,12 +1,12 @@
1TEMPLATE = lib 1TEMPLATE = lib
2CONFIG += qt warn_on release 2#CONFIG += qt warn_on release
3 #CONFIG += qt warn_on debug 3 CONFIG += qt warn_on debug
4DESTDIR = $(OPIEDIR)/plugins/networksetup 4#DESTDIR = $(OPIEDIR)/plugins/networksetup
5 HEADERS = wlanimp.h wlanmodule.h wextensions.h 5 HEADERS = wlanimp.h wlanmodule.h wextensions.h
6 SOURCES = wlanimp.cpp wlanmodule.cpp wextensions.cpp 6 SOURCES = wlanimp.cpp wlanmodule.cpp wextensions.cpp
7 INCLUDEPATH+= $(OPIEDIR)/include ../ 7 INCLUDEPATH+= $(OPIEDIR)/include ../
8 DEPENDPATH+= $(OPIEDIR)/include 8 DEPENDPATH+= $(OPIEDIR)/include
9LIBS += -lqpe 9LIBS += -lqpe
10 INTERFACES= wlan.ui info.ui 10 INTERFACES= wlan.ui info.ui
11 TARGET = wlanplugin 11 TARGET = wlanplugin
12 VERSION = 1.0.0 12 VERSION = 1.0.0
diff --git a/noncore/net/networksetup/wlan/wlanimp.cpp b/noncore/net/networksetup/wlan/wlanimp.cpp
index 94c7518..45952b9 100644
--- a/noncore/net/networksetup/wlan/wlanimp.cpp
+++ b/noncore/net/networksetup/wlan/wlanimp.cpp
@@ -1,239 +1,234 @@
1#include "wlanimp.h" 1#include "wlanimp.h"
2 2
3/* Config class */ 3/* Config class */
4#include <qpe/config.h> 4#include <qpe/config.h>
5/* Global namespace */ 5/* Global namespace */
6#include <qpe/global.h> 6#include <qpe/global.h>
7/* system() */ 7/* system() */
8#include <stdlib.h> 8#include <stdlib.h>
9#include <qfile.h> 9#include <qfile.h>
10#include <qdir.h> 10#include <qdir.h>
11#include <qtextstream.h> 11#include <qtextstream.h>
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13#include <qlineedit.h> 13#include <qlineedit.h>
14#include <qspinbox.h> 14#include <qspinbox.h>
15#include <qradiobutton.h> 15#include <qradiobutton.h>
16#include <qcheckbox.h> 16#include <qcheckbox.h>
17#include <qregexp.h> 17#include <qregexp.h>
18 18
19WLANImp::WLANImp( QWidget* parent, const char* name):WLAN(parent, name, Qt::WDestructiveClose){ 19WLANImp::WLANImp( QWidget* parent, const char* name, bool modal, WFlags fl):WLAN(parent, name, modal, fl){
20 config = new Config("wireless"); 20 config = new Config("wireless");
21 readConfig(); 21 readConfig();
22} 22}
23 23
24WLANImp::~WLANImp( ){ 24WLANImp::~WLANImp( ){
25 delete config; 25 delete config;
26} 26}
27 27
28void WLANImp::readConfig() 28void WLANImp::readConfig()
29{ 29{
30 qWarning( "WLANImp::readConfig() called." ); 30 qWarning( "WLANImp::readConfig() called." );
31 config->setGroup( "Properties" ); 31 config->setGroup( "Properties" );
32 QString ssid = config->readEntry( "SSID", "any" ); 32 QString ssid = config->readEntry( "SSID", "any" );
33 if( ssid == "any" || ssid == "ANY" ){ 33 if( ssid == "any" || ssid == "ANY" ){
34 essNon->setChecked( true ); 34 essNon->setChecked( true );
35 } else { 35 } else {
36 essSpecific->setChecked( true ); 36 essSpecific->setChecked( true );
37 essSpecificLineEdit->setText( ssid ); 37 essSpecificLineEdit->setText( ssid );
38 } 38 }
39 QString mode = config->readEntry( "Mode", "Managed" ); 39 QString mode = config->readEntry( "Mode", "Managed" );
40 if( mode == "adhoc" ) { 40 if( mode == "adhoc" ) {
41 network802->setChecked( true ); 41 network802->setChecked( true );
42 } else { 42 } else {
43 networkInfrastructure->setChecked( true ); 43 networkInfrastructure->setChecked( true );
44 } 44 }
45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) ); 45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) );
46// config->readEntry( "RATE", "auto" ); 46// config->readEntry( "RATE", "auto" );
47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false ); 47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false );
48 config->readEntry( "AuthType", "opensystem" ); 48 config->readEntry( "AuthType", "opensystem" );
49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true ); 49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true );
50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
51 switch( defaultkey ){ 51 switch( defaultkey ){
52 case 0: 52 case 0:
53 keyRadio0->setChecked( true ); 53 keyRadio0->setChecked( true );
54 break; 54 break;
55 case 1: 55 case 1:
56 keyRadio1->setChecked( true ); 56 keyRadio1->setChecked( true );
57 break; 57 break;
58 case 2: 58 case 2:
59 keyRadio2->setChecked( true ); 59 keyRadio2->setChecked( true );
60 break; 60 break;
61 case 3: 61 case 3:
62 keyRadio3->setChecked( true ); 62 keyRadio3->setChecked( true );
63 break; 63 break;
64 } 64 }
65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" )); 65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" ));
66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" )); 66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" ));
67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" )); 67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" ));
68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" )); 68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" ));
69 return; 69 return;
70} 70}
71 71
72bool WLANImp::writeConfig() 72bool WLANImp::writeConfig()
73{ 73{
74 qWarning( "WLANImp::writeConfig() called." ); 74 qWarning( "WLANImp::writeConfig() called." );
75 config->setGroup( "Properties" ); 75 config->setGroup( "Properties" );
76 if( essNon->isChecked() ) { 76 if( essNon->isChecked() ) {
77 config->writeEntry( "SSID", "any" ); 77 config->writeEntry( "SSID", "any" );
78 } else { 78 } else {
79 config->writeEntry( "SSID", essSpecificLineEdit->text() ); 79 config->writeEntry( "SSID", essSpecificLineEdit->text() );
80 } 80 }
81 if( networkInfrastructure->isChecked() ){ 81 if( networkInfrastructure->isChecked() ){
82 config->writeEntry( "Mode", "Managed" ); 82 config->writeEntry( "Mode", "Managed" );
83 } else if( network802->isChecked() ){ 83 } else if( network802->isChecked() ){
84 config->writeEntry( "Mode", "adhoc" ); 84 config->writeEntry( "Mode", "adhoc" );
85 } 85 }
86 config->writeEntry( "CHANNEL", networkChannel->value() ); 86 config->writeEntry( "CHANNEL", networkChannel->value() );
87// config->readEntry( "RATE", "auto" ); 87// config->readEntry( "RATE", "auto" );
88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" ); 88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" );
89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" ); 89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" );
90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" ); 90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" );
91 if( keyRadio0->isChecked() ){ 91 if( keyRadio0->isChecked() ){
92 config->writeEntry( "dot11WEPDefaultKeyID", 0 ); 92 config->writeEntry( "dot11WEPDefaultKeyID", 0 );
93 } else if( keyRadio1->isChecked() ){ 93 } else if( keyRadio1->isChecked() ){
94 config->writeEntry( "dot11WEPDefaultKeyID", 1 ); 94 config->writeEntry( "dot11WEPDefaultKeyID", 1 );
95 } else if( keyRadio2->isChecked() ){ 95 } else if( keyRadio2->isChecked() ){
96 config->writeEntry( "dot11WEPDefaultKeyID", 2 ); 96 config->writeEntry( "dot11WEPDefaultKeyID", 2 );
97 } else if( keyRadio3->isChecked() ){ 97 } else if( keyRadio3->isChecked() ){
98 config->writeEntry( "dot11WEPDefaultKeyID", 3 ); 98 config->writeEntry( "dot11WEPDefaultKeyID", 3 );
99 } 99 }
100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() ); 100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() );
101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() ); 101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() );
102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() ); 102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() );
103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() ); 103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() );
104 return true;
104 return writeWirelessOpts( ); 105 return writeWirelessOpts( );
105} 106}
106 107
107/** 108/**
108 */ 109 */
109void WLANImp::accept() 110void WLANImp::accept()
110{ 111{
111 if ( writeConfig() ) 112 if ( writeConfig() )
112 QDialog::accept(); 113 QDialog::accept();
113} 114}
114 115
115void WLANImp::done ( int r )
116{
117 QDialog::done ( r );
118 close ( );
119}
120
121bool WLANImp::writeWirelessOpts( QString scheme ) 116bool WLANImp::writeWirelessOpts( QString scheme )
122{ 117{
123 qWarning( "WLANImp::writeWirelessOpts entered." ); 118 qWarning( "WLANImp::writeWirelessOpts entered." );
124 QString prev = "/etc/pcmcia/wireless.opts"; 119 QString prev = "/etc/pcmcia/wireless.opts";
125 QFile prevFile(prev); 120 QFile prevFile(prev);
126 if ( !prevFile.open( IO_ReadOnly ) ) 121 if ( !prevFile.open( IO_ReadOnly ) )
127 return false; 122 return false;
128 123
129 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new"; 124 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new";
130 QFile tmpFile(tmp); 125 QFile tmpFile(tmp);
131 if ( !tmpFile.open( IO_WriteOnly ) ) 126 if ( !tmpFile.open( IO_WriteOnly ) )
132 return false; 127 return false;
133 128
134 bool retval = true; 129 bool retval = true;
135 130
136 QTextStream in( &prevFile ); 131 QTextStream in( &prevFile );
137 QTextStream out( &tmpFile ); 132 QTextStream out( &tmpFile );
138 133
139 config->setGroup("Properties"); 134 config->setGroup("Properties");
140 135
141 QString line; 136 QString line;
142 bool found=false; 137 bool found=false;
143 bool done=false; 138 bool done=false;
144 while ( !in.atEnd() ) { 139 while ( !in.atEnd() ) {
145 QString line = in.readLine(); 140 QString line = in.readLine();
146 QString wline = line.simplifyWhiteSpace(); 141 QString wline = line.simplifyWhiteSpace();
147 if ( !done ) { 142 if ( !done ) {
148 if ( found ) { 143 if ( found ) {
149 // skip existing entry for this scheme, and write our own. 144 // skip existing entry for this scheme, and write our own.
150 if ( wline == ";;" ) { 145 if ( wline == ";;" ) {
151 found = false; 146 found = false;
152 continue; 147 continue;
153 } else { 148 } else {
154 continue; 149 continue;
155 } 150 }
156 } else { 151 } else {
157 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) { 152 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) {
158 found=true; 153 found=true;
159 continue; // skip this line 154 continue; // skip this line
160 } else if ( wline == "esac" || wline == "*,*,*,*)" ) { 155 } else if ( wline == "esac" || wline == "*,*,*,*)" ) {
161 // end - add new entry 156 // end - add new entry
162 // Not all fields have a GUI, but all are supported 157 // Not all fields have a GUI, but all are supported
163 // in the letwork configuration files. 158 // in the letwork configuration files.
164 static const char* txtfields[] = { 159 static const char* txtfields[] = {
165 0 160 0
166 }; 161 };
167 QString readmode = config->readEntry( "Mode", "Managed" ); 162 QString readmode = config->readEntry( "Mode", "Managed" );
168 QString mode; 163 QString mode;
169 if( readmode == "Managed" ){ 164 if( readmode == "Managed" ){
170 mode = readmode; 165 mode = readmode;
171 } else if( readmode == "adhoc" ){ 166 } else if( readmode == "adhoc" ){
172 mode = "Ad-Hoc"; 167 mode = "Ad-Hoc";
173 } 168 }
174 QString key; 169 QString key;
175 if( wepEnabled->isChecked() ){ 170 if( wepEnabled->isChecked() ){
176 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 171 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
177 switch( defaultkey ){ 172 switch( defaultkey ){
178 case 0: 173 case 0:
179 key += keyLineEdit0->text(); 174 key += keyLineEdit0->text();
180 break; 175 break;
181 case 1: 176 case 1:
182 key += keyLineEdit1->text(); 177 key += keyLineEdit1->text();
183 break; 178 break;
184 case 2: 179 case 2:
185 key += keyLineEdit2->text(); 180 key += keyLineEdit2->text();
186 break; 181 break;
187 case 3: 182 case 3:
188 key += keyLineEdit3->text(); 183 key += keyLineEdit3->text();
189 break; 184 break;
190 } 185 }
191 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem") 186 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem")
192 key += " open"; 187 key += " open";
193 } 188 }
194 out << scheme << ",*,*,*)" << "\n" 189 out << scheme << ",*,*,*)" << "\n"
195 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n" 190 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n"
196 << " MODE=" << mode << "\n" 191 << " MODE=" << mode << "\n"
197 << " KEY=" << Global::shellQuote( key ) << "\n" 192 << " KEY=" << Global::shellQuote( key ) << "\n"
198 << " RATE=" << "auto" << "\n" 193 << " RATE=" << "auto" << "\n"
199 ; 194 ;
200 if( mode != "Managed" ) 195 if( mode != "Managed" )
201 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n"; 196 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n";
202 const char** f = txtfields; 197 const char** f = txtfields;
203 while (*f) { 198 while (*f) {
204 out << " " << *f << "=" << config->readEntry(*f,"") << "\n"; 199 out << " " << *f << "=" << config->readEntry(*f,"") << "\n";
205 ++f; 200 ++f;
206 } 201 }
207 out << " ;;\n"; 202 out << " ;;\n";
208 done = true; 203 done = true;
209 } 204 }
210 } 205 }
211 } 206 }
212 out << line << "\n"; 207 out << line << "\n";
213 } 208 }
214 209
215 prevFile.close(); 210 prevFile.close();
216 tmpFile.close(); 211 tmpFile.close();
217 QString initpath; 212 QString initpath;
218 //system("cardctl suspend"); 213 //system("cardctl suspend");
219 if( QDir("/etc/rc.d/init.d").exists() ){ 214 if( QDir("/etc/rc.d/init.d").exists() ){
220 initpath = "/etc/rc.d/init.d"; 215 initpath = "/etc/rc.d/init.d";
221 } else if( QDir("/etc/init.d").exists() ){ 216 } else if( QDir("/etc/init.d").exists() ){
222 initpath = "/etc/init.d"; 217 initpath = "/etc/init.d";
223 } 218 }
224 if( initpath ) 219 if( initpath )
225 system(QString("%1/pcmcia stop").arg(initpath)); 220 system(QString("%1/pcmcia stop").arg(initpath));
226 221
227 if( system( "mv " + tmp + " " + prev ) ) 222 if( system( "mv " + tmp + " " + prev ) )
228 retval = false; 223 retval = false;
229//#ifdef USE_SCHEMES 224//#ifdef USE_SCHEMES
230// if ( retval ) 225// if ( retval )
231 //SchemeChanger::changeScheme(scheme); 226 //SchemeChanger::changeScheme(scheme);
232//#endif 227//#endif
233 228
234 //system("cardctl resume"); 229 //system("cardctl resume");
235 if( initpath ) 230 if( initpath )
236 system(QString("%1/pcmcia start").arg(initpath)); 231 system(QString("%1/pcmcia start").arg(initpath));
237 232
238 return retval; 233 return retval;
239} 234}
diff --git a/noncore/net/networksetup/wlan/wlanimp.h b/noncore/net/networksetup/wlan/wlanimp.h
index 22ce143..59b7c59 100644
--- a/noncore/net/networksetup/wlan/wlanimp.h
+++ b/noncore/net/networksetup/wlan/wlanimp.h
@@ -1,28 +1,27 @@
1#ifndef WLANIMP_H 1#ifndef WLANIMP_H
2#define WLANIMP_H 2#define WLANIMP_H
3 3
4#include "wlan.h" 4#include "wlan.h"
5 5
6#include <qpe/config.h> 6#include <qpe/config.h>
7 7
8class WLANImp : public WLAN { 8class WLANImp : public WLAN {
9 Q_OBJECT 9 Q_OBJECT
10 10
11public: 11public:
12 WLANImp( QWidget* parent = 0, const char* name = 0); 12 WLANImp( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 );
13 ~WLANImp( ); 13 ~WLANImp( );
14 14
15protected: 15protected:
16 void accept(); 16 void accept();
17 void done ( int r );
18 17
19private: 18private:
20 void readConfig(); 19 void readConfig();
21 bool writeConfig(); 20 bool writeConfig();
22 bool writeWirelessOpts( QString scheme = "*" ); 21 bool writeWirelessOpts( QString scheme = "*" );
23 bool writeWlanngOpts( QString scheme = "*" ); 22 bool writeWlanngOpts( QString scheme = "*" );
24 Config* config; 23 Config* config;
25}; 24};
26 25
27#endif 26#endif
28 27
diff --git a/noncore/net/networksetup/wlan/wlanmodule.cpp b/noncore/net/networksetup/wlan/wlanmodule.cpp
index 7507c54..3363b8a 100644
--- a/noncore/net/networksetup/wlan/wlanmodule.cpp
+++ b/noncore/net/networksetup/wlan/wlanmodule.cpp
@@ -1,129 +1,126 @@
1#include "wlanmodule.h" 1#include "wlanmodule.h"
2#include "wlanimp.h" 2#include "wlanimp.h"
3#include "info.h" 3#include "info.h"
4#include "wextensions.h" 4#include "wextensions.h"
5 5
6#include <qlabel.h> 6#include <qlabel.h>
7#include <qprogressbar.h> 7#include <qprogressbar.h>
8 8
9/** 9/**
10 * Constructor, find all of the possible interfaces 10 * Constructor, find all of the possible interfaces
11 */ 11 */
12WLANModule::WLANModule() : Module() { 12WLANModule::WLANModule() : Module() {
13} 13}
14 14
15/** 15/**
16 */ 16 */
17WLANModule::~WLANModule(){ 17WLANModule::~WLANModule(){
18 qDebug("Deleting module");
18 Interface *i; 19 Interface *i;
19 for ( i=list.first(); i != 0; i=list.next() ) 20 for ( i=list.first(); i != 0; i=list.next() )
20 delete i; 21 delete i;
21} 22}
22 23
23/** 24/**
24 * Change the current profile 25 * Change the current profile
25 */ 26 */
26void WLANModule::setProfile(QString newProfile){ 27void WLANModule::setProfile(QString newProfile){
27 profile = newProfile; 28 profile = newProfile;
28} 29}
29 30
30/** 31/**
31 * get the icon name for this device. 32 * get the icon name for this device.
32 * @param Interface* can be used in determining the icon. 33 * @param Interface* can be used in determining the icon.
33 * @return QString the icon name (minus .png, .gif etc) 34 * @return QString the icon name (minus .png, .gif etc)
34 */ 35 */
35QString WLANModule::getPixmapName(Interface* ){ 36QString WLANModule::getPixmapName(Interface* ){
36 return "wlan"; 37 return "wlan";
37} 38}
38 39
39/** 40/**
40 * Check to see if the interface i is owned by this module. 41 * Check to see if the interface i is owned by this module.
41 * @param Interface* interface to check against 42 * @param Interface* interface to check against
42 * @return bool true if i is owned by this module, false otherwise. 43 * @return bool true if i is owned by this module, false otherwise.
43 */ 44 */
44bool WLANModule::isOwner(Interface *i){ 45bool WLANModule::isOwner(Interface *i){
45 WExtensions we(i->getInterfaceName()); 46 WExtensions we(i->getInterfaceName());
46 if(!we.doesHaveWirelessExtensions()) 47 if(!we.doesHaveWirelessExtensions())
47 return false; 48 return false;
48 49
49 i->setHardwareName("802.11b"); 50 i->setHardwareName("802.11b");
50 list.append(i); 51 list.append(i);
51 return true; 52 return true;
52} 53}
53 54
54/** 55/**
55 * Create, set tabWiget and return the WLANConfigure Module 56 * Create, set tabWiget and return the WLANConfigure Module
56 * @param tabWidget a pointer to the tab widget that this configure has. 57 * @param tabWidget a pointer to the tab widget that this configure has.
57 * @return QWidget* pointer to the tab widget in this modules configure. 58 * @return QWidget* pointer to the tab widget in this modules configure.
58 */ 59 */
59QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){ 60QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){
60 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig"); 61 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig", false, Qt::WDestructiveClose);
61 (*tabWidget) = wlanconfig->tabWidget; 62 (*tabWidget) = wlanconfig->tabWidget;
62 return wlanconfig; 63 return wlanconfig;
63} 64}
64 65
65/** 66/**
66 * Create, set tabWiget and return the Information Module 67 * Create, set tabWiget and return the Information Module
67 * @param tabWidget a pointer to the tab widget that this information has. 68 * @param tabWidget a pointer to the tab widget that this information has.
68 * @return QWidget* pointer to the tab widget in this modules info. 69 * @return QWidget* pointer to the tab widget in this modules info.
69 */ 70 */
70QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){ 71QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){
71 WExtensions we(i->getInterfaceName()); 72 WExtensions we(i->getInterfaceName());
72 if(!we.doesHaveWirelessExtensions()) 73 if(!we.doesHaveWirelessExtensions())
73 return NULL; 74 return NULL;
74 75
75 WlanInfo *info = new WlanInfo(0, "wireless info", Qt::WDestructiveClose); 76 WlanInfo *info = new WlanInfo(0, "wireless info", Qt::WDestructiveClose);
76 (*tabWidget) = info->tabWidget; 77 (*tabWidget) = info->tabWidget;
77 78
78 info->essidLabel->setText(we.essid()); 79 info->essidLabel->setText(we.essid());
79 info->apLabel->setText(we.ap()); 80 info->apLabel->setText(we.ap());
80 info->stationLabel->setText(we.station()); 81 info->stationLabel->setText(we.station());
81 info->modeLabel->setText(we.mode()); 82 info->modeLabel->setText(we.mode());
82 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency())); 83 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency()));
83 int signal = 0; 84 int signal = 0;
84 int noise = 0; 85 int noise = 0;
85 int quality = 0; 86 int quality = 0;
86 we.stats(signal, noise, quality); 87 we.stats(signal, noise, quality);
87 info->signalProgressBar->setProgress(signal); 88 info->signalProgressBar->setProgress(signal);
88 info->noiseProgressBar->setProgress(noise); 89 info->noiseProgressBar->setProgress(noise);
89 info->qualityProgressBar->setProgress(quality); 90 info->qualityProgressBar->setProgress(quality);
90 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate())); 91 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate()));
91 //WlanInfo info (0, "wireless info", true);
92 //info.show();
93 //return NULL;
94
95 return info; 92 return info;
96} 93}
97 94
98/** 95/**
99 * Get all active (up or down) interfaces 96 * Get all active (up or down) interfaces
100 * @return QList<Interface> A list of interfaces that exsist that havn't 97 * @return QList<Interface> A list of interfaces that exsist that havn't
101 * been called by isOwner() 98 * been called by isOwner()
102 */ 99 */
103QList<Interface> WLANModule::getInterfaces(){ 100QList<Interface> WLANModule::getInterfaces(){
104 return list; 101 return list;
105} 102}
106 103
107/** 104/**
108 * Attempt to add a new interface as defined by name 105 * Attempt to add a new interface as defined by name
109 * @param name the name of the type of interface that should be created given 106 * @param name the name of the type of interface that should be created given
110 * by possibleNewInterfaces(); 107 * by possibleNewInterfaces();
111 * @return Interface* NULL if it was unable to be created. 108 * @return Interface* NULL if it was unable to be created.
112 */ 109 */
113Interface *WLANModule::addNewInterface(QString ){ 110Interface *WLANModule::addNewInterface(QString ){
114 // We can't add a 802.11 interface, either the hardware will be there 111 // We can't add a 802.11 interface, either the hardware will be there
115 // or it wont. 112 // or it wont.
116 return NULL; 113 return NULL;
117} 114}
118 115
119/** 116/**
120 * Attempts to remove the interface, doesn't delete i 117 * Attempts to remove the interface, doesn't delete i
121 * @return bool true if successfull, false otherwise. 118 * @return bool true if successfull, false otherwise.
122 */ 119 */
123bool WLANModule::remove(Interface*){ 120bool WLANModule::remove(Interface*){
124 // Can't remove a hardware device, you can stop it though. 121 // Can't remove a hardware device, you can stop it though.
125 return false; 122 return false;
126} 123}
127 124
128// wlanmodule.cpp 125// wlanmodule.cpp
129 126
diff --git a/noncore/settings/networksettings/interfacesetupimp.cpp b/noncore/settings/networksettings/interfacesetupimp.cpp
index 1327726..a8731a9 100644
--- a/noncore/settings/networksettings/interfacesetupimp.cpp
+++ b/noncore/settings/networksettings/interfacesetupimp.cpp
@@ -1,147 +1,147 @@
1#include "interfacesetupimp.h" 1#include "interfacesetupimp.h"
2#include "interface.h" 2#include "interface.h"
3#include "interfaces.h" 3#include "interfaces.h"
4 4
5#include <qcombobox.h> 5#include <qcombobox.h>
6#include <qcheckbox.h> 6#include <qcheckbox.h>
7#include <qlineedit.h> 7#include <qlineedit.h>
8#include <qspinbox.h> 8#include <qspinbox.h>
9#include <qgroupbox.h> 9#include <qgroupbox.h>
10#include <qlabel.h> 10#include <qlabel.h>
11 11
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13 13
14#include <assert.h> 14#include <assert.h>
15 15
16#define DNSSCRIPT "interfacednsscript" 16#define DNSSCRIPT "interfacednsscript"
17 17
18/** 18/**
19 * Constuctor. Set up the connection and load the first profile. 19 * Constuctor. Set up the connection and load the first profile.
20 */ 20 */
21InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl) : InterfaceSetup(parent, name, modal, fl){ 21InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl) : InterfaceSetup(parent, name, modal, fl){
22 assert(i); 22 assert(i);
23 interface = i; 23 interface = i;
24 interfaces = new Interfaces(); 24 interfaces = new Interfaces();
25 bool error = false; 25 bool error = false;
26 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){ 26 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){
27 staticGroupBox->hide(); 27 staticGroupBox->hide();
28 dhcpCheckBox->hide(); 28 dhcpCheckBox->hide();
29 leaseTime->hide(); 29 leaseTime->hide();
30 leaseHoursLabel->hide(); 30 leaseHoursLabel->hide();
31 } 31 }
32} 32}
33 33
34/** 34/**
35 * Save the current settings, then write out the interfaces file and close. 35 * Save the current settings, then write out the interfaces file and close.
36 */ 36 */
37void InterfaceSetupImp::accept(){ 37void InterfaceSetupImp::accept(){
38 if(!saveSettings()) 38 if(!saveSettings())
39 return; 39 return;
40 interfaces->write(); 40 interfaces->write();
41 close(true); 41 QDialog::accept();
42} 42}
43 43
44/** 44/**
45 * Save the settings for the current Interface. 45 * Save the settings for the current Interface.
46 * @return bool true if successfull, false otherwise 46 * @return bool true if successfull, false otherwise
47 */ 47 */
48bool InterfaceSetupImp::saveSettings(){ 48bool InterfaceSetupImp::saveSettings(){
49 // eh can't really do anything about it other then return. :-D 49 // eh can't really do anything about it other then return. :-D
50 if(!interfaces->isInterfaceSet()) 50 if(!interfaces->isInterfaceSet())
51 return true; 51 return true;
52 52
53 bool error = false; 53 bool error = false;
54 // Loopback case 54 // Loopback case
55 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){ 55 if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){
56 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked()); 56 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked());
57 return true; 57 return true;
58 } 58 }
59 59
60 if(!dhcpCheckBox->isChecked() && (ipAddressEdit->text().isEmpty() || subnetMaskEdit->text().isEmpty() || firstDNSLineEdit->text().isEmpty())){ 60 if(!dhcpCheckBox->isChecked() && (ipAddressEdit->text().isEmpty() || subnetMaskEdit->text().isEmpty() || firstDNSLineEdit->text().isEmpty())){
61 QMessageBox::information(this, "Empy Fields.", "Please fill in address, subnet,\n gateway and the first dns entries.", "Ok"); 61 QMessageBox::information(this, "Empy Fields.", "Please fill in address, subnet,\n gateway and the first dns entries.", "Ok");
62 return false; 62 return false;
63 } 63 }
64 interfaces->removeAllInterfaceOptions(); 64 interfaces->removeAllInterfaceOptions();
65 65
66 // DHCP 66 // DHCP
67 if(dhcpCheckBox->isChecked()){ 67 if(dhcpCheckBox->isChecked()){
68 interfaces->setInterfaceMethod(INTERFACES_METHOD_DHCP); 68 interfaces->setInterfaceMethod(INTERFACES_METHOD_DHCP);
69 interfaces->setInterfaceOption("leasehours", QString("%1").arg(leaseTime->value())); 69 interfaces->setInterfaceOption("leasehours", QString("%1").arg(leaseTime->value()));
70 interfaces->setInterfaceOption("leasetime", QString("%1").arg(leaseTime->value()*60*60)); 70 interfaces->setInterfaceOption("leasetime", QString("%1").arg(leaseTime->value()*60*60));
71 } 71 }
72 else{ 72 else{
73 interfaces->setInterfaceMethod("static"); 73 interfaces->setInterfaceMethod("static");
74 interfaces->setInterfaceOption("address", ipAddressEdit->text()); 74 interfaces->setInterfaceOption("address", ipAddressEdit->text());
75 interfaces->setInterfaceOption("netmask", subnetMaskEdit->text()); 75 interfaces->setInterfaceOption("netmask", subnetMaskEdit->text());
76 interfaces->setInterfaceOption("gateway", gatewayEdit->text()); 76 interfaces->setInterfaceOption("gateway", gatewayEdit->text());
77 QString dns = firstDNSLineEdit->text() + " " + secondDNSLineEdit->text(); 77 QString dns = firstDNSLineEdit->text() + " " + secondDNSLineEdit->text();
78 interfaces->setInterfaceOption("up "DNSSCRIPT" add ", dns); 78 interfaces->setInterfaceOption("up "DNSSCRIPT" add ", dns);
79 interfaces->setInterfaceOption("down "DNSSCRIPT" remove ", dns); 79 interfaces->setInterfaceOption("down "DNSSCRIPT" remove ", dns);
80 } 80 }
81 81
82 // IP Information 82 // IP Information
83 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked()); 83 interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked());
84 return true; 84 return true;
85} 85}
86 86
87/** 87/**
88 * The Profile has changed. 88 * The Profile has changed.
89 * @profile the new profile. 89 * @profile the new profile.
90 */ 90 */
91void InterfaceSetupImp::setProfile(const QString &profile){ 91void InterfaceSetupImp::setProfile(const QString &profile){
92 QString newInterfaceName = interface->getInterfaceName(); 92 QString newInterfaceName = interface->getInterfaceName();
93 if(profile.length() > 0) 93 if(profile.length() > 0)
94 newInterfaceName += "_" + profile; 94 newInterfaceName += "_" + profile;
95 // See if we have to make a interface. 95 // See if we have to make a interface.
96 if(!interfaces->setInterface(newInterfaceName)){ 96 if(!interfaces->setInterface(newInterfaceName)){
97 // Add making for this new interface if need too 97 // Add making for this new interface if need too
98 if(profile != ""){ 98 if(profile != ""){
99 interfaces->copyInterface(interface->getInterfaceName(), newInterfaceName); 99 interfaces->copyInterface(interface->getInterfaceName(), newInterfaceName);
100 if(!interfaces->setMapping(interface->getInterfaceName())){ 100 if(!interfaces->setMapping(interface->getInterfaceName())){
101 interfaces->addMapping(interface->getInterfaceName()); 101 interfaces->addMapping(interface->getInterfaceName());
102 if(!interfaces->setMapping(interface->getInterfaceName())){ 102 if(!interfaces->setMapping(interface->getInterfaceName())){
103 qDebug("InterfaceSetupImp: Added Mapping, but still can't set."); 103 qDebug("InterfaceSetupImp: Added Mapping, but still can't set.");
104 return; 104 return;
105 } 105 }
106 } 106 }
107 interfaces->setMap("map", newInterfaceName); 107 interfaces->setMap("map", newInterfaceName);
108 interfaces->setScript("getprofile.sh"); 108 interfaces->setScript("getprofile.sh");
109 } 109 }
110 else{ 110 else{
111 interfaces->addInterface(newInterfaceName, INTERFACES_FAMILY_INET, INTERFACES_METHOD_DHCP); 111 interfaces->addInterface(newInterfaceName, INTERFACES_FAMILY_INET, INTERFACES_METHOD_DHCP);
112 if(!interfaces->setInterface(newInterfaceName)){ 112 if(!interfaces->setInterface(newInterfaceName)){
113 qDebug("InterfaceSetupImp: Added interface, but still can't set."); 113 qDebug("InterfaceSetupImp: Added interface, but still can't set.");
114 return; 114 return;
115 } 115 }
116 } 116 }
117 } 117 }
118 118
119 // We must have a valid interface to get this far so read some settings. 119 // We must have a valid interface to get this far so read some settings.
120 120
121 // DHCP 121 // DHCP
122 bool error = false; 122 bool error = false;
123 if(interfaces->getInterfaceMethod(error) == INTERFACES_METHOD_DHCP) 123 if(interfaces->getInterfaceMethod(error) == INTERFACES_METHOD_DHCP)
124 dhcpCheckBox->setChecked(true); 124 dhcpCheckBox->setChecked(true);
125 else 125 else
126 dhcpCheckBox->setChecked(false); 126 dhcpCheckBox->setChecked(false);
127 leaseTime->setValue(interfaces->getInterfaceOption("leasehours", error).toInt()); 127 leaseTime->setValue(interfaces->getInterfaceOption("leasehours", error).toInt());
128 if(error) 128 if(error)
129 leaseTime->setValue(interfaces->getInterfaceOption("leasetime", error).toInt()/60/60); 129 leaseTime->setValue(interfaces->getInterfaceOption("leasetime", error).toInt()/60/60);
130 if(error) 130 if(error)
131 leaseTime->setValue(24); 131 leaseTime->setValue(24);
132 132
133 // IP Information 133 // IP Information
134 autoStart->setChecked(interfaces->isAuto(interface->getInterfaceName())); 134 autoStart->setChecked(interfaces->isAuto(interface->getInterfaceName()));
135 QString dns = interfaces->getInterfaceOption("up interfacednsscript add", error); 135 QString dns = interfaces->getInterfaceOption("up interfacednsscript add", error);
136 if(dns.contains(" ")){ 136 if(dns.contains(" ")){
137 firstDNSLineEdit->setText(dns.mid(0, dns.find(" "))); 137 firstDNSLineEdit->setText(dns.mid(0, dns.find(" ")));
138 secondDNSLineEdit->setText(dns.mid(dns.find(" ")+1, dns.length())); 138 secondDNSLineEdit->setText(dns.mid(dns.find(" ")+1, dns.length()));
139 } 139 }
140 ipAddressEdit->setText(interfaces->getInterfaceOption("address", error)); 140 ipAddressEdit->setText(interfaces->getInterfaceOption("address", error));
141 subnetMaskEdit->setText(interfaces->getInterfaceOption("netmask", error)); 141 subnetMaskEdit->setText(interfaces->getInterfaceOption("netmask", error));
142 gatewayEdit->setText(interfaces->getInterfaceOption("gateway", error)); 142 gatewayEdit->setText(interfaces->getInterfaceOption("gateway", error));
143} 143}
144 144
145 145
146// interfacesetup.cpp 146// interfacesetup.cpp
147 147
diff --git a/noncore/settings/networksettings/interfacesetupimp.h b/noncore/settings/networksettings/interfacesetupimp.h
index 7df0d46..a0bec32 100644
--- a/noncore/settings/networksettings/interfacesetupimp.h
+++ b/noncore/settings/networksettings/interfacesetupimp.h
@@ -1,31 +1,31 @@
1#ifndef INTERFACESETUPIMP_H 1#ifndef INTERFACESETUPIMP_H
2#define INTERFACESETUPIMP_H 2#define INTERFACESETUPIMP_H
3 3
4#include "interfacesetup.h" 4#include "interfacesetup.h"
5 5
6class Interface; 6class Interface;
7class Interfaces; 7class Interfaces;
8 8
9class InterfaceSetupImp : public InterfaceSetup { 9class InterfaceSetupImp : public InterfaceSetup {
10 Q_OBJECT 10 Q_OBJECT
11 11
12public: 12public:
13 InterfaceSetupImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, bool modal = FALSE, WFlags fl = 0); 13 InterfaceSetupImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, bool modal = FALSE, WFlags fl = 0);
14 14
15protected slots: 15protected slots:
16 void accept(); 16 void accept();
17 17
18public slots: 18public slots:
19 void setProfile(const QString &profile); 19 void setProfile(const QString &profile);
20 20
21private: 21private:
22 bool saveSettings(); 22 bool saveSettings();
23 Interfaces *interfaces; 23 Interfaces *interfaces;
24 Interface *interface; 24 Interface *interface;
25 25
26}; 26};
27 27
28#endif 28#endif
29 29
30// interfacesetupimp.h 30// interfacesetupimp.h
31 31
diff --git a/noncore/settings/networksettings/mainwindowimp.cpp b/noncore/settings/networksettings/mainwindowimp.cpp
index c86acdc..4a088cb 100644
--- a/noncore/settings/networksettings/mainwindowimp.cpp
+++ b/noncore/settings/networksettings/mainwindowimp.cpp
@@ -1,514 +1,513 @@
1#include "mainwindowimp.h" 1#include "mainwindowimp.h"
2#include "addconnectionimp.h" 2#include "addconnectionimp.h"
3#include "interfaceinformationimp.h" 3#include "interfaceinformationimp.h"
4#include "interfacesetupimp.h" 4#include "interfacesetupimp.h"
5#include "interfaces.h" 5#include "interfaces.h"
6 6
7#include "module.h" 7#include "module.h"
8 8
9#include "kprocess.h" 9#include "kprocess.h"
10 10
11#include <qpushbutton.h> 11#include <qpushbutton.h>
12#include <qtabwidget.h> 12#include <qtabwidget.h>
13#include <qlistbox.h> 13#include <qlistbox.h>
14#include <qlineedit.h> 14#include <qlineedit.h>
15#include <qlistview.h> 15#include <qlistview.h>
16#include <qheader.h> 16#include <qheader.h>
17#include <qlabel.h> 17#include <qlabel.h>
18 18
19#include <qmainwindow.h> 19#include <qmainwindow.h>
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21 21
22#include <qpe/config.h> 22#include <qpe/config.h>
23#include <qpe/qlibrary.h> 23#include <qpe/qlibrary.h>
24#include <qpe/resource.h> 24#include <qpe/resource.h>
25#include <qpe/qpeapplication.h> 25#include <qpe/qpeapplication.h>
26 26
27#include <qlist.h> 27#include <qlist.h>
28#include <qdir.h> 28#include <qdir.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qtextstream.h> 30#include <qtextstream.h>
31 31
32#define TEMP_ALL "/tmp/ifconfig-a" 32#define TEMP_ALL "/tmp/ifconfig-a"
33#define TEMP_UP "/tmp/ifconfig" 33#define TEMP_UP "/tmp/ifconfig"
34 34
35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" 35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme"
36 36
37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){ 37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){
38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); 38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked()));
39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); 39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked()));
40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); 40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked()));
41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); 41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked()));
42 42
43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile())); 43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile()));
44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile())); 44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile()));
45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile())); 45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile()));
46 46
47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&))); 47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&)));
48 // Load connections. 48 // Load connections.
49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup"); 49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup");
50 getInterfaceList(); 50 getInterfaceList();
51 connectionList->header()->hide(); 51 connectionList->header()->hide();
52 52
53 53
54 Config cfg("NetworkSetup"); 54 Config cfg("NetworkSetup");
55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); 55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All"));
56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
57 profilesList->insertItem((*it)); 57 profilesList->insertItem((*it));
58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); 58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All"));
59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); 59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false);
60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); 60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME);
61 61
62 QFile file(scheme); 62 QFile file(scheme);
63 if ( file.open(IO_ReadOnly) ) { // file opened successfully 63 if ( file.open(IO_ReadOnly) ) { // file opened successfully
64 QTextStream stream( &file ); // use a text stream 64 QTextStream stream( &file ); // use a text stream
65 while ( !stream.eof() ) { // until end of file... 65 while ( !stream.eof() ) { // until end of file...
66 QString line = stream.readLine(); // line of text excluding '\n' 66 QString line = stream.readLine(); // line of text excluding '\n'
67 if(line.contains("SCHEME")){ 67 if(line.contains("SCHEME")){
68 line = line.mid(7, line.length()); 68 line = line.mid(7, line.length());
69 currentProfileLabel->setText(line); 69 currentProfileLabel->setText(line);
70 break; 70 break;
71 } 71 }
72 } 72 }
73 file.close(); 73 file.close();
74 } 74 }
75} 75}
76 76
77/** 77/**
78 * Deconstructor. Save profiles. Delete loaded libraries. 78 * Deconstructor. Save profiles. Delete loaded libraries.
79 */ 79 */
80MainWindowImp::~MainWindowImp(){ 80MainWindowImp::~MainWindowImp(){
81 qDebug("start Saving mainwindow"); 81 qDebug("Deleting main window");
82 // Save profiles. 82 // Save profiles.
83 Config cfg("NetworkSetup"); 83 Config cfg("NetworkSetup");
84 cfg.setGroup("General"); 84 cfg.setGroup("General");
85 cfg.writeEntry("Profiles", profiles.join(" ")); 85 cfg.writeEntry("Profiles", profiles.join(" "));
86 86
87 // Delete all interfaces that don't have owners. 87 // Delete all interfaces that don't have owners.
88 QMap<Interface*, QListViewItem*>::Iterator iIt; 88 QMap<Interface*, QListViewItem*>::Iterator iIt;
89 for( iIt = items.begin(); iIt != items.end(); ++iIt ){ 89 for( iIt = items.begin(); iIt != items.end(); ++iIt ){
90 if(iIt.key()->getModuleOwner() == NULL) 90 if(iIt.key()->getModuleOwner() == NULL)
91 delete iIt.key(); 91 delete iIt.key();
92 } 92 }
93 93
94 // Delete Modules and Libraries 94 // Delete Modules and Libraries
95 QMap<Module*, QLibrary*>::Iterator it; 95 QMap<Module*, QLibrary*>::Iterator it;
96 for( it = libraries.begin(); it != libraries.end(); ++it ){ 96 for( it = libraries.begin(); it != libraries.end(); ++it ){
97 delete it.key(); 97 delete it.key();
98 delete it.data(); 98 //delete it.data();
99 } 99 }
100 qDebug("done Saving mainwindow"); 100 qDebug("Done deleting main window");
101} 101}
102 102
103/** 103/**
104 * Load all modules that are found in the path 104 * Load all modules that are found in the path
105 * @param path a directory that is scaned for any plugins that can be loaded 105 * @param path a directory that is scaned for any plugins that can be loaded
106 * and attempts to load them 106 * and attempts to load them
107 */ 107 */
108void MainWindowImp::loadModules(QString path){ 108void MainWindowImp::loadModules(QString path){
109 //qDebug(path.latin1()); 109 //qDebug(path.latin1());
110 QDir d(path); 110 QDir d(path);
111 if(!d.exists()) 111 if(!d.exists())
112 return; 112 return;
113 113
114 // Don't want sym links 114 // Don't want sym links
115 d.setFilter( QDir::Files | QDir::NoSymLinks ); 115 d.setFilter( QDir::Files | QDir::NoSymLinks );
116 const QFileInfoList *list = d.entryInfoList(); 116 const QFileInfoList *list = d.entryInfoList();
117 QFileInfoListIterator it( *list ); 117 QFileInfoListIterator it( *list );
118 QFileInfo *fi; 118 QFileInfo *fi;
119 while ( (fi=it.current()) ) { 119 while ( (fi=it.current()) ) {
120 if(fi->fileName().contains(".so")){ 120 if(fi->fileName().contains(".so")){
121 loadPlugin(path + "/" + fi->fileName()); 121 loadPlugin(path + "/" + fi->fileName());
122 } 122 }
123 ++it; 123 ++it;
124 } 124 }
125} 125}
126 126
127/** 127/**
128 * Attempt to load a function and resolve a function. 128 * Attempt to load a function and resolve a function.
129 * @param pluginFileName - the name of the file in which to attempt to load 129 * @param pluginFileName - the name of the file in which to attempt to load
130 * @param resolveString - function pointer to resolve 130 * @param resolveString - function pointer to resolve
131 * @return pointer to the function with name resolveString or NULL 131 * @return pointer to the function with name resolveString or NULL
132 */ 132 */
133Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){ 133Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){
134 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1()); 134 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1());
135 QLibrary *lib = new QLibrary(pluginFileName); 135 QLibrary *lib = new QLibrary(pluginFileName);
136 void *functionPointer = lib->resolve(resolveString); 136 void *functionPointer = lib->resolve(resolveString);
137 if( !functionPointer ){ 137 if( !functionPointer ){
138 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1()); 138 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1());
139 delete lib; 139 delete lib;
140 return NULL; 140 return NULL;
141 } 141 }
142 142
143 // Try to get an object. 143 // Try to get an object.
144 Module *object = ((Module* (*)()) functionPointer)(); 144 Module *object = ((Module* (*)()) functionPointer)();
145 if(object == NULL){ 145 if(object == NULL){
146 qDebug("MainWindowImp: Couldn't create object, but did load library!"); 146 qDebug("MainWindowImp: Couldn't create object, but did load library!");
147 delete lib; 147 delete lib;
148 return NULL; 148 return NULL;
149 } 149 }
150 150
151 // Store for deletion later 151 // Store for deletion later
152 libraries.insert(object, lib); 152 libraries.insert(object, lib);
153 return object; 153 return object;
154} 154}
155 155
156/** 156/**
157 * The Add button was clicked. Bring up the add dialog and if OK is hit 157 * The Add button was clicked. Bring up the add dialog and if OK is hit
158 * load the plugin and append it to the list 158 * load the plugin and append it to the list
159 */ 159 */
160void MainWindowImp::addClicked(){ 160void MainWindowImp::addClicked(){
161 QMap<Module*, QLibrary*>::Iterator it; 161 QMap<Module*, QLibrary*>::Iterator it;
162 QMap<QString, QString> list; 162 QMap<QString, QString> list;
163 QMap<QString, Module*> newInterfaceOwners; 163 QMap<QString, Module*> newInterfaceOwners;
164 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port"); 164 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port");
165 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port"); 165 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port");
166 for( it = libraries.begin(); it != libraries.end(); ++it ){ 166 for( it = libraries.begin(); it != libraries.end(); ++it ){
167 if(it.key()){ 167 if(it.key()){
168 (it.key())->possibleNewInterfaces(list); 168 (it.key())->possibleNewInterfaces(list);
169 } 169 }
170 } 170 }
171 // See if the list has anything that we can add. 171 // See if the list has anything that we can add.
172 if(list.count() == 0){ 172 if(list.count() == 0){
173 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok"); 173 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok");
174 return; 174 return;
175 } 175 }
176 AddConnectionImp addNewConnection(this, "AddConnectionImp", true); 176 AddConnectionImp addNewConnection(this, "AddConnectionImp", true);
177 addNewConnection.addConnections(list); 177 addNewConnection.addConnections(list);
178 addNewConnection.showMaximized(); 178 addNewConnection.showMaximized();
179 if(QDialog::Accepted == addNewConnection.exec()){ 179 if(QDialog::Accepted == addNewConnection.exec()){
180 QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); 180 QListViewItem *item = addNewConnection.registeredServicesList->currentItem();
181 if(!item) 181 if(!item)
182 return; 182 return;
183 183
184 for( it = libraries.begin(); it != libraries.end(); ++it ){ 184 for( it = libraries.begin(); it != libraries.end(); ++it ){
185 if(it.key()){ 185 if(it.key()){
186 Interface *i = (it.key())->addNewInterface(item->text(0)); 186 Interface *i = (it.key())->addNewInterface(item->text(0));
187 if(i){ 187 if(i){
188 interfaceNames.insert(i->getInterfaceName(), i); 188 interfaceNames.insert(i->getInterfaceName(), i);
189 updateInterface(i); 189 updateInterface(i);
190 } 190 }
191 } 191 }
192 } 192 }
193 } 193 }
194} 194}
195 195
196/** 196/**
197 * Prompt the user to see if they really want to do this. 197 * Prompt the user to see if they really want to do this.
198 * If they do then remove from the list and unload. 198 * If they do then remove from the list and unload.
199 */ 199 */
200void MainWindowImp::removeClicked(){ 200void MainWindowImp::removeClicked(){
201 QListViewItem *item = connectionList->currentItem(); 201 QListViewItem *item = connectionList->currentItem();
202 if(!item) { 202 if(!item) {
203 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok"); 203 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok");
204 return; 204 return;
205 } 205 }
206 206
207 Interface *i = interfaceItems[item]; 207 Interface *i = interfaceItems[item];
208 if(i->getModuleOwner() == NULL){ 208 if(i->getModuleOwner() == NULL){
209 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok"); 209 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok");
210 } 210 }
211 else{ 211 else{
212 if(!i->getModuleOwner()->remove(i)) 212 if(!i->getModuleOwner()->remove(i))
213 QMessageBox::information(this, "Error", "Unable to remove.", "Ok"); 213 QMessageBox::information(this, "Error", "Unable to remove.", "Ok");
214 else{ 214 else{
215 QMessageBox::information(this, "Success", "Interface was removed.", "Ok"); 215 QMessageBox::information(this, "Success", "Interface was removed.", "Ok");
216 // TODO memory managment.... 216 // TODO memory managment....
217 // who deletes the interface? 217 // who deletes the interface?
218 } 218 }
219 } 219 }
220} 220}
221 221
222/** 222/**
223 * Pull up the configure about the currently selected interface. 223 * Pull up the configure about the currently selected interface.
224 * Report an error if no interface is selected. 224 * Report an error if no interface is selected.
225 * If the interface has a module owner then request its configure with a empty 225 * If the interface has a module owner then request its configure with a empty
226 * tab. If tab is !NULL then append the interfaces setup widget to it. 226 * tab. If tab is !NULL then append the interfaces setup widget to it.
227 */ 227 */
228void MainWindowImp::configureClicked(){ 228void MainWindowImp::configureClicked(){
229 QListViewItem *item = connectionList->currentItem(); 229 QListViewItem *item = connectionList->currentItem();
230 if(!item){ 230 if(!item){
231 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok); 231 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok);
232 return; 232 return;
233 } 233 }
234 234
235 QString currentProfile = currentProfileLabel->text(); 235 QString currentProfile = currentProfileLabel->text();
236 if(profilesList->count() <= 1 || currentProfile == "All"){ 236 if(profilesList->count() <= 1 || currentProfile == "All"){
237 currentProfile = ""; 237 currentProfile = "";
238 } 238 }
239 239
240 Interface *i = interfaceItems[item]; 240 Interface *i = interfaceItems[item];
241 if(i->getModuleOwner()){ 241 if(i->getModuleOwner()){
242 i->getModuleOwner()->setProfile(currentProfile); 242 i->getModuleOwner()->setProfile(currentProfile);
243 QTabWidget *tabWidget = NULL; 243 QTabWidget *tabWidget = NULL;
244 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget); 244 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget);
245 if(moduleConfigure != NULL){ 245 if(moduleConfigure != NULL){
246 if(tabWidget != NULL){ 246 if(tabWidget != NULL){
247 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, true); 247 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, false, Qt::WDestructiveClose);
248 configure->setProfile(currentProfile); 248 configure->setProfile(currentProfile);
249 tabWidget->insertTab(configure, "TCP/IP"); 249 tabWidget->insertTab(configure, "TCP/IP");
250
251 } 250 }
252 moduleConfigure->showMaximized(); 251 moduleConfigure->showMaximized();
253 moduleConfigure->show(); 252 moduleConfigure->show();
254 return; 253 return;
255 } 254 }
256 } 255 }
257 256
258 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, true); 257 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, false, Qt::WDestructiveClose);
259 configure->setProfile(currentProfile); 258 configure->setProfile(currentProfile);
260 configure->showMaximized(); 259 configure->showMaximized();
261 configure->show(); 260 configure->show();
262} 261}
263 262
264/** 263/**
265 * Pull up the information about the currently selected interface. 264 * Pull up the information about the currently selected interface.
266 * Report an error if no interface is selected. 265 * Report an error if no interface is selected.
267 * If the interface has a module owner then request its configure with a empty 266 * If the interface has a module owner then request its configure with a empty
268 * tab. If tab is !NULL then append the interfaces setup widget to it. 267 * tab. If tab is !NULL then append the interfaces setup widget to it.
269 */ 268 */
270void MainWindowImp::informationClicked(){ 269void MainWindowImp::informationClicked(){
271 QListViewItem *item = connectionList->currentItem(); 270 QListViewItem *item = connectionList->currentItem();
272 if(!item){ 271 if(!item){
273 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); 272 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok);
274 return; 273 return;
275 } 274 }
276 275
277 Interface *i = interfaceItems[item]; 276 Interface *i = interfaceItems[item];
278 if(!i->isAttached()){ 277 if(!i->isAttached()){
279 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok); 278 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok);
280 return; 279 return;
281 } 280 }
282 281
283 QStringList list; 282 QStringList list;
284 for(uint i = 0; i < profilesList->count(); i++){ 283 for(uint i = 0; i < profilesList->count(); i++){
285 list.append(profilesList->text(i)); 284 list.append(profilesList->text(i));
286 } 285 }
287 286
288 if(i->getModuleOwner()){ 287 if(i->getModuleOwner()){
289 QTabWidget *tabWidget = NULL; 288 QTabWidget *tabWidget = NULL;
290 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget); 289 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget);
291 if(moduleInformation != NULL){ 290 if(moduleInformation != NULL){
292 if(tabWidget != NULL){ 291 if(tabWidget != NULL){
293 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true); 292 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true);
294 tabWidget->insertTab(information, "TCP/IP"); 293 tabWidget->insertTab(information, "TCP/IP");
295 } 294 }
296 moduleInformation->showMaximized(); 295 moduleInformation->showMaximized();
297 moduleInformation->show(); 296 moduleInformation->show();
298 return; 297 return;
299 } 298 }
300 } 299 }
301 300
302 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true); 301 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true);
303 information->showMaximized(); 302 information->showMaximized();
304 information->show(); 303 information->show();
305} 304}
306 305
307/** 306/**
308 * Aquire the list of active interfaces from ifconfig 307 * Aquire the list of active interfaces from ifconfig
309 * Call ifconfig and ifconfig -a 308 * Call ifconfig and ifconfig -a
310 */ 309 */
311void MainWindowImp::getInterfaceList(){ 310void MainWindowImp::getInterfaceList(){
312 KShellProcess *processAll = new KShellProcess(); 311 KShellProcess *processAll = new KShellProcess();
313 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL; 312 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL;
314 connect(processAll, SIGNAL(processExited(KProcess *)), 313 connect(processAll, SIGNAL(processExited(KProcess *)),
315 this, SLOT(jobDone(KProcess *))); 314 this, SLOT(jobDone(KProcess *)));
316 threads.insert(processAll, TEMP_ALL); 315 threads.insert(processAll, TEMP_ALL);
317 316
318 KShellProcess *process = new KShellProcess(); 317 KShellProcess *process = new KShellProcess();
319 *process << "/sbin/ifconfig" << " > " TEMP_UP; 318 *process << "/sbin/ifconfig" << " > " TEMP_UP;
320 connect(process, SIGNAL(processExited(KProcess *)), 319 connect(process, SIGNAL(processExited(KProcess *)),
321 this, SLOT(jobDone(KProcess *))); 320 this, SLOT(jobDone(KProcess *)));
322 threads.insert(process, TEMP_UP); 321 threads.insert(process, TEMP_UP);
323 322
324 processAll->start(KShellProcess::NotifyOnExit); 323 processAll->start(KShellProcess::NotifyOnExit);
325 process->start(KShellProcess::NotifyOnExit); 324 process->start(KShellProcess::NotifyOnExit);
326} 325}
327 326
328void MainWindowImp::jobDone(KProcess *process){ 327void MainWindowImp::jobDone(KProcess *process){
329 QString fileName = threads[process]; 328 QString fileName = threads[process];
330 threads.remove(process); 329 threads.remove(process);
331 delete process; 330 delete process;
332 331
333 QFile file(fileName); 332 QFile file(fileName);
334 if (!file.open(IO_ReadOnly)){ 333 if (!file.open(IO_ReadOnly)){
335 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1()); 334 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1());
336 return; 335 return;
337 } 336 }
338 337
339 QTextStream stream( &file ); 338 QTextStream stream( &file );
340 QString line; 339 QString line;
341 while ( !stream.eof() ) { 340 while ( !stream.eof() ) {
342 line = stream.readLine(); 341 line = stream.readLine();
343 int space = line.find(" "); 342 int space = line.find(" ");
344 if(space > 1){ 343 if(space > 1){
345 // We have found an interface 344 // We have found an interface
346 QString interfaceName = line.mid(0, space); 345 QString interfaceName = line.mid(0, space);
347 Interface *i; 346 Interface *i;
348 // We have found an interface 347 // We have found an interface
349 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1()); 348 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1());
350 // See if we already have it 349 // See if we already have it
351 if(interfaceNames.find(interfaceName) == interfaceNames.end()){ 350 if(interfaceNames.find(interfaceName) == interfaceNames.end()){
352 if(fileName == TEMP_ALL) 351 if(fileName == TEMP_ALL)
353 i = new Interface(this, interfaceName, false); 352 i = new Interface(this, interfaceName, false);
354 else 353 else
355 i = new Interface(this, interfaceName, true); 354 i = new Interface(this, interfaceName, true);
356 i->setAttached(true); 355 i->setAttached(true);
357 356
358 QString hardName = "Ethernet"; 357 QString hardName = "Ethernet";
359 int hardwareName = line.find("Link encap:"); 358 int hardwareName = line.find("Link encap:");
360 int macAddress = line.find("HWaddr"); 359 int macAddress = line.find("HWaddr");
361 if(macAddress == -1) 360 if(macAddress == -1)
362 macAddress = line.length(); 361 macAddress = line.length();
363 if(hardwareName != -1) 362 if(hardwareName != -1)
364 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) ); 363 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) );
365 364
366 interfaceNames.insert(i->getInterfaceName(), i); 365 interfaceNames.insert(i->getInterfaceName(), i);
367 updateInterface(i); 366 updateInterface(i);
368 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 367 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
369 } 368 }
370 // It was an interface we already had. 369 // It was an interface we already had.
371 else{ 370 else{
372 if(fileName != TEMP_ALL) 371 if(fileName != TEMP_ALL)
373 (interfaceNames[interfaceName])->setStatus(true); 372 (interfaceNames[interfaceName])->setStatus(true);
374 } 373 }
375 } 374 }
376 } 375 }
377 file.close(); 376 file.close();
378 QFile::remove(fileName); 377 QFile::remove(fileName);
379 378
380 if(threads.count() == 0){ 379 if(threads.count() == 0){
381 Interfaces i; 380 Interfaces i;
382 QStringList list = i.getInterfaceList(); 381 QStringList list = i.getInterfaceList();
383 QMap<QString, Interface*>::Iterator it; 382 QMap<QString, Interface*>::Iterator it;
384 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) { 383 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) {
385 bool found = false; 384 bool found = false;
386 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){ 385 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){
387 if(it.key() == (*ni)) 386 if(it.key() == (*ni))
388 found = true; 387 found = true;
389 } 388 }
390 if(!found){ 389 if(!found){
391 if(!(*ni).contains("_")){ 390 if(!(*ni).contains("_")){
392 Interface *i = new Interface(this, *ni, false); 391 Interface *i = new Interface(this, *ni, false);
393 i->setAttached(false); 392 i->setAttached(false);
394 i->setHardwareName("Disconnected"); 393 i->setHardwareName("Disconnected");
395 interfaceNames.insert(i->getInterfaceName(), i); 394 interfaceNames.insert(i->getInterfaceName(), i);
396 updateInterface(i); 395 updateInterface(i);
397 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 396 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
398 } 397 }
399 } 398 }
400 } 399 }
401 } 400 }
402} 401}
403 402
404/** 403/**
405 * Update this interface. If no QListViewItem exists create one. 404 * Update this interface. If no QListViewItem exists create one.
406 * @param Interface* pointer to the interface that needs to be updated. 405 * @param Interface* pointer to the interface that needs to be updated.
407 */ 406 */
408void MainWindowImp::updateInterface(Interface *i){ 407void MainWindowImp::updateInterface(Interface *i){
409 if(!advancedUserMode){ 408 if(!advancedUserMode){
410 if(i->getInterfaceName() == "lo") 409 if(i->getInterfaceName() == "lo")
411 return; 410 return;
412 } 411 }
413 412
414 QListViewItem *item = NULL; 413 QListViewItem *item = NULL;
415 414
416 // Find the interface, making it if needed. 415 // Find the interface, making it if needed.
417 if(items.find(i) == items.end()){ 416 if(items.find(i) == items.end()){
418 item = new QListViewItem(connectionList, "", "", ""); 417 item = new QListViewItem(connectionList, "", "", "");
419 // See if you can't find a module owner for this interface 418 // See if you can't find a module owner for this interface
420 QMap<Module*, QLibrary*>::Iterator it; 419 QMap<Module*, QLibrary*>::Iterator it;
421 for( it = libraries.begin(); it != libraries.end(); ++it ){ 420 for( it = libraries.begin(); it != libraries.end(); ++it ){
422 if(it.key()->isOwner(i)) 421 if(it.key()->isOwner(i))
423 i->setModuleOwner(it.key()); 422 i->setModuleOwner(it.key());
424 } 423 }
425 items.insert(i, item); 424 items.insert(i, item);
426 interfaceItems.insert(item, i); 425 interfaceItems.insert(item, i);
427 } 426 }
428 else 427 else
429 item = items[i]; 428 item = items[i];
430 429
431 // Update the icons and information 430 // Update the icons and information
432 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down"))); 431 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down")));
433 432
434 QString typeName = "lan"; 433 QString typeName = "lan";
435 if(i->getHardwareName().contains("Local Loopback")) 434 if(i->getHardwareName().contains("Local Loopback"))
436 typeName = "lo"; 435 typeName = "lo";
437 if(i->getInterfaceName().contains("irda")) 436 if(i->getInterfaceName().contains("irda"))
438 typeName = "irda"; 437 typeName = "irda";
439 if(i->getInterfaceName().contains("wlan")) 438 if(i->getInterfaceName().contains("wlan"))
440 typeName = "wlan"; 439 typeName = "wlan";
441 if(i->getInterfaceName().contains("usb")) 440 if(i->getInterfaceName().contains("usb"))
442 typeName = "usb"; 441 typeName = "usb";
443 442
444 if(!i->isAttached()) 443 if(!i->isAttached())
445 typeName = "connect_no"; 444 typeName = "connect_no";
446 // Actually try to use the Module 445 // Actually try to use the Module
447 if(i->getModuleOwner() != NULL) 446 if(i->getModuleOwner() != NULL)
448 typeName = i->getModuleOwner()->getPixmapName(i); 447 typeName = i->getModuleOwner()->getPixmapName(i);
449 448
450 item->setPixmap(1, (Resource::loadPixmap(typeName))); 449 item->setPixmap(1, (Resource::loadPixmap(typeName)));
451 item->setText(2, i->getHardwareName()); 450 item->setText(2, i->getHardwareName());
452 item->setText(3, QString("(%1)").arg(i->getInterfaceName())); 451 item->setText(3, QString("(%1)").arg(i->getInterfaceName()));
453 item->setText(4, (i->getStatus()) ? i->getIp() : QString("")); 452 item->setText(4, (i->getStatus()) ? i->getIp() : QString(""));
454} 453}
455 454
456void MainWindowImp::newProfileChanged(const QString& newText){ 455void MainWindowImp::newProfileChanged(const QString& newText){
457 if(newText.length() > 0) 456 if(newText.length() > 0)
458 newProfileButton->setEnabled(true); 457 newProfileButton->setEnabled(true);
459 else 458 else
460 newProfileButton->setEnabled(false); 459 newProfileButton->setEnabled(false);
461} 460}
462 461
463/** 462/**
464 * Adds a new profile to the list of profiles. 463 * Adds a new profile to the list of profiles.
465 * Don't add profiles that already exists. 464 * Don't add profiles that already exists.
466 * Appends to the list and QStringList 465 * Appends to the list and QStringList
467 */ 466 */
468void MainWindowImp::addProfile(){ 467void MainWindowImp::addProfile(){
469 QString newProfileName = newProfile->text(); 468 QString newProfileName = newProfile->text();
470 if(profiles.grep(newProfileName).count() > 0){ 469 if(profiles.grep(newProfileName).count() > 0){
471 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok"); 470 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok");
472 return; 471 return;
473 } 472 }
474 profiles.append(newProfileName); 473 profiles.append(newProfileName);
475 profilesList->insertItem(newProfileName); 474 profilesList->insertItem(newProfileName);
476} 475}
477 476
478/** 477/**
479 * Removes the currently selected profile in the combo. 478 * Removes the currently selected profile in the combo.
480 * Doesn't delete if there are less then 2 profiles. 479 * Doesn't delete if there are less then 2 profiles.
481 */ 480 */
482void MainWindowImp::removeProfile(){ 481void MainWindowImp::removeProfile(){
483 if(profilesList->count() <= 1){ 482 if(profilesList->count() <= 1){
484 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok"); 483 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok");
485 return; 484 return;
486 } 485 }
487 QString profileToRemove = profilesList->currentText(); 486 QString profileToRemove = profilesList->currentText();
488 if(profileToRemove == "All"){ 487 if(profileToRemove == "All"){
489 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok"); 488 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok");
490 return; 489 return;
491 } 490 }
492 // Can't remove the curent profile 491 // Can't remove the curent profile
493 if(profileToRemove == currentProfileLabel->text()){ 492 if(profileToRemove == currentProfileLabel->text()){
494 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok"); 493 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok");
495 return; 494 return;
496 495
497 } 496 }
498 497
499 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){ 498 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){
500 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), "")); 499 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), ""));
501 profilesList->clear(); 500 profilesList->clear();
502 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 501 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
503 profilesList->insertItem((*it)); 502 profilesList->insertItem((*it));
504 503
505 // Remove any interface settings and mappings. 504 // Remove any interface settings and mappings.
506 Interfaces interfaces; 505 Interfaces interfaces;
507 // Go through them one by one 506 // Go through them one by one
508 QMap<Interface*, QListViewItem*>::Iterator it; 507 QMap<Interface*, QListViewItem*>::Iterator it;
509 for( it = items.begin(); it != items.end(); ++it ){ 508 for( it = items.begin(); it != items.end(); ++it ){
510 QString interfaceName = it.key()->getInterfaceName(); 509 QString interfaceName = it.key()->getInterfaceName();
511 qDebug(interfaceName.latin1()); 510 qDebug(interfaceName.latin1());
512 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){ 511 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){
513 interfaces.removeInterface(); 512 interfaces.removeInterface();
514 if(interfaces.setMapping(interfaceName)){ 513 if(interfaces.setMapping(interfaceName)){
diff --git a/noncore/settings/networksettings/networksetup.pro b/noncore/settings/networksettings/networksetup.pro
index f09db93..7299cc6 100644
--- a/noncore/settings/networksettings/networksetup.pro
+++ b/noncore/settings/networksettings/networksetup.pro
@@ -1,11 +1,11 @@
1 DESTDIR = $(OPIEDIR)/bin 1 #DESTDIR = $(OPIEDIR)/bin
2 TEMPLATE= app 2 TEMPLATE= app
3 #CONFIG = qt warn_on debug 3 CONFIG = qt warn_on debug
4 CONFIG = qt warn_on release 4 #CONFIG = qt warn_on release
5 HEADERS = mainwindowimp.h addconnectionimp.h interface.h interfaceinformationimp.h interfacesetupimp.h interfaces.h defaultmodule.h kprocctrl.h module.h kprocess.h 5 HEADERS = mainwindowimp.h addconnectionimp.h interface.h interfaceinformationimp.h interfacesetupimp.h interfaces.h defaultmodule.h kprocctrl.h module.h kprocess.h
6 SOURCES = main.cpp mainwindowimp.cpp addconnectionimp.cpp interface.cpp interfaceinformationimp.cpp interfacesetupimp.cpp kprocctrl.cpp kprocess.cpp interfaces.cpp 6 SOURCES = main.cpp mainwindowimp.cpp addconnectionimp.cpp interface.cpp interfaceinformationimp.cpp interfacesetupimp.cpp kprocctrl.cpp kprocess.cpp interfaces.cpp
7 INCLUDEPATH+= $(OPIEDIR)/include 7 INCLUDEPATH+= $(OPIEDIR)/include
8 DEPENDPATH+= $(OPIEDIR)/include 8 DEPENDPATH+= $(OPIEDIR)/include
9LIBS += -lqpe 9LIBS += -lqpe
10 INTERFACES= mainwindow.ui addconnection.ui interfaceinformation.ui interfaceadvanced.ui interfacesetup.ui 10 INTERFACES= mainwindow.ui addconnection.ui interfaceinformation.ui interfaceadvanced.ui interfacesetup.ui
11 TARGET = networksetup 11 TARGET = networksetup
diff --git a/noncore/settings/networksettings/wlan/wlan.pro b/noncore/settings/networksettings/wlan/wlan.pro
index 432a096..814a0b4 100644
--- a/noncore/settings/networksettings/wlan/wlan.pro
+++ b/noncore/settings/networksettings/wlan/wlan.pro
@@ -1,12 +1,12 @@
1TEMPLATE = lib 1TEMPLATE = lib
2CONFIG += qt warn_on release 2#CONFIG += qt warn_on release
3 #CONFIG += qt warn_on debug 3 CONFIG += qt warn_on debug
4DESTDIR = $(OPIEDIR)/plugins/networksetup 4#DESTDIR = $(OPIEDIR)/plugins/networksetup
5 HEADERS = wlanimp.h wlanmodule.h wextensions.h 5 HEADERS = wlanimp.h wlanmodule.h wextensions.h
6 SOURCES = wlanimp.cpp wlanmodule.cpp wextensions.cpp 6 SOURCES = wlanimp.cpp wlanmodule.cpp wextensions.cpp
7 INCLUDEPATH+= $(OPIEDIR)/include ../ 7 INCLUDEPATH+= $(OPIEDIR)/include ../
8 DEPENDPATH+= $(OPIEDIR)/include 8 DEPENDPATH+= $(OPIEDIR)/include
9LIBS += -lqpe 9LIBS += -lqpe
10 INTERFACES= wlan.ui info.ui 10 INTERFACES= wlan.ui info.ui
11 TARGET = wlanplugin 11 TARGET = wlanplugin
12 VERSION = 1.0.0 12 VERSION = 1.0.0
diff --git a/noncore/settings/networksettings/wlan/wlanimp.cpp b/noncore/settings/networksettings/wlan/wlanimp.cpp
index 94c7518..45952b9 100644
--- a/noncore/settings/networksettings/wlan/wlanimp.cpp
+++ b/noncore/settings/networksettings/wlan/wlanimp.cpp
@@ -1,239 +1,234 @@
1#include "wlanimp.h" 1#include "wlanimp.h"
2 2
3/* Config class */ 3/* Config class */
4#include <qpe/config.h> 4#include <qpe/config.h>
5/* Global namespace */ 5/* Global namespace */
6#include <qpe/global.h> 6#include <qpe/global.h>
7/* system() */ 7/* system() */
8#include <stdlib.h> 8#include <stdlib.h>
9#include <qfile.h> 9#include <qfile.h>
10#include <qdir.h> 10#include <qdir.h>
11#include <qtextstream.h> 11#include <qtextstream.h>
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13#include <qlineedit.h> 13#include <qlineedit.h>
14#include <qspinbox.h> 14#include <qspinbox.h>
15#include <qradiobutton.h> 15#include <qradiobutton.h>
16#include <qcheckbox.h> 16#include <qcheckbox.h>
17#include <qregexp.h> 17#include <qregexp.h>
18 18
19WLANImp::WLANImp( QWidget* parent, const char* name):WLAN(parent, name, Qt::WDestructiveClose){ 19WLANImp::WLANImp( QWidget* parent, const char* name, bool modal, WFlags fl):WLAN(parent, name, modal, fl){
20 config = new Config("wireless"); 20 config = new Config("wireless");
21 readConfig(); 21 readConfig();
22} 22}
23 23
24WLANImp::~WLANImp( ){ 24WLANImp::~WLANImp( ){
25 delete config; 25 delete config;
26} 26}
27 27
28void WLANImp::readConfig() 28void WLANImp::readConfig()
29{ 29{
30 qWarning( "WLANImp::readConfig() called." ); 30 qWarning( "WLANImp::readConfig() called." );
31 config->setGroup( "Properties" ); 31 config->setGroup( "Properties" );
32 QString ssid = config->readEntry( "SSID", "any" ); 32 QString ssid = config->readEntry( "SSID", "any" );
33 if( ssid == "any" || ssid == "ANY" ){ 33 if( ssid == "any" || ssid == "ANY" ){
34 essNon->setChecked( true ); 34 essNon->setChecked( true );
35 } else { 35 } else {
36 essSpecific->setChecked( true ); 36 essSpecific->setChecked( true );
37 essSpecificLineEdit->setText( ssid ); 37 essSpecificLineEdit->setText( ssid );
38 } 38 }
39 QString mode = config->readEntry( "Mode", "Managed" ); 39 QString mode = config->readEntry( "Mode", "Managed" );
40 if( mode == "adhoc" ) { 40 if( mode == "adhoc" ) {
41 network802->setChecked( true ); 41 network802->setChecked( true );
42 } else { 42 } else {
43 networkInfrastructure->setChecked( true ); 43 networkInfrastructure->setChecked( true );
44 } 44 }
45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) ); 45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) );
46// config->readEntry( "RATE", "auto" ); 46// config->readEntry( "RATE", "auto" );
47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false ); 47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false );
48 config->readEntry( "AuthType", "opensystem" ); 48 config->readEntry( "AuthType", "opensystem" );
49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true ); 49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true );
50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
51 switch( defaultkey ){ 51 switch( defaultkey ){
52 case 0: 52 case 0:
53 keyRadio0->setChecked( true ); 53 keyRadio0->setChecked( true );
54 break; 54 break;
55 case 1: 55 case 1:
56 keyRadio1->setChecked( true ); 56 keyRadio1->setChecked( true );
57 break; 57 break;
58 case 2: 58 case 2:
59 keyRadio2->setChecked( true ); 59 keyRadio2->setChecked( true );
60 break; 60 break;
61 case 3: 61 case 3:
62 keyRadio3->setChecked( true ); 62 keyRadio3->setChecked( true );
63 break; 63 break;
64 } 64 }
65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" )); 65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" ));
66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" )); 66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" ));
67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" )); 67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" ));
68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" )); 68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" ));
69 return; 69 return;
70} 70}
71 71
72bool WLANImp::writeConfig() 72bool WLANImp::writeConfig()
73{ 73{
74 qWarning( "WLANImp::writeConfig() called." ); 74 qWarning( "WLANImp::writeConfig() called." );
75 config->setGroup( "Properties" ); 75 config->setGroup( "Properties" );
76 if( essNon->isChecked() ) { 76 if( essNon->isChecked() ) {
77 config->writeEntry( "SSID", "any" ); 77 config->writeEntry( "SSID", "any" );
78 } else { 78 } else {
79 config->writeEntry( "SSID", essSpecificLineEdit->text() ); 79 config->writeEntry( "SSID", essSpecificLineEdit->text() );
80 } 80 }
81 if( networkInfrastructure->isChecked() ){ 81 if( networkInfrastructure->isChecked() ){
82 config->writeEntry( "Mode", "Managed" ); 82 config->writeEntry( "Mode", "Managed" );
83 } else if( network802->isChecked() ){ 83 } else if( network802->isChecked() ){
84 config->writeEntry( "Mode", "adhoc" ); 84 config->writeEntry( "Mode", "adhoc" );
85 } 85 }
86 config->writeEntry( "CHANNEL", networkChannel->value() ); 86 config->writeEntry( "CHANNEL", networkChannel->value() );
87// config->readEntry( "RATE", "auto" ); 87// config->readEntry( "RATE", "auto" );
88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" ); 88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" );
89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" ); 89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" );
90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" ); 90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" );
91 if( keyRadio0->isChecked() ){ 91 if( keyRadio0->isChecked() ){
92 config->writeEntry( "dot11WEPDefaultKeyID", 0 ); 92 config->writeEntry( "dot11WEPDefaultKeyID", 0 );
93 } else if( keyRadio1->isChecked() ){ 93 } else if( keyRadio1->isChecked() ){
94 config->writeEntry( "dot11WEPDefaultKeyID", 1 ); 94 config->writeEntry( "dot11WEPDefaultKeyID", 1 );
95 } else if( keyRadio2->isChecked() ){ 95 } else if( keyRadio2->isChecked() ){
96 config->writeEntry( "dot11WEPDefaultKeyID", 2 ); 96 config->writeEntry( "dot11WEPDefaultKeyID", 2 );
97 } else if( keyRadio3->isChecked() ){ 97 } else if( keyRadio3->isChecked() ){
98 config->writeEntry( "dot11WEPDefaultKeyID", 3 ); 98 config->writeEntry( "dot11WEPDefaultKeyID", 3 );
99 } 99 }
100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() ); 100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() );
101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() ); 101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() );
102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() ); 102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() );
103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() ); 103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() );
104 return true;
104 return writeWirelessOpts( ); 105 return writeWirelessOpts( );
105} 106}
106 107
107/** 108/**
108 */ 109 */
109void WLANImp::accept() 110void WLANImp::accept()
110{ 111{
111 if ( writeConfig() ) 112 if ( writeConfig() )
112 QDialog::accept(); 113 QDialog::accept();
113} 114}
114 115
115void WLANImp::done ( int r )
116{
117 QDialog::done ( r );
118 close ( );
119}
120
121bool WLANImp::writeWirelessOpts( QString scheme ) 116bool WLANImp::writeWirelessOpts( QString scheme )
122{ 117{
123 qWarning( "WLANImp::writeWirelessOpts entered." ); 118 qWarning( "WLANImp::writeWirelessOpts entered." );
124 QString prev = "/etc/pcmcia/wireless.opts"; 119 QString prev = "/etc/pcmcia/wireless.opts";
125 QFile prevFile(prev); 120 QFile prevFile(prev);
126 if ( !prevFile.open( IO_ReadOnly ) ) 121 if ( !prevFile.open( IO_ReadOnly ) )
127 return false; 122 return false;
128 123
129 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new"; 124 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new";
130 QFile tmpFile(tmp); 125 QFile tmpFile(tmp);
131 if ( !tmpFile.open( IO_WriteOnly ) ) 126 if ( !tmpFile.open( IO_WriteOnly ) )
132 return false; 127 return false;
133 128
134 bool retval = true; 129 bool retval = true;
135 130
136 QTextStream in( &prevFile ); 131 QTextStream in( &prevFile );
137 QTextStream out( &tmpFile ); 132 QTextStream out( &tmpFile );
138 133
139 config->setGroup("Properties"); 134 config->setGroup("Properties");
140 135
141 QString line; 136 QString line;
142 bool found=false; 137 bool found=false;
143 bool done=false; 138 bool done=false;
144 while ( !in.atEnd() ) { 139 while ( !in.atEnd() ) {
145 QString line = in.readLine(); 140 QString line = in.readLine();
146 QString wline = line.simplifyWhiteSpace(); 141 QString wline = line.simplifyWhiteSpace();
147 if ( !done ) { 142 if ( !done ) {
148 if ( found ) { 143 if ( found ) {
149 // skip existing entry for this scheme, and write our own. 144 // skip existing entry for this scheme, and write our own.
150 if ( wline == ";;" ) { 145 if ( wline == ";;" ) {
151 found = false; 146 found = false;
152 continue; 147 continue;
153 } else { 148 } else {
154 continue; 149 continue;
155 } 150 }
156 } else { 151 } else {
157 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) { 152 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) {
158 found=true; 153 found=true;
159 continue; // skip this line 154 continue; // skip this line
160 } else if ( wline == "esac" || wline == "*,*,*,*)" ) { 155 } else if ( wline == "esac" || wline == "*,*,*,*)" ) {
161 // end - add new entry 156 // end - add new entry
162 // Not all fields have a GUI, but all are supported 157 // Not all fields have a GUI, but all are supported
163 // in the letwork configuration files. 158 // in the letwork configuration files.
164 static const char* txtfields[] = { 159 static const char* txtfields[] = {
165 0 160 0
166 }; 161 };
167 QString readmode = config->readEntry( "Mode", "Managed" ); 162 QString readmode = config->readEntry( "Mode", "Managed" );
168 QString mode; 163 QString mode;
169 if( readmode == "Managed" ){ 164 if( readmode == "Managed" ){
170 mode = readmode; 165 mode = readmode;
171 } else if( readmode == "adhoc" ){ 166 } else if( readmode == "adhoc" ){
172 mode = "Ad-Hoc"; 167 mode = "Ad-Hoc";
173 } 168 }
174 QString key; 169 QString key;
175 if( wepEnabled->isChecked() ){ 170 if( wepEnabled->isChecked() ){
176 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 171 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
177 switch( defaultkey ){ 172 switch( defaultkey ){
178 case 0: 173 case 0:
179 key += keyLineEdit0->text(); 174 key += keyLineEdit0->text();
180 break; 175 break;
181 case 1: 176 case 1:
182 key += keyLineEdit1->text(); 177 key += keyLineEdit1->text();
183 break; 178 break;
184 case 2: 179 case 2:
185 key += keyLineEdit2->text(); 180 key += keyLineEdit2->text();
186 break; 181 break;
187 case 3: 182 case 3:
188 key += keyLineEdit3->text(); 183 key += keyLineEdit3->text();
189 break; 184 break;
190 } 185 }
191 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem") 186 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem")
192 key += " open"; 187 key += " open";
193 } 188 }
194 out << scheme << ",*,*,*)" << "\n" 189 out << scheme << ",*,*,*)" << "\n"
195 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n" 190 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n"
196 << " MODE=" << mode << "\n" 191 << " MODE=" << mode << "\n"
197 << " KEY=" << Global::shellQuote( key ) << "\n" 192 << " KEY=" << Global::shellQuote( key ) << "\n"
198 << " RATE=" << "auto" << "\n" 193 << " RATE=" << "auto" << "\n"
199 ; 194 ;
200 if( mode != "Managed" ) 195 if( mode != "Managed" )
201 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n"; 196 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n";
202 const char** f = txtfields; 197 const char** f = txtfields;
203 while (*f) { 198 while (*f) {
204 out << " " << *f << "=" << config->readEntry(*f,"") << "\n"; 199 out << " " << *f << "=" << config->readEntry(*f,"") << "\n";
205 ++f; 200 ++f;
206 } 201 }
207 out << " ;;\n"; 202 out << " ;;\n";
208 done = true; 203 done = true;
209 } 204 }
210 } 205 }
211 } 206 }
212 out << line << "\n"; 207 out << line << "\n";
213 } 208 }
214 209
215 prevFile.close(); 210 prevFile.close();
216 tmpFile.close(); 211 tmpFile.close();
217 QString initpath; 212 QString initpath;
218 //system("cardctl suspend"); 213 //system("cardctl suspend");
219 if( QDir("/etc/rc.d/init.d").exists() ){ 214 if( QDir("/etc/rc.d/init.d").exists() ){
220 initpath = "/etc/rc.d/init.d"; 215 initpath = "/etc/rc.d/init.d";
221 } else if( QDir("/etc/init.d").exists() ){ 216 } else if( QDir("/etc/init.d").exists() ){
222 initpath = "/etc/init.d"; 217 initpath = "/etc/init.d";
223 } 218 }
224 if( initpath ) 219 if( initpath )
225 system(QString("%1/pcmcia stop").arg(initpath)); 220 system(QString("%1/pcmcia stop").arg(initpath));
226 221
227 if( system( "mv " + tmp + " " + prev ) ) 222 if( system( "mv " + tmp + " " + prev ) )
228 retval = false; 223 retval = false;
229//#ifdef USE_SCHEMES 224//#ifdef USE_SCHEMES
230// if ( retval ) 225// if ( retval )
231 //SchemeChanger::changeScheme(scheme); 226 //SchemeChanger::changeScheme(scheme);
232//#endif 227//#endif
233 228
234 //system("cardctl resume"); 229 //system("cardctl resume");
235 if( initpath ) 230 if( initpath )
236 system(QString("%1/pcmcia start").arg(initpath)); 231 system(QString("%1/pcmcia start").arg(initpath));
237 232
238 return retval; 233 return retval;
239} 234}
diff --git a/noncore/settings/networksettings/wlan/wlanimp.h b/noncore/settings/networksettings/wlan/wlanimp.h
index 22ce143..59b7c59 100644
--- a/noncore/settings/networksettings/wlan/wlanimp.h
+++ b/noncore/settings/networksettings/wlan/wlanimp.h
@@ -1,28 +1,27 @@
1#ifndef WLANIMP_H 1#ifndef WLANIMP_H
2#define WLANIMP_H 2#define WLANIMP_H
3 3
4#include "wlan.h" 4#include "wlan.h"
5 5
6#include <qpe/config.h> 6#include <qpe/config.h>
7 7
8class WLANImp : public WLAN { 8class WLANImp : public WLAN {
9 Q_OBJECT 9 Q_OBJECT
10 10
11public: 11public:
12 WLANImp( QWidget* parent = 0, const char* name = 0); 12 WLANImp( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 );
13 ~WLANImp( ); 13 ~WLANImp( );
14 14
15protected: 15protected:
16 void accept(); 16 void accept();
17 void done ( int r );
18 17
19private: 18private:
20 void readConfig(); 19 void readConfig();
21 bool writeConfig(); 20 bool writeConfig();
22 bool writeWirelessOpts( QString scheme = "*" ); 21 bool writeWirelessOpts( QString scheme = "*" );
23 bool writeWlanngOpts( QString scheme = "*" ); 22 bool writeWlanngOpts( QString scheme = "*" );
24 Config* config; 23 Config* config;
25}; 24};
26 25
27#endif 26#endif
28 27
diff --git a/noncore/settings/networksettings/wlan/wlanmodule.cpp b/noncore/settings/networksettings/wlan/wlanmodule.cpp
index 7507c54..3363b8a 100644
--- a/noncore/settings/networksettings/wlan/wlanmodule.cpp
+++ b/noncore/settings/networksettings/wlan/wlanmodule.cpp
@@ -1,129 +1,126 @@
1#include "wlanmodule.h" 1#include "wlanmodule.h"
2#include "wlanimp.h" 2#include "wlanimp.h"
3#include "info.h" 3#include "info.h"
4#include "wextensions.h" 4#include "wextensions.h"
5 5
6#include <qlabel.h> 6#include <qlabel.h>
7#include <qprogressbar.h> 7#include <qprogressbar.h>
8 8
9/** 9/**
10 * Constructor, find all of the possible interfaces 10 * Constructor, find all of the possible interfaces
11 */ 11 */
12WLANModule::WLANModule() : Module() { 12WLANModule::WLANModule() : Module() {
13} 13}
14 14
15/** 15/**
16 */ 16 */
17WLANModule::~WLANModule(){ 17WLANModule::~WLANModule(){
18 qDebug("Deleting module");
18 Interface *i; 19 Interface *i;
19 for ( i=list.first(); i != 0; i=list.next() ) 20 for ( i=list.first(); i != 0; i=list.next() )
20 delete i; 21 delete i;
21} 22}
22 23
23/** 24/**
24 * Change the current profile 25 * Change the current profile
25 */ 26 */
26void WLANModule::setProfile(QString newProfile){ 27void WLANModule::setProfile(QString newProfile){
27 profile = newProfile; 28 profile = newProfile;
28} 29}
29 30
30/** 31/**
31 * get the icon name for this device. 32 * get the icon name for this device.
32 * @param Interface* can be used in determining the icon. 33 * @param Interface* can be used in determining the icon.
33 * @return QString the icon name (minus .png, .gif etc) 34 * @return QString the icon name (minus .png, .gif etc)
34 */ 35 */
35QString WLANModule::getPixmapName(Interface* ){ 36QString WLANModule::getPixmapName(Interface* ){
36 return "wlan"; 37 return "wlan";
37} 38}
38 39
39/** 40/**
40 * Check to see if the interface i is owned by this module. 41 * Check to see if the interface i is owned by this module.
41 * @param Interface* interface to check against 42 * @param Interface* interface to check against
42 * @return bool true if i is owned by this module, false otherwise. 43 * @return bool true if i is owned by this module, false otherwise.
43 */ 44 */
44bool WLANModule::isOwner(Interface *i){ 45bool WLANModule::isOwner(Interface *i){
45 WExtensions we(i->getInterfaceName()); 46 WExtensions we(i->getInterfaceName());
46 if(!we.doesHaveWirelessExtensions()) 47 if(!we.doesHaveWirelessExtensions())
47 return false; 48 return false;
48 49
49 i->setHardwareName("802.11b"); 50 i->setHardwareName("802.11b");
50 list.append(i); 51 list.append(i);
51 return true; 52 return true;
52} 53}
53 54
54/** 55/**
55 * Create, set tabWiget and return the WLANConfigure Module 56 * Create, set tabWiget and return the WLANConfigure Module
56 * @param tabWidget a pointer to the tab widget that this configure has. 57 * @param tabWidget a pointer to the tab widget that this configure has.
57 * @return QWidget* pointer to the tab widget in this modules configure. 58 * @return QWidget* pointer to the tab widget in this modules configure.
58 */ 59 */
59QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){ 60QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){
60 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig"); 61 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig", false, Qt::WDestructiveClose);
61 (*tabWidget) = wlanconfig->tabWidget; 62 (*tabWidget) = wlanconfig->tabWidget;
62 return wlanconfig; 63 return wlanconfig;
63} 64}
64 65
65/** 66/**
66 * Create, set tabWiget and return the Information Module 67 * Create, set tabWiget and return the Information Module
67 * @param tabWidget a pointer to the tab widget that this information has. 68 * @param tabWidget a pointer to the tab widget that this information has.
68 * @return QWidget* pointer to the tab widget in this modules info. 69 * @return QWidget* pointer to the tab widget in this modules info.
69 */ 70 */
70QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){ 71QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){
71 WExtensions we(i->getInterfaceName()); 72 WExtensions we(i->getInterfaceName());
72 if(!we.doesHaveWirelessExtensions()) 73 if(!we.doesHaveWirelessExtensions())
73 return NULL; 74 return NULL;
74 75
75 WlanInfo *info = new WlanInfo(0, "wireless info", Qt::WDestructiveClose); 76 WlanInfo *info = new WlanInfo(0, "wireless info", Qt::WDestructiveClose);
76 (*tabWidget) = info->tabWidget; 77 (*tabWidget) = info->tabWidget;
77 78
78 info->essidLabel->setText(we.essid()); 79 info->essidLabel->setText(we.essid());
79 info->apLabel->setText(we.ap()); 80 info->apLabel->setText(we.ap());
80 info->stationLabel->setText(we.station()); 81 info->stationLabel->setText(we.station());
81 info->modeLabel->setText(we.mode()); 82 info->modeLabel->setText(we.mode());
82 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency())); 83 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency()));
83 int signal = 0; 84 int signal = 0;
84 int noise = 0; 85 int noise = 0;
85 int quality = 0; 86 int quality = 0;
86 we.stats(signal, noise, quality); 87 we.stats(signal, noise, quality);
87 info->signalProgressBar->setProgress(signal); 88 info->signalProgressBar->setProgress(signal);
88 info->noiseProgressBar->setProgress(noise); 89 info->noiseProgressBar->setProgress(noise);
89 info->qualityProgressBar->setProgress(quality); 90 info->qualityProgressBar->setProgress(quality);
90 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate())); 91 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate()));
91 //WlanInfo info (0, "wireless info", true);
92 //info.show();
93 //return NULL;
94
95 return info; 92 return info;
96} 93}
97 94
98/** 95/**
99 * Get all active (up or down) interfaces 96 * Get all active (up or down) interfaces
100 * @return QList<Interface> A list of interfaces that exsist that havn't 97 * @return QList<Interface> A list of interfaces that exsist that havn't
101 * been called by isOwner() 98 * been called by isOwner()
102 */ 99 */
103QList<Interface> WLANModule::getInterfaces(){ 100QList<Interface> WLANModule::getInterfaces(){
104 return list; 101 return list;
105} 102}
106 103
107/** 104/**
108 * Attempt to add a new interface as defined by name 105 * Attempt to add a new interface as defined by name
109 * @param name the name of the type of interface that should be created given 106 * @param name the name of the type of interface that should be created given
110 * by possibleNewInterfaces(); 107 * by possibleNewInterfaces();
111 * @return Interface* NULL if it was unable to be created. 108 * @return Interface* NULL if it was unable to be created.
112 */ 109 */
113Interface *WLANModule::addNewInterface(QString ){ 110Interface *WLANModule::addNewInterface(QString ){
114 // We can't add a 802.11 interface, either the hardware will be there 111 // We can't add a 802.11 interface, either the hardware will be there
115 // or it wont. 112 // or it wont.
116 return NULL; 113 return NULL;
117} 114}
118 115
119/** 116/**
120 * Attempts to remove the interface, doesn't delete i 117 * Attempts to remove the interface, doesn't delete i
121 * @return bool true if successfull, false otherwise. 118 * @return bool true if successfull, false otherwise.
122 */ 119 */
123bool WLANModule::remove(Interface*){ 120bool WLANModule::remove(Interface*){
124 // Can't remove a hardware device, you can stop it though. 121 // Can't remove a hardware device, you can stop it though.
125 return false; 122 return false;
126} 123}
127 124
128// wlanmodule.cpp 125// wlanmodule.cpp
129 126