aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2005-12-19 00:13:44 +0000
committerFelix Domke <tmbinc@elitedvb.net>2005-12-19 00:13:44 +0000
commit6f55cd01cf53108209c299e66c2fe189dc61a344 (patch)
tree492dcd022652dc0ca3665f03203ff2c835d43460 /lib
parente840db3c6ec507a72859965e85d1c08e0750f506 (diff)
downloadenigma2-6f55cd01cf53108209c299e66c2fe189dc61a344.tar.gz
enigma2-6f55cd01cf53108209c299e66c2fe189dc61a344.zip
widget: don't crash when deallocating in wrong order
Diffstat (limited to 'lib')
-rw-r--r--lib/gui/ewidget.cpp2
-rw-r--r--lib/gui/ewidgetdesktop.cpp6
2 files changed, 8 insertions, 0 deletions
diff --git a/lib/gui/ewidget.cpp b/lib/gui/ewidget.cpp
index 6f7fa91b..3bc6e663 100644
--- a/lib/gui/ewidget.cpp
+++ b/lib/gui/ewidget.cpp
@@ -140,6 +140,8 @@ void eWidget::hide()
while (root && !root->m_desktop)
{
root = root->m_parent;
+ if (!root)
+ return;
abspos += root->position();
}
assert(root->m_desktop);
diff --git a/lib/gui/ewidgetdesktop.cpp b/lib/gui/ewidgetdesktop.cpp
index c89cd270..04bc85d9 100644
--- a/lib/gui/ewidgetdesktop.cpp
+++ b/lib/gui/ewidgetdesktop.cpp
@@ -325,6 +325,12 @@ eWidgetDesktop::eWidgetDesktop(eSize size): m_mainloop(0), m_timer(0)
eWidgetDesktop::~eWidgetDesktop()
{
+ /* tell registered root windows that they no longer have a desktop. */
+ for (ePtrList<eWidget>::iterator i(m_root.begin()); i != m_root.end(); )
+ {
+ i->m_desktop = 0;
+ i = m_root.erase(i);
+ }
/* destroy all buffers */
setCompositionMode(-1);
}