#include "rootwindow.hh"
#include "openbox.hh"
+#include "screen.hh"
#include "otk/display.hh"
namespace ob {
const otk::OBProperty *property = Openbox::instance->property();
- if (e.atom == property->atom(otk::OBProperty::net_desktop_names))
+ // compress changes to a single property into a single change
+ XEvent ce;
+ while (XCheckTypedEvent(otk::OBDisplay::display, e.type, &ce)) {
+ // XXX: it would be nice to compress ALL changes to a property, not just
+ // changes in a row without other props between.
+ if (ce.xproperty.atom != e.atom) {
+ XPutBackEvent(otk::OBDisplay::display, &ce);
+ break;
+ }
+ }
+
+ if (e.atom == property->atom(otk::OBProperty::net_desktop_names))
updateDesktopNames();
}
}
+void OBRootWindow::mapRequestHandler(const XMapRequestEvent &e)
+{
+#ifdef DEBUG
+ printf("MapRequest for 0x%lx\n", e.window);
+#endif // DEBUG
+
+ OBClient *client = Openbox::instance->findClient(e.window);
+
+ if (client) {
+ // XXX: uniconify and/or unshade the window
+ } else {
+ Openbox::instance->screen(_info->getScreenNumber())->
+ manageWindow(e.window);
+ }
+}
+
}