diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-02-16 18:14:05 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-02-16 18:14:05 +0000 |
| commit | 16a952c35dd15d52b304abaf9c366e9263b45430 (patch) | |
| tree | e069bc39630a56fb5af43ee81688fcbec4ee1b2c /src/config.cc | |
| parent | 893faed7b1222e71b0e2f618254913819b3365b9 (diff) | |
adjust how the config is loaded. it is not loaded at all during the screen's constructor, it is loaded afterwards and applied, but before windows are managed
Diffstat (limited to 'src/config.cc')
| -rw-r--r-- | src/config.cc | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/src/config.cc b/src/config.cc index b1495dc8..04728de2 100644 --- a/src/config.cc +++ b/src/config.cc @@ -3,6 +3,11 @@ #include "config.h" #include "config.hh" +#include "otk/screeninfo.hh" +#include "otk/renderstyle.hh" +#include "otk/util.hh" +#include "otk/property.hh" +#include "otk/display.hh" extern "C" { #include <Python.h> @@ -51,8 +56,11 @@ bool python_get_stringlist(const char *name, std::vector<otk::ustring> *value) return true; } -Config::Config() +void Config::load() { + const otk::ScreenInfo *info = otk::display->screenInfo(_screen); + Window root = info->rootWindow(); + // set up access to the python global variables PyObject *obmodule = PyImport_ImportModule("config"); obdict = PyModule_GetDict(obmodule); @@ -61,6 +69,12 @@ Config::Config() python_get_stringlist("DESKTOP_NAMES", &desktop_names); python_get_string("THEME", &theme); + // initialize the screen's style + otk::RenderStyle::setStyle(_screen, theme); + // draw the root window + otk::bexec("obsetroot " + otk::RenderStyle::style(_screen)->rootArgs(), + info->displayString()); + if (!python_get_string("TITLEBAR_LAYOUT", &titlebar_layout)) { fprintf(stderr, _("Unable to load config.%s\n"), "TITLEBAR_LAYOUT"); @@ -79,6 +93,28 @@ Config::Config() fprintf(stderr, _("Unable to load config.%s\n"), "NUMBER_OF_DESKTOPS"); ::exit(1); } + + // Set the net_desktop_names property + otk::Property::set(root, + otk::Property::atoms.net_desktop_names, + otk::Property::utf8, desktop_names); + // the above set() will cause screen::updateDesktopNames to fire right away + // so we have a list of desktop names + + XEvent ce; + ce.xclient.type = ClientMessage; + ce.xclient.message_type = otk::Property::atoms.net_number_of_desktops; + ce.xclient.display = **otk::display; + ce.xclient.window = root; + ce.xclient.format = 32; + ce.xclient.data.l[0] = num_desktops; + XSendEvent(**otk::display, root, False, + SubstructureNotifyMask | SubstructureRedirectMask, &ce); +} + +Config::Config(int screen) + : _screen(screen) +{ } Config::~Config() |
