| Age | Commit message (Collapse) | Author | 
|---|
|  |  | 
|  |  | 
|  | To find out whether there was a surface or not before a movement, the member
roots_cursor::wlr_surface has been added. | 
|  |  | 
|  | This commit allows outputs that need a CRTC to steal it from
user-disabled outputs. Note that in the case there are enough
CRTCs, disabled outputs don't loose it (so there's no modeset
and plane initialization needed after DPMS). CRTC allocation
still prefers to keep the old configuration, even if that means
allocating an extra CRTC to a disabled output.
CRTC reallocation now happen when enabling/disabling an output as
well as when trying to modeset. When enabling an output without a
CRTC, we realloc to try to steal a CRTC from a disabled output
(that doesn't really need the CRTC). When disabling an output, we
try to give our CRTC to an output that needs one. Modesetting is
similar to enabling.
A new DRM connector field has been added: `desired_enabled`.
Outputs without CRTCs get automatically disabled. This field keeps
track of the state desired by the user, allowing to automatically
re-enable outputs when a CRTC becomes free.
This required some changes to the allocation algorithm. Previously,
the algorithm tried to keep the previous configuration even if a
new configuration with a better score was possible (it only changed
configuration when the old one didn't work anymore). This is now
changed and the old configuration (still preferred) is only
retained without considering new possibilities when it's perfect
(all outputs have CRTCs).
User-disabled outputs now have `possible_crtcs` set to 0, meaning
they can only retain a previous CRTC (not acquire a new one). The
allocation algorithm has been updated to do not bump the score
when assigning a CRTC to a disabled output. | 
|  | output: make wlr_output_enable return a bool | 
|  | layer-shell: add _v1 suffix | 
|  |  | 
|  |  | 
|  |  | 
|  | Tablet grabs | 
|  | sx, sy used to store the buffer offset of the drag surface which was
then be added (by rootston) to the drag icon position.
Buffer offsets are handled already in surface_intersect_output
(output.c) so they were added twice for dnd surfaces. | 
|  | This commit handles better situations in which the number of
connected outputs is greater than the number of available CRTCs.
It'll enable as many outputs as possible, and transfer CRTCs to
outputs that need one on unplug.
This changes CRTC and plane reallocation to happen after scanning
DRM connectors instead of on modeset.
This cleanups CRTCs and planes on unplug to allow them to be
re-used for other outputs.
On modeset, if an output doesn't have a CRTC, the desired mode is
saved and used later when the output gains a CRTC.
Future work includes giving priority to enabled outputs over
disabled ones for CRTC allocation. This requires the compositor to
know about all outputs (even outputs without CRTCs) to properly
modeset outputs enabled in the compositor config file and disable
outputs disabled in the config file. | 
|  | Add wlr_log_get_verbosity method | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Adds a modal property to indicate whether the surface wants to be a
modal. | 
|  | Returns the verbosity passed to wlr_log_init(). | 
|  |  | 
|  |  | 
|  | introduce wlr_output_layout_farthest_output | 
|  | Similar to wlr_output_layout_adjacent_output but will return the
one that is the farthest away from the reference in given direction. | 
|  | This reverts commit 9c886f20b97b6ab1ac85b849f1fe7f16eb199ff0. | 
|  | This breaks wlroots when used as a meson subproject.
This reverts commit dea311992eb4ff3e343c3cf5b0603034223d2a42, reversing
changes made to 6db9c4b74667c1d917d720f5e96985a2461569fb. | 
|  | This is so we can potentially add comments to it, and so if a user looks
at the installed header, they can see the /* #undef WLR_HAS_FEATURE */
line to see every option, even if not available. | 
|  |  | 
|  |  | 
|  |  | 
|  | rootston: add keybinding to toggle decoration mode | 
|  |  | 
|  | Implement the tablet-v2 tablet tool's implicit grab semantics for
buttons and tip.
This avoids losing focus (to other [sub]surfaces) when a button is held,
or the tip is down.
This should help when the device is used close to a surface's border and
would otherwise have to be very precise. | 
|  | Texture functions, that create and manipulate textures should switch
the current context if necessary.
thanks to: @emersion
Fixes #934 | 
|  | Implement wlr-gamma-control-unstable-v1 | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Add xdg-decoration-unstable-v1 support | 
|  | rootston: focus newly-created surfaces | 
|  | This introduces -DWLR_USE_UNSTABLE and adds information regarding the
stability status to all headers. I started with a conservative set of
headers to mark as stable:
- types/wlr_matrix.h
- util/edges.h
- util/log.h
- util/region.h
- xcursor.h | 
|  | Whenever a new surface is created, we have to update the cursor focus,
even if there's no input event. So, we generate one motion event, and
reuse the code to update the proper cursor focus. We need to do this
for all surface roles - toplevels, popups, subsurfaces.
Fixes #1162 | 
|  | 153f37bdf57c61e7fb09162a6791afe8b9b4d0ef (#1145) removed the
wlr_xwayland_is_unamanged function while fixing OR, because it was
belieived that it's supposed to work around the broken OR handling.
This was a misunderstanding. is_unmanaged is (while sort of a hack)
intended to work around inherent differences between "real" X sessions
and our Xwayland/wayland situation.
The main reason it exists is to support applications like rofi and dzen,
while not handing focus to other OR windows (which should *not* be
required).
Traditionally, these applications just grabbed input from X and didn't
need to be focused by any logic in the WM. Which of course doesn't work
in wayland compositors. So we have to give them focus in some way.
Giving *every* OR window focus, breaks other applications that don't
expect focus to change.
A testcase that was pointed out to me where wlr_xwayland_is_unamanged was
breaking things is https://github.com/swaywm/sway/issues/2128 (syncplay,
gitk, gitgui)
Supposedly it broke using keyboard to navigate the menus.
I can't reproduce this with this patch. The popups can be navigated as
long as the parent has focus. | 
|  |  | 
|  | surface: add wlr_surface_role.precommit | 
|  | Implement the basic logic for tablet-v2 tablet_tool's grabs. And plug in
the default grab. | 
|  | This is useful for example when rendering decorations | 
|  | This prevents some future conflicts with the stable version.
Fixes #1133 |