diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | bcb704366cb5e333a626c18c308c7e0448a8e69f (patch) | |
tree | f0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /ksirc/objFinder.cpp | |
download | tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'ksirc/objFinder.cpp')
-rw-r--r-- | ksirc/objFinder.cpp | 160 |
1 files changed, 160 insertions, 0 deletions
diff --git a/ksirc/objFinder.cpp b/ksirc/objFinder.cpp new file mode 100644 index 00000000..4625b6cf --- /dev/null +++ b/ksirc/objFinder.cpp @@ -0,0 +1,160 @@ +#include "objFinder.h" + +#include <qapplication.h> +#include <qobjectlist.h> +#include <qwidgetlist.h> + +#include <stdlib.h> +#include <time.h> + +#include <kdebug.h> + +QDict<QObject> *objFinder::objList = new QDict<QObject>; + +/* + * So we can connect to the slots, etc + */ +objFinder *objFind = new objFinder(); + +objFinder::objFinder() + : QObject() +{ +} + +objFinder::~objFinder() +{ +} + +void objFinder::insert(QObject *obj, const char *key){ + QString name; + + if(obj == 0x0){ + qWarning("objFinder: Passed Null Object"); + return; + } + + if(key != 0){ + name = key; + } + else { + name = obj->name(); + if(name == 0){ + name = randString(); + } + } + objList->insert(name, obj); + connect(obj, SIGNAL(destroyed()), + objFind, SLOT(objDest())); + + emit objFind->inserted(obj); +} + +QObject *objFinder::find(const char *name, const char *inherits){ + QObject *found; + QDictIterator<QObject> it(*objList); + uint len = strlen(name); + while(it.current()){ + if(len == strlen(it.current()->name()) && + strcmp(it.current()->name(), name) == 0) + return it.current(); + QObjectList *qobl = it.current()->queryList(inherits, name, FALSE); + QObjectListIt itql( *qobl ); + if(itql.current() != 0x0){ + found = itql.current(); + delete qobl; + return found; + } + delete qobl; + ++it; + } + QWidgetList *all = QApplication::allWidgets(); + QWidgetListIt itW(*all); + while(itW.current()){ + if(len == strlen(itW.current()->name()) && + strcmp(itW.current()->name(), name) == 0){ + if(inherits != 0x0 && itW.current()->inherits(inherits) == FALSE){ + ++itW; + continue; + } + found = itW.current(); + delete all; + return found; + } + ++itW; + } + delete all; + + return 0x0; +} + +void objFinder::dumpTree(){ + QDictIterator<QObject> it(*objList); + while(it.current()){ + it.current()->dumpObjectTree(); + ++it; + } + QWidgetList *all = QApplication::allWidgets(); + QWidgetListIt itW(*all); + while(itW.current()){ + kdDebug(5008) << itW.current()->className() << "::" << itW.current()->name("unnamed") << endl; + ++itW; + } + +} + +QStringList objFinder::allObjects(){ + QStringList allNames; + QDictIterator<QObject> it(*objList); + while(it.current()){ + QObjectList *qobl = it.current()->queryList(); // Matches everything + QObjectListIt itql( *qobl ); + while(itql.current()){ + QString name; + name = itql.current()->className(); + name += "::"; + name += itql.current()->name("unnamed"); + allNames.append(name); + ++itql; + } + delete qobl; + ++it; + } + QWidgetList *all = QApplication::allWidgets(); + QWidgetListIt itW(*all); + while(itW.current()){ + QString name; + name = itW.current()->className(); + name += "::"; + name += itW.current()->name("unnamed"); + allNames.append(name); + ++itW; + } + delete all; + return allNames; +} + +QString objFinder::randString(){ + static bool runSrand = 0; + QString str = ""; + if(runSrand == 0){ + srand(time(NULL)); + } + for(int i = 0; i <= 8; i++){ + str.insert(0, (char) (1+(int) (94.0*rand()/(RAND_MAX+1.0))) + 0x20); + } + return str; +} + +void objFinder::objDest(){ + if(sender() == 0x0){ + return; + } + QDictIterator<QObject> it(*objList); + while(it.current()){ + if(it.current() == sender()){ + objList->remove(it.currentKey()); + } + ++it; + } +} +#include "objFinder.moc" |