X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fwidget.cc;h=c09ac4862566e8c8f93d0f4634ff6e7e33a15065;hb=6e2f3f9f8a2b4b83648c9c8b9993d321b3f60a79;hp=0675bf6ac290f709ad8ae3d9f107c6fa1871699b;hpb=38345bf32eeb1d506ce1f3fde93145a2c55828f3;p=chaz%2Fopenbox diff --git a/otk/widget.cc b/otk/widget.cc index 0675bf6a..c09ac486 100644 --- a/otk/widget.cc +++ b/otk/widget.cc @@ -59,6 +59,9 @@ Widget::~Widget() if (_visible) hide(); + if (_surface) + delete _surface; + _event_dispatcher->clearHandler(_window); std::for_each(_children.begin(), _children.end(), PointerAssassin()); @@ -274,7 +277,8 @@ void Widget::render(void) XSetWindowBackgroundPixmap(**display, _window, _surface->pixmap()); - delete s; // delete the old surface *after* its pixmap isn't in use anymore + if (s) + delete s; // delete the old surface *after* its pixmap isn't in use anymore } void Widget::adjust(void) @@ -400,16 +404,16 @@ void Widget::adjustVert(void) void Widget::update() { + WidgetList::iterator it = _children.begin(), end = _children.end(); + for (; it != end; ++it) + (*it)->update(); + if (_dirty) { adjust(); render(); XClearWindow(**display, _window); } - WidgetList::iterator it = _children.begin(), end = _children.end(); - for (; it != end; ++it) - (*it)->update(); - _dirty = false; }