add an UrgentNotify callback type. fire it when a window becomes "urgent"

This commit is contained in:
Dana Jansens 2003-01-24 00:44:36 +00:00
parent 39f19f427b
commit ab2968b3a5
5 changed files with 30 additions and 2 deletions

View file

@ -8,6 +8,7 @@
#include "frame.hh"
#include "screen.hh"
#include "openbox.hh"
#include "bindings.hh"
#include "otk/display.hh"
#include "otk/property.hh"
@ -44,6 +45,8 @@ Client::Client(int screen, Window window)
_transient_for = 0;
// pick a layer to start from
_layer = Layer_Normal;
// default to not urgent
_urgent = false;
getArea();
getDesktop();
@ -457,7 +460,7 @@ void Client::updateWMHints(bool initstate)
// assume a window takes input if it doesnt specify
_can_focus = true;
_urgent = false;
bool ur = false;
if ((hints = XGetWMHints(**otk::display, _window)) != NULL) {
if (hints->flags & InputHint)
@ -468,7 +471,7 @@ void Client::updateWMHints(bool initstate)
_iconic = hints->initial_state == IconicState;
if (hints->flags & XUrgencyHint)
_urgent = true;
ur = true;
if (hints->flags & WindowGroupHint) {
if (hints->window_group != _group) {
@ -481,6 +484,14 @@ void Client::updateWMHints(bool initstate)
XFree(hints);
}
if (ur != _urgent) {
_urgent = ur;
// fire the urgent callback if we're mapped, otherwise, wait until after
// we're mapped
if (_urgent && frame)
fireUrgent();
}
}
@ -1174,6 +1185,8 @@ void Client::applyStartupState()
_shaded = false;
shade(true);
}
if (_urgent)
fireUrgent();
if (_max_vert); // XXX: incomplete
if (_max_horz); // XXX: incomplete
@ -1186,6 +1199,14 @@ void Client::applyStartupState()
}
void Client::fireUrgent()
{
// call the python UrgentNotify callbacks
EventData data(_screen, this, EventUrgentNotify, 0);
openbox->bindings()->fireEvent(&data);
}
void Client::shade(bool shade)
{
if (!(_functions & Func_Shade) || // can't

View file

@ -406,6 +406,10 @@ private:
*/
void shade(bool shade);
//! Fires the urgent callbacks which lets the user do what they want with
//! urgent windows
void fireUrgent();
//! Fullscreen's or unfullscreen's the client window
/*!
@param fs true if the window should be made fullscreen; false if it should

View file

@ -914,6 +914,7 @@ EventShutdown = _openbox.EventShutdown
EventKey = _openbox.EventKey
EventFocus = _openbox.EventFocus
EventBell = _openbox.EventBell
EventUrgentNotify = _openbox.EventUrgentNotify
NUM_EVENTS = _openbox.NUM_EVENTS
class MouseData(_object):
__swig_setmethods__ = {}

View file

@ -12095,6 +12095,7 @@ static swig_const_info swig_const_table[] = {
{ SWIG_PY_INT, (char *)"EventKey", (long) ob::EventKey, 0, 0, 0},
{ SWIG_PY_INT, (char *)"EventFocus", (long) ob::EventFocus, 0, 0, 0},
{ SWIG_PY_INT, (char *)"EventBell", (long) ob::EventBell, 0, 0, 0},
{ SWIG_PY_INT, (char *)"EventUrgentNotify", (long) ob::EventUrgentNotify, 0, 0, 0},
{ SWIG_PY_INT, (char *)"NUM_EVENTS", (long) ob::NUM_EVENTS, 0, 0, 0},
{ SWIG_PY_INT, (char *)"X_PROTOCOL", (long) 11, 0, 0, 0},
{ SWIG_PY_INT, (char *)"X_PROTOCOL_REVISION", (long) 0, 0, 0, 0},

View file

@ -64,6 +64,7 @@ enum EventAction {
EventKey,
EventFocus,
EventBell,
EventUrgentNotify,
NUM_EVENTS
};