diff options
-rw-r--r-- | src/Ewmh.cc | 32 |
1 files changed, 18 insertions, 14 deletions
diff --git a/src/Ewmh.cc b/src/Ewmh.cc index 210122d..246dc70 100644 --- a/src/Ewmh.cc +++ b/src/Ewmh.cc | |||
@@ -1,5 +1,5 @@ | |||
1 | // Ewmh.cc for fluxbox | 1 | // Ewmh.cc for fluxbox |
2 | // Copyright (c) 2002 Henrik Kinnunen (fluxgen@fluxbox.org) | 2 | // Copyright (c) 2002-2003 Henrik Kinnunen (fluxgen at user.sourceforge.net) |
3 | // | 3 | // |
4 | // Permission is hereby granted, free of charge, to any person obtaining a | 4 | // Permission is hereby granted, free of charge, to any person obtaining a |
5 | // copy of this software and associated documentation files (the "Software"), | 5 | // copy of this software and associated documentation files (the "Software"), |
@@ -13,13 +13,13 @@ | |||
13 | // | 13 | // |
14 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 14 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
15 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 15 | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
16 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | 16 | // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
17 | // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 17 | // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
18 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | 18 | // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
19 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 19 | // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
20 | // DEALINGS IN THE SOFTWARE. | 20 | // DEALINGS IN THE SOFTWARE. |
21 | 21 | ||
22 | // $Id: Ewmh.cc,v 1.11 2003/03/03 21:51:00 rathnor Exp $ | 22 | // $Id: Ewmh.cc,v 1.12 2003/03/04 11:06:03 fluxgen Exp $ |
23 | 23 | ||
24 | #include "Ewmh.hh" | 24 | #include "Ewmh.hh" |
25 | 25 | ||
@@ -37,13 +37,14 @@ Ewmh::Ewmh() { | |||
37 | 37 | ||
38 | Ewmh::~Ewmh() { | 38 | Ewmh::~Ewmh() { |
39 | while (!m_windows.empty()) { | 39 | while (!m_windows.empty()) { |
40 | XDestroyWindow(BaseDisplay::getXDisplay(), m_windows.back()); | 40 | XDestroyWindow(FbTk::App::instance()->display(), m_windows.back()); |
41 | m_windows.pop_back(); | 41 | m_windows.pop_back(); |
42 | } | 42 | } |
43 | } | 43 | } |
44 | 44 | ||
45 | void Ewmh::initForScreen(BScreen &screen) { | 45 | void Ewmh::initForScreen(BScreen &screen) { |
46 | Display *disp = BaseDisplay::getXDisplay(); | 46 | Display *disp = FbTk::App::getXDisplay(); |
47 | |||
47 | 48 | ||
48 | Window wincheck = XCreateSimpleWindow(disp, | 49 | Window wincheck = XCreateSimpleWindow(disp, |
49 | screen.getRootWindow(), 0, 0, 5, 5, 0, 0, 0); | 50 | screen.getRootWindow(), 0, 0, 5, 5, 0, 0, 0); |
@@ -83,14 +84,16 @@ void Ewmh::initForScreen(BScreen &screen) { | |||
83 | 84 | ||
84 | XChangeProperty(disp, screen.getRootWindow(), | 85 | XChangeProperty(disp, screen.getRootWindow(), |
85 | m_net_supported, XA_ATOM, 32, | 86 | m_net_supported, XA_ATOM, 32, |
86 | PropModeReplace, (unsigned char *) &atomsupported, (sizeof atomsupported)/sizeof atomsupported[0]); | 87 | PropModeReplace, |
88 | (unsigned char *) &atomsupported, | ||
89 | (sizeof atomsupported)/sizeof atomsupported[0]); | ||
87 | 90 | ||
88 | 91 | ||
89 | } | 92 | } |
90 | 93 | ||
91 | void Ewmh::setupWindow(FluxboxWindow &win) { | 94 | void Ewmh::setupWindow(FluxboxWindow &win) { |
92 | 95 | ||
93 | Display *disp = BaseDisplay::getXDisplay(); | 96 | Display *disp = FbTk::App::instance()->display(); |
94 | Atom ret_type; | 97 | Atom ret_type; |
95 | int fmt; | 98 | int fmt; |
96 | unsigned long nitems, bytes_after; | 99 | unsigned long nitems, bytes_after; |
@@ -156,7 +159,7 @@ void Ewmh::updateClientList(BScreen &screen) { | |||
156 | 159 | ||
157 | //number of windows to show in client list | 160 | //number of windows to show in client list |
158 | num = win; | 161 | num = win; |
159 | XChangeProperty(BaseDisplay::getXDisplay(), | 162 | XChangeProperty(FbTk::App::instance()->display(), |
160 | screen.getRootWindow(), | 163 | screen.getRootWindow(), |
161 | m_net_client_list, | 164 | m_net_client_list, |
162 | XA_CARDINAL, 32, | 165 | XA_CARDINAL, 32, |
@@ -177,7 +180,7 @@ void Ewmh::updateWorkspaceNames(BScreen &screen) { | |||
177 | } | 180 | } |
178 | 181 | ||
179 | if (XStringListToTextProperty(names, number_of_desks, &text)) { | 182 | if (XStringListToTextProperty(names, number_of_desks, &text)) { |
180 | XSetTextProperty(BaseDisplay::getXDisplay(), screen.getRootWindow(), | 183 | XSetTextProperty(FbTk::App::instance()->display(), screen.getRootWindow(), |
181 | &text, m_net_desktop_names); | 184 | &text, m_net_desktop_names); |
182 | XFree(text.value); | 185 | XFree(text.value); |
183 | } | 186 | } |
@@ -188,7 +191,7 @@ void Ewmh::updateWorkspaceNames(BScreen &screen) { | |||
188 | 191 | ||
189 | void Ewmh::updateCurrentWorkspace(BScreen &screen) { | 192 | void Ewmh::updateCurrentWorkspace(BScreen &screen) { |
190 | size_t workspace = screen.getCurrentWorkspaceID(); | 193 | size_t workspace = screen.getCurrentWorkspaceID(); |
191 | XChangeProperty(BaseDisplay::getXDisplay(), | 194 | XChangeProperty(FbTk::App::instance()->display(), |
192 | screen.getRootWindow(), | 195 | screen.getRootWindow(), |
193 | m_net_current_desktop, XA_CARDINAL, 32, PropModeReplace, | 196 | m_net_current_desktop, XA_CARDINAL, 32, PropModeReplace, |
194 | (unsigned char *)&workspace, 1); | 197 | (unsigned char *)&workspace, 1); |
@@ -197,7 +200,7 @@ void Ewmh::updateCurrentWorkspace(BScreen &screen) { | |||
197 | 200 | ||
198 | void Ewmh::updateWorkspaceCount(BScreen &screen) { | 201 | void Ewmh::updateWorkspaceCount(BScreen &screen) { |
199 | size_t numworkspaces = screen.getCount(); | 202 | size_t numworkspaces = screen.getCount(); |
200 | XChangeProperty(BaseDisplay::getXDisplay(), screen.getRootWindow(), | 203 | XChangeProperty(FbTk::App::instance()->display(), screen.getRootWindow(), |
201 | m_net_number_of_desktops, XA_CARDINAL, 32, PropModeReplace, | 204 | m_net_number_of_desktops, XA_CARDINAL, 32, PropModeReplace, |
202 | (unsigned char *)&numworkspaces, 1); | 205 | (unsigned char *)&numworkspaces, 1); |
203 | } | 206 | } |
@@ -219,7 +222,7 @@ void Ewmh::updateWorkspace(FluxboxWindow &win) { | |||
219 | if (win.isStuck()) | 222 | if (win.isStuck()) |
220 | workspace = 0xFFFFFFFF; // appear on all desktops/workspaces | 223 | workspace = 0xFFFFFFFF; // appear on all desktops/workspaces |
221 | 224 | ||
222 | XChangeProperty(BaseDisplay::getXDisplay(), win.getClientWindow(), | 225 | XChangeProperty(FbTk::App::instance()->display(), win.getClientWindow(), |
223 | m_net_wm_desktop, XA_CARDINAL, 32, PropModeReplace, | 226 | m_net_wm_desktop, XA_CARDINAL, 32, PropModeReplace, |
224 | (unsigned char *)&workspace, 1); | 227 | (unsigned char *)&workspace, 1); |
225 | } | 228 | } |
@@ -232,7 +235,8 @@ bool Ewmh::checkClientMessage(const XClientMessageEvent &ce, BScreen * screen, F | |||
232 | return true; | 235 | return true; |
233 | // ce.data.l[0] = workspace number | 236 | // ce.data.l[0] = workspace number |
234 | // valid window and workspace number? | 237 | // valid window and workspace number? |
235 | if (win == 0 || static_cast<unsigned int>(ce.data.l[0]) >= screen->getCount()) | 238 | if (win == 0 || |
239 | static_cast<unsigned int>(ce.data.l[0]) >= screen->getCount()) | ||
236 | return true; | 240 | return true; |
237 | 241 | ||
238 | screen->sendToWorkspace(ce.data.l[0], win, false); | 242 | screen->sendToWorkspace(ce.data.l[0], win, false); |
@@ -327,7 +331,7 @@ bool Ewmh::checkClientMessage(const XClientMessageEvent &ce, BScreen * screen, F | |||
327 | 331 | ||
328 | 332 | ||
329 | void Ewmh::createAtoms() { | 333 | void Ewmh::createAtoms() { |
330 | Display *disp = BaseDisplay::getXDisplay(); | 334 | Display *disp = FbTk::App::instance()->display(); |
331 | m_net_supported = XInternAtom(disp, "_NET_SUPPORTED", False); | 335 | m_net_supported = XInternAtom(disp, "_NET_SUPPORTED", False); |
332 | m_net_client_list = XInternAtom(disp, "_NET_CLIENT_LIST", False); | 336 | m_net_client_list = XInternAtom(disp, "_NET_CLIENT_LIST", False); |
333 | m_net_client_list_stacking = XInternAtom(disp, "_NET_CLIENT_LIST_STACKING", False); | 337 | m_net_client_list_stacking = XInternAtom(disp, "_NET_CLIENT_LIST_STACKING", False); |