fluxbox/src/CurrentWindowCmd.cc

557 lines
20 KiB
C++
Raw Normal View History

2003-06-30 14:35:11 +00:00
// CurrentWindowCmd.cc for Fluxbox - an X11 Window manager
2006-02-16 06:53:05 +00:00
// Copyright (c) 2003 - 2006 Henrik Kinnunen (fluxgen at fluxbox dot org)
2003-06-30 14:35:11 +00:00
// and Simon Bowden (rathnor at users.sourceforge.net)
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
#include "CurrentWindowCmd.hh"
#include "fluxbox.hh"
2008-08-05 07:05:21 +00:00
#include "Layer.hh"
2003-06-30 14:35:11 +00:00
#include "Window.hh"
2007-10-15 18:05:28 +00:00
#include "WindowCmd.hh"
2003-06-30 14:35:11 +00:00
#include "Screen.hh"
#include "WinClient.hh"
2003-06-30 14:35:11 +00:00
#include "FocusControl.hh"
#include "FbTk/CommandParser.hh"
#include "FbTk/stringstream.hh"
#include "FbTk/StringUtil.hh"
using FbTk::Command;
namespace {
FbTk::Command<void> *createCurrentWindowCmd(const std::string &command,
const std::string &args, bool trusted) {
if (command == "minimizewindow" || command == "minimize" || command == "iconify")
return new CurrentWindowCmd(&FluxboxWindow::iconify);
else if (command == "maximizewindow" || command == "maximize")
return new CurrentWindowCmd(&FluxboxWindow::maximizeFull);
else if (command == "maximizevertical")
return new CurrentWindowCmd(&FluxboxWindow::maximizeVertical);
else if (command == "maximizehorizontal")
return new CurrentWindowCmd(&FluxboxWindow::maximizeHorizontal);
else if (command == "raise")
return new CurrentWindowCmd(&FluxboxWindow::raise);
else if (command == "raiselayer")
return new CurrentWindowCmd(&FluxboxWindow::raiseLayer);
else if (command == "lower")
return new CurrentWindowCmd(&FluxboxWindow::lower);
else if (command == "lowerlayer")
return new CurrentWindowCmd(&FluxboxWindow::lowerLayer);
else if (command == "activate" || command == "focus")
return new CurrentWindowCmd((void (FluxboxWindow::*)())&FluxboxWindow::focus);
else if (command == "close")
return new CurrentWindowCmd(&FluxboxWindow::close);
else if (command == "killwindow" || command == "kill")
return new CurrentWindowCmd(&FluxboxWindow::kill);
else if (command == "shade" || command == "shadewindow")
return new CurrentWindowCmd(&FluxboxWindow::shade);
else if (command == "shadeon" )
return new CurrentWindowCmd(&FluxboxWindow::shadeOn);
else if (command == "shadeoff" )
return new CurrentWindowCmd(&FluxboxWindow::shadeOff);
else if (command == "stick" || command == "stickwindow")
return new CurrentWindowCmd(&FluxboxWindow::stick);
else if (command == "toggledecor")
return new CurrentWindowCmd(&FluxboxWindow::toggleDecoration);
else if (command == "nexttab")
return new CurrentWindowCmd(&FluxboxWindow::nextClient);
else if (command == "prevtab")
return new CurrentWindowCmd(&FluxboxWindow::prevClient);
else if (command == "movetableft")
return new CurrentWindowCmd(&FluxboxWindow::moveClientLeft);
else if (command == "movetabright")
return new CurrentWindowCmd(&FluxboxWindow::moveClientRight);
else if (command == "detachclient")
return new CurrentWindowCmd(&FluxboxWindow::detachCurrentClient);
else if (command == "windowmenu")
return new CurrentWindowCmd(&FluxboxWindow::popupMenu);
return 0;
}
REGISTER_COMMAND_PARSER(minimizewindow, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(minimize, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(iconify, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(maximizewindow, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(maximize, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(maximizevertical, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(maximizehorizontal, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(raise, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(raiselayer, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(lower, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(lowerlayer, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(activate, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(focus, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(close, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(killwindow, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(kill, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(shade, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(shadewindow, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(shadeon, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(shadeoff, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(stick, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(stickwindow, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(toggledecor, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(nexttab, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(prevtab, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(movetableft, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(movetabright, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(detachclient, createCurrentWindowCmd, void);
REGISTER_COMMAND_PARSER(windowmenu, createCurrentWindowCmd, void);
}; // end anonymous namespace
2007-10-13 21:51:37 +00:00
void WindowHelperCmd::execute() {
2007-10-15 18:05:28 +00:00
if (WindowCmd<void>::window() || FocusControl::focusedFbWindow())
2007-10-13 21:51:37 +00:00
real_execute();
}
2003-06-30 14:35:11 +00:00
FluxboxWindow &WindowHelperCmd::fbwindow() {
// will exist from execute above
FluxboxWindow *tmp = WindowCmd<void>::window();
if (tmp) return *tmp;
return *FocusControl::focusedFbWindow();
2003-06-30 14:35:11 +00:00
}
bool WindowHelperBoolCmd::execute() {
if (WindowCmd<void>::window() || FocusControl::focusedFbWindow())
return real_execute();
return false;
}
FluxboxWindow &WindowHelperBoolCmd::fbwindow() {
2007-10-13 21:51:37 +00:00
// will exist from execute above
2007-10-15 18:05:28 +00:00
FluxboxWindow *tmp = WindowCmd<void>::window();
if (tmp) return *tmp;
return *FocusControl::focusedFbWindow();
2007-10-13 21:51:37 +00:00
}
2003-06-30 14:35:11 +00:00
WinClient &WindowHelperBoolCmd::winclient() {
// will exist from execute above
WinClient *tmp = WindowCmd<void>::client();
if (tmp) return *tmp;
return *FocusControl::focusedWindow();
}
2007-10-13 21:51:37 +00:00
void CurrentWindowCmd::real_execute() {
(fbwindow().*m_action)();
2003-06-30 14:35:11 +00:00
}
namespace {
FbTk::Command<void> *parseIntCmd(const string &command, const string &args,
bool trusted) {
int num = (command == "sethead" ? 0 : 1);
FbTk_istringstream iss(args.c_str());
iss >> num;
if (command == "sethead")
return new SetHeadCmd(num);
else if (command == "tab")
return new GoToTabCmd(num);
else if (command == "sendtonextworkspace")
return new SendToNextWorkspaceCmd(num);
else if (command == "sendtoprevworkspace")
return new SendToPrevWorkspaceCmd(num);
else if (command == "taketonextworkspace")
return new TakeToNextWorkspaceCmd(num);
else if (command == "taketoprevworkspace")
return new TakeToPrevWorkspaceCmd(num);
else if (command == "sendtoworkspace")
// workspaces appear 1-indexed to the user, hence the minus 1
return new SendToWorkspaceCmd(num-1);
else if (command == "taketoworkspace")
return new TakeToWorkspaceCmd(num-1);
return 0;
}
REGISTER_COMMAND_PARSER(sethead, parseIntCmd, void);
REGISTER_COMMAND_PARSER(tab, parseIntCmd, void);
REGISTER_COMMAND_PARSER(sendtonextworkspace, parseIntCmd, void);
REGISTER_COMMAND_PARSER(sendtoprevworkspace, parseIntCmd, void);
REGISTER_COMMAND_PARSER(taketonextworkspace, parseIntCmd, void);
REGISTER_COMMAND_PARSER(taketoprevworkspace, parseIntCmd, void);
REGISTER_COMMAND_PARSER(sendtoworkspace, parseIntCmd, void);
REGISTER_COMMAND_PARSER(taketoworkspace, parseIntCmd, void);
}; // end anonymous namespace
void SetHeadCmd::real_execute() {
fbwindow().setOnHead(m_head);
}
2003-06-30 14:35:11 +00:00
void SendToWorkspaceCmd::real_execute() {
fbwindow().screen().sendToWorkspace(m_workspace_num, &fbwindow(), false);
2003-06-30 14:35:11 +00:00
}
void SendToNextWorkspaceCmd::real_execute() {
const int ws_nr =
( fbwindow().workspaceNumber() + m_delta ) %
fbwindow().screen().numberOfWorkspaces();
fbwindow().screen().sendToWorkspace(ws_nr, &fbwindow(), false);
}
void SendToPrevWorkspaceCmd::real_execute() {
int ws_nr = (fbwindow().workspaceNumber() - m_delta );
if ( ws_nr < 0 )
ws_nr += fbwindow().screen().numberOfWorkspaces();
ws_nr = ws_nr % fbwindow().screen().numberOfWorkspaces();
fbwindow().screen().sendToWorkspace(ws_nr, &fbwindow(), false);
}
void TakeToWorkspaceCmd::real_execute() {
fbwindow().screen().sendToWorkspace(m_workspace_num, &fbwindow());
}
void TakeToNextWorkspaceCmd::real_execute() {
unsigned int ws_nr =
( fbwindow().workspaceNumber() + m_delta) %
fbwindow().screen().numberOfWorkspaces();
fbwindow().screen().sendToWorkspace(ws_nr, &fbwindow());
}
void TakeToPrevWorkspaceCmd::real_execute() {
int ws_nr = (fbwindow().workspaceNumber() - m_delta);
if ( ws_nr < 0 )
ws_nr += fbwindow().screen().numberOfWorkspaces();
ws_nr = ws_nr % fbwindow().screen().numberOfWorkspaces();
fbwindow().screen().sendToWorkspace(ws_nr, &fbwindow());
}
void GoToTabCmd::real_execute() {
int num = m_tab_num;
if (num < 0) num += fbwindow().numClients() + 1;
if (num < 1) num = 1;
if (num > fbwindow().numClients()) num = fbwindow().numClients();
FluxboxWindow::ClientList::iterator it = fbwindow().clientList().begin();
while (--num > 0) ++it;
2007-01-13 18:59:49 +00:00
(*it)->focus();
}
REGISTER_COMMAND(startmoving, StartMovingCmd, void);
void StartMovingCmd::real_execute() {
const XEvent &last = Fluxbox::instance()->lastEvent();
if (last.type == ButtonPress) {
const XButtonEvent &be = last.xbutton;
fbwindow().startMoving(be.x_root, be.y_root);
}
}
FbTk::Command<void> *StartResizingCmd::parse(const string &cmd, const string &args,
bool trusted) {
FluxboxWindow::ResizeModel mode = FluxboxWindow::DEFAULTRESIZE;
std::vector<string> tokens;
FbTk::StringUtil::stringtok<std::vector<string> >(tokens, args);
if (!tokens.empty()) {
string arg = FbTk::StringUtil::toLower(tokens[0]);
if (arg == "nearestcorner")
mode = FluxboxWindow::QUADRANTRESIZE;
else if (arg == "nearestedge")
mode = FluxboxWindow::NEARESTEDGERESIZE;
else if (arg == "center")
mode = FluxboxWindow::CENTERRESIZE;
else if (arg == "topleft")
mode = FluxboxWindow::TOPLEFTRESIZE;
else if (arg == "top")
mode = FluxboxWindow::TOPRESIZE;
else if (arg == "topright")
mode = FluxboxWindow::TOPRIGHTRESIZE;
else if (arg == "left")
mode = FluxboxWindow::LEFTRESIZE;
else if (arg == "right")
mode = FluxboxWindow::RIGHTRESIZE;
else if (arg == "bottomleft")
mode = FluxboxWindow::BOTTOMLEFTRESIZE;
else if (arg == "bottom")
mode = FluxboxWindow::BOTTOMRESIZE;
else if (arg == "bottomright")
mode = FluxboxWindow::BOTTOMRIGHTRESIZE;
}
return new StartResizingCmd(mode);
}
REGISTER_COMMAND_PARSER(startresizing, StartResizingCmd::parse, void);
void StartResizingCmd::real_execute() {
const XEvent &last = Fluxbox::instance()->lastEvent();
if (last.type == ButtonPress) {
const XButtonEvent &be = last.xbutton;
int x = be.x_root - fbwindow().x()
- fbwindow().frame().window().borderWidth();
int y = be.y_root - fbwindow().y()
- fbwindow().frame().window().borderWidth();
fbwindow().startResizing(x, y, fbwindow().getResizeDirection(x, y, m_mode));
}
}
REGISTER_COMMAND(starttabbing, StartTabbingCmd, void);
2007-12-21 07:07:46 +00:00
void StartTabbingCmd::real_execute() {
const XEvent &last = Fluxbox::instance()->lastEvent();
if (last.type == ButtonPress) {
const XButtonEvent &be = last.xbutton;
fbwindow().startTabbing(be);
}
}
FbTk::Command<void> *MoveCmd::parse(const string &command, const string &args,
bool trusted) {
FbTk_istringstream is(args.c_str());
int dx = 0, dy = 0;
is >> dx >> dy;
if (command == "moveright")
dy = 0;
else if (command == "moveleft") {
dy = 0;
dx = -dx;
} else if (command == "movedown") {
dy = dx;
dx = 0;
} else if (command == "moveup") {
dy = -dx;
dx = 0;
}
return new MoveCmd(dx, dy);
}
REGISTER_COMMAND_PARSER(move, MoveCmd::parse, void);
REGISTER_COMMAND_PARSER(moveright, MoveCmd::parse, void);
REGISTER_COMMAND_PARSER(moveleft, MoveCmd::parse, void);
REGISTER_COMMAND_PARSER(moveup, MoveCmd::parse, void);
REGISTER_COMMAND_PARSER(movedown, MoveCmd::parse, void);
MoveCmd::MoveCmd(const int step_size_x, const int step_size_y) :
m_step_size_x(step_size_x), m_step_size_y(step_size_y) { }
2003-06-30 14:35:11 +00:00
void MoveCmd::real_execute() {
fbwindow().move(
fbwindow().x() + m_step_size_x,
2003-10-26 12:36:55 +00:00
fbwindow().y() + m_step_size_y);
2003-06-30 14:35:11 +00:00
}
FbTk::Command<void> *ResizeCmd::parse(const string &command, const string &args,
bool trusted) {
FbTk_istringstream is(args.c_str());
int dx = 0, dy = 0;
is >> dx >> dy;
if (command == "resizehorizontal")
dy = 0;
else if (command == "resizevertical") {
dy = dx;
dx = 0;
}
if (command == "resizeto")
return new ResizeToCmd(dx, dy);
return new ResizeCmd(dx, dy);
}
REGISTER_COMMAND_PARSER(resize, ResizeCmd::parse, void);
REGISTER_COMMAND_PARSER(resizeto, ResizeCmd::parse, void);
REGISTER_COMMAND_PARSER(resizehorizontal, ResizeCmd::parse, void);
REGISTER_COMMAND_PARSER(resizevertical, ResizeCmd::parse, void);
2003-09-06 15:43:27 +00:00
ResizeCmd::ResizeCmd(const int step_size_x, const int step_size_y) :
2004-11-22 18:46:59 +00:00
m_step_size_x(step_size_x), m_step_size_y(step_size_y) { }
2003-09-06 15:43:27 +00:00
void ResizeCmd::real_execute() {
int w = std::max<int>(static_cast<int>(fbwindow().width() +
m_step_size_x * fbwindow().winClient().width_inc),
2004-11-22 18:46:59 +00:00
fbwindow().frame().titlebarHeight() * 2 + 10);
int h = std::max<int>(static_cast<int>(fbwindow().height() +
m_step_size_y * fbwindow().winClient().height_inc),
2004-11-22 18:46:59 +00:00
fbwindow().frame().titlebarHeight() + 10);
fbwindow().resize(w, h);
}
2003-10-25 22:11:22 +00:00
FbTk::Command<void> *MoveToCmd::parse(const string &cmd, const string &args,
bool trusted) {
typedef std::vector<string> StringTokens;
StringTokens tokens;
FbTk::StringUtil::stringtok<StringTokens>(tokens, args);
if (tokens.size() < 2)
return 0;
unsigned int refc = MoveToCmd::UPPER|MoveToCmd::LEFT;
int dx = 0, dy = 0;
if (tokens[0][0] == '*')
refc |= MoveToCmd::IGNORE_X;
else
dx = atoi(tokens[0].c_str());
if (tokens[1][0] == '*' && ! (refc & MoveToCmd::IGNORE_X))
refc |= MoveToCmd::IGNORE_Y;
else
dy = atoi(tokens[1].c_str());
if (tokens.size() >= 3) {
tokens[2] = FbTk::StringUtil::toLower(tokens[2]);
if (tokens[2] == "left" || tokens[2] == "upperleft" || tokens[2] == "lowerleft") {
refc |= MoveToCmd::LEFT;
refc &= ~MoveToCmd::RIGHT;
} else if (tokens[2] == "right" || tokens[2] == "upperright" || tokens[2] == "lowerright") {
refc |= MoveToCmd::RIGHT;
refc &= ~MoveToCmd::LEFT;
}
if (tokens[2] == "upper" || tokens[2] == "upperleft" || tokens[2] == "upperright") {
refc |= MoveToCmd::UPPER;
refc &= ~MoveToCmd::LOWER;
} else if (tokens[2] == "lower" || tokens[2] == "lowerleft" || tokens[2] == "lowerright") {
refc |= MoveToCmd::LOWER;
refc &= ~MoveToCmd::UPPER;
}
}
return new MoveToCmd(dx, dy, refc);
}
REGISTER_COMMAND_PARSER(moveto, MoveToCmd::parse, void);
MoveToCmd::MoveToCmd(const int step_size_x, const int step_size_y, const unsigned int refc) :
m_step_size_x(step_size_x), m_step_size_y(step_size_y), m_refc(refc) { }
2003-10-25 22:11:22 +00:00
void MoveToCmd::real_execute() {
int x = 0;
int y = 0;
const int head = fbwindow().screen().getHead(fbwindow().fbWindow());
if (m_refc & MoveToCmd::LOWER)
y = fbwindow().screen().maxBottom(head) - fbwindow().height() - 2 * fbwindow().frame().window().borderWidth() - m_step_size_y;
if (m_refc & MoveToCmd::UPPER)
y = fbwindow().screen().maxTop(head) + m_step_size_y;
if (m_refc & MoveToCmd::RIGHT)
x = fbwindow().screen().maxRight(head) - fbwindow().width() - 2 * fbwindow().frame().window().borderWidth() - m_step_size_x;
if (m_refc & MoveToCmd::LEFT)
x = fbwindow().screen().maxLeft(head) + m_step_size_x;
if (m_refc & MoveToCmd::IGNORE_X)
x = fbwindow().x();
if (m_refc & MoveToCmd::IGNORE_Y)
y = fbwindow().y();
fbwindow().move(x, y);
2003-10-25 22:11:22 +00:00
}
2003-10-25 22:11:22 +00:00
ResizeToCmd::ResizeToCmd(const int step_size_x, const int step_size_y) :
2003-10-26 12:36:55 +00:00
m_step_size_x(step_size_x), m_step_size_y(step_size_y) { }
2003-10-25 22:11:22 +00:00
void ResizeToCmd::real_execute() {
2004-11-22 18:46:59 +00:00
if (m_step_size_x > 0 && m_step_size_y > 0)
fbwindow().resize(m_step_size_x, m_step_size_y);
2003-10-25 22:11:22 +00:00
}
REGISTER_COMMAND(fullscreen, FullscreenCmd, void);
FullscreenCmd::FullscreenCmd() { }
void FullscreenCmd::real_execute() {
fbwindow().setFullscreen(!fbwindow().isFullscreen());
}
2007-02-02 19:04:57 +00:00
2008-08-05 07:05:21 +00:00
FbTk::Command<void> *SetLayerCmd::parse(const string &command,
const string &args, bool trusted) {
int l = Layer::getNumFromString(args);
return (l == -1) ? 0 : new SetLayerCmd(l);
}
REGISTER_COMMAND_PARSER(setlayer, SetLayerCmd::parse, void);
void SetLayerCmd::real_execute() {
fbwindow().moveToLayer(m_layer);
}
FbTk::Command<void> *SetAlphaCmd::parse(const string &command, const string &args,
bool trusted) {
typedef std::vector<string> StringTokens;
StringTokens tokens;
FbTk::StringUtil::stringtok<StringTokens>(tokens, args);
int focused, unfocused;
bool relative, un_rel;
if (tokens.empty()) { // set default alpha
focused = unfocused = 256;
relative = un_rel = false;
} else {
relative = un_rel = (tokens[0][0] == '+' || tokens[0][0] == '-');
focused = unfocused = atoi(tokens[0].c_str());
}
if (tokens.size() > 1) { // set different unfocused alpha
un_rel = (tokens[1][0] == '+' || tokens[1][0] == '-');
unfocused = atoi(tokens[1].c_str());
}
return new SetAlphaCmd(focused, relative, unfocused, un_rel);
}
REGISTER_COMMAND_PARSER(setalpha, SetAlphaCmd::parse, void);
2007-02-02 19:04:57 +00:00
SetAlphaCmd::SetAlphaCmd(int focused, bool relative,
int unfocused, bool un_relative) :
m_focus(focused), m_unfocus(unfocused),
m_relative(relative), m_un_relative(un_relative) { }
void SetAlphaCmd::real_execute() {
if (m_focus == 256 && m_unfocus == 256) {
// made up signal to return to default
fbwindow().setDefaultAlpha();
2007-02-02 19:04:57 +00:00
return;
}
int new_alpha;
if (m_relative) {
new_alpha = fbwindow().getFocusedAlpha() + m_focus;
if (new_alpha < 0) new_alpha = 0;
if (new_alpha > 255) new_alpha = 255;
fbwindow().setFocusedAlpha(new_alpha);
} else
fbwindow().setFocusedAlpha(m_focus);
if (m_un_relative) {
new_alpha = fbwindow().getUnfocusedAlpha() + m_unfocus;
if (new_alpha < 0) new_alpha = 0;
if (new_alpha > 255) new_alpha = 255;
fbwindow().setUnfocusedAlpha(new_alpha);
} else
fbwindow().setUnfocusedAlpha(m_unfocus);
}
REGISTER_COMMAND_WITH_ARGS(matches, MatchCmd, bool);
bool MatchCmd::real_execute() {
return m_pat.match(winclient());
}