summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--noncore/settings/networksettings/interfaces/interfacesetupimp.cpp75
-rw-r--r--noncore/settings/networksettings/interfaces/interfacesetupimp.h6
2 files changed, 50 insertions, 31 deletions
diff --git a/noncore/settings/networksettings/interfaces/interfacesetupimp.cpp b/noncore/settings/networksettings/interfaces/interfacesetupimp.cpp
index 56bbe93..2a5520d 100644
--- a/noncore/settings/networksettings/interfaces/interfacesetupimp.cpp
+++ b/noncore/settings/networksettings/interfaces/interfacesetupimp.cpp
@@ -16,3 +16,18 @@
*/
-InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, WFlags fl) : InterfaceSetup(parent, name, fl), interface(i){
+InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, Interfaces *j, WFlags fl) : InterfaceSetup(parent, name, fl), interfaces(j), interface(i), delInterfaces(false){
+}
+
+/**
+ * Constuctor. Set up the connection. A profile must be set.
+ */
+InterfaceSetupImp::InterfaceSetupImp(QWidget* parent, const char* name, Interface *i, WFlags fl) : InterfaceSetup(parent, name, fl), interface(i), delInterfaces(true){
+ interfaces = new Interfaces;
+}
+
+/**
+ * Destructor
+ */
+InterfaceSetupImp::~InterfaceSetupImp(){
+ if(delInterfaces)
+ delete interfaces;
}
@@ -25,3 +40,3 @@ bool InterfaceSetupImp::saveChanges(){
return false;
- interfaces.write();
+ interfaces->write();
return true;
@@ -35,3 +50,3 @@ bool InterfaceSetupImp::saveSettings(){
// eh can't really do anything about it other then return. :-D
- if(!interfaces.isInterfaceSet())
+ if(!interfaces->isInterfaceSet())
return true;
@@ -40,4 +55,4 @@ bool InterfaceSetupImp::saveSettings(){
// Loopback case
- if(interfaces.getInterfaceMethod(error) == INTERFACES_LOOPBACK){
- interfaces.setAuto(interface->getInterfaceName(), autoStart->isChecked());
+ if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){
+ interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked());
return true;
@@ -49,3 +64,3 @@ bool InterfaceSetupImp::saveSettings(){
}
- interfaces.removeAllInterfaceOptions();
+ interfaces->removeAllInterfaceOptions();
@@ -53,12 +68,12 @@ bool InterfaceSetupImp::saveSettings(){
if(dhcpCheckBox->isChecked())
- interfaces.setInterfaceMethod(INTERFACES_METHOD_DHCP);
+ interfaces->setInterfaceMethod(INTERFACES_METHOD_DHCP);
else{
- interfaces.setInterfaceMethod("static");
- interfaces.setInterfaceOption("address", ipAddressEdit->text());
- interfaces.setInterfaceOption("netmask", subnetMaskEdit->text());
- interfaces.setInterfaceOption("gateway", gatewayEdit->text());
+ interfaces->setInterfaceMethod("static");
+ interfaces->setInterfaceOption("address", ipAddressEdit->text());
+ interfaces->setInterfaceOption("netmask", subnetMaskEdit->text());
+ interfaces->setInterfaceOption("gateway", gatewayEdit->text());
if(!firstDNSLineEdit->text().isEmpty() || !secondDNSLineEdit->text().isEmpty()){
QString dns = firstDNSLineEdit->text() + " " + secondDNSLineEdit->text();
- interfaces.setInterfaceOption("up "DNSSCRIPT" -a ", dns);
- interfaces.setInterfaceOption("down "DNSSCRIPT" -r ", dns);
+ interfaces->setInterfaceOption("up "DNSSCRIPT" -a ", dns);
+ interfaces->setInterfaceOption("down "DNSSCRIPT" -r ", dns);
}
@@ -67,3 +82,3 @@ bool InterfaceSetupImp::saveSettings(){
// IP Information
- interfaces.setAuto(interface->getInterfaceName(), autoStart->isChecked());
+ interfaces->setAuto(interface->getInterfaceName(), autoStart->isChecked());
return true;
@@ -78,3 +93,3 @@ void InterfaceSetupImp::setProfile(const QString &profile){
bool error = false;
- if(interfaces.getInterfaceMethod(error) == INTERFACES_LOOPBACK){
+ if(interfaces->getInterfaceMethod(error) == INTERFACES_LOOPBACK){
staticGroupBox->hide();
@@ -90,9 +105,9 @@ void InterfaceSetupImp::setProfile(const QString &profile){
// See if we have to make a interface.
- if(!interfaces.setInterface(newInterfaceName)){
+ if(!interfaces->setInterface(newInterfaceName)){
// Add making for this new interface if need too
if(profile != ""){
- interfaces.copyInterface(interface->getInterfaceName(), newInterfaceName);
- if(!interfaces.setMapping(interface->getInterfaceName())){
- interfaces.addMapping(interface->getInterfaceName());
- if(!interfaces.setMapping(interface->getInterfaceName())){
+ interfaces->copyInterface(interface->getInterfaceName(), newInterfaceName);
+ if(!interfaces->setMapping(interface->getInterfaceName())){
+ interfaces->addMapping(interface->getInterfaceName());
+ if(!interfaces->setMapping(interface->getInterfaceName())){
qDebug("InterfaceSetupImp: Added Mapping, but still can't setInterface.");
@@ -101,8 +116,8 @@ void InterfaceSetupImp::setProfile(const QString &profile){
}
- interfaces.setMap("map", newInterfaceName);
- interfaces.setScript("getprofile.sh");
+ interfaces->setMap("map", newInterfaceName);
+ interfaces->setScript("getprofile.sh");
}
else{
- interfaces.addInterface(newInterfaceName, INTERFACES_FAMILY_INET, INTERFACES_METHOD_DHCP);
- if(!interfaces.setInterface(newInterfaceName)){
+ interfaces->addInterface(newInterfaceName, INTERFACES_FAMILY_INET, INTERFACES_METHOD_DHCP);
+ if(!interfaces->setInterface(newInterfaceName)){
qDebug("InterfaceSetupImp: Added interface, but still can't setInterface.");
@@ -117,3 +132,3 @@ void InterfaceSetupImp::setProfile(const QString &profile){
bool error = false;
- if(interfaces.getInterfaceMethod(error) == INTERFACES_METHOD_DHCP)
+ if(interfaces->getInterfaceMethod(error) == INTERFACES_METHOD_DHCP)
dhcpCheckBox->setChecked(true);
@@ -123,4 +138,4 @@ void InterfaceSetupImp::setProfile(const QString &profile){
// IP Information
- autoStart->setChecked(interfaces.isAuto(interface->getInterfaceName()));
- QString dns = interfaces.getInterfaceOption("up "DNSSCRIPT" -a", error);
+ autoStart->setChecked(interfaces->isAuto(interface->getInterfaceName()));
+ QString dns = interfaces->getInterfaceOption("up "DNSSCRIPT" -a", error);
if(dns.contains(" ")){
@@ -129,5 +144,5 @@ void InterfaceSetupImp::setProfile(const QString &profile){
}
- ipAddressEdit->setText(interfaces.getInterfaceOption("address", error));
- subnetMaskEdit->setText(interfaces.getInterfaceOption("netmask", error));
- gatewayEdit->setText(interfaces.getInterfaceOption("gateway", error));
+ ipAddressEdit->setText(interfaces->getInterfaceOption("address", error));
+ subnetMaskEdit->setText(interfaces->getInterfaceOption("netmask", error));
+ gatewayEdit->setText(interfaces->getInterfaceOption("gateway", error));
}
diff --git a/noncore/settings/networksettings/interfaces/interfacesetupimp.h b/noncore/settings/networksettings/interfaces/interfacesetupimp.h
index 9ec526c..c4ace77 100644
--- a/noncore/settings/networksettings/interfaces/interfacesetupimp.h
+++ b/noncore/settings/networksettings/interfaces/interfacesetupimp.h
@@ -14,2 +14,4 @@ public:
InterfaceSetupImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, WFlags fl = 0);
+ InterfaceSetupImp( QWidget* parent = 0, const char* name = 0, Interface *i = 0, Interfaces *j = 0, WFlags fl = 0);
+ ~InterfaceSetupImp();
bool saveChanges();
@@ -21,4 +23,6 @@ public slots:
private:
- Interfaces interfaces;
+ Interfaces *interfaces;
Interface *interface;
+
+ bool delInterfaces;
};