gets a whole lotta window information now, and updtes when it changes!
This commit is contained in:
parent
e8b6f65186
commit
5112b62704
3 changed files with 64 additions and 10 deletions
|
@ -41,18 +41,24 @@ WindowList _clients;
|
||||||
WindowList::iterator _active = _clients.end();
|
WindowList::iterator _active = _clients.end();
|
||||||
|
|
||||||
|
|
||||||
XWindow &findWindow(const XEvent &e) {
|
XWindow *findWindow(const XEvent &e) {
|
||||||
WindowList::iterator it, end = _clients.end();
|
WindowList::iterator it, end = _clients.end();
|
||||||
for (it = _clients.begin(); it != end; ++it)
|
for (it = _clients.begin(); it != end; ++it)
|
||||||
if (**it == e.xany.window)
|
if (**it == e.xany.window)
|
||||||
break;
|
break;
|
||||||
assert(it != end); // this means a client somehow got removed from the
|
if(it == end)
|
||||||
// list!
|
return 0;
|
||||||
return **it;
|
return *it;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void processEvent(const XEvent &e) {
|
void processEvent(const XEvent &e) {
|
||||||
|
XWindow *window = 0;
|
||||||
|
if (e.xany.window != _root) {
|
||||||
|
window = findWindow(e); // find the window
|
||||||
|
assert(window); // we caught an event for a window we don't know about!?
|
||||||
|
}
|
||||||
|
|
||||||
switch (e.type) {
|
switch (e.type) {
|
||||||
case PropertyNotify:
|
case PropertyNotify:
|
||||||
if (e.xany.window == _root) {
|
if (e.xany.window == _root) {
|
||||||
|
@ -74,15 +80,19 @@ void processEvent(const XEvent &e) {
|
||||||
} else {
|
} else {
|
||||||
// a client window
|
// a client window
|
||||||
if (e.xproperty.atom == _xatom->getAtom(XAtom::net_wm_state))
|
if (e.xproperty.atom == _xatom->getAtom(XAtom::net_wm_state))
|
||||||
findWindow(e).updateState();
|
window->updateState();
|
||||||
if (e.xproperty.atom == _xatom->getAtom(XAtom::net_wm_desktop))
|
else if (e.xproperty.atom == _xatom->getAtom(XAtom::net_wm_desktop))
|
||||||
findWindow(e).updateDesktop();
|
window->updateDesktop();
|
||||||
|
else if (e.xproperty.atom == _xatom->getAtom(XAtom::net_wm_name) ||
|
||||||
|
e.xproperty.atom == _xatom->getAtom(XAtom::wm_name))
|
||||||
|
window->updateTitle();
|
||||||
|
else if (e.xproperty.atom == _xatom->getAtom(XAtom::wm_class))
|
||||||
|
window->updateClass();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case DestroyNotify:
|
case DestroyNotify:
|
||||||
case UnmapNotify:
|
case UnmapNotify:
|
||||||
cout << "unmap notify\n";
|
window->setUnmapped(true);
|
||||||
findWindow(e).setUnmapped(true);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,13 +35,14 @@ using std::endl;
|
||||||
using std::hex;
|
using std::hex;
|
||||||
using std::dec;
|
using std::dec;
|
||||||
|
|
||||||
|
|
||||||
XWindow::XWindow(Window window) : _window(window) {
|
XWindow::XWindow(Window window) : _window(window) {
|
||||||
_unmapped = false;
|
_unmapped = false;
|
||||||
|
|
||||||
XSelectInput(_display, _window, PropertyChangeMask | StructureNotifyMask);
|
XSelectInput(_display, _window, PropertyChangeMask | StructureNotifyMask);
|
||||||
updateState();
|
updateState();
|
||||||
updateDesktop();
|
updateDesktop();
|
||||||
|
updateTitle();
|
||||||
|
updateClass();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -80,3 +81,32 @@ void XWindow::updateDesktop() {
|
||||||
static_cast<unsigned long>(_desktop)))
|
static_cast<unsigned long>(_desktop)))
|
||||||
_desktop = 0;
|
_desktop = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void XWindow::updateTitle() {
|
||||||
|
_title = "";
|
||||||
|
|
||||||
|
// try netwm
|
||||||
|
if (! _xatom->getValue(_window, XAtom::net_wm_name, XAtom::utf8, _title)) {
|
||||||
|
// try old x stuff
|
||||||
|
_xatom->getValue(_window, XAtom::wm_name, XAtom::ansi, _title);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_title.empty())
|
||||||
|
_title = "Unnamed";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void XWindow::updateClass() {
|
||||||
|
// set the defaults
|
||||||
|
_app_name = _app_class = "";
|
||||||
|
|
||||||
|
XAtom::StringVect v;
|
||||||
|
unsigned long num = 2;
|
||||||
|
|
||||||
|
if (! _xatom->getValue(_window, XAtom::wm_class, XAtom::ansi, num, v))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (num > 0) _app_name = v[0];
|
||||||
|
if (num > 1) _app_class = v[1];
|
||||||
|
}
|
||||||
|
|
|
@ -28,6 +28,7 @@ extern "C" {
|
||||||
}
|
}
|
||||||
|
|
||||||
#include <list>
|
#include <list>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
class XWindow;
|
class XWindow;
|
||||||
|
|
||||||
|
@ -36,7 +37,13 @@ typedef std::list<XWindow *> WindowList;
|
||||||
class XWindow {
|
class XWindow {
|
||||||
private:
|
private:
|
||||||
Window _window;
|
Window _window;
|
||||||
|
|
||||||
unsigned int _desktop;
|
unsigned int _desktop;
|
||||||
|
std::string _title;
|
||||||
|
std::string _app_name;
|
||||||
|
std::string _app_class;
|
||||||
|
|
||||||
|
// states
|
||||||
bool _shaded;
|
bool _shaded;
|
||||||
bool _iconic;
|
bool _iconic;
|
||||||
bool _max_vert;
|
bool _max_vert;
|
||||||
|
@ -49,7 +56,12 @@ public:
|
||||||
virtual ~XWindow();
|
virtual ~XWindow();
|
||||||
|
|
||||||
inline Window window() const { return _window; }
|
inline Window window() const { return _window; }
|
||||||
|
|
||||||
inline unsigned int desktop() const { return _desktop; }
|
inline unsigned int desktop() const { return _desktop; }
|
||||||
|
inline const std::string &title() const { return _title; }
|
||||||
|
inline const std::string &appName() const { return _app_name; }
|
||||||
|
inline const std::string &appClass() const { return _app_name; }
|
||||||
|
|
||||||
inline bool shaded() const { return _shaded; }
|
inline bool shaded() const { return _shaded; }
|
||||||
inline bool iconic() const { return _iconic; }
|
inline bool iconic() const { return _iconic; }
|
||||||
inline bool maxVert() const { return _max_vert; }
|
inline bool maxVert() const { return _max_vert; }
|
||||||
|
@ -59,6 +71,8 @@ public:
|
||||||
|
|
||||||
void updateState();
|
void updateState();
|
||||||
void updateDesktop();
|
void updateDesktop();
|
||||||
|
void updateTitle();
|
||||||
|
void updateClass();
|
||||||
|
|
||||||
bool operator == (const XWindow &w) const { return w._window == _window; }
|
bool operator == (const XWindow &w) const { return w._window == _window; }
|
||||||
bool operator == (const Window &w) const { return w == _window; }
|
bool operator == (const Window &w) const { return w == _window; }
|
||||||
|
|
Loading…
Reference in a new issue