-rw-r--r-- | noncore/settings/networksettings/mainwindow/mainwindowimp.cpp | 56 |
1 files changed, 13 insertions, 43 deletions
diff --git a/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp b/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp index a4a2875..fb7d7c9 100644 --- a/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp +++ b/noncore/settings/networksettings/mainwindow/mainwindowimp.cpp | |||
@@ -10,200 +10,191 @@ | |||
10 | #include <opie2/odebug.h> | 10 | #include <opie2/odebug.h> |
11 | #include <qpe/qcopenvelope_qws.h> | 11 | #include <qpe/qcopenvelope_qws.h> |
12 | #include <qpe/qpeapplication.h> | 12 | #include <qpe/qpeapplication.h> |
13 | #include <qpe/config.h> | 13 | #include <qpe/config.h> |
14 | #include <qpe/qlibrary.h> | 14 | #include <qpe/qlibrary.h> |
15 | #include <qpe/resource.h> | 15 | #include <qpe/resource.h> |
16 | 16 | ||
17 | /* QT */ | 17 | /* QT */ |
18 | #include <qpushbutton.h> | 18 | #include <qpushbutton.h> |
19 | #include <qlistbox.h> | 19 | #include <qlistbox.h> |
20 | #include <qlineedit.h> | 20 | #include <qlineedit.h> |
21 | #include <qlistview.h> | 21 | #include <qlistview.h> |
22 | #include <qheader.h> | 22 | #include <qheader.h> |
23 | #include <qlabel.h> | 23 | #include <qlabel.h> |
24 | #include <qtabwidget.h> // in order to disable the profiles tab | 24 | #include <qtabwidget.h> // in order to disable the profiles tab |
25 | #include <qmessagebox.h> | 25 | #include <qmessagebox.h> |
26 | 26 | ||
27 | 27 | ||
28 | #if QT_VERSION < 300 | 28 | #if QT_VERSION < 300 |
29 | #include <qlist.h> | 29 | #include <qlist.h> |
30 | #else | 30 | #else |
31 | #include <qptrlist.h> | 31 | #include <qptrlist.h> |
32 | #endif | 32 | #endif |
33 | #include <qdir.h> | 33 | #include <qdir.h> |
34 | #include <qfile.h> | 34 | #include <qfile.h> |
35 | #include <qtextstream.h> | 35 | #include <qtextstream.h> |
36 | #include <qregexp.h> | 36 | #include <qregexp.h> |
37 | 37 | ||
38 | /* STD */ | 38 | /* STD */ |
39 | #include <net/if.h> | 39 | #include <net/if.h> |
40 | #include <sys/ioctl.h> | 40 | #include <sys/ioctl.h> |
41 | #include <sys/socket.h> | 41 | #include <sys/socket.h> |
42 | 42 | ||
43 | #define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" | 43 | #define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" |
44 | #define _PROCNETDEV "/proc/net/dev" | 44 | #define _PROCNETDEV "/proc/net/dev" |
45 | 45 | ||
46 | MainWindowImp::MainWindowImp(QWidget *parent, const char *name, WFlags) : MainWindow(parent, name, Qt::WStyle_ContextHelp), advancedUserMode(true), scheme(DEFAULT_SCHEME) | 46 | MainWindowImp::MainWindowImp(QWidget *parent, const char *name, WFlags) : MainWindow(parent, name, Qt::WStyle_ContextHelp), advancedUserMode(true), scheme(DEFAULT_SCHEME) |
47 | { | 47 | { |
48 | connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); | 48 | connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); |
49 | connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); | 49 | connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); |
50 | connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); | 50 | connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); |
51 | connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); | 51 | connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); |
52 | 52 | ||
53 | //remove tab with no function | 53 | //remove tab with no function |
54 | tabWidget->removePage( tab ); | 54 | tabWidget->removePage( tab ); |
55 | 55 | ||
56 | // Load connections. | 56 | // Load connections. |
57 | // /usr/local/kde/lib/libinterfaces.la | 57 | // /usr/local/kde/lib/libinterfaces.la |
58 | #ifdef QWS | ||
59 | loadModules(QPEApplication::qpeDir() + "plugins/networksettings"); | 58 | loadModules(QPEApplication::qpeDir() + "plugins/networksettings"); |
60 | #else | ||
61 | loader = KLibLoader::self(); | ||
62 | loadModules(QString("/usr/")+KStandardDirs::kde_default("lib")); | ||
63 | #endif | ||
64 | getAllInterfaces(); | 59 | getAllInterfaces(); |
65 | 60 | ||
66 | Interfaces i; | 61 | Interfaces i; |
67 | QStringList list = i.getInterfaceList(); | 62 | QStringList list = i.getInterfaceList(); |
68 | QMap<QString, Interface*>::Iterator it; | 63 | QMap<QString, Interface*>::Iterator it; |
69 | for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) | 64 | for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) |
70 | { | 65 | { |
71 | /* | 66 | /* |
72 | * we skipped it in getAllInterfaces now | 67 | * we skipped it in getAllInterfaces now |
73 | * we need to ignore it as well | 68 | * we need to ignore it as well |
74 | */ | 69 | */ |
75 | if (m_handledIfaces.contains( *ni) ) | 70 | if (m_handledIfaces.contains( *ni) ) |
76 | { | 71 | { |
77 | odebug << "Not up iface handled by module" << oendl; | 72 | odebug << "Not up iface handled by module" << oendl; |
78 | continue; | 73 | continue; |
79 | } | 74 | } |
80 | bool found = false; | 75 | bool found = false; |
81 | for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ) | 76 | for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ) |
82 | { | 77 | { |
83 | if(it.key() == (*ni)) | 78 | if(it.key() == (*ni)) |
84 | found = true; | 79 | found = true; |
85 | } | 80 | } |
86 | if(!found) | 81 | if(!found) |
87 | { | 82 | { |
88 | if(!(*ni).contains("_")) | 83 | if(!(*ni).contains("_")) |
89 | { | 84 | { |
90 | Interface *i = new Interface(this, *ni, false); | 85 | Interface *i = new Interface(this, *ni, false); |
91 | i->setAttached(false); | 86 | i->setAttached(false); |
92 | i->setHardwareName(tr("Disconnected")); | 87 | i->setHardwareName(tr("Disconnected")); |
93 | interfaceNames.insert(i->getInterfaceName(), i); | 88 | interfaceNames.insert(i->getInterfaceName(), i); |
94 | updateInterface(i); | 89 | updateInterface(i); |
95 | connect(i, SIGNAL(updateInterface(Interface*)), this, SLOT(updateInterface(Interface*))); | 90 | connect(i, SIGNAL(updateInterface(Interface*)), this, SLOT(updateInterface(Interface*))); |
96 | } | 91 | } |
97 | } | 92 | } |
98 | } | 93 | } |
99 | 94 | ||
100 | //getInterfaceList(); | 95 | //getInterfaceList(); |
101 | connectionList->header()->hide(); | 96 | connectionList->header()->hide(); |
102 | 97 | ||
103 | Config cfg("NetworkSetup"); | 98 | Config cfg("NetworkSetup"); |
104 | profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); | 99 | profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); |
105 | for ( QStringList::Iterator it = profiles.begin(); | 100 | for ( QStringList::Iterator it = profiles.begin(); |
106 | it != profiles.end(); ++it) | 101 | it != profiles.end(); ++it) |
107 | profilesList->insertItem((*it)); | 102 | profilesList->insertItem((*it)); |
108 | currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); | 103 | currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); |
109 | advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); | 104 | advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); |
110 | scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); | 105 | scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); |
111 | 106 | ||
112 | QFile file(scheme); | 107 | QFile file(scheme); |
113 | if ( file.open(IO_ReadOnly) ) | 108 | if ( file.open(IO_ReadOnly) ) |
114 | { // file opened successfully | 109 | { // file opened successfully |
115 | QTextStream stream( &file ); // use a text stream | 110 | QTextStream stream( &file ); // use a text stream |
116 | while ( !stream.eof() ) | 111 | while ( !stream.eof() ) |
117 | { // until end of file... | 112 | { // until end of file... |
118 | QString line = stream.readLine(); // line of text excluding '\n' | 113 | QString line = stream.readLine(); // line of text excluding '\n' |
119 | if(line.contains("SCHEME")) | 114 | if(line.contains("SCHEME")) |
120 | { | 115 | { |
121 | line = line.mid(7, line.length()); | 116 | line = line.mid(7, line.length()); |
122 | currentProfileLabel->setText(line); | 117 | currentProfileLabel->setText(line); |
123 | break; | 118 | break; |
124 | } | 119 | } |
125 | } | 120 | } |
126 | file.close(); | 121 | file.close(); |
127 | } | 122 | } |
128 | makeChannel(); | 123 | makeChannel(); |
129 | } | 124 | } |
130 | 125 | ||
131 | /** | 126 | /** |
132 | * Deconstructor. Save profiles. Delete loaded libraries. | 127 | * Deconstructor. Save profiles. Delete loaded libraries. |
133 | */ | 128 | */ |
134 | MainWindowImp::~MainWindowImp() | 129 | MainWindowImp::~MainWindowImp() |
135 | { | 130 | { |
136 | // Save profiles. | 131 | // Save profiles. |
137 | Config cfg("NetworkSetup"); | 132 | Config cfg("NetworkSetup"); |
138 | cfg.setGroup("General"); | 133 | cfg.setGroup("General"); |
139 | cfg.writeEntry("Profiles", profiles.join(" ")); | 134 | cfg.writeEntry("Profiles", profiles.join(" ")); |
140 | 135 | ||
141 | // Delete all interfaces that don't have owners. | 136 | // Delete all interfaces that don't have owners. |
142 | QMap<Interface*, QListViewItem*>::Iterator iIt; | 137 | QMap<Interface*, QListViewItem*>::Iterator iIt; |
143 | for( iIt = items.begin(); iIt != items.end(); ++iIt ) | 138 | for( iIt = items.begin(); iIt != items.end(); ++iIt ) |
144 | { | 139 | { |
145 | if(iIt.key()->getModuleOwner() == NULL) | 140 | if(iIt.key()->getModuleOwner() == NULL) |
146 | delete iIt.key(); | 141 | delete iIt.key(); |
147 | } | 142 | } |
148 | 143 | ||
149 | #ifdef QWS | ||
150 | // Delete Modules and Libraries | 144 | // Delete Modules and Libraries |
151 | QMap<Module*, QLibrary*>::Iterator it; | 145 | QMap<Module*, QLibrary*>::Iterator it; |
152 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 146 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
153 | { | 147 | { |
154 | delete it.key(); | 148 | delete it.key(); |
155 | // I wonder why I can't delete the libraries | 149 | // I wonder why I can't delete the libraries |
156 | // What fucking shit this is. | 150 | // What fucking shit this is. |
157 | //delete it.data(); | 151 | //delete it.data(); |
158 | } | 152 | } |
159 | #else | ||
160 | // klibloader automaticly deletes the libraries for us... | ||
161 | #endif | ||
162 | } | 153 | } |
163 | 154 | ||
164 | /** | 155 | /** |
165 | * Query the kernel for all of the interfaces. | 156 | * Query the kernel for all of the interfaces. |
166 | */ | 157 | */ |
167 | void MainWindowImp::getAllInterfaces() | 158 | void MainWindowImp::getAllInterfaces() |
168 | { | 159 | { |
169 | int sockfd = socket(PF_INET, SOCK_DGRAM, 0); | 160 | int sockfd = socket(PF_INET, SOCK_DGRAM, 0); |
170 | if(sockfd == -1) | 161 | if(sockfd == -1) |
171 | return; | 162 | return; |
172 | 163 | ||
173 | struct ifreq ifr; | 164 | struct ifreq ifr; |
174 | QStringList ifaces; | 165 | QStringList ifaces; |
175 | QFile procFile(QString(_PROCNETDEV)); | 166 | QFile procFile(QString(_PROCNETDEV)); |
176 | int result; | 167 | int result; |
177 | Interface *i; | 168 | Interface *i; |
178 | 169 | ||
179 | if (! procFile.exists()) | 170 | if (! procFile.exists()) |
180 | { | 171 | { |
181 | struct ifreq ifrs[100]; | 172 | struct ifreq ifrs[100]; |
182 | struct ifconf ifc; | 173 | struct ifconf ifc; |
183 | ifc.ifc_len = sizeof(ifrs); | 174 | ifc.ifc_len = sizeof(ifrs); |
184 | ifc.ifc_req = ifrs; | 175 | ifc.ifc_req = ifrs; |
185 | result = ioctl(sockfd, SIOCGIFCONF, &ifc); | 176 | result = ioctl(sockfd, SIOCGIFCONF, &ifc); |
186 | 177 | ||
187 | for (unsigned int i = 0; i < ifc.ifc_len / sizeof(struct ifreq); i++) | 178 | for (unsigned int i = 0; i < ifc.ifc_len / sizeof(struct ifreq); i++) |
188 | { | 179 | { |
189 | struct ifreq *pifr = &ifrs[i]; | 180 | struct ifreq *pifr = &ifrs[i]; |
190 | 181 | ||
191 | ifaces += pifr->ifr_name; | 182 | ifaces += pifr->ifr_name; |
192 | } | 183 | } |
193 | } | 184 | } |
194 | else | 185 | else |
195 | { | 186 | { |
196 | procFile.open(IO_ReadOnly); | 187 | procFile.open(IO_ReadOnly); |
197 | QString line; | 188 | QString line; |
198 | QTextStream procTs(&procFile); | 189 | QTextStream procTs(&procFile); |
199 | int loc = -1; | 190 | int loc = -1; |
200 | 191 | ||
201 | procTs.readLine(); // eat a line | 192 | procTs.readLine(); // eat a line |
202 | procTs.readLine(); // eat a line | 193 | procTs.readLine(); // eat a line |
203 | while((line = procTs.readLine().simplifyWhiteSpace()) != QString::null) | 194 | while((line = procTs.readLine().simplifyWhiteSpace()) != QString::null) |
204 | { | 195 | { |
205 | if((loc = line.find(":")) != -1) | 196 | if((loc = line.find(":")) != -1) |
206 | { | 197 | { |
207 | ifaces += line.left(loc); | 198 | ifaces += line.left(loc); |
208 | } | 199 | } |
209 | } | 200 | } |
@@ -239,178 +230,157 @@ void MainWindowImp::getAllInterfaces() | |||
239 | i->setHardwareName("Point to Point"); | 230 | i->setHardwareName("Point to Point"); |
240 | else if ((flags & IFF_MULTICAST) == IFF_MULTICAST) | 231 | else if ((flags & IFF_MULTICAST) == IFF_MULTICAST) |
241 | i->setHardwareName("Multicast"); | 232 | i->setHardwareName("Multicast"); |
242 | else if ((flags & IFF_LOOPBACK) == IFF_LOOPBACK) | 233 | else if ((flags & IFF_LOOPBACK) == IFF_LOOPBACK) |
243 | i->setHardwareName("Loopback"); | 234 | i->setHardwareName("Loopback"); |
244 | else | 235 | else |
245 | i->setHardwareName("Unknown"); | 236 | i->setHardwareName("Unknown"); |
246 | 237 | ||
247 | owarn << "Adding interface " << ifr.ifr_name << " to interfaceNames\n" << oendl; | 238 | owarn << "Adding interface " << ifr.ifr_name << " to interfaceNames\n" << oendl; |
248 | interfaceNames.insert(i->getInterfaceName(), i); | 239 | interfaceNames.insert(i->getInterfaceName(), i); |
249 | updateInterface(i); | 240 | updateInterface(i); |
250 | connect(i, SIGNAL(updateInterface(Interface*)), | 241 | connect(i, SIGNAL(updateInterface(Interface*)), |
251 | this, SLOT(updateInterface(Interface*))); | 242 | this, SLOT(updateInterface(Interface*))); |
252 | } | 243 | } |
253 | // now lets ask the plugins too ;) | 244 | // now lets ask the plugins too ;) |
254 | QMap<Module*, QLibrary*>::Iterator it; | 245 | QMap<Module*, QLibrary*>::Iterator it; |
255 | QList<Interface> ilist; | 246 | QList<Interface> ilist; |
256 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 247 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
257 | { | 248 | { |
258 | if(it.key()) | 249 | if(it.key()) |
259 | { | 250 | { |
260 | ilist = it.key()->getInterfaces(); | 251 | ilist = it.key()->getInterfaces(); |
261 | for( i = ilist.first(); i != 0; i = ilist.next() ) | 252 | for( i = ilist.first(); i != 0; i = ilist.next() ) |
262 | { | 253 | { |
263 | owarn << "Adding interface " << i->getInterfaceName().latin1() << " to interfaceNames\n" << oendl; | 254 | owarn << "Adding interface " << i->getInterfaceName().latin1() << " to interfaceNames\n" << oendl; |
264 | interfaceNames.insert(i->getInterfaceName(), i); | 255 | interfaceNames.insert(i->getInterfaceName(), i); |
265 | updateInterface(i); | 256 | updateInterface(i); |
266 | connect(i, SIGNAL(updateInterface(Interface*)), | 257 | connect(i, SIGNAL(updateInterface(Interface*)), |
267 | this, SLOT(updateInterface(Interface*))); | 258 | this, SLOT(updateInterface(Interface*))); |
268 | } | 259 | } |
269 | } | 260 | } |
270 | } | 261 | } |
271 | } | 262 | } |
272 | 263 | ||
273 | /** | 264 | /** |
274 | * Load all modules that are found in the path | 265 | * Load all modules that are found in the path |
275 | * @param path a directory that is scaned for any plugins that can be loaded | 266 | * @param path a directory that is scaned for any plugins that can be loaded |
276 | * and attempts to load them | 267 | * and attempts to load them |
277 | */ | 268 | */ |
278 | void MainWindowImp::loadModules(const QString &path) | 269 | void MainWindowImp::loadModules(const QString &path) |
279 | { | 270 | { |
280 | #ifdef DEBUG | 271 | #ifdef DEBUG |
281 | odebug << "MainWindowImp::loadModules: " << path.latin1() << "" << oendl; | 272 | odebug << "MainWindowImp::loadModules: " << path.latin1() << "" << oendl; |
282 | #endif | 273 | #endif |
283 | QDir d(path); | 274 | QDir d(path); |
284 | if(!d.exists()) | 275 | if(!d.exists()) |
285 | return; | 276 | return; |
286 | 277 | ||
278 | QString lang = ::getenv("LANG"); | ||
287 | // Don't want sym links | 279 | // Don't want sym links |
288 | d.setFilter( QDir::Files | QDir::NoSymLinks ); | 280 | d.setFilter( QDir::Files | QDir::NoSymLinks ); |
289 | const QFileInfoList *list = d.entryInfoList(); | 281 | const QFileInfoList *list = d.entryInfoList(); |
290 | QFileInfoListIterator it( *list ); | 282 | QFileInfoListIterator it( *list ); |
291 | QFileInfo *fi; | 283 | QFileInfo *fi; |
292 | while ( (fi=it.current()) ) | 284 | while ( (fi=it.current()) ) |
293 | { | 285 | { |
294 | #ifdef QWS | ||
295 | if(fi->fileName().contains(".so")) | 286 | if(fi->fileName().contains(".so")) |
296 | { | 287 | { |
297 | #else | 288 | /* if loaded install translation */ |
298 | if(fi->fileName().contains(".so") && fi->fileName().contains("networksettings_")) | 289 | if( loadPlugin(path + "/" + fi->fileName()) != 0l ){ |
299 | { | 290 | QTranslator *trans = new QTranslator(qApp); |
300 | #endif | 291 | QString fn = QPEApplication::qpeDir()+"/i18n/"+lang+"/"+ fi->fileName().left( fi->fileName().find(".") )+".qm"; |
301 | loadPlugin(path + "/" + fi->fileName()); | 292 | if( trans->load( fn ) ) |
293 | qApp->installTranslator( trans ); | ||
294 | else | ||
295 | delete trans; | ||
296 | } | ||
302 | odebug << "loaded plugin: >" << QString(path + "/" + fi->fileName()).latin1() << "< " << oendl; | 297 | odebug << "loaded plugin: >" << QString(path + "/" + fi->fileName()).latin1() << "< " << oendl; |
303 | } | 298 | } |
304 | ++it; | 299 | ++it; |
305 | } | 300 | } |
306 | } | 301 | } |
307 | 302 | ||
308 | /** | 303 | /** |
309 | * Attempt to load a function and resolve a function. | 304 | * Attempt to load a function and resolve a function. |
310 | * @param pluginFileName - the name of the file in which to attempt to load | 305 | * @param pluginFileName - the name of the file in which to attempt to load |
311 | * @param resolveString - function pointer to resolve | 306 | * @param resolveString - function pointer to resolve |
312 | * @return pointer to the function with name resolveString or NULL | 307 | * @return pointer to the function with name resolveString or NULL |
313 | */ | 308 | */ |
314 | Module* MainWindowImp::loadPlugin(const QString &pluginFileName, const QString &resolveString) | 309 | Module* MainWindowImp::loadPlugin(const QString &pluginFileName, const QString &resolveString) |
315 | { | 310 | { |
316 | #ifdef DEBUG | 311 | #ifdef DEBUG |
317 | odebug << "MainWindowImp::loadPlugin: " << pluginFileName.latin1() << ": resolving " << resolveString.latin1() << "" << oendl; | 312 | odebug << "MainWindowImp::loadPlugin: " << pluginFileName.latin1() << ": resolving " << resolveString.latin1() << "" << oendl; |
318 | #endif | 313 | #endif |
319 | #ifdef QWS | ||
320 | QLibrary *lib = new QLibrary(pluginFileName); | 314 | QLibrary *lib = new QLibrary(pluginFileName); |
321 | void *functionPointer = lib->resolve(resolveString); | 315 | void *functionPointer = lib->resolve(resolveString); |
322 | if( !functionPointer ) | 316 | if( !functionPointer ) |
323 | { | 317 | { |
324 | #ifdef DEBUG | 318 | #ifdef DEBUG |
325 | odebug << "MainWindowImp::loadPlugin: Warning: " << pluginFileName.latin1() << " is not a plugin" << oendl; | 319 | odebug << "MainWindowImp::loadPlugin: Warning: " << pluginFileName.latin1() << " is not a plugin" << oendl; |
326 | #endif | 320 | #endif |
327 | delete lib; | 321 | delete lib; |
328 | return NULL; | 322 | return 0; |
329 | } | 323 | } |
330 | // Try to get an object. | 324 | // Try to get an object. |
331 | Module *object = ((Module* (*)()) functionPointer)(); | 325 | Module *object = ((Module* (*)()) functionPointer)(); |
332 | if(object == NULL) | 326 | if(object == 0) |
333 | { | 327 | { |
334 | #ifdef DEBUG | 328 | #ifdef DEBUG |
335 | odebug << "MainWindowImp: Couldn't create object, but did load library!" << oendl; | 329 | odebug << "MainWindowImp: Couldn't create object, but did load library!" << oendl; |
336 | #endif | 330 | #endif |
337 | delete lib; | 331 | delete lib; |
338 | return NULL; | 332 | return 0; |
339 | } | 333 | } |
340 | 334 | ||
341 | m_handledIfaces += object->handledInterfaceNames(); | 335 | m_handledIfaces += object->handledInterfaceNames(); |
342 | // Store for deletion later | 336 | // Store for deletion later |
343 | libraries.insert(object, lib); | 337 | libraries.insert(object, lib); |
344 | return object; | 338 | return object; |
345 | |||
346 | #else | ||
347 | QLibrary *lib = loader->library(pluginFileName); | ||
348 | if( !lib || !lib->hasSymbol(resolveString) ) | ||
349 | { | ||
350 | odebug << QString("MainWindowImp::loadPlugin: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1() << oendl; | ||
351 | return NULL; | ||
352 | } | ||
353 | // Try to get an object. | ||
354 | Module *object = ((Module* (*)()) lib->symbol(resolveString))(); | ||
355 | if(object == NULL) | ||
356 | { | ||
357 | #ifdef DEBUG | ||
358 | odebug << "MainWindowImp: Couldn't create object, but did load library!" << oendl; | ||
359 | #endif | ||
360 | return NULL; | ||
361 | } | ||
362 | #ifdef DEBUG | ||
363 | odebug << "MainWindowImp::loadPlugin:: Found object, storing." << oendl; | ||
364 | #endif | ||
365 | // Store for deletion later | ||
366 | libraries.insert(object, lib); | ||
367 | return object; | ||
368 | #endif | ||
369 | } | 339 | } |
370 | 340 | ||
371 | /** | 341 | /** |
372 | * The Add button was clicked. Bring up the add dialog and if OK is hit | 342 | * The Add button was clicked. Bring up the add dialog and if OK is hit |
373 | * load the plugin and append it to the list | 343 | * load the plugin and append it to the list |
374 | */ | 344 | */ |
375 | void MainWindowImp::addClicked() | 345 | void MainWindowImp::addClicked() |
376 | { | 346 | { |
377 | QMap<Module*, QLibrary*>::Iterator it; | 347 | QMap<Module*, QLibrary*>::Iterator it; |
378 | QMap<QString, QString> list; | 348 | QMap<QString, QString> list; |
379 | QMap<QString, Module*> newInterfaceOwners; | 349 | QMap<QString, Module*> newInterfaceOwners; |
380 | 350 | ||
381 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 351 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
382 | { | 352 | { |
383 | if(it.key()) | 353 | if(it.key()) |
384 | { | 354 | { |
385 | (it.key())->possibleNewInterfaces(list); | 355 | (it.key())->possibleNewInterfaces(list); |
386 | } | 356 | } |
387 | } | 357 | } |
388 | // See if the list has anything that we can add. | 358 | // See if the list has anything that we can add. |
389 | if(list.count() == 0) | 359 | if(list.count() == 0) |
390 | { | 360 | { |
391 | QMessageBox::information(this, "Sorry", "Nothing to add.", QMessageBox::Ok); | 361 | QMessageBox::information(this, "Sorry", "Nothing to add.", QMessageBox::Ok); |
392 | return; | 362 | return; |
393 | } | 363 | } |
394 | AddConnectionImp addNewConnection(this, "AddConnectionImp", true); | 364 | AddConnectionImp addNewConnection(this, "AddConnectionImp", true); |
395 | addNewConnection.addConnections(list); | 365 | addNewConnection.addConnections(list); |
396 | if( QDialog::Accepted == QPEApplication::execDialog( &addNewConnection ) ) | 366 | if( QDialog::Accepted == QPEApplication::execDialog( &addNewConnection ) ) |
397 | { | 367 | { |
398 | QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); | 368 | QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); |
399 | if(!item) | 369 | if(!item) |
400 | return; | 370 | return; |
401 | 371 | ||
402 | for( it = libraries.begin(); it != libraries.end(); ++it ) | 372 | for( it = libraries.begin(); it != libraries.end(); ++it ) |
403 | { | 373 | { |
404 | if(it.key()) | 374 | if(it.key()) |
405 | { | 375 | { |
406 | Interface *i = (it.key())->addNewInterface(item->text(0)); | 376 | Interface *i = (it.key())->addNewInterface(item->text(0)); |
407 | if(i) | 377 | if(i) |
408 | { | 378 | { |
409 | odebug << "iface name " << i->getInterfaceName().latin1() << "" << oendl; | 379 | odebug << "iface name " << i->getInterfaceName().latin1() << "" << oendl; |
410 | interfaceNames.insert(i->getInterfaceName(), i); | 380 | interfaceNames.insert(i->getInterfaceName(), i); |
411 | updateInterface(i); | 381 | updateInterface(i); |
412 | } | 382 | } |
413 | } | 383 | } |
414 | } | 384 | } |
415 | } | 385 | } |
416 | } | 386 | } |