make stacking_order exclusive during shutdown
Client::releaseClient() deletes all Client objects referenced by stacking_order, thus those pointers dangle and everything trying to touch it died an ugly death. REVIEW: 112020 BUG: 323383
This commit is contained in:
parent
3b2f744b49
commit
a3357695a7
1 changed files with 7 additions and 2 deletions
|
@ -420,8 +420,13 @@ Workspace::~Workspace()
|
||||||
// TODO: grabXServer();
|
// TODO: grabXServer();
|
||||||
|
|
||||||
// Use stacking_order, so that kwin --replace keeps stacking order
|
// Use stacking_order, so that kwin --replace keeps stacking order
|
||||||
for (ToplevelList::iterator it = stacking_order.begin(), end = stacking_order.end(); it != end; ++it) {
|
const ToplevelList stack = stacking_order;
|
||||||
Client *c = qobject_cast<Client*>(*it);
|
// "mutex" the stackingorder, since anything trying to access it from now on will find
|
||||||
|
// many dangeling pointers and crash
|
||||||
|
stacking_order.clear();
|
||||||
|
|
||||||
|
for (ToplevelList::const_iterator it = stack.constBegin(), end = stack.constEnd(); it != end; ++it) {
|
||||||
|
Client *c = qobject_cast<Client*>(const_cast<Toplevel*>(*it));
|
||||||
if (!c) {
|
if (!c) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue