2007-11-27 19:40:25 +00:00
|
|
|
/********************************************************************
|
2007-04-29 17:35:43 +00:00
|
|
|
KWin - the KDE window manager
|
|
|
|
This file is part of the KDE project.
|
|
|
|
|
|
|
|
Copyright (C) 1999, 2000 Matthias Ettrich <ettrich@kde.org>
|
|
|
|
Copyright (C) 2003 Lubos Lunak <l.lunak@kde.org>
|
|
|
|
|
2007-11-27 19:40:25 +00:00
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*********************************************************************/
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
#ifndef KWIN_CLIENT_H
|
|
|
|
#define KWIN_CLIENT_H
|
|
|
|
|
2007-06-25 08:51:44 +00:00
|
|
|
#include <config-X11.h>
|
|
|
|
|
2008-02-02 20:54:19 +00:00
|
|
|
#include <QFrame>
|
2007-04-29 17:35:43 +00:00
|
|
|
#include <QPixmap>
|
|
|
|
#include <netwm.h>
|
|
|
|
#include <kdebug.h>
|
|
|
|
#include <assert.h>
|
|
|
|
#include <kshortcut.h>
|
|
|
|
#include <X11/X.h>
|
|
|
|
#include <X11/Xlib.h>
|
|
|
|
#include <X11/Xutil.h>
|
|
|
|
#include <fixx11h.h>
|
|
|
|
|
|
|
|
#include "utils.h"
|
|
|
|
#include "options.h"
|
|
|
|
#include "workspace.h"
|
|
|
|
#include "kdecoration.h"
|
|
|
|
#include "rules.h"
|
|
|
|
#include "toplevel.h"
|
2009-11-15 03:24:04 +00:00
|
|
|
#include "clientgroup.h"
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2007-06-25 08:51:44 +00:00
|
|
|
#ifdef HAVE_XSYNC
|
|
|
|
#include <X11/extensions/sync.h>
|
|
|
|
#endif
|
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
// TODO: Cleanup the order of things in this .h file
|
|
|
|
|
2007-11-26 15:42:44 +00:00
|
|
|
class QProcess;
|
2007-04-29 17:35:43 +00:00
|
|
|
class QTimer;
|
|
|
|
class KStartupInfoData;
|
|
|
|
|
|
|
|
namespace KWin
|
|
|
|
{
|
2011-01-30 14:34:42 +00:00
|
|
|
namespace TabBox
|
|
|
|
{
|
2009-09-13 11:36:45 +00:00
|
|
|
|
|
|
|
class TabBoxClientImpl;
|
|
|
|
}
|
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
class Workspace;
|
|
|
|
class Client;
|
|
|
|
class Bridge;
|
2009-04-22 17:29:56 +00:00
|
|
|
class PaintRedirector;
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
class Client
|
|
|
|
: public Toplevel
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
Q_OBJECT
|
2011-12-22 13:39:55 +00:00
|
|
|
/**
|
|
|
|
* Whether this Client is active or not. Use Workspace::activateClient() to activate a Client.
|
|
|
|
* @see Workspace::activateClient
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool active READ isActive NOTIFY activeChanged)
|
2011-12-22 13:53:11 +00:00
|
|
|
/**
|
|
|
|
* The Caption of the Client. Read from WM_NAME property together with a suffix for hostname and shortcut.
|
|
|
|
* To read only the caption as provided by WM_NAME, use the getter with an additional @c false value.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(QString caption READ caption NOTIFY captionChanged)
|
2011-12-22 13:56:56 +00:00
|
|
|
/**
|
|
|
|
* Whether the window can be closed by the user. The value is evaluated each time the getter is called.
|
|
|
|
* Because of that no changed signal is provided.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool closeable READ isCloseable)
|
2011-12-22 14:02:35 +00:00
|
|
|
/**
|
|
|
|
* The desktop this Client is on. If the Client is on all desktops the property has value -1.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(int desktop READ desktop WRITE setDesktop NOTIFY desktopChanged)
|
2011-12-22 14:34:55 +00:00
|
|
|
/**
|
|
|
|
* Whether this Client is fullScreen. A Client might either be fullScreen due to the _NET_WM property
|
|
|
|
* or through a legacy support hack. The fullScreen state can only be changed if the Client does not
|
|
|
|
* use the legacy hack. To be sure whether the state changed, connect to the notify signal.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool fullScreen READ isFullScreen WRITE setFullScreen NOTIFY fullScreenChanged)
|
2011-12-22 14:43:35 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client can be set to fullScreen. The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool fullScreenable READ isFullScreenable)
|
2011-12-22 18:38:52 +00:00
|
|
|
/**
|
|
|
|
* The geometry of this Client. Be aware that depending on resize mode the geometryChanged signal
|
|
|
|
* might be emitted at each resize step or only at the end of the resize operation.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(QRect geometry READ geometry WRITE setGeometry)
|
2011-12-22 17:28:24 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client is set to be kept above other windows.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool keepAbove READ keepAbove WRITE setKeepAbove NOTIFY keepAboveChanged)
|
|
|
|
/**
|
|
|
|
* Whether the Client is set to be kept below other windows.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool keepBelow READ keepBelow WRITE setKeepBelow NOTIFY keepBelowChanged)
|
2011-12-22 17:30:37 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client can be maximized both horizontally and vertically.
|
|
|
|
* The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool maximizable READ isMaximizable)
|
2011-12-22 17:30:37 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client can be minimized. The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool minimizable READ isMinimizable)
|
2011-12-22 18:01:01 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client is minimized.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool minimized READ isMinimized WRITE setMinimized NOTIFY minimizedChanged)
|
2011-12-22 16:54:07 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client represents a modal window.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool modal READ isModal NOTIFY modalChanged)
|
2011-12-22 17:16:04 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client is moveable. Even if it is not moveable, it might be possible to move
|
|
|
|
* it to another screen. The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
* @see moveableAcrossScreens
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool moveable READ isMovable)
|
2011-12-22 17:16:04 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client can be moved to another screen. The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
* @see moveable
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool moveableAcrossScreens READ isMovableAcrossScreens)
|
2011-12-22 16:54:59 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client provides context help. Mostly needed by decorations to decide whether to
|
|
|
|
* show the help button or not.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool providesContextHelp READ providesContextHelp CONSTANT)
|
2011-12-22 17:16:04 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client can be resized. The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool resizeable READ isResizable)
|
2011-12-22 17:10:18 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client can be shaded. The property is evaluated each time it is invoked.
|
|
|
|
* Because of that there is no notify signal.
|
|
|
|
**/
|
2011-12-18 09:29:32 +00:00
|
|
|
Q_PROPERTY(bool shadeable READ isShadeable)
|
2011-12-22 17:10:18 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client is shaded.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool shade READ isShade WRITE setShade NOTIFY shadeChanged)
|
2011-12-22 16:00:08 +00:00
|
|
|
/**
|
|
|
|
* Whether the Client is a transient Window to another Window.
|
|
|
|
* @see transientFor
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool transient READ isTransient NOTIFY transientChanged)
|
|
|
|
/**
|
|
|
|
* The Client to which this Client is a transient if any.
|
|
|
|
* Property uses a QObject. If the property is needed as a Client, perform a qobject_cast.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(QObject *transientFor READ transientFor NOTIFY transientChanged)
|
2011-12-29 09:19:36 +00:00
|
|
|
/**
|
|
|
|
* By how much the window wishes to grow/shrink at least. Usually QSize(1,1).
|
|
|
|
* MAY BE DISOBEYED BY THE WM! It's only for information, do NOT rely on it at all.
|
|
|
|
* The value is evaluated each time the getter is called.
|
|
|
|
* Because of that no changed signal is provided.
|
|
|
|
*/
|
|
|
|
Q_PROPERTY(QSize basicUnit READ basicUnit)
|
|
|
|
/**
|
|
|
|
* Whether the Client is currently being moved by the user.
|
|
|
|
* Notify signal is emitted when the Client starts or ends move/resize mode.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool move READ isMove NOTIFY moveResizedChanged)
|
|
|
|
/**
|
|
|
|
* Whether the Client is currently being resized by the user.
|
|
|
|
* Notify signal is emitted when the Client starts or ends move/resize mode.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool resize READ isResize NOTIFY moveResizedChanged)
|
|
|
|
/**
|
|
|
|
* The optional geometry representing the minimized Client in e.g a taskbar.
|
|
|
|
* See _NET_WM_ICON_GEOMETRY at http://standards.freedesktop.org/wm-spec/wm-spec-latest.html .
|
|
|
|
* The value is evaluated each time the getter is called.
|
|
|
|
* Because of that no changed signal is provided.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(QRect iconGeometry READ iconGeometry)
|
|
|
|
/**
|
|
|
|
* Returns whether the window is any of special windows types (desktop, dock, splash, ...),
|
|
|
|
* i.e. window types that usually don't have a window frame and the user does not use window
|
|
|
|
* management (moving, raising,...) on them.
|
|
|
|
* The value is evaluated each time the getter is called.
|
|
|
|
* Because of that no changed signal is provided.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool specialWindow READ isSpecialWindow)
|
|
|
|
/**
|
|
|
|
* Whether the Client can accept keyboard focus.
|
|
|
|
* The value is evaluated each time the getter is called.
|
|
|
|
* Because of that no changed signal is provided.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool wantsInput READ wantsInput)
|
|
|
|
// TODO: a QIcon with all icon sizes?
|
|
|
|
Q_PROPERTY(QPixmap icon READ icon NOTIFY iconChanged)
|
|
|
|
/**
|
|
|
|
* Whether the Client should be excluded from window switching effects.
|
|
|
|
**/
|
|
|
|
Q_PROPERTY(bool skipSwitcher READ skipSwitcher WRITE setSkipSwitcher NOTIFY skipSwitcherChanged)
|
2011-01-30 14:34:42 +00:00
|
|
|
public:
|
|
|
|
Client(Workspace* ws);
|
|
|
|
Window wrapperId() const;
|
|
|
|
Window decorationId() const;
|
2011-11-09 19:39:13 +00:00
|
|
|
Window inputId() const { return input_window; }
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
const Client* transientFor() const;
|
|
|
|
Client* transientFor();
|
|
|
|
bool isTransient() const;
|
|
|
|
bool groupTransient() const;
|
|
|
|
bool wasOriginallyGroupTransient() const;
|
|
|
|
ClientList mainClients() const; // Call once before loop , is not indirect
|
|
|
|
ClientList allMainClients() const; // Call once before loop , is indirect
|
|
|
|
bool hasTransient(const Client* c, bool indirect) const;
|
|
|
|
const ClientList& transients() const; // Is not indirect
|
|
|
|
void checkTransient(Window w);
|
|
|
|
Client* findModal(bool allow_itself = false);
|
|
|
|
const Group* group() const;
|
|
|
|
Group* group();
|
|
|
|
void checkGroup(Group* gr = NULL, bool force = false);
|
|
|
|
void changeClientLeaderGroup(Group* gr);
|
|
|
|
const WindowRules* rules() const;
|
|
|
|
void removeRule(Rules* r);
|
|
|
|
void setupWindowRules(bool ignore_temporary);
|
|
|
|
void applyWindowRules();
|
|
|
|
void updateWindowRules();
|
|
|
|
void updateFullscreenMonitors(NETFullscreenMonitors topology);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true for "special" windows and false for windows which are "normal"
|
|
|
|
* (normal=window which has a border, can be moved by the user, can be closed, etc.)
|
|
|
|
* true for Desktop, Dock, Splash, Override and TopMenu (and Toolbar??? - for now)
|
|
|
|
* false for Normal, Dialog, Utility and Menu (and Toolbar??? - not yet) TODO
|
|
|
|
*/
|
|
|
|
bool isSpecialWindow() const;
|
|
|
|
bool hasNETSupport() const;
|
|
|
|
|
|
|
|
QSize minSize() const;
|
|
|
|
QSize maxSize() const;
|
2011-11-02 22:05:03 +00:00
|
|
|
QSize basicUnit() const;
|
2011-01-30 14:34:42 +00:00
|
|
|
virtual QPoint clientPos() const; // Inside of geometry()
|
|
|
|
virtual QSize clientSize() const;
|
|
|
|
virtual QRect visibleRect() const;
|
2011-11-09 19:39:13 +00:00
|
|
|
QPoint inputPos() const { return input_offset; } // Inside of geometry()
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
bool windowEvent(XEvent* e);
|
|
|
|
virtual bool eventFilter(QObject* o, QEvent* e);
|
2007-06-25 08:51:44 +00:00
|
|
|
#ifdef HAVE_XSYNC
|
2011-01-30 14:34:42 +00:00
|
|
|
void syncEvent(XSyncAlarmNotifyEvent* e);
|
2007-06-25 08:51:44 +00:00
|
|
|
#endif
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
bool manage(Window w, bool isMapped);
|
|
|
|
void releaseWindow(bool on_shutdown = false);
|
|
|
|
void destroyClient();
|
|
|
|
|
|
|
|
/// How to resize the window in order to obey constains (mainly aspect ratios)
|
|
|
|
enum Sizemode {
|
|
|
|
SizemodeAny,
|
|
|
|
SizemodeFixedW, ///< Try not to affect width
|
|
|
|
SizemodeFixedH, ///< Try not to affect height
|
|
|
|
SizemodeMax ///< Try not to make it larger in either direction
|
|
|
|
};
|
|
|
|
QSize adjustedSize(const QSize&, Sizemode mode = SizemodeAny) const;
|
|
|
|
QSize adjustedSize() const;
|
|
|
|
|
|
|
|
QPixmap icon() const;
|
|
|
|
QPixmap icon(const QSize& size) const;
|
|
|
|
QPixmap miniIcon() const;
|
|
|
|
QPixmap bigIcon() const;
|
|
|
|
QPixmap hugeIcon() const;
|
|
|
|
|
|
|
|
bool isActive() const;
|
|
|
|
void setActive(bool);
|
|
|
|
|
|
|
|
virtual int desktop() const;
|
|
|
|
void setDesktop(int);
|
|
|
|
void setOnAllDesktops(bool set);
|
|
|
|
|
|
|
|
virtual QStringList activities() const;
|
|
|
|
void setOnActivity(const QString &activity, bool enable);
|
|
|
|
void setOnAllActivities(bool set);
|
|
|
|
void setOnActivities(QStringList newActivitiesList);
|
|
|
|
void updateActivities(bool includeTransients);
|
|
|
|
|
|
|
|
/// Is not minimized and not hidden. I.e. normally visible on some virtual desktop.
|
|
|
|
bool isShown(bool shaded_is_shown) const;
|
|
|
|
bool isHiddenInternal() const; // For compositing
|
|
|
|
|
|
|
|
bool isShade() const; // True only for ShadeNormal
|
|
|
|
ShadeMode shadeMode() const; // Prefer isShade()
|
2011-12-22 17:10:18 +00:00
|
|
|
void setShade(bool set);
|
2011-01-30 14:34:42 +00:00
|
|
|
void setShade(ShadeMode mode);
|
|
|
|
bool isShadeable() const;
|
|
|
|
|
|
|
|
bool isMinimized() const;
|
|
|
|
bool isMaximizable() const;
|
|
|
|
QRect geometryRestore() const;
|
|
|
|
MaximizeMode maximizeModeRestore() const;
|
|
|
|
MaximizeMode maximizeMode() const;
|
|
|
|
bool isMinimizable() const;
|
|
|
|
void setMaximize(bool vertically, bool horizontally);
|
|
|
|
QRect iconGeometry() const;
|
|
|
|
|
2011-12-22 14:34:55 +00:00
|
|
|
void setFullScreen(bool set, bool user = true);
|
2011-01-30 14:34:42 +00:00
|
|
|
bool isFullScreen() const;
|
|
|
|
bool isFullScreenable(bool fullscreen_hack = false) const;
|
|
|
|
bool isActiveFullScreen() const;
|
|
|
|
bool userCanSetFullScreen() const;
|
|
|
|
QRect geometryFSRestore() const {
|
|
|
|
return geom_fs_restore; // Only for session saving
|
|
|
|
}
|
|
|
|
int fullScreenMode() const {
|
|
|
|
return fullscreen_mode; // only for session saving
|
|
|
|
}
|
|
|
|
|
|
|
|
bool noBorder() const;
|
|
|
|
void setNoBorder(bool set);
|
|
|
|
bool userCanSetNoBorder() const;
|
|
|
|
void checkNoBorder();
|
|
|
|
|
|
|
|
bool skipTaskbar(bool from_outside = false) const;
|
|
|
|
void setSkipTaskbar(bool set, bool from_outside);
|
|
|
|
|
|
|
|
bool skipPager() const;
|
|
|
|
void setSkipPager(bool);
|
|
|
|
|
|
|
|
bool skipSwitcher() const;
|
|
|
|
void setSkipSwitcher(bool set);
|
|
|
|
|
|
|
|
bool keepAbove() const;
|
|
|
|
void setKeepAbove(bool);
|
|
|
|
bool keepBelow() const;
|
|
|
|
void setKeepBelow(bool);
|
|
|
|
Layer layer() const;
|
|
|
|
Layer belongsToLayer() const;
|
|
|
|
void invalidateLayer();
|
|
|
|
int sessionStackingOrder() const;
|
|
|
|
|
|
|
|
void setModal(bool modal);
|
|
|
|
bool isModal() const;
|
|
|
|
|
|
|
|
// Auxiliary functions, depend on the windowType
|
|
|
|
bool wantsTabFocus() const;
|
|
|
|
bool wantsInput() const;
|
|
|
|
|
|
|
|
bool isResizable() const;
|
|
|
|
bool isMovable() const;
|
|
|
|
bool isMovableAcrossScreens() const;
|
|
|
|
bool isCloseable() const; ///< May be closed by the user (May have a close button)
|
|
|
|
|
|
|
|
void takeActivity(int flags, bool handled, allowed_t); // Takes ActivityFlags as arg (in utils.h)
|
|
|
|
void takeFocus(allowed_t);
|
|
|
|
void demandAttention(bool set = true);
|
|
|
|
|
|
|
|
void setMask(const QRegion& r, int mode = X::Unsorted);
|
|
|
|
QRegion mask() const;
|
|
|
|
|
|
|
|
void updateDecoration(bool check_workspace_pos, bool force = false);
|
|
|
|
bool checkBorderSizes(bool also_resize);
|
|
|
|
void triggerDecorationRepaint();
|
|
|
|
|
|
|
|
void updateShape();
|
|
|
|
|
2011-12-22 18:38:52 +00:00
|
|
|
void setGeometry(int x, int y, int w, int h, ForceGeometry_t force = NormalGeometrySet);
|
|
|
|
void setGeometry(const QRect& r, ForceGeometry_t force = NormalGeometrySet);
|
2011-01-30 14:34:42 +00:00
|
|
|
void move(int x, int y, ForceGeometry_t force = NormalGeometrySet);
|
|
|
|
void move(const QPoint& p, ForceGeometry_t force = NormalGeometrySet);
|
|
|
|
/// plainResize() simply resizes
|
2011-12-22 18:38:52 +00:00
|
|
|
void plainResize(int w, int h, ForceGeometry_t force = NormalGeometrySet);
|
|
|
|
void plainResize(const QSize& s, ForceGeometry_t force = NormalGeometrySet);
|
2011-01-30 14:34:42 +00:00
|
|
|
/// resizeWithChecks() resizes according to gravity, and checks workarea position
|
|
|
|
void resizeWithChecks(int w, int h, ForceGeometry_t force = NormalGeometrySet);
|
|
|
|
void resizeWithChecks(const QSize& s, ForceGeometry_t force = NormalGeometrySet);
|
|
|
|
void keepInArea(QRect area, bool partial = false);
|
2011-03-07 21:31:44 +00:00
|
|
|
void setElectricBorderMode(QuickTileMode mode);
|
|
|
|
QuickTileMode electricBorderMode() const;
|
2011-01-30 14:34:42 +00:00
|
|
|
void setElectricBorderMaximizing(bool maximizing);
|
|
|
|
bool isElectricBorderMaximizing() const;
|
2011-03-07 21:31:44 +00:00
|
|
|
QRect electricBorderMaximizeGeometry(QPoint pos, int desktop);
|
2011-01-30 14:34:42 +00:00
|
|
|
QSize sizeForClientSize(const QSize&, Sizemode mode = SizemodeAny, bool noframe = false) const;
|
|
|
|
|
|
|
|
/** Set the quick tile mode ("snap") of this window.
|
|
|
|
* This will also handle preserving and restoring of window geometry as necessary.
|
|
|
|
* @param mode The tile mode (left/right) to give this window.
|
|
|
|
*/
|
|
|
|
void setQuickTileMode(QuickTileMode mode, bool keyboard = false);
|
|
|
|
|
|
|
|
void growHorizontal();
|
|
|
|
void shrinkHorizontal();
|
|
|
|
void growVertical();
|
|
|
|
void shrinkVertical();
|
|
|
|
|
|
|
|
bool providesContextHelp() const;
|
|
|
|
KShortcut shortcut() const;
|
|
|
|
void setShortcut(const QString& cut);
|
|
|
|
|
|
|
|
WindowOperation mouseButtonToWindowOperation(Qt::MouseButtons button);
|
|
|
|
bool performMouseCommand(Options::MouseCommand, const QPoint& globalPos, bool handled = false);
|
|
|
|
|
|
|
|
QRect adjustedClientArea(const QRect& desktop, const QRect& area) const;
|
|
|
|
|
|
|
|
Colormap colormap() const;
|
|
|
|
|
|
|
|
/// Updates visibility depending on being shaded, virtual desktop, etc.
|
|
|
|
void updateVisibility();
|
|
|
|
/// Hides a client - Basically like minimize, but without effects, it's simply hidden
|
|
|
|
void hideClient(bool hide);
|
|
|
|
bool hiddenPreview() const; ///< Window is mapped in order to get a window pixmap
|
|
|
|
|
|
|
|
virtual void setupCompositing();
|
|
|
|
virtual void finishCompositing();
|
2011-03-20 14:42:05 +00:00
|
|
|
inline bool isBlockingCompositing() { return blocks_compositing; }
|
|
|
|
void updateCompositeBlocking(bool readProperty = false);
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
QString caption(bool full = true) const;
|
|
|
|
void updateCaption();
|
|
|
|
|
|
|
|
void keyPressEvent(uint key_code); // FRAME ??
|
|
|
|
void updateMouseGrab();
|
|
|
|
Window moveResizeGrabWindow() const;
|
|
|
|
|
|
|
|
const QPoint calculateGravitation(bool invert, int gravity = 0) const; // FRAME public?
|
|
|
|
|
|
|
|
void NETMoveResize(int x_root, int y_root, NET::Direction direction);
|
|
|
|
void NETMoveResizeWindow(int flags, int x, int y, int width, int height);
|
|
|
|
void restackWindow(Window above, int detail, NET::RequestSource source, Time timestamp,
|
|
|
|
bool send_event = false);
|
|
|
|
|
|
|
|
void gotPing(Time timestamp);
|
|
|
|
|
2011-09-29 15:52:19 +00:00
|
|
|
void checkWorkspacePosition(QRect oldGeometry = QRect(), int oldDesktop = -2);
|
2011-01-30 14:34:42 +00:00
|
|
|
void updateUserTime(Time time = CurrentTime);
|
|
|
|
Time userTime() const;
|
|
|
|
bool hasUserTimeSupport() const;
|
|
|
|
bool ignoreFocusStealing() const;
|
|
|
|
|
|
|
|
/// Does 'delete c;'
|
|
|
|
static void deleteClient(Client* c, allowed_t);
|
|
|
|
|
|
|
|
static bool belongToSameApplication(const Client* c1, const Client* c2, bool active_hack = false);
|
|
|
|
static bool sameAppWindowRoleMatch(const Client* c1, const Client* c2, bool active_hack);
|
|
|
|
static void readIcons(Window win, QPixmap* icon, QPixmap* miniicon, QPixmap* bigicon, QPixmap* hugeicon);
|
|
|
|
|
2011-12-22 18:01:01 +00:00
|
|
|
void setMinimized(bool set);
|
2011-01-30 14:34:42 +00:00
|
|
|
void minimize(bool avoid_animation = false);
|
|
|
|
void unminimize(bool avoid_animation = false);
|
|
|
|
void closeWindow();
|
|
|
|
void killWindow();
|
|
|
|
void maximize(MaximizeMode);
|
|
|
|
void toggleShade();
|
|
|
|
void showContextHelp();
|
|
|
|
void cancelShadeHoverTimer();
|
|
|
|
void cancelAutoRaise();
|
|
|
|
void checkActiveModal();
|
|
|
|
StrutRect strutRect(StrutArea area) const;
|
|
|
|
StrutRects strutRects() const;
|
|
|
|
bool hasStrut() const;
|
|
|
|
|
|
|
|
// Tabbing functions
|
|
|
|
ClientGroup* clientGroup() const; // Returns a pointer to client_group
|
|
|
|
void setClientGroup(ClientGroup* group);
|
|
|
|
/*
|
|
|
|
* If shown is true the client is mapped and raised, if false
|
|
|
|
* the client is unmapped and hidden, this function is called
|
|
|
|
* when the tabbing group of the client switches its visible
|
|
|
|
* client.
|
|
|
|
*/
|
|
|
|
void setClientShown(bool shown);
|
|
|
|
/*
|
|
|
|
* When a click is done in the decoration and it calls the group
|
|
|
|
* to change the visible client it starts to move-resize the new
|
|
|
|
* client, this function stops it.
|
|
|
|
*/
|
|
|
|
void dontMoveResize();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether or not the window has a strut that expands through the invisible area of
|
|
|
|
* an xinerama setup where the monitors are not the same resolution.
|
|
|
|
*/
|
|
|
|
bool hasOffscreenXineramaStrut() const;
|
|
|
|
|
|
|
|
bool isMove() const {
|
|
|
|
return moveResizeMode && mode == PositionCenter;
|
|
|
|
}
|
|
|
|
bool isResize() const {
|
|
|
|
return moveResizeMode && mode != PositionCenter;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Decorations <-> Effects
|
|
|
|
const QPixmap *topDecoPixmap() const {
|
|
|
|
return &decorationPixmapTop;
|
|
|
|
}
|
|
|
|
const QPixmap *leftDecoPixmap() const {
|
|
|
|
return &decorationPixmapLeft;
|
|
|
|
}
|
|
|
|
const QPixmap *bottomDecoPixmap() const {
|
|
|
|
return &decorationPixmapBottom;
|
|
|
|
}
|
|
|
|
const QPixmap *rightDecoPixmap() const {
|
|
|
|
return &decorationPixmapRight;
|
|
|
|
}
|
|
|
|
|
|
|
|
int paddingLeft() const {
|
|
|
|
return padding_left;
|
|
|
|
}
|
|
|
|
int paddingRight() const {
|
|
|
|
return padding_right;
|
|
|
|
}
|
|
|
|
int paddingTop() const {
|
|
|
|
return padding_top;
|
|
|
|
}
|
|
|
|
int paddingBottom() const {
|
|
|
|
return padding_bottom;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool decorationPixmapRequiresRepaint();
|
|
|
|
void ensureDecorationPixmapsPainted();
|
|
|
|
|
2011-04-10 19:24:27 +00:00
|
|
|
QRect decorationRect() const;
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
QRect transparentRect() const;
|
|
|
|
|
|
|
|
QRegion decorationPendingRegion() const;
|
|
|
|
|
|
|
|
enum CoordinateMode {
|
|
|
|
DecorationRelative, // Relative to the top left corner of the decoration
|
|
|
|
WindowRelative // Relative to the top left corner of the window
|
|
|
|
};
|
|
|
|
void layoutDecorationRects(QRect &left, QRect &top, QRect &right, QRect &bottom, CoordinateMode mode) const;
|
|
|
|
|
|
|
|
TabBox::TabBoxClientImpl* tabBoxClient() const {
|
|
|
|
return m_tabBoxClient;
|
|
|
|
}
|
2011-12-01 12:15:11 +00:00
|
|
|
bool isFirstInTabBox() const {
|
|
|
|
return m_firstInTabBox;
|
|
|
|
}
|
|
|
|
void setFirstInTabBox(bool enable) {
|
|
|
|
m_firstInTabBox = enable;
|
|
|
|
}
|
|
|
|
void updateFirstInTabBox();
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
//sets whether the client should be treated as a SessionInteract window
|
|
|
|
void setSessionInteract(bool needed);
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
void autoRaise();
|
|
|
|
void shadeHover();
|
|
|
|
void shadeUnhover();
|
|
|
|
void shortcutActivated();
|
|
|
|
void delayedMoveResize();
|
|
|
|
|
|
|
|
private:
|
|
|
|
friend class Bridge; // FRAME
|
|
|
|
virtual void processMousePressEvent(QMouseEvent* e);
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Use Workspace::createClient()
|
|
|
|
virtual ~Client(); ///< Use destroyClient() or releaseWindow()
|
|
|
|
|
|
|
|
Position mousePosition(const QPoint&) const;
|
|
|
|
void updateCursor();
|
|
|
|
|
|
|
|
// Handlers for X11 events
|
|
|
|
bool mapRequestEvent(XMapRequestEvent* e);
|
|
|
|
void unmapNotifyEvent(XUnmapEvent* e);
|
|
|
|
void destroyNotifyEvent(XDestroyWindowEvent* e);
|
|
|
|
void configureRequestEvent(XConfigureRequestEvent* e);
|
|
|
|
virtual void propertyNotifyEvent(XPropertyEvent* e);
|
|
|
|
void clientMessageEvent(XClientMessageEvent* e);
|
|
|
|
void enterNotifyEvent(XCrossingEvent* e);
|
|
|
|
void leaveNotifyEvent(XCrossingEvent* e);
|
|
|
|
void focusInEvent(XFocusInEvent* e);
|
|
|
|
void focusOutEvent(XFocusOutEvent* e);
|
|
|
|
virtual void damageNotifyEvent(XDamageNotifyEvent* e);
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
bool buttonPressEvent(Window w, int button, int state, int x, int y, int x_root, int y_root);
|
|
|
|
bool buttonReleaseEvent(Window w, int button, int state, int x, int y, int x_root, int y_root);
|
|
|
|
bool motionNotifyEvent(Window w, int state, int x, int y, int x_root, int y_root);
|
|
|
|
void checkQuickTilingMaximizationZones(int xroot, int yroot);
|
|
|
|
|
|
|
|
bool processDecorationButtonPress(int button, int state, int x, int y, int x_root, int y_root,
|
|
|
|
bool ignoreMenu = false);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual void debug(QDebug& stream) const;
|
|
|
|
virtual bool shouldUnredirect() const;
|
|
|
|
|
|
|
|
private slots:
|
2011-08-13 14:39:58 +00:00
|
|
|
void delayedSetShortcut();
|
|
|
|
void performMoveResize();
|
|
|
|
void removeSyncSupport();
|
2011-01-30 14:34:42 +00:00
|
|
|
void pingTimeout();
|
|
|
|
void processKillerExited();
|
|
|
|
void demandAttentionKNotify();
|
|
|
|
void repaintDecorationPending();
|
|
|
|
|
2010-09-21 14:31:40 +00:00
|
|
|
//Signals for the scripting interface
|
2011-01-01 09:39:02 +00:00
|
|
|
//Signals make an excellent way for communication
|
2010-09-21 14:31:40 +00:00
|
|
|
//in between objects as compared to simple function
|
|
|
|
//calls
|
2011-01-30 14:34:42 +00:00
|
|
|
signals:
|
|
|
|
void clientManaging(KWin::Client*);
|
|
|
|
void s_unminimized();
|
|
|
|
void maximizeSet(QPair<bool, bool>);
|
2011-02-28 20:03:13 +00:00
|
|
|
void clientMaximizedStateChanged(KWin::Client*, KDecorationDefines::MaximizeMode);
|
2011-03-06 09:55:27 +00:00
|
|
|
void clientMinimized(KWin::Client* client, bool animate);
|
2011-03-06 10:08:19 +00:00
|
|
|
void clientUnminimized(KWin::Client* client, bool animate);
|
2011-03-13 11:41:30 +00:00
|
|
|
void clientStartUserMovedResized(KWin::Client*);
|
|
|
|
void clientStepUserMovedResized(KWin::Client *, const QRect&);
|
|
|
|
void clientFinishUserMovedResized(KWin::Client*);
|
2011-12-22 13:39:55 +00:00
|
|
|
void activeChanged();
|
2011-12-22 13:53:11 +00:00
|
|
|
void captionChanged();
|
2011-12-22 14:02:35 +00:00
|
|
|
void desktopChanged();
|
2011-12-22 14:34:55 +00:00
|
|
|
void fullScreenChanged();
|
2011-12-22 16:00:08 +00:00
|
|
|
void transientChanged();
|
2011-12-22 16:54:07 +00:00
|
|
|
void modalChanged();
|
2011-12-22 17:10:18 +00:00
|
|
|
void shadeChanged();
|
2011-12-22 17:28:24 +00:00
|
|
|
void keepAboveChanged();
|
|
|
|
void keepBelowChanged();
|
2011-12-22 18:01:01 +00:00
|
|
|
void minimizedChanged();
|
2011-12-29 09:19:36 +00:00
|
|
|
void moveResizedChanged();
|
|
|
|
void iconChanged();
|
|
|
|
void skipSwitcherChanged();
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
void exportMappingState(int s); // ICCCM 4.1.3.1, 4.1.4, NETWM 2.5.1
|
|
|
|
bool isManaged() const; ///< Returns false if this client is not yet managed
|
|
|
|
void updateAllowedActions(bool force = false);
|
|
|
|
QRect fullscreenMonitorsArea(NETFullscreenMonitors topology) const;
|
|
|
|
void changeMaximize(bool horizontal, bool vertical, bool adjust);
|
|
|
|
int checkFullScreenHack(const QRect& geom) const; // 0 - None, 1 - One xinerama screen, 2 - Full area
|
|
|
|
void updateFullScreenHack(const QRect& geom);
|
|
|
|
void getWmNormalHints();
|
|
|
|
void getMotifHints();
|
|
|
|
void getIcons();
|
|
|
|
void fetchName();
|
|
|
|
void fetchIconicName();
|
|
|
|
QString readName() const;
|
|
|
|
void setCaption(const QString& s, bool force = false);
|
|
|
|
bool hasTransientInternal(const Client* c, bool indirect, ConstClientList& set) const;
|
|
|
|
void finishWindowRules();
|
|
|
|
void setShortcutInternal(const KShortcut& cut);
|
|
|
|
|
|
|
|
void configureRequest(int value_mask, int rx, int ry, int rw, int rh, int gravity, bool from_tool);
|
|
|
|
NETExtendedStrut strut() const;
|
|
|
|
int checkShadeGeometry(int w, int h);
|
|
|
|
void blockGeometryUpdates(bool block);
|
|
|
|
void getSyncCounter();
|
|
|
|
void sendSyncRequest();
|
|
|
|
bool startMoveResize();
|
|
|
|
void finishMoveResize(bool cancel);
|
|
|
|
void leaveMoveResize();
|
|
|
|
void checkUnrestrictedMoveResize();
|
|
|
|
void handleMoveResize(int x, int y, int x_root, int y_root);
|
|
|
|
void startDelayedMoveResize();
|
|
|
|
void stopDelayedMoveResize();
|
|
|
|
void positionGeometryTip();
|
|
|
|
void grabButton(int mod);
|
|
|
|
void ungrabButton(int mod);
|
|
|
|
void resetMaximize();
|
|
|
|
void resizeDecoration(const QSize& s);
|
|
|
|
|
|
|
|
void pingWindow();
|
|
|
|
void killProcess(bool ask, Time timestamp = CurrentTime);
|
|
|
|
void updateUrgency();
|
|
|
|
static void sendClientMessage(Window w, Atom a, Atom protocol,
|
|
|
|
long data1 = 0, long data2 = 0, long data3 = 0);
|
|
|
|
|
|
|
|
void embedClient(Window w, const XWindowAttributes& attr);
|
|
|
|
void detectNoBorder();
|
|
|
|
void destroyDecoration();
|
|
|
|
void updateFrameExtents();
|
|
|
|
|
|
|
|
void internalShow(allowed_t);
|
|
|
|
void internalHide(allowed_t);
|
|
|
|
void internalKeep(allowed_t);
|
|
|
|
void map(allowed_t);
|
|
|
|
void unmap(allowed_t);
|
|
|
|
void updateHiddenPreview();
|
|
|
|
|
|
|
|
void updateInputShape();
|
|
|
|
void repaintDecorationPixmap(QPixmap& pix, const QRect& r, const QPixmap& src, QRegion reg);
|
|
|
|
void resizeDecorationPixmaps();
|
|
|
|
|
|
|
|
Time readUserTimeMapTimestamp(const KStartupInfoId* asn_id, const KStartupInfoData* asn_data,
|
|
|
|
bool session) const;
|
|
|
|
Time readUserCreationTime() const;
|
|
|
|
void startupIdChanged();
|
|
|
|
|
2011-09-29 13:17:59 +00:00
|
|
|
void checkOffscreenPosition (QRect* geom, const QRect& screenArea);
|
2011-07-28 20:18:41 +00:00
|
|
|
|
2011-11-09 19:39:13 +00:00
|
|
|
void updateInputWindow();
|
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
Window client;
|
|
|
|
Window wrapper;
|
|
|
|
KDecoration* decoration;
|
|
|
|
Bridge* bridge;
|
|
|
|
int desk;
|
|
|
|
QStringList activityList;
|
|
|
|
bool buttonDown;
|
|
|
|
bool moveResizeMode;
|
|
|
|
Window move_resize_grab_window;
|
|
|
|
bool move_resize_has_keyboard_grab;
|
|
|
|
bool unrestrictedMoveResize;
|
2011-11-02 20:13:47 +00:00
|
|
|
int moveResizeStartScreen;
|
2011-12-09 19:44:06 +00:00
|
|
|
static bool s_haveResizeEffect;
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
Position mode;
|
|
|
|
QPoint moveOffset;
|
|
|
|
QPoint invertedMoveOffset;
|
|
|
|
QRect moveResizeGeom;
|
|
|
|
QRect initialMoveResizeGeom;
|
|
|
|
XSizeHints xSizeHint;
|
|
|
|
void sendSyntheticConfigureNotify();
|
|
|
|
enum MappingState {
|
|
|
|
Withdrawn, ///< Not handled, as per ICCCM WithdrawnState
|
|
|
|
Mapped, ///< The frame is mapped
|
|
|
|
Unmapped, ///< The frame is not mapped
|
|
|
|
Kept ///< The frame should be unmapped, but is kept (For compositing)
|
|
|
|
};
|
|
|
|
MappingState mapping_state;
|
|
|
|
|
|
|
|
/** The quick tile mode of this window.
|
|
|
|
*/
|
2011-03-07 21:31:44 +00:00
|
|
|
int quick_tile_mode;
|
2011-01-30 14:34:42 +00:00
|
|
|
QRect geom_pretile;
|
|
|
|
|
|
|
|
void readTransient();
|
|
|
|
Window verifyTransientFor(Window transient_for, bool set);
|
|
|
|
void addTransient(Client* cl);
|
|
|
|
void removeTransient(Client* cl);
|
|
|
|
void removeFromMainClients();
|
|
|
|
void cleanGrouping();
|
|
|
|
void checkGroupTransients();
|
|
|
|
void setTransient(Window new_transient_for_id);
|
|
|
|
Client* transient_for;
|
|
|
|
Window transient_for_id;
|
|
|
|
Window original_transient_for_id;
|
|
|
|
ClientList transients_list; // SELI TODO: Make this ordered in stacking order?
|
|
|
|
ShadeMode shade_mode;
|
|
|
|
uint active : 1;
|
|
|
|
uint deleting : 1; ///< True when doing cleanup and destroying the client
|
|
|
|
uint keep_above : 1; ///< NET::KeepAbove (was stays_on_top)
|
|
|
|
uint skip_taskbar : 1;
|
|
|
|
uint original_skip_taskbar : 1; ///< Unaffected by KWin
|
|
|
|
uint Pdeletewindow : 1; ///< Does the window understand the DeleteWindow protocol?
|
|
|
|
uint Ptakefocus : 1;///< Does the window understand the TakeFocus protocol?
|
|
|
|
uint Ptakeactivity : 1; ///< Does it support _NET_WM_TAKE_ACTIVITY
|
|
|
|
uint Pcontexthelp : 1; ///< Does the window understand the ContextHelp protocol?
|
|
|
|
uint Pping : 1; ///< Does it support _NET_WM_PING?
|
|
|
|
uint input : 1; ///< Does the window want input in its wm_hints
|
|
|
|
uint skip_pager : 1;
|
|
|
|
uint skip_switcher : 1;
|
|
|
|
uint motif_may_resize : 1;
|
|
|
|
uint motif_may_move : 1;
|
|
|
|
uint motif_may_close : 1;
|
|
|
|
uint keep_below : 1; ///< NET::KeepBelow
|
|
|
|
uint minimized : 1;
|
|
|
|
uint hidden : 1; ///< Forcibly hidden by calling hide()
|
|
|
|
uint modal : 1; ///< NET::Modal
|
|
|
|
uint noborder : 1;
|
|
|
|
uint app_noborder : 1; ///< App requested no border via window type, shape extension, etc.
|
|
|
|
uint motif_noborder : 1; ///< App requested no border via Motif WM hints
|
|
|
|
uint urgency : 1; ///< XWMHints, UrgencyHint
|
|
|
|
uint ignore_focus_stealing : 1; ///< Don't apply focus stealing prevention to this client
|
|
|
|
uint demands_attention : 1;
|
2011-03-20 14:42:05 +00:00
|
|
|
bool blocks_compositing;
|
2011-01-30 14:34:42 +00:00
|
|
|
WindowRules client_rules;
|
|
|
|
void getWMHints();
|
|
|
|
void readIcons();
|
|
|
|
void getWindowProtocols();
|
|
|
|
QPixmap icon_pix;
|
|
|
|
QPixmap miniicon_pix;
|
|
|
|
QPixmap bigicon_pix;
|
|
|
|
QPixmap hugeicon_pix;
|
|
|
|
QCursor cursor;
|
|
|
|
// DON'T reorder - Saved to config files !!!
|
|
|
|
enum FullScreenMode {
|
|
|
|
FullScreenNone,
|
|
|
|
FullScreenNormal,
|
|
|
|
FullScreenHack ///< Non-NETWM fullscreen (noborder and size of desktop)
|
|
|
|
};
|
|
|
|
FullScreenMode fullscreen_mode;
|
|
|
|
MaximizeMode max_mode;
|
|
|
|
QRect geom_restore;
|
|
|
|
QRect geom_fs_restore;
|
|
|
|
MaximizeMode maxmode_restore;
|
|
|
|
QTimer* autoRaiseTimer;
|
|
|
|
QTimer* shadeHoverTimer;
|
|
|
|
QTimer* delayedMoveResizeTimer;
|
|
|
|
Colormap cmap;
|
|
|
|
QString cap_normal, cap_iconic, cap_suffix;
|
|
|
|
Group* in_group;
|
|
|
|
Window window_group;
|
|
|
|
ClientGroup* client_group;
|
|
|
|
Layer in_layer;
|
|
|
|
QTimer* ping_timer;
|
|
|
|
QProcess* process_killer;
|
|
|
|
Time ping_timestamp;
|
|
|
|
Time user_time;
|
|
|
|
unsigned long allowed_actions;
|
|
|
|
QSize client_size;
|
|
|
|
int block_geometry_updates; // > 0 = New geometry is remembered, but not actually set
|
|
|
|
enum PendingGeometry_t {
|
|
|
|
PendingGeometryNone,
|
|
|
|
PendingGeometryNormal,
|
|
|
|
PendingGeometryForced
|
|
|
|
};
|
|
|
|
PendingGeometry_t pending_geometry_update;
|
|
|
|
QRect geom_before_block;
|
|
|
|
QRect deco_rect_before_block;
|
|
|
|
bool shade_geometry_change;
|
2007-06-25 08:51:44 +00:00
|
|
|
#ifdef HAVE_XSYNC
|
2011-08-13 14:39:58 +00:00
|
|
|
struct {
|
|
|
|
XSyncCounter counter;
|
|
|
|
XSyncValue value;
|
|
|
|
XSyncAlarm alarm;
|
|
|
|
QTimer *timeout, *failsafeTimeout;
|
|
|
|
bool isPending;
|
|
|
|
} syncRequest;
|
2007-06-25 08:51:44 +00:00
|
|
|
#endif
|
2011-01-30 14:34:42 +00:00
|
|
|
int border_left, border_right, border_top, border_bottom;
|
|
|
|
int padding_left, padding_right, padding_top, padding_bottom;
|
|
|
|
QRegion _mask;
|
|
|
|
static bool check_active_modal; ///< \see Client::checkActiveModal()
|
|
|
|
KShortcut _shortcut;
|
|
|
|
int sm_stacking_order;
|
|
|
|
friend struct FetchNameInternalPredicate;
|
|
|
|
friend struct CheckIgnoreFocusStealingProcedure;
|
|
|
|
friend struct ResetupRulesProcedure;
|
|
|
|
friend class GeometryUpdatesBlocker;
|
|
|
|
QTimer* demandAttentionKNotifyTimer;
|
|
|
|
QPixmap decorationPixmapLeft, decorationPixmapRight, decorationPixmapTop, decorationPixmapBottom;
|
2011-05-15 11:22:28 +00:00
|
|
|
// we (instead of Qt) initialize the Pixmaps, and have to free them
|
|
|
|
bool m_responsibleForDecoPixmap;
|
2011-01-30 14:34:42 +00:00
|
|
|
PaintRedirector* paintRedirector;
|
|
|
|
TabBox::TabBoxClientImpl* m_tabBoxClient;
|
2011-12-01 12:15:11 +00:00
|
|
|
bool m_firstInTabBox;
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
bool electricMaximizing;
|
2011-03-07 21:31:44 +00:00
|
|
|
QuickTileMode electricMode;
|
2011-01-30 14:34:42 +00:00
|
|
|
|
|
|
|
friend bool performTransiencyCheck();
|
|
|
|
|
|
|
|
void checkActivities();
|
|
|
|
bool activitiesDefined; //whether the x property was actually set
|
|
|
|
|
|
|
|
bool needsSessionInteract;
|
2011-11-09 19:39:13 +00:00
|
|
|
|
|
|
|
Window input_window;
|
|
|
|
QPoint input_offset;
|
2011-01-30 14:34:42 +00:00
|
|
|
};
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
/**
|
|
|
|
* Helper for Client::blockGeometryUpdates() being called in pairs (true/false)
|
|
|
|
*/
|
2007-04-29 17:35:43 +00:00
|
|
|
class GeometryUpdatesBlocker
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
GeometryUpdatesBlocker(Client* c)
|
|
|
|
: cl(c) {
|
|
|
|
cl->blockGeometryUpdates(true);
|
|
|
|
}
|
|
|
|
~GeometryUpdatesBlocker() {
|
|
|
|
cl->blockGeometryUpdates(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Client* cl;
|
|
|
|
};
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
/**
|
|
|
|
* NET WM Protocol handler class
|
|
|
|
*/
|
2008-11-17 08:03:39 +00:00
|
|
|
class WinInfo : public NETWinInfo2
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
|
|
|
private:
|
|
|
|
typedef KWin::Client Client; // Because of NET::Client
|
|
|
|
|
|
|
|
public:
|
|
|
|
WinInfo(Client* c, Display * display, Window window,
|
|
|
|
Window rwin, const unsigned long pr[], int pr_size);
|
|
|
|
virtual void changeDesktop(int desktop);
|
|
|
|
virtual void changeFullscreenMonitors(NETFullscreenMonitors topology);
|
|
|
|
virtual void changeState(unsigned long state, unsigned long mask);
|
|
|
|
void disable();
|
|
|
|
|
|
|
|
private:
|
|
|
|
Client * m_client;
|
|
|
|
};
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Window Client::wrapperId() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return wrapper;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Window Client::decorationId() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return decoration != NULL ? decoration->widget()->winId() : None;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline const Client* Client::transientFor() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return transient_for;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Client* Client::transientFor()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return transient_for;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::groupTransient() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-07-19 16:24:51 +00:00
|
|
|
return transient_for_id == rootWindow();
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
// Needed because verifyTransientFor() may set transient_for_id to root window,
|
2007-04-29 17:35:43 +00:00
|
|
|
// if the original value has a problem (window doesn't exist, etc.)
|
|
|
|
inline bool Client::wasOriginallyGroupTransient() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-07-19 16:24:51 +00:00
|
|
|
return original_transient_for_id == rootWindow();
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::isTransient() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return transient_for_id != None;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline const ClientList& Client::transients() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return transients_list;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline const Group* Client::group() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return in_group;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Group* Client::group()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return in_group;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2009-11-15 03:24:04 +00:00
|
|
|
inline ClientGroup* Client::clientGroup() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2009-11-15 03:24:04 +00:00
|
|
|
return client_group;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2009-11-15 03:24:04 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
inline bool Client::isMinimized() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return minimized;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::isActive() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return active;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
inline bool Client::isShown(bool shaded_is_shown) const
|
|
|
|
{
|
|
|
|
return !isMinimized() && (!isShade() || shaded_is_shown) && !hidden &&
|
|
|
|
(clientGroup() == NULL || clientGroup()->visible() == this);
|
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
inline bool Client::isHiddenInternal() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2008-02-23 13:41:53 +00:00
|
|
|
return hidden;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2008-02-23 13:41:53 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
inline bool Client::isShade() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return shade_mode == ShadeNormal;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2008-12-18 13:50:57 +00:00
|
|
|
inline ShadeMode Client::shadeMode() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return shade_mode;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline QPixmap Client::icon() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return icon_pix;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline QPixmap Client::miniIcon() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return miniicon_pix;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2010-06-12 06:56:40 +00:00
|
|
|
inline QPixmap Client::bigIcon() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2010-06-12 06:56:40 +00:00
|
|
|
return bigicon_pix;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2010-06-12 06:56:40 +00:00
|
|
|
|
|
|
|
inline QPixmap Client::hugeIcon() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2010-06-12 06:56:40 +00:00
|
|
|
return hugeicon_pix;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2010-06-12 06:56:40 +00:00
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
inline QRect Client::geometryRestore() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return geom_restore;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Client::MaximizeMode Client::maximizeModeRestore() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return maxmode_restore;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Client::MaximizeMode Client::maximizeMode() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return max_mode;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
inline bool Client::skipTaskbar(bool from_outside) const
|
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return from_outside ? original_skip_taskbar : skip_taskbar;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::skipPager() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return skip_pager;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2010-05-03 20:04:44 +00:00
|
|
|
inline bool Client::skipSwitcher() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2010-05-03 20:04:44 +00:00
|
|
|
return skip_switcher;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2010-05-03 20:04:44 +00:00
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
inline bool Client::keepAbove() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return keep_above;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::keepBelow() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return keep_below;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::isFullScreen() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return fullscreen_mode != FullScreenNone;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::isModal() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return modal;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::hasNETSupport() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return info->hasNETSupport();
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Colormap Client::colormap() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return cmap;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline void Client::invalidateLayer()
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
in_layer = UnknownLayer;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline int Client::sessionStackingOrder() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return sm_stacking_order;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::isManaged() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2008-08-12 11:02:58 +00:00
|
|
|
return mapping_state != Withdrawn;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline QPoint Client::clientPos() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
|
|
|
return QPoint(border_left, border_top);
|
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline QSize Client::clientSize() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return client_size;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2009-06-11 20:12:11 +00:00
|
|
|
inline QRect Client::visibleRect() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2011-04-10 19:24:27 +00:00
|
|
|
return Toplevel::visibleRect().adjusted(-padding_left, -padding_top, padding_right, padding_bottom);
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2009-06-11 20:12:11 +00:00
|
|
|
|
2011-12-22 18:38:52 +00:00
|
|
|
inline void Client::setGeometry(const QRect& r, ForceGeometry_t force)
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2011-12-22 18:38:52 +00:00
|
|
|
setGeometry(r.x(), r.y(), r.width(), r.height(), force);
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
inline void Client::move(const QPoint& p, ForceGeometry_t force)
|
|
|
|
{
|
|
|
|
move(p.x(), p.y(), force);
|
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-12-22 18:38:52 +00:00
|
|
|
inline void Client::plainResize(const QSize& s, ForceGeometry_t force)
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2011-12-22 18:38:52 +00:00
|
|
|
plainResize(s.width(), s.height(), force);
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
inline void Client::resizeWithChecks(const QSize& s, ForceGeometry_t force)
|
|
|
|
{
|
|
|
|
resizeWithChecks(s.width(), s.height(), force);
|
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline bool Client::hasUserTimeSupport() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return info->userTime() != -1U;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2008-12-18 13:50:57 +00:00
|
|
|
|
2007-04-29 17:35:43 +00:00
|
|
|
inline bool Client::ignoreFocusStealing() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return ignore_focus_stealing;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline const WindowRules* Client::rules() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return &client_rules;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
KWIN_PROCEDURE(CheckIgnoreFocusStealingProcedure, Client, cl->ignore_focus_stealing = options->checkIgnoreFocusStealing(cl));
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline Window Client::moveResizeGrabWindow() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return move_resize_grab_window;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
inline KShortcut Client::shortcut() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2007-04-29 17:35:43 +00:00
|
|
|
return _shortcut;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
inline void Client::removeRule(Rules* rule)
|
|
|
|
{
|
|
|
|
client_rules.remove(rule);
|
|
|
|
}
|
2007-04-29 17:35:43 +00:00
|
|
|
|
2007-07-04 09:51:10 +00:00
|
|
|
inline bool Client::hiddenPreview() const
|
2011-01-30 14:34:42 +00:00
|
|
|
{
|
2008-08-12 11:02:58 +00:00
|
|
|
return mapping_state == Kept;
|
2011-01-30 14:34:42 +00:00
|
|
|
}
|
2007-07-04 09:51:10 +00:00
|
|
|
|
2011-01-30 14:34:42 +00:00
|
|
|
KWIN_COMPARE_PREDICATE(WrapperIdMatchPredicate, Client, Window, cl->wrapperId() == value);
|
2011-11-09 19:39:13 +00:00
|
|
|
KWIN_COMPARE_PREDICATE(InputIdMatchPredicate, Client, Window, cl->inputId() == value);
|
2007-04-29 17:35:43 +00:00
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
#endif
|