KDecorationBridge becomes private again

With 4933f08ae49328e36e2654434d28917310882ee5 the KDecorationBridge
interface became public to allow Compiz to easily implement the class.

From a KWin perspective this change did not make much sense. The Bridge
is meant to be the interface towards KWin. It is an internal interface
and exporting it doesn't change the fact that it is internal.

The change got introduced in a time when it was still common to use
Compiz in the kde-workspaces. This has changed. None of the top ten
distributions on distrowatch are shipping the integration parts of Compiz
in an up to date version. Most distros are still on Compiz 0.8, which
requires manual patching to keep up with changes in the decoration API.
Distros on Compiz 0.9 are not shipping the KDE integration - this
includes Ubuntu.

Given this development it is no longer justified to have additional work
on KWin side and because of that the API which should be internal is
marked as internal again.

In case Compiz is still interested in providing the kde-window-decorator
the header file can easily be pulled from our repository. In addition
this patch includes a method
int decoration_bridge_version()
which returns the current bridge API version. Kde-window-decorator can
resolve this method and verify that the version is not higher than what
is supported. The version number is provided in kdecoration.h by the
define KWIN_DECORATION_BRIDGE_API_VERSION. We will increate the version
number once per release in case the bridge changed. 4.11 will have the
version number 1.

This change in behavior has been discussed and agreed in [1].

The change also unexports KDecorationBridgeUnstable. This class should
have never been exported, it was incorrect and the parent class had not
been exported anyway. This is just a note to indicate that it is not an
ABI break and there is no reason to increase the so number.

[1] http://lists.kde.org/?l=kwin&m=136335502805911&w=2

CCMAIL: compiz@lists.freedesktop.org
CCMAIL: dev@lists.compiz.org

REVIEW: 109536
This commit is contained in:
Martin Gräßlin 2013-03-17 12:24:18 +01:00
parent 010b3c94de
commit e107910b30
4 changed files with 15 additions and 10 deletions

View file

@ -24,5 +24,4 @@ install( FILES
kdecoration.h
kdecorationfactory.h
kcommondecoration.h
kdecorationbridge.h
DESTINATION ${INCLUDE_INSTALL_DIR} COMPONENT Devel )

View file

@ -658,4 +658,13 @@ void KDecorationOptions::setTitleButtonsRight(const QString& b)
d->title_buttons_right = b;
}
extern "C" {
int decoration_bridge_version()
{
return KWIN_DECORATION_BRIDGE_API_VERSION;
}
}
#include "kdecoration.moc"

View file

@ -47,6 +47,11 @@ DEALINGS IN THE SOFTWARE.
KWIN_EXPORT int decoration_version() { return KWIN_DECORATION_API_VERSION; } \
}
#define KWIN_DECORATION_BRIDGE_API_VERSION 1
extern "C" {
int decoration_bridge_version();
}
class KConfig;
/** @defgroup kdecoration KWin decorations library */

View file

@ -28,18 +28,12 @@ DEALINGS IN THE SOFTWARE.
#include "kdecoration.h"
#include <QWidget>
/** @addtogroup kdecoration */
/** @{ */
/**
* @short Bridge class for communicating between decorations and KWin core.
*
* This class allows communication between decorations and KWin core while allowing
* to keep binary compatibility. Decorations do not need to use it directly at all.
*/
// This class is supposed to keep binary compatibility, just like KDecoration.
// Extending should be done the same way, i.e. inheriting KDecorationBridge2 from it
// and adding new functionality there.
class KDecorationBridge : public KDecorationDefines
{
public:
@ -91,7 +85,7 @@ public:
virtual void grabXServer(bool grab) = 0;
};
class KWIN_EXPORT KDecorationBridgeUnstable
class KDecorationBridgeUnstable
: public KDecorationBridge
{
public:
@ -117,6 +111,4 @@ public:
virtual WindowOperation buttonToWindowOperation(Qt::MouseButtons button) = 0;
};
/** @} */
#endif