X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fapplication.cc;h=1f65046b361c8727cedc5692c37d51984bfa628c;hb=3dfe9f4ebeb7abd8446c52db0232b9f610a78846;hp=e325a58218bc824557bcf4b5573a85b4b9bff9f3;hpb=0348a2f3abd2334f5f5812c5fb45c1b4fffb46a5;p=chaz%2Fopenbox diff --git a/otk/application.cc b/otk/application.cc index e325a582..1f65046b 100644 --- a/otk/application.cc +++ b/otk/application.cc @@ -1,66 +1,49 @@ // -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- -#ifdef HAVE_CONFIG_H -# include "../config.h" -#endif +#include "config.h" #include "application.hh" #include "eventhandler.hh" -#include "widget.hh" #include "timer.hh" #include "property.hh" #include "rendercolor.hh" +#include "renderstyle.hh" +#include "display.hh" -extern "C" { -#ifdef HAVE_STDLIB_H -# include -#endif -} - +#include #include namespace otk { +extern void initialize(); +extern void destroy(); + Application::Application(int argc, char **argv) : EventDispatcher(), - _display(), _dockable(false), _appwidget_count(0) { (void)argc; (void)argv; - const ScreenInfo *s_info = _display.screenInfo(DefaultScreen(*_display)); - - Timer::initialize(); - RenderColor::initialize(); - Property::initialize(); - _img_ctrl = new ImageControl(s_info, True, 4, 5, 200); - _style_conf = new Configuration(False); - _style = new Style(_img_ctrl); - + otk::initialize(); + + _screen = DefaultScreen(**display); + loadStyle(); } Application::~Application() { - delete _style_conf; - delete _img_ctrl; - delete _style; - RenderColor::destroy(); - Timer::destroy(); + otk::destroy(); } void Application::loadStyle(void) { - // find the style name as a property + // XXX: find the style name as a property std::string style = "/usr/local/share/openbox/styles/artwiz"; - _style_conf->setFile(style); - if (!_style_conf->load()) { - std::cerr << "ERROR: Unable to load style \"" << style << "\".\n"; - ::exit(1); - } - _style->load(*_style_conf); + //_style->load(style); + otk::RenderStyle::setStyle(_screen, style); } void Application::run(void) @@ -74,7 +57,8 @@ void Application::run(void) while (_appwidget_count > 0) { dispatchEvents(); - Timer::dispatchTimers(); // fire pending events + if (_appwidget_count > 0) + Timer::dispatchTimers(); // fire pending events } }