Martin Gräßlin
2f2e17ac19
Drop reset from AuroraeClient
...
Was only delegating to parent class thus not doing anything.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
0ba75ca07f
Drop the reset methods in KDecorationFactory
...
They are no longer used by any decoration or by KWin core.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
d29b9bf03a
Introduce a compositingChanged signal in KDecorationOptions
...
Connected from a signal in DecorationPlugins in KWin core replacing
the previous reset method.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
69be5b3e25
Oxygen connects to the new KDecorationOptions signals
...
At least to those it is interested in.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
9797fe2122
Aurorae connects to new changed signals by KDecorationOptions
...
No longer implements the reset() method by KDecorationFactory.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
d403bfcadb
Make KDecorationOptions::updateSettings protected
...
Only called from KWin::Options, so no need to have it public.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
ad85c6bc99
Introduce changed signals in KDecorationOptions
...
For this KDecorationOptions becomes a QObject. The changed flags from
updateSettings are removed. Instead the method just emits the proper
changed signals.
This should allow better handling in the Factories.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
e923426930
Add a recreateDecorations signal to KDecorationFactory
...
A factory is supposed to emit this signal whenever the decorations
need to be recrated. The DecorationPlugins inside KWin Core connect
to the signal and recreate the decorations.
This signal is supposed to replace the reset method which encoded
this information in the return value and which is already ignored.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
e2583e679f
No longer pass changed mask from KWin core to the decorations
...
The changed mask is going to be replaced by more specific signals so
we don't need to calculate the change mask in KWin core anymore.
We still need to call reset in the decoration plugin to check whether
a new decoration library needs to be loaded.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
c2fdc66cee
Remove pure virtual updateSettings from DecorationOptions
...
Not really needed as it's only invoked from inside KWin core to the
Options class.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
ae50ef270b
Make KDecorationFactory ctor protected
...
It's not supposed to be invoked directly, but always through a
subclass.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
784c40a338
KDecorationFactory inherits from QObject
...
Adjusting to reality: our decorations have the factory already inheriting
from QObject.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
10e044151e
Drop KDecorationFactoryUnstable
...
Did nothing and no longer needed.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
a90072d753
Merge KDecorationUnstable into KDecoration
...
Also KCommonDecorationUnstable is merged into KCommonDecoration.
2013-09-12 09:27:38 +02:00
Martin Gräßlin
afcf6dbc41
Remove deprecated functionality from libkdecorations
2013-09-12 09:27:37 +02:00
Martin Gräßlin
c8331784ba
Merge KDecorationBridgeUnstable into KDecorationBridge
2013-09-12 09:27:37 +02:00
Sebastian Kügler
a1641efdf1
Remove kdeqt5staging
...
Reviewed-by: Martin
2013-09-11 13:57:41 +02:00
Martin Gräßlin
75fe5f6965
Port Client::firstInTabBox to XCB
...
That code needs testing with Plasma Active.
2013-09-11 08:39:17 +02:00
Martin Gräßlin
5cf871d827
Port readWindowProperty in effects.cpp to XCB
2013-09-11 08:38:10 +02:00
Martin Gräßlin
634a84e5c0
Port reading the shadow property to XCB
2013-09-11 08:21:44 +02:00
Martin Gräßlin
c754ba7f8d
Use Xcb::Atom for resolving the highlight windows atom in TabBox
...
Nice side-effect: it will only be fetched once and not every time
highlight is invoked or ended.
2013-09-10 15:30:11 +02:00
Martin Gräßlin
108252194a
Use Xcb::Atom in KWin::Atoms to resolve all atoms
...
During startup we only create the request, the reply will be fetched
once the atom is needed.
To make proper use of this async behavior the creation of Atoms is
moved directly to the claim of the manager selection, so they can be
fetched while we wait for the previous manager selection to give up
on it.
2013-09-10 15:30:11 +02:00
Martin Gräßlin
c29a622be1
Introduce a wrapper class for InternAtom
...
Not extending Xcb::Wrapper as it does not operate on a window.
Instead it is a specified class for the specific usecase.
2013-09-10 15:30:11 +02:00
Martin Gräßlin
64dde54f35
Perform crash count checking before we claimed the manager selection
...
The crash count checking does not depend on whether or not we will
be able to claim the window manager selection. As claiming the selection
can take up to one second we should try to get as many checks which do
not depend on it out.
2013-09-10 15:30:11 +02:00
Martin Gräßlin
5d6c52e26c
Drop initing variable from kwin/main.cpp
...
It's nowhere read, just set once to true and once to false and by
that rather useless.
2013-09-10 15:30:11 +02:00
Martin Gräßlin
439122e2bc
Use Xcb::CurrentInput in the focus in event handler
2013-09-10 15:30:11 +02:00
Martin Gräßlin
4576a0b6db
Port last UngrabPointer to XCB
2013-09-10 15:30:11 +02:00
Martin Gräßlin
1121b2abb0
Port setting kwin_running atom to XCB
2013-09-10 15:30:11 +02:00
Martin Gräßlin
e687c91402
Add a changeProperty method to Xcb::Window
...
Used from Client to directly change properties on its client.
2013-09-10 15:30:11 +02:00
Martin Gräßlin
85ea66f736
Port remainind XSync calls to XCB variant
2013-09-10 15:30:11 +02:00
Martin Gräßlin
4173de1164
Port remaining set input focus to XCB
2013-09-10 15:30:11 +02:00
Martin Gräßlin
77edf8eb69
Port all XAllowEvents to xcb_allow_events in kwin
2013-09-10 15:30:11 +02:00
Martin Gräßlin
1fd857eecb
And add the grabButton() to Xcb::Window
...
Again most of the arguments have a default value to ease the usage
inside KWin and remove the horrific long methods.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
f354b41680
Add ungrabButton to Xcb::Window
...
The order of attributes is reversed compared to xcb_ungrab_button
to better allow for default arguments.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
3ee886be2d
Add setBorderWidth() method to Xcb::Window
...
Performs the configure window call.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
592ea89b01
Port all remaining XDeleteProperty calls to XCB
2013-09-10 15:30:10 +02:00
Martin Gräßlin
e3a1cc0b5d
Add deleteProperty() method to Xcb::Window
...
Calls xcb_delete_property on the managed window with the passed in
xcb_atom_t.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
48f32b3bca
Use Xcb::Window::selectInput where useful
...
Replacing to direct xcb commands with our wrapper.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
49da9a8fdb
Add a reparent() method to Xcb::Window
...
Reparents the managed window to the passed in parent window.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
4215599e97
And add a lower() method to Xcb::Window
...
Just like ::raise().
2013-09-10 15:30:10 +02:00
Martin Gräßlin
070921f114
Add a kill() method to Xcb::Window
2013-09-10 15:30:10 +02:00
Martin Gräßlin
484c61a81e
Use Window wrapper methods for manipulating the frame
...
And by that it's also mostly ported to XCB.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
cfd93246b3
Toplevel::frameId() becomes virtual
...
The frameId only makes sense for a Client, in case of Unmanaged the
same window id is used as for the window() handle. Client creates the
frame and destroys it.
Given that it makes sense to let Client manage the frame properly.
The ::frameId() is therefore virtual and as base implementation it
returns the client id. Client reimplements it and returns the proper
frame id.
Method is also implemented in Deleted as it used to be passed to
deleted.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
4e5a44e23c
XMapWindow(wrapperId()) -> m_wrapper.map()
2013-09-10 15:30:10 +02:00
Martin Gräßlin
ba7c5936fe
Use Client::m_client instead of Toplevel::window() where useful
...
Allows to use .setGeometry() instead of XMoveResizeWindow.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
0d9ab27798
Use the wrapper methods for Client::m_client instead of xcb_foo
2013-09-10 15:30:10 +02:00
Martin Gräßlin
c1483f41d4
Use Xcb::Window wrapper class for Client::m_client
...
Now we can use the wrapper for the client which we manage.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
577525c2bb
Use Xcb::Window wraper for Toplevel::client
...
Uses the new API to not destroy the window in the dtor.
At the same time the variable is renamed to m_client to follow the
common naming scheme.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
72c367cf2d
Extend Xcb::Window wrapper to optionally not destroy window in dtor
...
We have windows which we don't want to destroy (e.g. the managed
clients) but still would like to be able to use the nicer API.
Therefore the not creating ctor and reset method have a second bool
arg to whether destroy the window or not. Default is to keep the
RAII functionality.
2013-09-10 15:30:10 +02:00
Martin Gräßlin
b9e39f0d95
Use delete ctor in KWin::Xcb::Window
...
That's just nicer than not implementing the private ctor.
2013-09-10 15:30:10 +02:00