git: 70148c11889b - main - x11-toolkits/wlroots: update to 0.13.0

Jan Beich jbeich at FreeBSD.org
Wed Apr 7 21:00:29 UTC 2021


The branch main has been updated by jbeich:

URL: https://cgit.FreeBSD.org/ports/commit/?id=70148c11889b8de458a1c3ea23c94d05af404296

commit 70148c11889b8de458a1c3ea23c94d05af404296
Author:     Jan Beich <jbeich at FreeBSD.org>
AuthorDate: 2021-02-23 17:26:36 +0000
Commit:     Jan Beich <jbeich at FreeBSD.org>
CommitDate: 2021-04-07 20:59:00 +0000

    x11-toolkits/wlroots: update to 0.13.0
    
    Changes:        https://github.com/swaywm/wlroots/releases/tag/0.13.0
    Reported by:    GitHub (watch releases)
    Tested by:      Evgeniy Khramtsov (via CFT on x11@ list)
---
 x11-toolkits/wlroots/Makefile          |  25 +-
 x11-toolkits/wlroots/distinfo          |  18 +-
 x11-toolkits/wlroots/pkg-plist         |   5 +-
 x11-wm/cage/Makefile                   |  10 +-
 x11-wm/cage/distinfo                   |  12 +
 x11-wm/gamescope/Makefile              |   3 +
 x11-wm/gamescope/distinfo              |   4 +
 x11-wm/hikari/Makefile                 |   3 +-
 x11-wm/hikari/files/patch-wlroots-0.13 | 439 +++++++++++++++++++++++++++++++++
 x11-wm/labwc/Makefile                  |   7 +
 x11-wm/labwc/distinfo                  |   8 +
 x11-wm/phoc/Makefile                   |   9 +
 x11-wm/phoc/distinfo                   |   2 +
 x11-wm/river/Makefile                  |   1 +
 x11-wm/river/files/patch-wlroots-0.13  | 373 ++++++++++++++++++++++++++++
 x11-wm/sway/Makefile                   |  13 +-
 x11-wm/sway/distinfo                   |  18 ++
 x11-wm/wayfire-plugins-extra/Makefile  |   1 +
 x11-wm/wayfire/Makefile                |  14 +-
 x11-wm/wayfire/distinfo                |  16 ++
 20 files changed, 955 insertions(+), 26 deletions(-)

diff --git a/x11-toolkits/wlroots/Makefile b/x11-toolkits/wlroots/Makefile
index e327aa468266..16ae013a3737 100644
--- a/x11-toolkits/wlroots/Makefile
+++ b/x11-toolkits/wlroots/Makefile
@@ -1,10 +1,10 @@
 PORTNAME=	wlroots
-DISTVERSION=	0.12.0
+DISTVERSION=	0.13.0
 CATEGORIES=	x11-toolkits
 
 PATCH_SITES=	https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/commit/
-PATCHFILES+=	8bdf0df41719.patch:-p1 # https://github.com/swaywm/wlroots/pull/2064
-PATCHFILES+=	90cb6d26877b.patch:-p1 # https://github.com/swaywm/wlroots/pull/2064
+PATCHFILES+=	7c0e2a271a4c.patch:-p1 # https://github.com/swaywm/wlroots/pull/2064
+PATCHFILES+=	d3b759ac5f08.patch:-p1 # https://github.com/swaywm/wlroots/pull/2064
 
 MAINTAINER=	jbeich at FreeBSD.org
 COMMENT=	Modular Wayland compositor library
@@ -17,7 +17,7 @@ BUILD_DEPENDS=	evdev-proto>0:devel/evdev-proto \
 		wayland-protocols>=1.17:graphics/wayland-protocols
 LIB_DEPENDS=	libudev.so:devel/libudev-devd \
 		libdrm.so:graphics/libdrm \
-		libwayland-egl.so:graphics/wayland \
+		libwayland-server.so:graphics/wayland \
 		libinput.so:x11/libinput \
 		libxkbcommon.so:x11/libxkbcommon
 RUN_DEPENDS=	libudev-devd>=0.4.1:devel/libudev-devd \
@@ -31,13 +31,13 @@ USE_LDCONFIG=	yes
 GH_ACCOUNT=	swaywm
 MESON_ARGS=	-Dexamples=false
 
-OPTIONS_DEFINE=	CONSOLEKIT LIBSEAT X11
-OPTIONS_DEFAULT=LIBSEAT X11
+OPTIONS_DEFINE=	CONSOLEKIT LIBSEAT UUID X11
+OPTIONS_DEFAULT=LIBSEAT UUID X11
 OPTIONS_SUB=	yes
 
 CONSOLEKIT_DESC=	DRM sessions without root using ConsoleKit2
 CONSOLEKIT_PATCH_SITES=	https://github.com/unrelentingtech/${GH_PROJECT}/commit/:ck2
-CONSOLEKIT_PATCHFILES=	fcee578b13eb.patch:-p1:ck2 # https://github.com/swaywm/wlroots/pull/1467
+CONSOLEKIT_PATCHFILES=	fb837ae10b1f.patch:-p1:ck2 # https://github.com/swaywm/wlroots/pull/1467
 CONSOLEKIT_LIB_DEPENDS=	libdbus-1.so:devel/dbus \
 			libconsolekit.so:sysutils/consolekit2
 CONSOLEKIT_MESON_ENABLED=	consolekit2
@@ -49,10 +49,17 @@ LIBSEAT_DESC=		DRM sessions with/without root via libseat (experimental)
 LIBSEAT_LIB_DEPENDS=	libseat.so:sysutils/seatd
 LIBSEAT_MESON_ENABLED=	libseat
 
+# uuid_create() is random on NetBSD and OpenBSD but not DragonFly and FreeBSD
+# See also https://github.com/netbsd/src/commit/8651e9a438af
+UUID_DESC=		Exported surfaces to use random UUIDs via libuuid
+UUID_LIB_DEPENDS=	libuuid.so:misc/e2fsprogs-libuuid
+
 X11_LIB_DEPENDS=	libxcb-errors.so:x11/xcb-util-errors \
+			libxcb-render-util.so:x11/xcb-util-renderutil \
 			libxcb-icccm.so:x11/xcb-util-wm
+X11_BUILD_DEPENDS=	xwayland-devel>0:x11-servers/xwayland-devel
 X11_RUN_DEPENDS=	xwayland-devel>0:x11-servers/xwayland-devel
-X11_USE=		XORG=x11,xcb
-X11_MESON_ENABLED=	x11-backend xcb-icccm xwayland
+X11_USE=		XORG=xcb
+X11_MESON_ENABLED=	x11-backend xwayland
 
 .include <bsd.port.mk>
diff --git a/x11-toolkits/wlroots/distinfo b/x11-toolkits/wlroots/distinfo
index 3706fc23d866..d35910fd7972 100644
--- a/x11-toolkits/wlroots/distinfo
+++ b/x11-toolkits/wlroots/distinfo
@@ -1,9 +1,9 @@
-TIMESTAMP = 1604844104
-SHA256 (swaywm-wlroots-0.12.0_GH0.tar.gz) = c9e9f4f6d2f526d0b2886daf3ec37e64831773059aa669fb98a88522a1626bdb
-SIZE (swaywm-wlroots-0.12.0_GH0.tar.gz) = 476936
-SHA256 (8bdf0df41719.patch) = 038fb04b004f862f5ee9a2ad6f97592c94501283b17af6537d19469467cb2e28
-SIZE (8bdf0df41719.patch) = 5800
-SHA256 (90cb6d26877b.patch) = 65c9c9f45d9916da143b76dec3280f7414c757ff2cf9992897ed69cfcaed5edd
-SIZE (90cb6d26877b.patch) = 3971
-SHA256 (fcee578b13eb.patch) = 641ae85b3730854f9cbafe9f5f27ddc7c79fa5eb59ff1f5d2ea64f6e6179ca29
-SIZE (fcee578b13eb.patch) = 27688
+TIMESTAMP = 1617734115
+SHA256 (swaywm-wlroots-0.13.0_GH0.tar.gz) = f6bea37fd4a6f5e5f552b83d61adae8c73e64b0bcb9ae0ab464ebcd9309d3cf3
+SIZE (swaywm-wlroots-0.13.0_GH0.tar.gz) = 503575
+SHA256 (7c0e2a271a4c.patch) = 2b92d3dde7640061ed85ab1690031f7627bebc2366e8c4da217017188ba7195e
+SIZE (7c0e2a271a4c.patch) = 5729
+SHA256 (d3b759ac5f08.patch) = 82109857db12457632a3a8d5de33830613bbd525f3c724d4aa3ce6fd94a7a57c
+SIZE (d3b759ac5f08.patch) = 4028
+SHA256 (fb837ae10b1f.patch) = ecf07d813ae796eca946e909a35434a93b07fc349d6ca8b48d7834cb2dfb4071
+SIZE (fb837ae10b1f.patch) = 27075
diff --git a/x11-toolkits/wlroots/pkg-plist b/x11-toolkits/wlroots/pkg-plist
index 85bed060f161..6e275d0f95b9 100644
--- a/x11-toolkits/wlroots/pkg-plist
+++ b/x11-toolkits/wlroots/pkg-plist
@@ -76,6 +76,9 @@ include/wlr/types/wlr_virtual_keyboard_v1.h
 include/wlr/types/wlr_virtual_pointer_v1.h
 include/wlr/types/wlr_xcursor_manager.h
 include/wlr/types/wlr_xdg_decoration_v1.h
+include/wlr/types/wlr_xdg_foreign_registry.h
+include/wlr/types/wlr_xdg_foreign_v1.h
+include/wlr/types/wlr_xdg_foreign_v2.h
 include/wlr/types/wlr_xdg_output_v1.h
 include/wlr/types/wlr_xdg_shell.h
 include/wlr/util/edges.h
@@ -85,5 +88,5 @@ include/wlr/version.h
 include/wlr/xcursor.h
 %%X11%%include/wlr/xwayland.h
 lib/libwlroots.so
-lib/libwlroots.so.7
+lib/libwlroots.so.8
 libdata/pkgconfig/wlroots.pc
diff --git a/x11-wm/cage/Makefile b/x11-wm/cage/Makefile
index 3ba6b07a2358..785db5d30ef0 100644
--- a/x11-wm/cage/Makefile
+++ b/x11-wm/cage/Makefile
@@ -1,11 +1,17 @@
 PORTNAME=	cage
 DISTVERSIONPREFIX=	v
 DISTVERSION=	0.1.2.1
-PORTREVISION=	2
+PORTREVISION=	3
 CATEGORIES=	x11-wm
 
 PATCH_SITES=	https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/commit/
 PATCHFILES+=	70ecdcb02ea0.patch:-p1 # https://github.com/Hjdskes/cage/pull/148
+PATCHFILES+=	43f1ea36d669.patch:-p1 # https://github.com/Hjdskes/cage/pull/174
+PATCHFILES+=	e3b1a57acaee.patch:-p1 # https://github.com/Hjdskes/cage/pull/174
+PATCHFILES+=	0db62672a4c1.patch:-p1 # https://github.com/Hjdskes/cage/pull/174
+PATCHFILES+=	2852b4e6d024.patch:-p1 # https://github.com/Hjdskes/cage/pull/174
+PATCHFILES+=	956b0cc6a476.patch:-p1 # https://github.com/Hjdskes/cage/pull/174
+PATCHFILES+=	e1956ccb723e.patch:-p1 # https://github.com/Hjdskes/cage/pull/174
 
 MAINTAINER=	jbeich at FreeBSD.org
 COMMENT=	Wayland kiosk
@@ -15,7 +21,7 @@ LICENSE_FILE=	${WRKSRC}/LICENSE
 
 BUILD_DEPENDS=	evdev-proto>0:devel/evdev-proto \
 		wayland-protocols>=1.14:graphics/wayland-protocols \
-		wlroots>=0.11.0:x11-toolkits/wlroots
+		wlroots>=0.13.0:x11-toolkits/wlroots
 LIB_DEPENDS=	libwayland-server.so:graphics/wayland \
 		libwlroots.so:x11-toolkits/wlroots \
 		libxkbcommon.so:x11/libxkbcommon
diff --git a/x11-wm/cage/distinfo b/x11-wm/cage/distinfo
index 37e8097a9c86..287d0c9cb86b 100644
--- a/x11-wm/cage/distinfo
+++ b/x11-wm/cage/distinfo
@@ -3,3 +3,15 @@ SHA256 (Hjdskes-cage-v0.1.2.1_GH0.tar.gz) = 38a3e3968f00cc58fe1d9448e972cfac7d1e
 SIZE (Hjdskes-cage-v0.1.2.1_GH0.tar.gz) = 24600
 SHA256 (70ecdcb02ea0.patch) = 2dd0e99d181986c6b2d5e04e89f692e3d77b8bd2a3a08f94cf8a27b38489eb3c
 SIZE (70ecdcb02ea0.patch) = 2137
+SHA256 (43f1ea36d669.patch) = b81ffa42da2ab21d12616315c83c932b7d88c1d365229615c7489ce5129f7010
+SIZE (43f1ea36d669.patch) = 1114
+SHA256 (e3b1a57acaee.patch) = d40a85a5dc75eb0dae37e0f1b9a033d21efa75717177529182e69bd6812bd482
+SIZE (e3b1a57acaee.patch) = 1056
+SHA256 (0db62672a4c1.patch) = 9b7d8a4c3ae8fe10a799b272e3d727bb1c32fc490ad546bc32a6c373c745b556
+SIZE (0db62672a4c1.patch) = 1457
+SHA256 (2852b4e6d024.patch) = 073b0a07897b7f9a134f22c9297dd97fb35233c8265c08b1f3fa54d8bc596cd8
+SIZE (2852b4e6d024.patch) = 7147
+SHA256 (956b0cc6a476.patch) = e77e1266ca9c0e6e119d18ea32669c7494d3d46f71c354c1446014439090f884
+SIZE (956b0cc6a476.patch) = 2993
+SHA256 (e1956ccb723e.patch) = 20cb74a2b070b0b13df437924962dd475afb5510e57fb817b37e999127851ba6
+SIZE (e1956ccb723e.patch) = 1115
diff --git a/x11-wm/gamescope/Makefile b/x11-wm/gamescope/Makefile
index 771958b44ae2..1e5b25601a35 100644
--- a/x11-wm/gamescope/Makefile
+++ b/x11-wm/gamescope/Makefile
@@ -1,5 +1,6 @@
 PORTNAME=	gamescope
 DISTVERSION=	3.7.1
+PORTREVISION=	1
 CATEGORIES=	x11-wm
 
 PATCH_SITES=	https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/commit/
@@ -8,6 +9,8 @@ PATCHFILES+=	620f8f5bc530.patch:-p1 # https://github.com/Plagman/gamescope/pull/
 PATCHFILES+=	892d79b0f37e.patch:-p1 # https://github.com/Plagman/gamescope/pull/119
 PATCHFILES+=	ae60c865d9d8.patch:-p1 # https://github.com/Plagman/gamescope/pull/119
 PATCHFILES+=	d59836199ebe.patch:-p1 # https://github.com/Plagman/gamescope/issues/120
+PATCHFILES+=	9d84b38c9042.patch:-p1 # wlroots 0.13
+PATCHFILES+=	a9d8a368d809.patch:-p1 # wlroots 0.13
 
 MAINTAINER=	jbeich at FreeBSD.org
 COMMENT=	Micro-compositor from SteamOS
diff --git a/x11-wm/gamescope/distinfo b/x11-wm/gamescope/distinfo
index 4989ae4c8251..a02bbea2aade 100644
--- a/x11-wm/gamescope/distinfo
+++ b/x11-wm/gamescope/distinfo
@@ -13,3 +13,7 @@ SHA256 (ae60c865d9d8.patch) = 41593e80d11a80c17a173cd03330738fc9deb82626c6788e15
 SIZE (ae60c865d9d8.patch) = 1111
 SHA256 (d59836199ebe.patch) = 40b519ef847b979ba088325cdd7170bed91936b79d845c65d2126b2b25166a1e
 SIZE (d59836199ebe.patch) = 2586
+SHA256 (9d84b38c9042.patch) = 635e87956399b4c82c8d5234e48752537aa4621d24d02dc0923f61ed040ebab0
+SIZE (9d84b38c9042.patch) = 1514
+SHA256 (a9d8a368d809.patch) = b3eb5e323b351870a3c97df610bc27e33713623017e4a219b13dbc8b6df752a5
+SIZE (a9d8a368d809.patch) = 912
diff --git a/x11-wm/hikari/Makefile b/x11-wm/hikari/Makefile
index 213d9bde31d6..31120173e6a6 100644
--- a/x11-wm/hikari/Makefile
+++ b/x11-wm/hikari/Makefile
@@ -1,5 +1,6 @@
 PORTNAME=	hikari
 DISTVERSION=	2.2.3
+PORTREVISION=	1
 CATEGORIES=	x11-wm
 MASTER_SITES=	https://hikari.acmelabs.space/releases/
 
@@ -11,7 +12,7 @@ LICENSE_FILE=	${WRKSRC}/LICENSE
 
 BUILD_DEPENDS=	evdev-proto>0:devel/evdev-proto \
 		wayland-protocols>=1.14:graphics/wayland-protocols \
-		wlroots>=0.9.0<0.13.0:x11-toolkits/wlroots
+		wlroots>=0.13.0<0.14.0:x11-toolkits/wlroots
 LIB_DEPENDS=	libinput.so:x11/libinput \
 		libucl.so:textproc/libucl \
 		libwayland-server.so:graphics/wayland \
diff --git a/x11-wm/hikari/files/patch-wlroots-0.13 b/x11-wm/hikari/files/patch-wlroots-0.13
new file mode 100644
index 000000000000..41ff4f72f408
--- /dev/null
+++ b/x11-wm/hikari/files/patch-wlroots-0.13
@@ -0,0 +1,439 @@
+In file included from src/action.c:7:
+In file included from include/hikari/server.h:29:
+In file included from include/hikari/layer_shell.h:4:
+/usr/local/include/wlr/types/wlr_layer_shell_v1.h:52:52: error: field has incomplete type 'enum zwlr_layer_surface_v1_keyboard_interactivity'
+        enum zwlr_layer_surface_v1_keyboard_interactivity keyboard_interactive;
+                                                          ^
+/usr/local/include/wlr/types/wlr_layer_shell_v1.h:52:7: note: forward declaration of 'enum zwlr_layer_surface_v1_keyboard_interactivity'
+        enum zwlr_layer_surface_v1_keyboard_interactivity keyboard_interactive;
+             ^
+In file included from src/configuration.c:29:
+In file included from include/hikari/server.h:8:
+In file included from /usr/local/include/wlr/types/wlr_virtual_keyboard_v1.h:14:
+In file included from /usr/local/include/wlr/interfaces/wlr_keyboard.h:13:
+/usr/local/include/wlr/types/wlr_keyboard.h:113:10: error: conflicting types for 'wlr_keyboard_get_modifiers'
+uint32_t wlr_keyboard_get_modifiers(struct wlr_keyboard *keyboard);
+         ^
+include/hikari/keyboard.h:61:24: note: previous implicit declaration is here
+  uint32_t modifiers = wlr_keyboard_get_modifiers(keyboard->device->keyboard);
+                       ^
+In file included from src/configuration.c:32:
+include/hikari/switch.h:14:25: error: field has incomplete type 'enum wlr_switch_state'
+  enum wlr_switch_state state;
+                        ^
+include/hikari/switch.h:14:8: note: forward declaration of 'enum wlr_switch_state'
+  enum wlr_switch_state state;
+       ^
+src/dnd_mode.c:25:23: error: use of undeclared identifier 'WLR_KEY_RELEASED'; did you mean 'WLR_BUTTON_RELEASED'?
+  if (event->state == WLR_KEY_RELEASED) {
+src/group_assign_mode.c:256:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/input_grab_mode.c:53:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/layout_select_mode.c:62:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/lock_mode.c:180:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/mark_assign_mode.c:164:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/mark_select_mode.c:40:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/move_mode.c:35:23: error: use of undeclared identifier 'WLR_KEY_RELEASED'; did you mean 'WLR_BUTTON_RELEASED'?
+  if (event->state == WLR_KEY_RELEASED) {
+src/normal_mode.c:322:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+src/resize_mode.c:35:23: error: use of undeclared identifier 'WLR_KEY_RELEASED'; did you mean 'WLR_BUTTON_RELEASED'?
+  if (event->state == WLR_KEY_RELEASED) {
+src/sheet_assign_mode.c:169:23: error: use of undeclared identifier 'WLR_KEY_PRESSED'
+  if (event->state == WLR_KEY_PRESSED) {
+                      ^
+
+src/server.c:756:61: error: too many arguments to function call, expected single argument 'display', have 2 arguments
+  server->backend = wlr_backend_autocreate(server->display, NULL);
+                    ~~~~~~~~~~~~~~~~~~~~~~                  ^~~~
+/usr/include/sys/_null.h:34:14: note: expanded from macro 'NULL'
+#define NULL    ((void *)0)
+                ^~~~~~~~~~~
+/usr/local/include/wlr/backend.h:35:21: note: 'wlr_backend_autocreate' declared here
+struct wlr_backend *wlr_backend_autocreate(struct wl_display *display);
+                    ^
+
+00:00:00.167 [render/gles2/texture.c:162] Unsupported pixel format 0x0
+
+--- include/hikari/keyboard.h.orig	2020-07-21 06:19:04 UTC
++++ include/hikari/keyboard.h
+@@ -6,6 +6,7 @@
+ #include <xkbcommon/xkbcommon.h>
+ 
+ #include <wlr/types/wlr_input_device.h>
++#include <wlr/types/wlr_keyboard.h>
+ 
+ #include <hikari/binding_group.h>
+ #include <hikari/keyboard_config.h>
+--- include/hikari/switch.h.orig	2020-07-21 06:19:04 UTC
++++ include/hikari/switch.h
+@@ -2,6 +2,7 @@
+ #define HIKARI_SWITCH_H
+ 
+ #include <wlr/types/wlr_input_device.h>
++#include <wlr/types/wlr_switch.h>
+ 
+ struct hikari_action;
+ struct hikari_switch_config;
+--- protocol/wlr-layer-shell-unstable-v1.xml.orig	2020-05-01 08:37:51 UTC
++++ protocol/wlr-layer-shell-unstable-v1.xml
+@@ -25,7 +25,7 @@
+     THIS SOFTWARE.
+   </copyright>
+ 
+-  <interface name="zwlr_layer_shell_v1" version="2">
++  <interface name="zwlr_layer_shell_v1" version="4">
+     <description summary="create surfaces that are layers of the desktop">
+       Clients can use this interface to assign the surface_layer role to
+       wl_surfaces. Such surfaces are assigned to a "layer" of the output and
+@@ -47,6 +47,12 @@
+         or manipulate a buffer prior to the first layer_surface.configure call
+         must also be treated as errors.
+ 
++        After creating a layer_surface object and setting it up, the client
++        must perform an initial commit without any buffer attached.
++        The compositor will reply with a layer_surface.configure event.
++        The client must acknowledge it and is then allowed to attach a buffer
++        to map the surface.
++
+         You may pass NULL for output to allow the compositor to decide which
+         output to use. Generally this will be the one that the user most
+         recently interacted with.
+@@ -82,9 +88,19 @@
+       <entry name="top" value="2"/>
+       <entry name="overlay" value="3"/>
+     </enum>
++
++    <!-- Version 3 additions -->
++
++    <request name="destroy" type="destructor" since="3">
++      <description summary="destroy the layer_shell object">
++        This request indicates that the client will not use the layer_shell
++        object any more. Objects that have been created through this instance
++        are not affected.
++      </description>
++    </request>
+   </interface>
+ 
+-  <interface name="zwlr_layer_surface_v1" version="2">
++  <interface name="zwlr_layer_surface_v1" version="4">
+     <description summary="layer metadata interface">
+       An interface that may be implemented by a wl_surface, for surfaces that
+       are designed to be rendered as a layer of a stacked desktop-like
+@@ -93,6 +109,14 @@
+       Layer surface state (layer, size, anchor, exclusive zone,
+       margin, interactivity) is double-buffered, and will be applied at the
+       time wl_surface.commit of the corresponding wl_surface is called.
++
++      Attaching a null buffer to a layer surface unmaps it.
++
++      Unmapping a layer_surface means that the surface cannot be shown by the
++      compositor until it is explicitly mapped again. The layer_surface
++      returns to the state it had right after layer_shell.get_layer_surface.
++      The client can re-map the surface by performing a commit without any
++      buffer attached, waiting for a configure event and handling it as usual.
+     </description>
+ 
+     <request name="set_size">
+@@ -179,21 +203,85 @@
+       <arg name="left" type="int"/>
+     </request>
+ 
++    <enum name="keyboard_interactivity">
++      <description summary="types of keyboard interaction possible for a layer shell surface">
++        Types of keyboard interaction possible for layer shell surfaces. The
++        rationale for this is twofold: (1) some applications are not interested
++        in keyboard events and not allowing them to be focused can improve the
++        desktop experience; (2) some applications will want to take exclusive
++        keyboard focus.
++      </description>
++
++      <entry name="none" value="0">
++        <description summary="no keyboard focus is possible">
++          This value indicates that this surface is not interested in keyboard
++          events and the compositor should never assign it the keyboard focus.
++
++          This is the default value, set for newly created layer shell surfaces.
++
++          This is useful for e.g. desktop widgets that display information or
++          only have interaction with non-keyboard input devices.
++        </description>
++      </entry>
++      <entry name="exclusive" value="1">
++        <description summary="request exclusive keyboard focus">
++          Request exclusive keyboard focus if this surface is above the shell surface layer.
++
++          For the top and overlay layers, the seat will always give
++          exclusive keyboard focus to the top-most layer which has keyboard
++          interactivity set to exclusive. If this layer contains multiple
++          surfaces with keyboard interactivity set to exclusive, the compositor
++          determines the one receiving keyboard events in an implementation-
++          defined manner. In this case, no guarantee is made when this surface
++          will receive keyboard focus (if ever).
++
++          For the bottom and background layers, the compositor is allowed to use
++          normal focus semantics.
++
++          This setting is mainly intended for applications that need to ensure
++          they receive all keyboard events, such as a lock screen or a password
++          prompt.
++        </description>
++      </entry>
++      <entry name="on_demand" value="2" since="4">
++        <description summary="request regular keyboard focus semantics">
++          This requests the compositor to allow this surface to be focused and
++          unfocused by the user in an implementation-defined manner. The user
++          should be able to unfocus this surface even regardless of the layer
++          it is on.
++
++          Typically, the compositor will want to use its normal mechanism to
++          manage keyboard focus between layer shell surfaces with this setting
++          and regular toplevels on the desktop layer (e.g. click to focus).
++          Nevertheless, it is possible for a compositor to require a special
++          interaction to focus or unfocus layer shell surfaces (e.g. requiring
++          a click even if focus follows the mouse normally, or providing a
++          keybinding to switch focus between layers).
++
++          This setting is mainly intended for desktop shell components (e.g.
++          panels) that allow keyboard interaction. Using this option can allow
++          implementing a desktop shell that can be fully usable without the
++          mouse.
++        </description>
++      </entry>
++    </enum>
++
+     <request name="set_keyboard_interactivity">
+       <description summary="requests keyboard events">
+-        Set to 1 to request that the seat send keyboard events to this layer
+-        surface. For layers below the shell surface layer, the seat will use
+-        normal focus semantics. For layers above the shell surface layers, the
+-        seat will always give exclusive keyboard focus to the top-most layer
+-        which has keyboard interactivity set to true.
++        Set how keyboard events are delivered to this surface. By default,
++        layer shell surfaces do not receive keyboard events; this request can
++        be used to change this.
+ 
++        This setting is inherited by child surfaces set by the get_popup
++        request.
++
+         Layer surfaces receive pointer, touch, and tablet events normally. If
+         you do not want to receive them, set the input region on your surface
+         to an empty region.
+ 
+-        Events is double-buffered, see wl_surface.commit.
++        Keyboard interactivity is double-buffered, see wl_surface.commit.
+       </description>
+-      <arg name="keyboard_interactivity" type="uint"/>
++      <arg name="keyboard_interactivity" type="uint" enum="keyboard_interactivity"/>
+     </request>
+ 
+     <request name="get_popup">
+@@ -278,6 +366,7 @@
+       <entry name="invalid_surface_state" value="0" summary="provided surface state is invalid"/>
+       <entry name="invalid_size" value="1" summary="size is invalid"/>
+       <entry name="invalid_anchor" value="2" summary="anchor bitfield is invalid"/>
++      <entry name="invalid_keyboard_interactivity" value="3" summary="keyboard interactivity is invalid"/>
+     </enum>
+ 
+     <enum name="anchor" bitfield="true">
+@@ -295,7 +384,7 @@
+ 
+         Layer is double-buffered, see wl_surface.commit.
+       </description>
+-      <arg name="layer" type="uint" enum="layer" summary="layer to move this surface to"/>
++      <arg name="layer" type="uint" enum="zwlr_layer_shell_v1.layer" summary="layer to move this surface to"/>
+     </request>
+   </interface>
+ </protocol>
+--- src/dnd_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/dnd_mode.c
+@@ -22,7 +22,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_RELEASED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_RELEASED) {
+     hikari_server_enter_normal_mode(NULL);
+   }
+ }
+--- src/group_assign_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/group_assign_mode.c
+@@ -253,7 +253,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     uint32_t keycode = event->keycode + 8;
+     hikari_keyboard_for_keysym(keyboard, keycode, handle_keysym);
+   }
+--- src/indicator_bar.c.orig	2020-09-08 08:20:26 UTC
++++ src/indicator_bar.c
+@@ -4,6 +4,7 @@
+ #include <pango/pangocairo.h>
+ #include <string.h>
+ 
++#include <drm_fourcc.h>
+ #include <wlr/backend.h>
+ #include <wlr/render/wlr_renderer.h>
+ #include <wlr/render/wlr_texture.h>
+@@ -120,7 +121,7 @@ hikari_indicator_bar_update(struct hikari_indicator_ba
+   int stride = cairo_format_stride_for_width(CAIRO_FORMAT_ARGB32, width);
+ 
+   indicator_bar->texture = wlr_texture_from_pixels(
+-      wlr_renderer, WL_SHM_FORMAT_ARGB8888, stride, width, height, data);
++      wlr_renderer, DRM_FORMAT_ARGB8888, stride, width, height, data);
+ 
+   cairo_surface_destroy(surface);
+   g_object_unref(layout);
+--- src/input_grab_mode.c.orig	2020-10-22 15:14:16 UTC
++++ src/input_grab_mode.c
+@@ -50,7 +50,7 @@ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+   struct hikari_workspace *workspace = hikari_server.workspace;
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     uint32_t modifiers = hikari_server.keyboard_state.modifiers;
+     struct hikari_binding_group *bindings = &keyboard->bindings[modifiers];
+ 
+--- src/layout_select_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/layout_select_mode.c
+@@ -59,7 +59,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     apply_layout(hikari_configuration, event, keyboard);
+   }
+ }
+--- src/lock_indicator.c.orig	2020-07-21 06:19:04 UTC
++++ src/lock_indicator.c
+@@ -1,5 +1,6 @@
+ #include <hikari/lock_indicator.h>
+ 
++#include <drm_fourcc.h>
+ #include <wlr/backend.h>
+ #include <wlr/render/wlr_renderer.h>
+ #include <wlr/types/wlr_matrix.h>
+@@ -45,7 +46,7 @@ init_indicator_circle(float color[static 4])
+   int stride = cairo_format_stride_for_width(CAIRO_FORMAT_ARGB32, size);
+ 
+   texture = wlr_texture_from_pixels(
+-      wlr_renderer, WL_SHM_FORMAT_ARGB8888, stride, size, size, data);
++      wlr_renderer, DRM_FORMAT_ARGB8888, stride, size, size, data);
+ 
+   cairo_surface_destroy(surface);
+   g_object_unref(layout);
+--- src/lock_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/lock_mode.c
+@@ -177,7 +177,7 @@ key_handler(
+ {
+   struct hikari_lock_mode *mode = get_mode();
+ 
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     const xkb_keysym_t *syms;
+     uint32_t keycode = event->keycode + 8;
+     uint32_t codepoint;
+--- src/mark_assign_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/mark_assign_mode.c
+@@ -161,7 +161,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     assign_mark(event, keyboard);
+   }
+ }
+--- src/mark_select_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/mark_select_mode.c
+@@ -37,7 +37,7 @@ key_handler(
+ {
+   struct hikari_workspace *workspace = hikari_server.workspace;
+ 
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     mark_select(workspace, event, keyboard);
+   }
+ }
+--- src/move_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/move_mode.c
+@@ -32,7 +32,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_RELEASED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_RELEASED) {
+     hikari_server_enter_normal_mode(NULL);
+   }
+ }
+--- src/normal_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/normal_mode.c
+@@ -319,7 +319,7 @@ key_handler(
+     return;
+   }
+ 
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     uint32_t modifiers = hikari_server.keyboard_state.modifiers;
+     struct hikari_binding_group *bindings = &keyboard->bindings[modifiers];
+ 
+--- src/output.c.orig	2020-09-08 08:20:26 UTC
++++ src/output.c
+@@ -1,5 +1,6 @@
+ #include <hikari/output.h>
+ 
++#include <drm_fourcc.h>
+ #include <wlr/backend.h>
+ 
+ #include <hikari/memory.h>
+@@ -86,7 +87,7 @@ hikari_output_load_background(struct hikari_output *ou
+       wlr_backend_get_renderer(output->wlr_output->backend);
+ 
+   output->background = wlr_texture_from_pixels(renderer,
+-      WL_SHM_FORMAT_ARGB8888,
++      DRM_FORMAT_ARGB8888,
+       stride,
+       output_width,
+       output_height,
+--- src/resize_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/resize_mode.c
+@@ -32,7 +32,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_RELEASED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_RELEASED) {
+     hikari_server_enter_normal_mode(NULL);
+   }
+ }
+--- src/server.c.orig	2020-09-08 08:20:26 UTC
++++ src/server.c
+@@ -753,7 +753,7 @@ hikari_server_prepare_privileged(void)
+     goto done;
+   }
+ 
+-  server->backend = wlr_backend_autocreate(server->display, NULL);
++  server->backend = wlr_backend_autocreate(server->display);
+   if (server->backend == NULL) {
+     fprintf(stderr, "error: could not create backend\n");
+     goto done;
+--- src/sheet_assign_mode.c.orig	2020-09-08 08:20:26 UTC
++++ src/sheet_assign_mode.c
+@@ -166,7 +166,7 @@ static void
+ key_handler(
+     struct hikari_keyboard *keyboard, struct wlr_event_keyboard_key *event)
+ {
+-  if (event->state == WLR_KEY_PRESSED) {
++  if (event->state == WL_KEYBOARD_KEY_STATE_PRESSED) {
+     uint32_t keycode = event->keycode + 8;
+     hikari_keyboard_for_keysym(keyboard, keycode, handle_keysym);
+   }
diff --git a/x11-wm/labwc/Makefile b/x11-wm/labwc/Makefile
index e28ef85041e8..0f41419b618d 100644
--- a/x11-wm/labwc/Makefile
+++ b/x11-wm/labwc/Makefile
@@ -1,7 +1,14 @@
 PORTNAME=	labwc
 DISTVERSION=	0.1.0
+PORTREVISION=	1
 CATEGORIES=	x11-wm
 
+PATCH_SITES=	https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/commit/
+PATCHFILES+=	2ee21e9a82d8.patch:-p1 # https://github.com/johanmalm/labwc/pull/26
+PATCHFILES+=	ad07acc13cee.patch:-p1 # https://github.com/johanmalm/labwc/pull/26
+PATCHFILES+=	c9023dd2c6af.patch:-p1 # https://github.com/johanmalm/labwc/pull/26
+PATCHFILES+=	0ca3eb8f790c.patch:-p1 # https://github.com/johanmalm/labwc/pull/26
+
 MAINTAINER=	jbeich at FreeBSD.org
 COMMENT=	Openbox alternative for Wayland
 
diff --git a/x11-wm/labwc/distinfo b/x11-wm/labwc/distinfo
index 1a39fad6b455..a06d629ec38f 100644
--- a/x11-wm/labwc/distinfo
+++ b/x11-wm/labwc/distinfo
@@ -1,3 +1,11 @@
 TIMESTAMP = 1615031145
 SHA256 (johanmalm-labwc-0.1.0_GH0.tar.gz) = c3087c0dc846c18499a335fe04c9bc46f014f7421739573636f6f8f746fd3c84
 SIZE (johanmalm-labwc-0.1.0_GH0.tar.gz) = 59533
+SHA256 (2ee21e9a82d8.patch) = 2f6a312853a14ceb5853cfd6b59c49b6110f7ee12363b5b0f19eb176471aaa27
+SIZE (2ee21e9a82d8.patch) = 1422
+SHA256 (ad07acc13cee.patch) = e104ba1327136dc22b02ab7475f65f3ff2845fe644fecfd884cfbd6337df6248
+SIZE (ad07acc13cee.patch) = 5132
+SHA256 (c9023dd2c6af.patch) = ac6e04d88c1d7ded9d9a989721ac26f6954ed3d3e1680d90a93d1f04f07adc1d
+SIZE (c9023dd2c6af.patch) = 2465
+SHA256 (0ca3eb8f790c.patch) = 89ce5081ff675e17c308de0bb73ce5439452958d0a803e5c7a7015be177b3e4b
+SIZE (0ca3eb8f790c.patch) = 1715
diff --git a/x11-wm/phoc/Makefile b/x11-wm/phoc/Makefile
index 00f0d178174e..311d6b779146 100644
--- a/x11-wm/phoc/Makefile
+++ b/x11-wm/phoc/Makefile
@@ -1,8 +1,12 @@
 PORTNAME=	phoc
 DISTVERSIONPREFIX=	v
 DISTVERSION=	0.7.0
+PORTREVISION=	1
 CATEGORIES=	x11-wm
 
+PATCH_SITES=	${GL_SITE}/${GL_ACCOUNT}/${GL_PROJECT}/-/commit/
+PATCHFILES+=	b37bf15194e6.diff:-p1 # https://source.puri.sm/Librem5/phoc/-/merge_requests/241
+
 MAINTAINER=	jbeich at FreeBSD.org
 COMMENT=	Phone compositor
 
@@ -32,5 +36,10 @@ GLIB_SCHEMAS=	sm.puri.phoc.gschema.xml
 post-extract:
 # Avoid confusing Meson instead of forcing -Dembed-wlroots=disabled
 	@${RMDIR} ${WRKSRC}/subprojects/wlroots
+.if defined(PATCHFILES) && ${PATCHFILES:Mb37bf15194e6*}
+# Pretend to be a regular file for vendor patch to apply as is
+	@${ECHO_CMD} "Subproject commit 3d227f140e3c4af42d759477fc38e82a4c3dc4ef" \
+		>${WRKSRC}/subprojects/wlroots
+.endif
 
 .include <bsd.port.mk>
diff --git a/x11-wm/phoc/distinfo b/x11-wm/phoc/distinfo
index fe3826d9ede0..7403915ca708 100644
--- a/x11-wm/phoc/distinfo
+++ b/x11-wm/phoc/distinfo
@@ -1,3 +1,5 @@
 TIMESTAMP = 1616120558
 SHA256 (Librem5-phoc-f26fa0123742ba95d303ad552fc1f8d2d0117288_GL0.tar.gz) = 266c58250ca0f1ef6daf1bdcf5fb30af8fea674a9ee3237b8c9fc0700ebfe320
 SIZE (Librem5-phoc-f26fa0123742ba95d303ad552fc1f8d2d0117288_GL0.tar.gz) = 143148
+SHA256 (b37bf15194e6.diff) = 0a0e8652dab5b4fabc751ed1274b7b94575d2f226917392a960f1c4c477b9f93
+SIZE (b37bf15194e6.diff) = 19468
diff --git a/x11-wm/river/Makefile b/x11-wm/river/Makefile
index aa75fb544674..c30da18fbb5e 100644
--- a/x11-wm/river/Makefile
+++ b/x11-wm/river/Makefile
@@ -1,5 +1,6 @@
 PORTNAME=	river
 PORTVERSION=	s20210328
+PORTREVISION=	1
 CATEGORIES=	x11-wm
 
 MAINTAINER=	jbeich at FreeBSD.org
diff --git a/x11-wm/river/files/patch-wlroots-0.13 b/x11-wm/river/files/patch-wlroots-0.13
new file mode 100644
index 000000000000..4c8afdd02055
--- /dev/null
+++ b/x11-wm/river/files/patch-wlroots-0.13
@@ -0,0 +1,373 @@
+https://github.com/swaywm/zig-wlroots/commit/4902876cd4f9
+https://github.com/ifreund/river/commit/73594ee57c95
+
+--- deps/zig-wlroots/src/backend.zig.orig	2021-02-15 17:19:02 UTC
++++ deps/zig-wlroots/src/backend.zig
+@@ -15,9 +15,9 @@ pub const Backend = extern struct {
+ 
+     // backend.h
+ 
+-    extern fn wlr_backend_autocreate(server: *wl.Server, create_renderer_func: ?wlr.Renderer.CreateFn) ?*Backend;
+-    pub fn autocreate(server: *wl.Server, create_renderer_func: ?wlr.Renderer.CreateFn) !*Backend {
+-        return wlr_backend_autocreate(server, create_renderer_func) orelse error.BackendCreateFailed;
++    extern fn wlr_backend_autocreate(server: *wl.Server) ?*Backend;
++    pub fn autocreate(server: *wl.Server) !*Backend {
++        return wlr_backend_autocreate(server) orelse error.BackendCreateFailed;
+     }
+ 
+     extern fn wlr_backend_start(backend: *Backend) bool;
+--- deps/zig-wlroots/src/backend/session.zig.orig	2021-02-15 17:19:02 UTC
++++ deps/zig-wlroots/src/backend/session.zig
+@@ -6,17 +6,24 @@ const wl = wayland.server.wl;
+ pub const Device = extern struct {
+     fd: c_int,
+     dev: u64,
+-    signal: wl.Signal(*Session),
+-
+     /// Session.devices
+     link: wl.list.Link,
++
++    events: extern struct {
++        change: wl.Signal(void),
++    },
+ };
+ 
+ pub const Session = extern struct {
+     const Impl = opaque {};
+ 
++    pub const event = struct {
++        pub const Add = extern struct {
++            path: [*:0]const u8,
++        };
++    };
++
+     impl: *const Impl,
+-    session_signal: wl.Signal(*Session),
+     active: bool,
+ 
+     vtnr: c_uint,
+@@ -29,9 +36,12 @@ pub const Session = extern struct {
+ 
+     devices: wl.list.Head(Device, "link"),
+ 
++    server: *wl.Server,
+     server_destroy: wl.Listener(*wl.Server),
+ 
+     events: extern struct {
++        active: wl.Signal(void),
++        add_drm_card: wl.Signal(*event.Add),
+         destroy: wl.Signal(*Session),
+     },
+ 
+@@ -43,20 +53,19 @@ pub const Session = extern struct {
+     extern fn wlr_session_destroy(session: *Session) void;
+     pub const destroy = wlr_session_destroy;
+ 
+-    extern fn wlr_session_open_file(session: *Session, path: [*:0]const u8) c_int;
+-    pub const openFile = wlr_session_open_file;
++    extern fn wlr_session_open_file(session: *Session, path: [*:0]const u8) ?*Device;
++    pub fn openFile(session: *Session, path: [*:0]const u8) !*Device {
++        return wlr_session_open_file(session, path) orelse error.SessionOpenFileFailed;
++    }
+ 
+-    extern fn wlr_session_close_file(session: *Session, fd: c_int) void;
++    extern fn wlr_session_close_file(session: *Session, device: *Device) void;
+     pub const closeFile = wlr_session_close_file;
+ 
+-    extern fn wlr_session_signal_add(session: *Session, fd: c_int, listener: *wl.Listener(*Session)) void;
+-    pub const signalAdd = wlr_session_signal_add;
+-
+     extern fn wlr_session_change_vt(session: *Session, vt: c_uint) bool;
+     pub fn changeVt(session: *Session, vt: c_uint) !void {
+         if (!wlr_session_change_vt(session, vt)) return error.ChangeVtFailed;
+     }
+ 
+-    extern fn wlr_session_find_gpus(session: *Session, ret_len: usize, ret: [*]c_int) usize;
++    extern fn wlr_session_find_gpus(session: *Session, ret_len: usize, ret: [*]*Device) usize;
+     pub const findGpus = wlr_session_find_gpus;
+ };
+--- deps/zig-wlroots/src/render/renderer.zig.orig	2021-02-15 17:19:02 UTC
++++ deps/zig-wlroots/src/render/renderer.zig
+@@ -6,14 +6,6 @@ const wl = wayland.server.wl;
+ pub const Renderer = extern struct {
+     const Impl = opaque {};
+ 
+-    pub const CreateFn = fn (
+-        egl: *wlr.Egl,
+-        platform: c_uint, // EGLenum
+-        remote_display: ?*c_void,
+-        config_attribs: *i32, // EGLint
+-        visual_id: i32, // EGLint
+-    ) callconv(.C) ?*Renderer;
+-
+     impl: *const Impl,
+     rendering: bool,
+     events: extern struct {
+@@ -22,8 +14,7 @@ pub const Renderer = extern struct {
+ 
+     // wlr_renderer functions:
+ 
+-    // TODO: int types
+-    extern fn wlr_renderer_begin(renderer: *Renderer, width: c_int, height: c_int) void;
++    extern fn wlr_renderer_begin(renderer: *Renderer, width: u32, height: u32) void;
+     pub const begin = wlr_renderer_begin;
+ 
+     pub extern fn wlr_renderer_end(renderer: *Renderer) void;
+@@ -47,8 +38,8 @@ pub const Renderer = extern struct {
+     extern fn wlr_renderer_scissor(renderer: *Renderer, box: *wlr.Box) void;
+     pub const scissor = wlr_renderer_scissor;
+ 
+-    extern fn wlr_renderer_get_formats(renderer: *Renderer, len: *usize) [*]const wl.Shm.Format;
+-    pub const getFormats = wlr_renderer_get_formats;
++    extern fn wlr_renderer_get_shm_texture_formats(renderer: *Renderer, len: *usize) [*]const wl.Shm.Format;
++    pub const getShmTextureFormats = wlr_renderer_get_shm_texture_formats;
+ 
+     extern fn wlr_renderer_resource_is_wl_drm_buffer(renderer: *Renderer, buffer: *wl.Buffer) bool;
+     pub const resourceIsWlDrmBuffer = wlr_renderer_resource_is_wl_drm_buffer;
+@@ -62,7 +53,7 @@ pub const Renderer = extern struct {
+     pub const wlDrmBufferGetSize = wlr_renderer_wl_drm_buffer_get_size;
+ 
+     // TODO:
+-    //extern fn wlr_renderer_get_dmabuf_formats(renderer: *Renderer) [*c]const struct_wlr_drm_format_set;
++    //extern fn wlr_renderer_get_dmabuf_texture_formats(renderer: *Renderer) [*c]const struct_wlr_drm_format_set;
+     //pub const getDmabufFormats = wlr_renderer_get_dmabuf_formats;
+ 
+     extern fn wlr_renderer_read_pixels(
+@@ -86,9 +77,6 @@ pub const Renderer = extern struct {
+         src: *wlr.DmabufAttributes,
+     ) bool;
+     pub const blitDmabuf = wlr_renderer_blit_dmabuf;
+-
+-    extern fn wlr_renderer_format_supported(renderer: *Renderer, fmt: wl.Shm.Format) bool;
+-    pub const formatSupported = wlr_renderer_format_supported;
+ 
+     extern fn wlr_renderer_get_drm_fd(renderer: *Renderer) c_int;
+     pub const getDrmFd = wlr_renderer_get_drm_fd;
+--- deps/zig-wlroots/src/render/texture.zig.orig	2021-03-01 13:53:50 UTC
++++ deps/zig-wlroots/src/render/texture.zig
+@@ -10,7 +10,7 @@ pub const Texture = extern struct {
+     width: u32,
+     height: u32,
+ 
+-    extern fn wlr_texture_from_pixels(renderer: *wlr.Renderer, wl_fmt: wl.Shm.Format, stride: u32, width: u32, height: u32, data: *const c_void) ?*Texture;
++    extern fn wlr_texture_from_pixels(renderer: *wlr.Renderer, fmt: u32, stride: u32, width: u32, height: u32, data: *const c_void) ?*Texture;
+     pub const fromPixels = wlr_texture_from_pixels;
+ 
+     extern fn wlr_texture_from_wl_drm(renderer: *wlr.Renderer, data: *wl.Drm) ?*Texture;
+--- deps/zig-wlroots/src/types/buffer.zig.orig	2021-02-15 17:19:02 UTC
++++ deps/zig-wlroots/src/types/buffer.zig
+@@ -49,6 +49,9 @@ pub const ClientBuffer = extern struct {
+     resource_destroy: wl.Listener(*wl.Buffer),
+     release: wl.Listener(void),
+ 
++    extern fn wlr_client_buffer_get(buffer: *wlr.Buffer) ?*ClientBuffer;
++    pub const get = wlr_client_buffer_get;
++
+     extern fn wlr_client_buffer_import(renderer: *wlr.Renderer, resource: *wl.Buffer) ?*ClientBuffer;
+     pub const import = wlr_client_buffer_import;
+ 
+--- deps/zig-wlroots/src/types/layer_shell_v1.zig.orig	2021-02-15 17:19:02 UTC
++++ deps/zig-wlroots/src/types/layer_shell_v1.zig
+@@ -109,7 +109,7 @@ pub const LayerSurfaceV1 = extern struct {
+         );
+     }
+ 
+-    extern fn wlr_layer_surface_v1_for_each_popup(
++    extern fn wlr_layer_surface_v1_for_each_popup_surface(
+         surface: *LayerSurfaceV1,
+         iterator: fn (*wlr.Surface, c_int, c_int, ?*c_void) callconv(.C) void,
+         user_data: ?*c_void,
+@@ -120,7 +120,7 @@ pub const LayerSurfaceV1 = extern struct {
+         iterator: fn (surface: *wlr.Surface, sx: c_int, sy: c_int, data: T) callconv(.C) void,
+         data: T,
+     ) void {
+-        wlr_layer_surface_v1_for_each_popup(
++        wlr_layer_surface_v1_for_each_popup_surface(
+             surface,
+             @ptrCast(fn (*wlr.Surface, c_int, c_int, ?*c_void) callconv(.C) void, iterator),
+             data,
+--- deps/zig-wlroots/src/types/output.zig.orig	2021-02-15 17:19:02 UTC
++++ deps/zig-wlroots/src/types/output.zig
+@@ -105,6 +105,11 @@ pub const Output = extern struct {
+             /// This is a bitfield of Present.flag members
+             flags: u32,
+         };
++
++        pub const Bind = extern struct {
++            output: *wlr.Output,
++            resource: *wl.Output,
++        };
+     };
+ 
+     const Impl = opaque {};
*** 304 LINES SKIPPED ***


More information about the dev-commits-ports-all mailing list