X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=otk%2Fapplication.cc;h=94842ca5848dd96617e84a91d6cb20ed54cbfc52;hb=dca8c61a91cab29128a72f252b70f4bd9f7786ff;hp=29dc6bf4b4be70491c97b4028a2799ad9f145a2a;hpb=34a9f87ed27b44d5f0337477605fc22306802eac;p=chaz%2Fopenbox diff --git a/otk/application.cc b/otk/application.cc index 29dc6bf4..94842ca5 100644 --- a/otk/application.cc +++ b/otk/application.cc @@ -1,10 +1,15 @@ +// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- + +#include "config.h" + #include "application.hh" #include "eventhandler.hh" -#include "widget.hh" +#include "timer.hh" +#include "property.hh" +#include "rendercolor.hh" +#include "renderstyle.hh" extern "C" { -#include - #ifdef HAVE_STDLIB_H # include #endif @@ -14,76 +19,54 @@ extern "C" { namespace otk { -OtkApplication::OtkApplication(int argc, char **argv) - : OtkEventDispatcher(), _main_widget(0), _dockable(false) +Application::Application(int argc, char **argv) + : EventDispatcher(), + _display(), + _dockable(false), + _appwidget_count(0) { - argc = argc; - argv = argv; - - OBDisplay::initialize(0); - const ScreenInfo *s_info = OBDisplay::screenInfo(DefaultScreen(OBDisplay::display)); + (void)argc; + (void)argv; - _timer_manager = new OBTimerQueueManager(); - _img_ctrl = new BImageControl(_timer_manager, s_info, True, 4, 5, 200); - _style_conf = new Configuration(False); - _style = new Style(_img_ctrl); + _screen = DefaultScreen(*_display); + + Timer::initialize(); + RenderColor::initialize(); + RenderStyle::initialize(); + Property::initialize(); loadStyle(); } -OtkApplication::~OtkApplication() +Application::~Application() { - delete _style_conf; - delete _img_ctrl; - delete _timer_manager; - delete _style; - - OBDisplay::destroy(); + RenderStyle::destroy(); + RenderColor::destroy(); + Timer::destroy(); } -void OtkApplication::loadStyle(void) +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 << "Unable to load style \"" << style << "\". Aborting.\n"; - ::exit(1); - } - _style->load(*_style_conf); + //_style->load(style); } -void OtkApplication::exec(void) +void Application::run(void) { - if (!_main_widget) { - std::cerr << "No main widget set. You must create a main OtkWidget for " << - "the OtkApplication before calling OtkApplication::exec().\n"; + if (_appwidget_count <= 0) { + std::cerr << "ERROR: No main widgets exist. You must create and show() " << + "an AppWidget for the Application before calling " << + "Application::run().\n"; ::exit(1); } - while (1) { - dispatchEvents(); - _timer_manager->fire(); // fire pending events - } -} -bool OtkApplication::setMainWidget(const OtkWidget *main_widget) -{ - // ignore it if it has already been set - if (_main_widget) { - std::cerr << "More than one main OtkWidget being created for the " << - "OtkApplication!\n"; - return false; + while (_appwidget_count > 0) { + dispatchEvents(); + if (_appwidget_count <= 0) + break; + Timer::dispatchTimers(); // fire pending events } - - _main_widget = main_widget; - - // set WM Protocols on the window - Atom protocols[2]; - protocols[0] = XInternAtom(OBDisplay::display, "WM_PROTOCOLS", false); - protocols[1] = XInternAtom(OBDisplay::display, "WM_DELETE_WINDOW", false); - XSetWMProtocols(OBDisplay::display, _main_widget->getWindow(), protocols, 2); - - return true; } }