]> Dogcows Code - chaz/openbox/blobdiff - otk/application.cc
add a keyboard plugin
[chaz/openbox] / otk / application.cc
index efe86d153a21490decf652ab396bc9cdaf765c17..1f65046b361c8727cedc5692c37d51984bfa628c 100644 (file)
@@ -1,48 +1,41 @@
 // -*- 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 <stdlib.h>
-#endif
-}
-
+#include <cstdlib>
 #include <iostream>
 
 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;
 
-  Timer::initialize();
-  RenderColor::initialize();
-  Property::initialize();
-  _style = new RenderStyle(DefaultScreen(*_display), ""); // XXX: get a path!
-
+  otk::initialize();
+  
+  _screen = DefaultScreen(**display);
+  
   loadStyle();
 }
 
 Application::~Application()
 {
-  delete _style;
-  RenderColor::destroy();
-  Timer::destroy();
+  otk::destroy();
 }
 
 void Application::loadStyle(void)
@@ -50,6 +43,7 @@ void Application::loadStyle(void)
   // XXX: find the style name as a property
   std::string style = "/usr/local/share/openbox/styles/artwiz";
   //_style->load(style);
+  otk::RenderStyle::setStyle(_screen, style);
 }
 
 void Application::run(void)
@@ -63,9 +57,8 @@ void Application::run(void)
 
   while (_appwidget_count > 0) {
     dispatchEvents();
-    if (_appwidget_count <= 0)
-      break;
-    Timer::dispatchTimers(); // fire pending events
+    if (_appwidget_count > 0)
+      Timer::dispatchTimers(); // fire pending events
   }
 }
 
This page took 0.022038 seconds and 4 git commands to generate.