Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 8 Apr 2021 01:15:39 GMT
From:      Jan Beich <jbeich@FreeBSD.org>
To:        ports-committers@FreeBSD.org, dev-commits-ports-all@FreeBSD.org, dev-commits-ports-main@FreeBSD.org
Subject:   git: 9b92750c9dd3 - main - x11-wm/river: update to s20210407
Message-ID:  <202104080115.1381FdYU095391@gitrepo.freebsd.org>

next in thread | raw e-mail | index | archive | help
The branch main has been updated by jbeich:

URL: https://cgit.FreeBSD.org/ports/commit/?id=9b92750c9dd3461a9e7dfb468f9da56af90d4a5f

commit 9b92750c9dd3461a9e7dfb468f9da56af90d4a5f
Author:     Jan Beich <jbeich@FreeBSD.org>
AuthorDate: 2021-04-07 22:21:17 +0000
Commit:     Jan Beich <jbeich@FreeBSD.org>
CommitDate: 2021-04-08 01:15:09 +0000

    x11-wm/river: update to s20210407
    
    Changes:        https://github.com/ifreund/river/compare/3c1f1df...9e3e920
---
 x11-wm/river/Makefile                 |   9 +-
 x11-wm/river/distinfo                 |  10 +-
 x11-wm/river/files/patch-types        |   6 +-
 x11-wm/river/files/patch-wlroots-0.13 | 373 ----------------------------------
 4 files changed, 12 insertions(+), 386 deletions(-)

diff --git a/x11-wm/river/Makefile b/x11-wm/river/Makefile
index c30da18fbb5e..c80b8fb9bb87 100644
--- a/x11-wm/river/Makefile
+++ b/x11-wm/river/Makefile
@@ -1,6 +1,5 @@
 PORTNAME=	river
-PORTVERSION=	s20210328
-PORTREVISION=	1
+PORTVERSION=	s20210407
 CATEGORIES=	x11-wm
 
 MAINTAINER=	jbeich@FreeBSD.org
@@ -10,7 +9,7 @@ LICENSE=	GPLv3+
 LICENSE_FILE=	${WRKSRC}/LICENSE
 
 BUILD_DEPENDS=	wayland-protocols>0:graphics/wayland-protocols \
-		wlroots>=0.12.0:x11-toolkits/wlroots \
+		wlroots>=0.13.0:x11-toolkits/wlroots \
 		zig>=0.7.1:lang/zig
 LIB_DEPENDS=	libevdev.so:devel/libevdev \
 		libwayland-server.so:graphics/wayland \
@@ -21,11 +20,11 @@ USES=		pkgconfig xorg
 USE_GITHUB=	yes
 USE_XORG=	pixman
 GH_ACCOUNT=	ifreund
-GH_TAGNAME=	3c1f1df
+GH_TAGNAME=	9e3e920
 GH_TUPLE=	ifreund:zig-pixman:7847fd1:zig_pixman/deps/zig-pixman \
 		ifreund:zig-wayland:f170fe0:zig_wayland/deps/zig-wayland \
 		ifreund:zig-xkbcommon:9e4d41f:zig_xkbcommon/deps/zig-xkbcommon \
-		swaywm:zig-wlroots:35e5676:zig_wlroots/deps/zig-wlroots
+		swaywm:zig-wlroots:6c62568:zig_wlroots/deps/zig-wlroots
 MAKE_ENV=	DESTDIR="${STAGEDIR}"
 CONFIGURE_ARGS=	--prefix "${PREFIX}" \
 		${WITH_DEBUG:U-Drelease-fast=true} \
diff --git a/x11-wm/river/distinfo b/x11-wm/river/distinfo
index e905bf41e978..be75703bfe7b 100644
--- a/x11-wm/river/distinfo
+++ b/x11-wm/river/distinfo
@@ -1,11 +1,11 @@
-TIMESTAMP = 1616932522
-SHA256 (ifreund-river-s20210328-3c1f1df_GH0.tar.gz) = 212c3b93193b8354e07b669d31a81a5dd3f9e819c638a626e29129a65d1a357b
-SIZE (ifreund-river-s20210328-3c1f1df_GH0.tar.gz) = 104754
+TIMESTAMP = 1617834077
+SHA256 (ifreund-river-s20210407-9e3e920_GH0.tar.gz) = a502b32b50bb0a957500b70685a1a0487f857acadcf14b6fc1d0d78735cb4647
+SIZE (ifreund-river-s20210407-9e3e920_GH0.tar.gz) = 105558
 SHA256 (ifreund-zig-pixman-7847fd1_GH0.tar.gz) = d2f5eef6d8566565c25f0df08aac7d537f303f6ab2b7e7a2aca3a556df60053c
 SIZE (ifreund-zig-pixman-7847fd1_GH0.tar.gz) = 6548
 SHA256 (ifreund-zig-wayland-f170fe0_GH0.tar.gz) = 5ab51c15c56921a1e1269da469bbbd2ac5d8b9bb01e09b9db9409d06a76d5014
 SIZE (ifreund-zig-wayland-f170fe0_GH0.tar.gz) = 52945
 SHA256 (ifreund-zig-xkbcommon-9e4d41f_GH0.tar.gz) = 3af5c9a448cf311d9cc819c8fd1dba114fbd7a4407f4174f95e4c82bb37f447b
 SIZE (ifreund-zig-xkbcommon-9e4d41f_GH0.tar.gz) = 19025
-SHA256 (swaywm-zig-wlroots-35e5676_GH0.tar.gz) = 691843a46766df352d65865fe97d38445b55ee3e4b27c93f2701699d74861cbb
-SIZE (swaywm-zig-wlroots-35e5676_GH0.tar.gz) = 33576
+SHA256 (swaywm-zig-wlroots-6c62568_GH0.tar.gz) = 85acd43b8cfdc448734ef1fc4f78e5114a16533bcebd32933e089eaf87444d6f
+SIZE (swaywm-zig-wlroots-6c62568_GH0.tar.gz) = 33930
diff --git a/x11-wm/river/files/patch-types b/x11-wm/river/files/patch-types
index 492149f3eab4..c4e442b08876 100644
--- a/x11-wm/river/files/patch-types
+++ b/x11-wm/river/files/patch-types
@@ -16,7 +16,7 @@ xwayland: if (build_options.xwayland) *wlr.Xwayland else void,
     var server: Server = undefined;
                          ^
 
---- deps/zig-wlroots/src/backend/session.zig.orig	2020-12-24 11:19:51 UTC
+--- deps/zig-wlroots/src/backend/session.zig.orig	2021-04-07 22:14:45 UTC
 +++ deps/zig-wlroots/src/backend/session.zig
 @@ -5,7 +5,7 @@ const wl = wayland.server.wl;
  
@@ -24,9 +24,9 @@ xwayland: if (build_options.xwayland) *wlr.Xwayland else void,
      fd: c_int,
 -    dev: os.dev_t,
 +    dev: u64,
-     signal: wl.Signal(*Session),
- 
      /// Session.devices
+     link: wl.list.Link,
+ 
 --- deps/zig-wlroots/src/xwayland.zig.orig	2020-12-24 11:19:51 UTC
 +++ deps/zig-wlroots/src/xwayland.zig
 @@ -37,7 +37,7 @@ pub const XwaylandServer = extern struct {
diff --git a/x11-wm/river/files/patch-wlroots-0.13 b/x11-wm/river/files/patch-wlroots-0.13
deleted file mode 100644
index 4c8afdd02055..000000000000
--- a/x11-wm/river/files/patch-wlroots-0.13
+++ /dev/null
@@ -1,373 +0,0 @@
-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 {};
-@@ -151,10 +156,9 @@ pub const Output = extern struct {
-         precommit: wl.Signal(*event.Precommit),
-         commit: wl.Signal(*event.Commit),
-         present: wl.Signal(*event.Present),
-+        bind: wl.Signal(*event.Bind),
-         enable: wl.Signal(*Output),
-         mode: wl.Signal(*Output),
--        scale: wl.Signal(*Output),
--        transform: wl.Signal(*Output),
-         description: wl.Signal(*Output),
-         destroy: wl.Signal(*Output),
-     },
---- deps/zig-wlroots/src/types/surface.zig.orig	2021-02-15 17:19:02 UTC
-+++ deps/zig-wlroots/src/types/surface.zig
-@@ -49,6 +49,9 @@ pub const Surface = extern struct {
-         },
- 
-         buffer_destroy: wl.Listener(*wl.Buffer),
-+
-+        cached_state_locks: usize,
-+        cached_state_link: wl.list.Head(Surface, "cached"),
-     };
- 
-     pub const Role = extern struct {
-@@ -57,6 +60,16 @@ pub const Surface = extern struct {
-         precommit: ?fn (surface: *Surface) callconv(.C) void,
-     };
- 
-+    pub const Output = extern struct {
-+        surface: *wlr.Surface,
-+        output: *wlr.Output,
-+
-+        // Surface.current_outputs
-+        link: wl.list.Link,
-+        bind: wl.Listener(*wlr.Output.event.Bind),
-+        destroy: wl.Listener(*wlr.Output),
-+    };
-+
-     resource: *wl.Surface,
-     renderer: *wlr.Renderer,
- 
-@@ -73,6 +86,8 @@ pub const Surface = extern struct {
-     pending: State,
-     previous: State,
- 
-+    cached: wl.list.Head(State, "cached_link"),
-+
-     role: ?*const Role,
-     role_data: ?*c_void,
- 
-@@ -84,6 +99,8 @@ pub const Surface = extern struct {
- 
-     subsurfaces: wl.list.Head(Subsurface, "parent_link"),
-     subsurface_pending_list: wl.list.Head(Subsurface, "parent_pending_link"),
-+
-+    current_outputs: wl.list.Head(Surface.Output, "link"),
- 
-     renderer_destroy: wl.Listener(*wlr.Renderer),
- 
---- deps/zig-wlroots/src/types/xdg_shell.zig.orig	2021-02-15 17:19:02 UTC
-+++ deps/zig-wlroots/src/types/xdg_shell.zig
-@@ -311,7 +311,7 @@ pub const XdgSurface = extern struct {
-     extern fn wlr_xdg_surface_schedule_configure(surface: *wlr.XdgSurface) u32;
-     pub const scheduleConfigure = wlr_xdg_surface_schedule_configure;
- 
--    extern fn wlr_xdg_surface_for_each_popup(
-+    extern fn wlr_xdg_surface_for_each_popup_surface(
-         surface: *wlr.XdgSurface,
-         iterator: fn (surface: *wlr.Surface, sx: c_int, sy: c_int, data: ?*c_void) callconv(.C) void,
-         user_data: ?*c_void,
-@@ -322,7 +322,7 @@ pub const XdgSurface = extern struct {
-         iterator: fn (surface: *wlr.Surface, sx: c_int, sy: c_int, data: T) callconv(.C) void,
-         data: T,
-     ) void {
--        wlr_xdg_surface_for_each_popup(
-+        wlr_xdg_surface_for_each_popup_surface(
-             surface,
-             @ptrCast(fn (surface: *wlr.Surface, sx: c_int, sy: c_int, data: ?*c_void) callconv(.C) void, iterator),
-             data,
---- deps/zig-wlroots/src/xwayland.zig.orig	2021-02-15 17:19:02 UTC
-+++ deps/zig-wlroots/src/xwayland.zig
-@@ -13,6 +13,14 @@ const xcb = struct {
-     const Pixmap = u32;
-     const Window = u32;
-     const Atom = u32;
-+
-+    const StackMode = extern enum {
-+        above = 0,
-+        below = 1,
-+        top_if = 2,
-+        bottom_if = 3,
-+        opposite = 4,
-+    };
- };
- 
- pub const Xwm = opaque {};
-@@ -33,7 +41,7 @@ pub const XwaylandServer = extern struct {
- 
-     pid: os.pid_t,
-     client: ?*wl.Client,
--    sigusr1_source: ?*wl.EventSource,
-+    pipe_source: ?*wl.EventSource,
-     wm_fd: [2]c_int,
-     wl_fd: [2]c_int,
- 
-@@ -258,6 +266,9 @@ pub const XwaylandSurface = extern struct {
- 
-     extern fn wlr_xwayland_surface_activate(surface: *XwaylandSurface, activated: bool) void;
-     pub const activate = wlr_xwayland_surface_activate;
-+
-+    extern fn wlr_xwayland_surface_restack(surface: *XwaylandSurface, sibling: *XwaylandSurface, mode: xcb.StackMode) void;
-+    pub const restack = wlr_xwayland_surface_restack;
- 
-     extern fn wlr_xwayland_surface_configure(surface: *XwaylandSurface, x: i16, y: i16, width: u16, height: u16) void;
-     pub const configure = wlr_xwayland_surface_configure;
---- river/Server.zig.orig	2021-02-22 13:47:31 UTC
-+++ river/Server.zig
-@@ -78,7 +78,7 @@ pub fn init(self: *Self) !void {
-     errdefer self.sigterm_source.remove();
- 
-     // This frees itself when the wl.Server is destroyed
--    self.backend = try wlr.Backend.autocreate(self.wl_server, null);
-+    self.backend = try wlr.Backend.autocreate(self.wl_server);
- 
-     // This backend is used to create a noop output for use when no actual
-     // outputs are available. This frees itself when the wl.Server is destroyed.
-@@ -140,7 +140,6 @@ pub fn deinit(self: *Self) void {
- 
-     self.root.deinit();
- 
--    self.noop_backend.destroy();
-     self.wl_server.destroy();
- 
-     self.input_manager.deinit();
---- river/render.zig.orig	2021-02-22 13:47:31 UTC
-+++ river/render.zig
-@@ -54,7 +54,7 @@ pub fn renderOutput(output: *Output) void {
- 
-     output.wlr_output.attachRender(null) catch return;
- 
--    renderer.begin(output.wlr_output.width, output.wlr_output.height);
-+    renderer.begin(@intCast(u32, output.wlr_output.width), @intCast(u32, output.wlr_output.height));
- 
-     // Find the first visible fullscreen view in the stack if there is one
-     var it = ViewStack(View).iter(output.views.first, .forward, output.current.tags, renderFilter);
-@@ -227,24 +227,7 @@ fn renderViewPopups(output: *const Output, view: *View
-         .when = now,
-         .opacity = view.opacity,
-     };
--    view.forEachPopup(*SurfaceRenderData, renderPopupSurfaceIterator, &rdata);
--}
--
--// TODO(wlroots): replace with wlr_xdg_surface_for_each_popup_surface()
--fn renderPopupSurfaceIterator(
--    surface: *wlr.Surface,
--    surface_x: c_int,
--    surface_y: c_int,
--    rdata: *SurfaceRenderData,
--) callconv(.C) void {
--    var new_rdata = SurfaceRenderData{
--        .output = rdata.output,
--        .output_x = rdata.output_x + surface_x,
--        .output_y = rdata.output_y + surface_y,
--        .when = rdata.when,
--        .opacity = rdata.opacity,
--    };
--    surface.forEachSurface(*SurfaceRenderData, renderSurfaceIterator, &new_rdata);
-+    view.forEachPopup(*SurfaceRenderData, renderSurfaceIterator, &rdata);
- }
- 
- fn renderDragIcons(output: *const Output, now: *os.timespec) void {



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202104080115.1381FdYU095391>