X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fappwidget.cc;h=8b157225fd09031477d6e5a5965c9157ab6d1941;hb=a4c8a839a3decc54e515fd110710195eca23fd2b;hp=bd1acbf83d38592ed2c7484e6f6780cec66b4b64;hpb=e7bb906637f2b1b62b81950c99ab49443ba815f5;p=chaz%2Fopenbox diff --git a/otk/appwidget.cc b/otk/appwidget.cc index bd1acbf8..8b157225 100644 --- a/otk/appwidget.cc +++ b/otk/appwidget.cc @@ -1,11 +1,11 @@ // -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- -#ifdef HAVE_CONFIG_H -# include "../config.h" -#endif +#include "config.h" #include "appwidget.hh" #include "application.hh" +#include "property.hh" +#include "renderstyle.hh" extern "C" { #include @@ -13,46 +13,42 @@ extern "C" { namespace otk { -OtkAppWidget::OtkAppWidget(OtkApplication *app, Direction direction, - Cursor cursor, int bevel_width) - : OtkWidget(app, app->getStyle(), direction, cursor, bevel_width), +AppWidget::AppWidget(Application *app, Direction direction, int bevel) + : Widget(app->screen(), app, direction, bevel), _application(app) { assert(app); - _wm_protocols = XInternAtom(OBDisplay::display, "WM_PROTOCOLS", false); - _wm_delete = XInternAtom(OBDisplay::display, "WM_DELETE_WINDOW", false); - // set WM Protocols on the window Atom protocols[2]; - protocols[0] = _wm_protocols; - protocols[1] = _wm_delete; - XSetWMProtocols(OBDisplay::display, getWindow(), protocols, 2); + protocols[0] = Property::atoms.wm_protocols; + protocols[1] = Property::atoms.wm_delete_window; + XSetWMProtocols(**display, window(), protocols, 2); } -OtkAppWidget::~OtkAppWidget() +AppWidget::~AppWidget() { } -void OtkAppWidget::show(void) +void AppWidget::show() { - OtkWidget::show(true); - + if (!visible()) _application->_appwidget_count++; + Widget::show(true); } -void OtkAppWidget::hide(void) +void AppWidget::hide() { - OtkWidget::hide(); - - _application->_appwidget_count--; + if (visible()) + _application->_appwidget_count--; + Widget::hide(); } -void OtkAppWidget::clientMessageHandler(const XClientMessageEvent &e) +void AppWidget::clientMessageHandler(const XClientMessageEvent &e) { - OtkEventHandler::clientMessageHandler(e); - if (e.message_type == _wm_protocols && - static_cast(e.data.l[0]) == _wm_delete) + EventHandler::clientMessageHandler(e); + if (e.message_type == Property::atoms.wm_protocols && + static_cast(e.data.l[0]) == Property::atoms.wm_delete_window) hide(); }