summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-02-16 18:14:05 +0000
committerDana Jansens <danakj@orodu.net>2003-02-16 18:14:05 +0000
commit16a952c35dd15d52b304abaf9c366e9263b45430 (patch)
treee069bc39630a56fb5af43ee81688fcbec4ee1b2c /src
parent893faed7b1222e71b0e2f618254913819b3365b9 (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')
-rw-r--r--src/config.cc38
-rw-r--r--src/config.hh9
-rw-r--r--src/screen.cc19
-rw-r--r--src/screen.hh2
4 files changed, 48 insertions, 20 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()
diff --git a/src/config.hh b/src/config.hh
index f0205509..6cbbaacd 100644
--- a/src/config.hh
+++ b/src/config.hh
@@ -13,7 +13,10 @@
namespace ob {
-struct Config {
+class Config {
+ int _screen;
+
+public:
std::vector<otk::ustring> desktop_names;
otk::ustring theme;
otk::ustring titlebar_layout;
@@ -21,8 +24,10 @@ struct Config {
long drag_threshold;
long num_desktops;
- Config();
+ Config(int screen);
~Config();
+
+ void load();
};
}
diff --git a/src/screen.cc b/src/screen.cc
index 6eaa5cc5..e2e701d3 100644
--- a/src/screen.cc
+++ b/src/screen.cc
@@ -40,7 +40,8 @@ namespace ob {
Screen::Screen(int screen)
- : _number(screen)
+ : _number(screen),
+ _config(screen)
{
assert(screen >= 0); assert(screen < ScreenCount(**otk::display));
_info = otk::display->screenInfo(screen);
@@ -67,12 +68,6 @@ Screen::Screen(int screen)
XDefineCursor(**otk::display, _info->rootWindow(),
openbox->cursors().session);
- // initialize the screen's style
- otk::RenderStyle::setStyle(_number, _config.theme);
- // draw the root window
- otk::bexec("obsetroot " + otk::RenderStyle::style(_number)->rootArgs(),
- _info->displayString());
-
// set up notification of netwm support
changeSupportedAtoms();
@@ -83,17 +78,9 @@ Screen::Screen(int screen)
otk::Property::atoms.net_desktop_geometry,
otk::Property::atoms.cardinal, geometry, 2);
- // Set the net_desktop_names property
- otk::Property::set(_info->rootWindow(),
- otk::Property::atoms.net_desktop_names,
- otk::Property::utf8, _config.desktop_names);
- // the above set() will cause the updateDesktopNames to fire right away so
- // we have a list of desktop names
-
_desktop = 0;
- changeNumDesktops(_config.num_desktops); // set the hint
-
+ changeNumDesktops(1); // set the hint
changeDesktop(0); // set the hint
// don't start in showing-desktop mode
diff --git a/src/screen.hh b/src/screen.hh
index 457ca324..65eacaee 100644
--- a/src/screen.hh
+++ b/src/screen.hh
@@ -165,7 +165,7 @@ public:
inline bool managed() const { return _managed; }
//! Returns the config options set by the user scripts
- const Config& config() const { return _config; }
+ Config& config() { return _config; }
//! An offscreen window which gets focus when nothing else has it
inline Window focuswindow() const { return _focuswindow; }