summaryrefslogtreecommitdiffstats
path: root/kdecore/kwinmodule.h
diff options
context:
space:
mode:
Diffstat (limited to 'kdecore/kwinmodule.h')
-rw-r--r--kdecore/kwinmodule.h358
1 files changed, 358 insertions, 0 deletions
diff --git a/kdecore/kwinmodule.h b/kdecore/kwinmodule.h
new file mode 100644
index 000000000..d0e9624b9
--- /dev/null
+++ b/kdecore/kwinmodule.h
@@ -0,0 +1,358 @@
+/* This file is part of the KDE libraries
+ Copyright (C) 1999 Matthias Ettrich ([email protected])
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public
+ License as published by the Free Software Foundation; either
+ version 2 of the License, or (at your option) any later version.
+
+ This library 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
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public License
+ along with this library; see the file COPYING.LIB. If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA.
+*/
+/*
+ * kwinmodule.h. Part of the KDE project.
+ */
+
+#ifndef KWINMODULE_H
+#define KWINMODULE_H
+
+#include <qobject.h>
+#include <qvaluelist.h>
+#include "kdelibs_export.h"
+
+#ifdef Q_OS_UNIX
+
+class KWinModulePrivate;
+
+/**
+ *
+ * The class KWinModule provides information about the state of the
+ * window manager as required by windowmanager modules. It informs a
+ * module about all currently managed windows and changes to them (via
+ * Qt signals).
+ *
+ * KWinModule uses NETRootInfo internally. Modules written with this
+ * class will work fine under any window manager that implements the
+ * NET_WM protocol.
+ *
+ * There are no methods to manipulate windows. Those are defined in
+ * the classes KWin, NETWinInfo and NETRootInfo.
+ *
+ *
+ * @short Base class for KDE Window Manager modules.
+ * @author Matthias Ettrich ([email protected])
+ */
+class KDECORE_EXPORT KWinModule : public QObject
+{
+ Q_OBJECT
+
+public:
+
+ enum { INFO_DESKTOP=1,
+ INFO_WINDOWS=2,
+ INFO_ALL=32767 };
+ /**
+ * Creates a KWinModule object and connects to the window
+ * manager.
+ * @param parent the parent for the QObject
+ * @param what The information you are interested in:
+ * INFO_DESKTOP: currentDesktop,
+ * numberOfDesktops,
+ * desktopName,
+ * currentDesktopChanged,
+ * numberOfDesktopsChanged,
+ * desktopNameChanged,
+ * activeWindow,
+ * activeWindowChanged,
+ * workArea(int desktop),
+ * workAreaChanged
+ *
+ * INFO_WINDOWS: windows,
+ * windowAdded,
+ * windowRemoved,
+ * stackingOrder,
+ * systemTrayWindows,
+ * systemTrayWindowAdded,
+ * systemTrayWindowRemoved,
+ * windowChanged,
+ * strutChanged,
+ * workArea(const QValueList<WId> &excludes, int desktop)
+ **/
+ KWinModule( QObject* parent, int what );
+ /**
+ * Creates a KWinModule object and connects to the window
+ * manager.
+ * @param parent the parent for the QObject
+ **/
+ KWinModule( QObject* parent = 0 );
+
+ /**
+ * Destructor. Internal cleanup, nothing fancy.
+ **/
+ ~KWinModule();
+
+ /**
+ * Returns the list of all toplevel windows currently managed by the
+ * window manager in the order of creation. Please do not rely on
+ * indexes of this list: Whenever you enter Qt's event loop in your
+ * application, it may happen that entries are removed or added.
+ * Your module should perhaps work on a copy of this list and verify a
+ * window with hasWId() before any operations.
+ *
+ * Iteration over this list can be done easily with
+ * \code
+ * QValueList<WId>::ConstIterator it;
+ * for ( it = module->windows().begin();
+ * it != modules->windows().end(); ++it ) {
+ * ... do something here, (*it) is the current WId.
+ * }
+ * \endcode
+ * @return the list of all toplevel windows
+ */
+ const QValueList<WId>& windows() const;
+
+ /**
+ * Returns the list of all toplevel windows currently managed by the
+ * window manager in the current stacking order (from lower to
+ * higher). May be useful for pagers.
+ * @return the list of all toplevel windows in stacking order
+ */
+ const QValueList<WId>& stackingOrder() const;
+
+ /**
+ * Test to see if @p id still managed at present.
+ * @param id the window id to test
+ * @return true if the window id is still managed
+ **/
+ bool hasWId(WId id) const;
+
+ /**
+ * Returns a list of the system tray windows.
+ * @return a list of all system tray windows
+ **/
+ const QValueList<WId>& systemTrayWindows() const;
+
+ /**
+ * Returns the current virtual desktop.
+ * @return the current virtual desktop
+ **/
+ int currentDesktop() const;
+
+ /**
+ * Returns the number of virtual desktops.
+ * @return the number of virtual desktops
+ **/
+ int numberOfDesktops() const;
+
+ /**
+ * Returns the number of viewports in x and y direction
+ * on the virtual desktop.
+ * @return the number of virtual desktops
+ * @since 3.5.5
+ **/
+ QSize numberOfViewports(int desktop) const;
+
+ /**
+ * Returns the current viewport on the given virtual desktop
+ * @return the number of virtual desktops
+ * @since 3.5.5
+ **/
+ QPoint currentViewport(int desktop) const;
+
+ /**
+ * Returns the currently active window, or 0 if no window is active.
+ * @return the window id of the active window, or 0 if no window is
+ * active
+ **/
+ WId activeWindow() const;
+
+ /**
+ * Returns the workarea for the specified desktop, or the current
+ * work area if no desktop has been specified.
+ * @param desktop the number of the desktop to check, -1 for the
+ * current desktop
+ * @return the size and position of the desktop
+ **/
+ QRect workArea( int desktop = - 1 ) const;
+
+
+ /**
+ * Returns the workarea for the specified desktop, or the current
+ * work area if no desktop has been specified. Excludes struts of
+ * clients in the exclude List.
+ *
+ * @param excludes the list of clients whose struts will be excluded
+ * @param desktop the number of the desktop to check, -1 for the
+ * current desktop
+ * @return the size and position of the desktop
+ **/
+ QRect workArea( const QValueList<WId> &excludes, int desktop = -1) const;
+
+ /**
+ * Returns the name of the specified desktop.
+ * @param desktop the number of the desktop
+ * @return the name of the desktop
+ **/
+ QString desktopName( int desktop ) const;
+
+ /**
+ * Sets the name of the specified desktop.
+ * @param desktop the number of the desktop
+ * @param name the new name for the desktop
+ **/
+ void setDesktopName( int desktop, const QString& name );
+
+ /**
+ * Returns the state of showing the desktop.
+ * @since 3.5
+ */
+ bool showingDesktop() const;
+
+ /**
+ * Informs kwin via dcop to not manage a window with the
+ * specified @p title.
+ *
+ * Useful for swallowing legacy applications, for example java
+ * applets.
+ *
+ * @param title the title of the window
+ */
+ void doNotManage( const QString& title );
+
+
+signals:
+
+ /**
+ * Switched to another virtual desktop.
+ * @param desktop the number of the new desktop
+ */
+ void currentDesktopChanged( int desktop);
+
+ /**
+ * A window has been added.
+ * @param id the id of the the window
+ */
+ void windowAdded(WId id);
+
+ /**
+ * A window has been removed.
+ * @param id the id of the window that has been removed
+ */
+ void windowRemoved(WId id);
+
+ /**
+ * Hint that \<Window> is active (= has focus) now.
+ * @param id the id of the window that is active
+ */
+ void activeWindowChanged(WId id);
+
+ /**
+ * Desktops have been renamed.
+ */
+ void desktopNamesChanged();
+
+ /**
+ * The number of desktops changed.
+ * @param num the new number of desktops
+ */
+ void numberOfDesktopsChanged(int num);
+
+ /**
+ * Emitted when a dock window has been added.
+ * @param id the id of the new system tray window
+ */
+ void systemTrayWindowAdded(WId id);
+
+ /**
+ * Emitted when a dock window has been removed.
+ * @param id the id of the former system tray window
+ */
+ void systemTrayWindowRemoved(WId id);
+
+ /**
+ * The workarea has changed.
+ */
+ void workAreaChanged();
+
+ /**
+ * Something changed with the struts, may or may not have changed
+ * the work area. Usually just using the workAreaChanged() signal
+ * is sufficient.
+ */
+ void strutChanged();
+
+ /**
+ * Emitted when the stacking order of the window changed. The new order
+ * can be obtained with stackingOrder().
+ */
+ void stackingOrderChanged();
+
+
+ /**
+ * The window changed.
+ *
+ * The properties parameter contains the NET properties that
+ * were modified (see netwm_def.h). First element are NET::Property
+ * values, second element are NET::Property2 values (i.e. the format
+ * is the same like for the NETWinInfo class constructor).
+ * @param id the id of the window
+ * @param properties the properties that were modified
+ */
+ void windowChanged(WId id, const unsigned long* properties );
+
+ /**
+ * @deprecated
+ * The window changed.
+ *
+ * The unsigned int parameter contains the NET properties that
+ * were modified (see netwm_def.h).
+ * @param id the id of the window
+ * @param properties the properties that were modified
+ */
+ void windowChanged(WId id, unsigned int properties);
+
+ /**
+ * The window changed somehow.
+ * @param id the id of the window
+ */
+ void windowChanged(WId id);
+
+ /**
+ * The state of showing the desktop has changed.
+ * @since 3.5
+ */
+ void showingDesktopChanged( bool showing );
+
+ /**
+ * The state of showing the desktop has changed.
+ * @since 3.5.5
+ */
+ void desktopGeometryChanged(int desktop);
+
+ /**
+ * The viewport position has changed
+ * @since 3.5
+ */
+ void currentDesktopViewportChanged(int desktop, const QPoint& viewport);
+
+protected:
+ virtual void connectNotify( const char* signal );
+
+private:
+ void init(int);
+
+ KWinModulePrivate* d;
+
+ friend class KWinModulePrivate;
+};
+
+#endif //Q_OS_UNIX
+
+#endif