[Mesa-dev] [PATCH 7/7] wayland-egl: rework and simplify wl_egl_window initialization
Emil Velikov
emil.l.velikov at gmail.com
Fri Sep 29 12:14:42 UTC 2017
From: Emil Velikov <emil.velikov at collabora.com>
Use calloc instead of malloc + explicitly zeroing the different fields.
We need special handling for the version field which if of type
const intptr_t.
As we're here document why keeping the constness is a good idea.
The wl_egl_window_resize() call is replaced with an explicit set of the
width/height.
Cc: Miguel A. Vico <mvicomoya at nvidia.com>
Cc: Daniel Stone <daniels at collabora.com>
Signed-off-by: Emil Velikov <emil.velikov at collabora.com>
---
Miguel I believe the comment correctly describes the design plan, while
addressing Dan's comment that things look a bit ugly.
Dan, if you prefer I could still use malloc + c99 initializer.
I opted for this route since it provides nice place to document why
things are as they are.
---
src/egl/wayland/wayland-egl/wayland-egl.c | 26 ++++++++++++++++----------
1 file changed, 16 insertions(+), 10 deletions(-)
diff --git a/src/egl/wayland/wayland-egl/wayland-egl.c b/src/egl/wayland/wayland-egl/wayland-egl.c
index 4501c6dc956..e7cea895ece 100644
--- a/src/egl/wayland/wayland-egl/wayland-egl.c
+++ b/src/egl/wayland/wayland-egl/wayland-egl.c
@@ -61,26 +61,32 @@ WL_EGL_EXPORT struct wl_egl_window *
wl_egl_window_create(struct wl_surface *surface,
int width, int height)
{
- struct wl_egl_window _INIT_ = { .version = WL_EGL_WINDOW_VERSION };
struct wl_egl_window *egl_window;
if (width <= 0 || height <= 0)
return NULL;
- egl_window = malloc(sizeof *egl_window);
+ egl_window = calloc(1, sizeof *egl_window);
if (!egl_window)
return NULL;
- memcpy(egl_window, &_INIT_, sizeof *egl_window);
+ /* Cast away the constness to set the version number.
+ *
+ * We want the const notation since it gives an explicit
+ * feedback to the backend implementation, should it try to
+ * change it.
+ *
+ * The latter in itself is not too surprising as these days APIs
+ * tend to provide bidirectional version field.
+ */
+ intptr_t *version = (intptr_t *)&egl_window->version;
+ *version = WL_EGL_WINDOW_VERSION;
egl_window->surface = surface;
- egl_window->private = NULL;
- egl_window->resize_callback = NULL;
- egl_window->destroy_window_callback = NULL;
- wl_egl_window_resize(egl_window, width, height, 0, 0);
- egl_window->attached_width = 0;
- egl_window->attached_height = 0;
-
+
+ egl_window->width = width;
+ egl_window->height = height;
+
return egl_window;
}
--
2.14.1
More information about the mesa-dev
mailing list