From dc0f355f0ace3538dfea541907aca53ec2ff9590 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kristian=20H=C3=B8gsberg?= Date: Sun, 7 Dec 2008 15:22:22 -0500 Subject: [PATCH] Fix API to always include socket name length. --- egl-compositor.c | 2 +- flower.c | 2 +- glx-compositor.c | 2 +- screenshot.c | 2 +- wayland-client.c | 12 ++++++------ wayland-client.h | 2 +- wayland.c | 15 ++++++++------- wayland.h | 2 +- window.c | 4 ++-- 9 files changed, 22 insertions(+), 21 deletions(-) diff --git a/egl-compositor.c b/egl-compositor.c index b52166ff..c0cd49ac 100644 --- a/egl-compositor.c +++ b/egl-compositor.c @@ -1042,7 +1042,7 @@ int main(int argc, char *argv[]) wl_display_set_compositor(display, &ec->base); - if (wl_display_add_socket(display, socket_name)) { + if (wl_display_add_socket(display, socket_name, sizeof socket_name)) { fprintf(stderr, "failed to add socket: %m\n"); exit(EXIT_FAILURE); } diff --git a/flower.c b/flower.c index e3801658..99382978 100644 --- a/flower.c +++ b/flower.c @@ -149,7 +149,7 @@ int main(int argc, char *argv[]) loop = g_main_loop_new(NULL, FALSE); - display = wl_display_create(socket_name); + display = wl_display_create(socket_name, sizeof socket_name); if (display == NULL) { fprintf(stderr, "failed to create display: %m\n"); return -1; diff --git a/glx-compositor.c b/glx-compositor.c index a9a07576..68f5374c 100644 --- a/glx-compositor.c +++ b/glx-compositor.c @@ -369,7 +369,7 @@ int main(int argc, char *argv[]) wl_display_set_compositor(display, &gc->base); - if (wl_display_add_socket(display, socket_name)) { + if (wl_display_add_socket(display, socket_name, sizeof socket_name)) { fprintf(stderr, "failed to add socket: %m\n"); exit(EXIT_FAILURE); } diff --git a/screenshot.c b/screenshot.c index 1d62c462..931afa39 100644 --- a/screenshot.c +++ b/screenshot.c @@ -84,7 +84,7 @@ int main(int argc, char *argv[]) GSource *source; struct screenshooter *s; - display = wl_display_create(socket_name); + display = wl_display_create(socket_name, sizeof socket_name); if (display == NULL) { fprintf(stderr, "failed to create display: %m\n"); return -1; diff --git a/wayland-client.c b/wayland-client.c index 7a0fa75c..26eebce2 100644 --- a/wayland-client.c +++ b/wayland-client.c @@ -83,11 +83,11 @@ connection_update(struct wl_connection *connection, } WL_EXPORT struct wl_display * -wl_display_create(const char *address) +wl_display_create(const char *name, size_t name_size) { struct wl_display *display; struct wl_global *global; - struct sockaddr_un name; + struct sockaddr_un addr; socklen_t size; char buffer[256]; uint32_t id, length, count, i; @@ -103,12 +103,12 @@ wl_display_create(const char *address) return NULL; } - name.sun_family = AF_LOCAL; - memcpy(name.sun_path, address, strlen(address + 1) + 2); + addr.sun_family = AF_LOCAL; + memcpy(addr.sun_path, name, name_size); - size = offsetof (struct sockaddr_un, sun_path) + sizeof socket_name; + size = offsetof (struct sockaddr_un, sun_path) + name_size; - if (connect(display->fd, (struct sockaddr *) &name, size) < 0) { + if (connect(display->fd, (struct sockaddr *) &addr, size) < 0) { close(display->fd); free(display); return NULL; diff --git a/wayland-client.h b/wayland-client.h index 491577a7..52b8613a 100644 --- a/wayland-client.h +++ b/wayland-client.h @@ -38,7 +38,7 @@ struct wl_surface; typedef int (*wl_display_update_func_t)(uint32_t mask, void *data); -struct wl_display *wl_display_create(const char *address); +struct wl_display *wl_display_create(const char *name, size_t name_size); void wl_display_destroy(struct wl_display *display); int wl_display_get_fd(struct wl_display *display, wl_display_update_func_t update, void *data); diff --git a/wayland.c b/wayland.c index 5f321ba8..d218631b 100644 --- a/wayland.c +++ b/wayland.c @@ -90,7 +90,7 @@ struct wl_object_ref { struct wl_object *object; struct wl_list link; }; - + static void wl_surface_destroy(struct wl_client *client, struct wl_surface *surface) @@ -762,9 +762,10 @@ socket_data(int fd, uint32_t mask, void *data) } WL_EXPORT int -wl_display_add_socket(struct wl_display *display, const char *socket_name) +wl_display_add_socket(struct wl_display *display, + const char *name, size_t name_size) { - struct sockaddr_un name; + struct sockaddr_un addr; int sock; socklen_t size; @@ -772,11 +773,11 @@ wl_display_add_socket(struct wl_display *display, const char *socket_name) if (sock < 0) return -1; - name.sun_family = AF_LOCAL; - memcpy(name.sun_path, socket_name, sizeof socket_name); + addr.sun_family = AF_LOCAL; + memcpy(addr.sun_path, name, name_size); - size = offsetof (struct sockaddr_un, sun_path) + sizeof socket_name; - if (bind(sock, (struct sockaddr *) &name, size) < 0) + size = offsetof (struct sockaddr_un, sun_path) + name_size; + if (bind(sock, (struct sockaddr *) &addr, size) < 0) return -1; if (listen(sock, 1) < 0) diff --git a/wayland.h b/wayland.h index 4fa9f12b..021d5d90 100644 --- a/wayland.h +++ b/wayland.h @@ -119,7 +119,7 @@ wl_input_device_create(struct wl_display *display, const char *path); struct wl_display *wl_display_create(void); struct wl_event_loop *wl_display_get_event_loop(struct wl_display *display); -int wl_display_add_socket(struct wl_display *display, const char *socket_name); +int wl_display_add_socket(struct wl_display *display, const char *name, size_t name_size); void wl_display_run(struct wl_display *display); void diff --git a/window.c b/window.c index e7a275e4..63c49b9b 100644 --- a/window.c +++ b/window.c @@ -270,7 +270,7 @@ event_handler(struct wl_display *display, buffer->name, buffer->stride, 0, 0, buffer->width, buffer->height); wl_display_commit(window->display, 0); - window->gears_angle += 1; + window->gears_angle += 1; } else if (object == 1) { fprintf(stderr, "unexpected event from display: %d\n", @@ -418,7 +418,7 @@ int main(int argc, char *argv[]) return -1; } - display = wl_display_create(socket_name); + display = wl_display_create(socket_name, sizeof socket_name); if (display == NULL) { fprintf(stderr, "failed to create display: %m\n"); return -1;