X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fapplication.cc;h=efe86d153a21490decf652ab396bc9cdaf765c17;hb=dddac554808d7352a06733938cfddc19839b99d0;hp=fda65dc1fd0ec84a8881564cb0cdc5172a31cd42;hpb=8f8acc24933830d4f5784616b9b0c5896bde0b93;p=chaz%2Fopenbox diff --git a/otk/application.cc b/otk/application.cc index fda65dc1..efe86d15 100644 --- a/otk/application.cc +++ b/otk/application.cc @@ -7,6 +7,9 @@ #include "application.hh" #include "eventhandler.hh" #include "widget.hh" +#include "timer.hh" +#include "property.hh" +#include "rendercolor.hh" extern "C" { #ifdef HAVE_STDLIB_H @@ -20,44 +23,33 @@ namespace otk { Application::Application(int argc, char **argv) : EventDispatcher(), + _display(), _dockable(false), _appwidget_count(0) { (void)argc; (void)argv; - Display::initialize(0); - const ScreenInfo *s_info = - Display::screenInfo(DefaultScreen(Display::display)); - - _timer_manager = new TimerQueueManager(); - _img_ctrl = new ImageControl(_timer_manager, s_info, True, 4, 5, 200); - _style_conf = new Configuration(False); - _style = new Style(_img_ctrl); + Timer::initialize(); + RenderColor::initialize(); + Property::initialize(); + _style = new RenderStyle(DefaultScreen(*_display), ""); // XXX: get a path! loadStyle(); } Application::~Application() { - delete _style_conf; - delete _img_ctrl; - delete _timer_manager; delete _style; - - Display::destroy(); + RenderColor::destroy(); + Timer::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); } void Application::run(void) @@ -71,7 +63,9 @@ void Application::run(void) while (_appwidget_count > 0) { dispatchEvents(); - _timer_manager->fire(); // fire pending events + if (_appwidget_count <= 0) + break; + Timer::dispatchTimers(); // fire pending events } }