From 2bcc53419e7cbd0f28d90242c750a381f434865d Mon Sep 17 00:00:00 2001 From: Aaron Seigo Date: Sun, 20 Nov 2011 18:50:41 +0100 Subject: [PATCH 1/4] don't count custom panel contaiments (e.g. the grouping desktop) the same as a desktop containment from the "useful things missing from bug reports" and "wondering wtf is wrong with people while trying to get the useful bits out of a bug report" files ... BUG:260360 --- containment.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/containment.cpp b/containment.cpp index 00a8a77b2..9e3a50511 100644 --- a/containment.cpp +++ b/containment.cpp @@ -987,7 +987,9 @@ void ContainmentPrivate::setScreen(int newScreen, int newDesktop, bool preventIn //kDebug() << activity() << "setting screen to " << newScreen << newDesktop << "and type is" << type; Containment *swapScreensWith(0); - if (type == Containment::DesktopContainment || type >= Containment::CustomContainment) { + const bool isDesktopContainment = type == Containment::DesktopContainment || + type == Containment::CustomContainment; + if (isDesktopContainment) { // we want to listen to changes in work area if our screen changes if (toolBox) { if (screen < 0 && newScreen > -1) { @@ -1011,8 +1013,7 @@ void ContainmentPrivate::setScreen(int newScreen, int newDesktop, bool preventIn } } - if (newScreen < numScreens && newScreen > -1 && - (type == Containment::DesktopContainment || type >= Containment::CustomContainment)) { + if (newScreen < numScreens && newScreen > -1 && isDesktopContainment) { q->resize(corona->screenGeometry(newScreen).size()); } From 7f0e9fb3b2ba92afeb394efa2bd532ecd0ef685c Mon Sep 17 00:00:00 2001 From: Ben Cooksley Date: Tue, 22 Nov 2011 21:14:54 +1300 Subject: [PATCH 2/4] Don't crash on exit. BUG:284989 REVIEW:103202 --- private/containment_p.h | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/private/containment_p.h b/private/containment_p.h index 4025bf4d3..75a6f807e 100644 --- a/private/containment_p.h +++ b/private/containment_p.h @@ -67,10 +67,14 @@ public: ~ContainmentPrivate() { - qDeleteAll(applets); + // qDeleteAll is broken with Qt4.8, delete it by hand + while (!applets.isEmpty()) { + delete applets.first(); + } applets.clear(); qDeleteAll(dropMenus); + dropMenus.clear(); } void createToolBox(); From f6f8d8b2ee72216adccdb3aaf0ba90bd046e6093 Mon Sep 17 00:00:00 2001 From: Aaron Seigo Date: Tue, 22 Nov 2011 12:17:06 +0100 Subject: [PATCH 3/4] when setAllowedRunners is called, call loadRunners, which now also allows for being called while a search is in progress loadRunners intelligently only unloads those runners with are no longer to be loaded, so this is a performance win. it now also checks to see if there are pending jobs for the runners to be deleted (if any) and if so it creates a delayed deleter for them -> no crashes --- private/runnerjobs.cpp | 14 ++++++++++---- private/runnerjobs_p.h | 5 +++-- runnermanager.cpp | 38 ++++++++++++++++++++++++++++++++------ 3 files changed, 45 insertions(+), 12 deletions(-) diff --git a/private/runnerjobs.cpp b/private/runnerjobs.cpp index 67bb501fe..6a8a7710f 100644 --- a/private/runnerjobs.cpp +++ b/private/runnerjobs.cpp @@ -170,10 +170,11 @@ Plasma::AbstractRunner* FindMatchesJob::runner() const return m_runner; } -DelayedJobCleaner::DelayedJobCleaner(QSet jobs, ThreadWeaver::WeaverInterface *weaver) - : QObject(weaver), - m_weaver(weaver), - m_jobs(jobs) +DelayedJobCleaner::DelayedJobCleaner(const QSet &jobs, const QSet &runners) + : QObject(Weaver::instance()), + m_weaver(Weaver::instance()), + m_jobs(jobs), + m_runners(runners) { connect(m_weaver, SIGNAL(finished()), this, SLOT(checkIfFinished())); @@ -182,6 +183,11 @@ DelayedJobCleaner::DelayedJobCleaner(QSet jobs, ThreadWeaver::W } } +DelayedJobCleaner::~DelayedJobCleaner() +{ + qDeleteAll(m_runners); +} + void DelayedJobCleaner::jobDone(ThreadWeaver::Job *job) { FindMatchesJob *runJob = dynamic_cast(job); diff --git a/private/runnerjobs_p.h b/private/runnerjobs_p.h index 19c0f1efa..0f400983e 100644 --- a/private/runnerjobs_p.h +++ b/private/runnerjobs_p.h @@ -126,16 +126,17 @@ private: class DelayedJobCleaner : public QObject { public: - DelayedJobCleaner(QSet jobs, ThreadWeaver::WeaverInterface *weaver); + DelayedJobCleaner(const QSet &jobs, const QSet &runners = QSet()); + ~DelayedJobCleaner(); private Q_SLOTS: void jobDone(ThreadWeaver::Job*); void checkIfFinished(); - //connect(ThreadWeaver::instance(), SIGNAL(finished()), this, SLOT(checkIfFinished())); private: ThreadWeaver::WeaverInterface *m_weaver; QSet m_jobs; + QSet m_runners; }; } diff --git a/runnermanager.cpp b/runnermanager.cpp index 7c24fee8b..0baece10e 100644 --- a/runnermanager.cpp +++ b/runnermanager.cpp @@ -188,6 +188,7 @@ public: advertiseSingleRunnerIds.clear(); + QSet deadRunners; QMutableListIterator it(offers); while (it.hasNext()) { KPluginInfo &description = it.next(); @@ -223,9 +224,32 @@ public: } } else if (loaded) { //Remove runner - AbstractRunner *runner = runners.take(runnerName); + deadRunners.insert(runners.take(runnerName)); kDebug() << "Removing runner: " << runnerName; - delete runner; + } + } + + if (!deadRunners.isEmpty()) { + QSet deadJobs; + foreach (FindMatchesJob *job, searchJobs) { + if (deadRunners.contains(job->runner())) { + QObject::disconnect(job, SIGNAL(done(ThreadWeaver::Job*)), q, SLOT(jobDone(ThreadWeaver::Job*))); + searchJobs.remove(job); + deadJobs.insert(job); + } + } + + foreach (FindMatchesJob *job, oldSearchJobs) { + if (deadRunners.contains(job->runner())) { + oldSearchJobs.remove(job); + deadJobs.insert(job); + } + } + + if (deadJobs.isEmpty()) { + qDeleteAll(deadRunners); + } else { + new DelayedJobCleaner(deadJobs, deadRunners); } } @@ -429,7 +453,7 @@ RunnerManager::RunnerManager(KConfigGroup &c, QObject *parent) RunnerManager::~RunnerManager() { if (!qApp->closingDown() && (!d->searchJobs.isEmpty() || !d->oldSearchJobs.isEmpty())) { - new DelayedJobCleaner(d->searchJobs + d->oldSearchJobs, Weaver::instance()); + new DelayedJobCleaner(d->searchJobs + d->oldSearchJobs); } delete d; @@ -443,11 +467,13 @@ void RunnerManager::reloadConfiguration() void RunnerManager::setAllowedRunners(const QStringList &runners) { - qDeleteAll(d->runners); - d->runners.clear(); - KConfigGroup config = d->configGroup(); config.writeEntry("pluginWhiteList", runners); + + if (!d->runners.isEmpty()) { + // this has been called with runners already created. so let's do an instant reload + d->loadRunners(); + } } QStringList RunnerManager::allowedRunners() const From d47a6bf33b4628e9f304ce0da71d8edb56956940 Mon Sep 17 00:00:00 2001 From: Aaron Seigo Date: Tue, 22 Nov 2011 12:20:14 +0100 Subject: [PATCH 4/4] constify --- runnermanager.cpp | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/runnermanager.cpp b/runnermanager.cpp index 0baece10e..49569a303 100644 --- a/runnermanager.cpp +++ b/runnermanager.cpp @@ -177,7 +177,7 @@ public: KPluginInfo::List offers = RunnerManager::listRunnerInfo(); const bool loadAll = config.readEntry("loadAll", false); - QStringList whiteList = config.readEntry("pluginWhiteList", QStringList()); + const QStringList whiteList = config.readEntry("pluginWhiteList", QStringList()); const bool noWhiteList = whiteList.isEmpty(); KConfigGroup pluginConf; if (conf.isValid()) { @@ -204,8 +204,7 @@ public: description.load(pluginConf); const bool loaded = runners.contains(runnerName); - const bool selected = loadAll || - (description.isPluginEnabled() && (noWhiteList || whiteList.contains(runnerName))); + const bool selected = loadAll || (description.isPluginEnabled() && (noWhiteList || whiteList.contains(runnerName))); const bool singleQueryModeEnabled = description.property("X-Plasma-AdvertiseSingleRunnerQueryMode").toBool();