clients/window: drop support for rgb565

Remove member preferred_format from struct window and hardcode
ARGB32 pixel format for clients/window.

The member preferred_format was first added to allow hinting
of a preference for RGB565 when creating a window. But it is
not being used for a long time now. So it's safe to remove it
from the code, dropping support for RGB565 in clients/window.

Signed-off-by: Leandro Ribeiro <leandrohr@riseup.net>
dev
Leandro Ribeiro 5 years ago committed by Daniel Stone
parent 90eee632ca
commit f0cd00a855
  1. 46
      clients/window.c
  2. 11
      clients/window.h

@ -146,7 +146,6 @@ struct display {
cairo_surface_t *dummy_surface; cairo_surface_t *dummy_surface;
void *dummy_surface_data; void *dummy_surface_data;
int has_rgb565;
int data_device_manager_version; int data_device_manager_version;
struct wp_viewporter *viewporter; struct wp_viewporter *viewporter;
}; };
@ -249,8 +248,6 @@ struct window {
int fullscreen; int fullscreen;
int maximized; int maximized;
enum preferred_format preferred_format;
window_key_handler_t key_handler; window_key_handler_t key_handler;
window_keyboard_focus_handler_t keyboard_focus_handler; window_keyboard_focus_handler_t keyboard_focus_handler;
window_data_handler_t data_handler; window_data_handler_t data_handler;
@ -830,7 +827,6 @@ display_create_shm_surface_from_pool(struct display *display,
struct shm_surface_data *data; struct shm_surface_data *data;
uint32_t format; uint32_t format;
cairo_surface_t *surface; cairo_surface_t *surface;
cairo_format_t cairo_format;
int stride, length, offset; int stride, length, offset;
void *map; void *map;
@ -838,12 +834,8 @@ display_create_shm_surface_from_pool(struct display *display,
if (data == NULL) if (data == NULL)
return NULL; return NULL;
if (flags & SURFACE_HINT_RGB565 && display->has_rgb565) stride = cairo_format_stride_for_width (CAIRO_FORMAT_ARGB32,
cairo_format = CAIRO_FORMAT_RGB16_565; rectangle->width);
else
cairo_format = CAIRO_FORMAT_ARGB32;
stride = cairo_format_stride_for_width (cairo_format, rectangle->width);
length = stride * rectangle->height; length = stride * rectangle->height;
data->pool = NULL; data->pool = NULL;
map = shm_pool_allocate(pool, length, &offset); map = shm_pool_allocate(pool, length, &offset);
@ -854,7 +846,7 @@ display_create_shm_surface_from_pool(struct display *display,
} }
surface = cairo_image_surface_create_for_data (map, surface = cairo_image_surface_create_for_data (map,
cairo_format, CAIRO_FORMAT_ARGB32,
rectangle->width, rectangle->width,
rectangle->height, rectangle->height,
stride); stride);
@ -862,14 +854,10 @@ display_create_shm_surface_from_pool(struct display *display,
cairo_surface_set_user_data(surface, &shm_surface_data_key, cairo_surface_set_user_data(surface, &shm_surface_data_key,
data, shm_surface_data_destroy); data, shm_surface_data_destroy);
if (flags & SURFACE_HINT_RGB565 && display->has_rgb565)
format = WL_SHM_FORMAT_RGB565;
else {
if (flags & SURFACE_OPAQUE) if (flags & SURFACE_OPAQUE)
format = WL_SHM_FORMAT_XRGB8888; format = WL_SHM_FORMAT_XRGB8888;
else else
format = WL_SHM_FORMAT_ARGB8888; format = WL_SHM_FORMAT_ARGB8888;
}
data->buffer = wl_shm_pool_create_buffer(pool->pool, offset, data->buffer = wl_shm_pool_create_buffer(pool->pool, offset,
rectangle->width, rectangle->width,
@ -902,8 +890,7 @@ display_create_shm_surface(struct display *display,
} }
} }
pool = shm_pool_create(display, pool = shm_pool_create(display, data_length_for_shm_surface(rectangle));
data_length_for_shm_surface(rectangle));
if (!pool) if (!pool)
return NULL; return NULL;
@ -1491,9 +1478,6 @@ window_create_main_surface(struct window *window)
if (window->resizing) if (window->resizing)
flags |= SURFACE_HINT_RESIZE; flags |= SURFACE_HINT_RESIZE;
if (window->preferred_format == WINDOW_PREFERRED_FORMAT_RGB565)
flags |= SURFACE_HINT_RGB565;
surface_create_surface(surface, flags); surface_create_surface(surface, flags);
} }
@ -5260,7 +5244,6 @@ window_create_internal(struct display *display, int custom)
assert(custom || display->xdg_shell); assert(custom || display->xdg_shell);
window->custom = custom; window->custom = custom;
window->preferred_format = WINDOW_PREFERRED_FORMAT_NONE;
surface->buffer_type = get_preferred_buffer_type(display); surface->buffer_type = get_preferred_buffer_type(display);
@ -5612,13 +5595,6 @@ window_get_buffer_type(struct window *window)
return window->main_surface->buffer_type; return window->main_surface->buffer_type;
} }
void
window_set_preferred_format(struct window *window,
enum preferred_format format)
{
window->preferred_format = format;
}
struct widget * struct widget *
window_add_subsurface(struct window *window, void *data, window_add_subsurface(struct window *window, void *data,
enum subsurface_mode default_mode) enum subsurface_mode default_mode)
@ -5995,19 +5971,6 @@ input_destroy(struct input *input)
free(input); free(input);
} }
static void
shm_format(void *data, struct wl_shm *wl_shm, uint32_t format)
{
struct display *d = data;
if (format == WL_SHM_FORMAT_RGB565)
d->has_rgb565 = 1;
}
struct wl_shm_listener shm_listener = {
shm_format
};
static void static void
xdg_wm_base_ping(void *data, struct xdg_wm_base *shell, uint32_t serial) xdg_wm_base_ping(void *data, struct xdg_wm_base *shell, uint32_t serial)
{ {
@ -6052,7 +6015,6 @@ registry_handle_global(void *data, struct wl_registry *registry, uint32_t id,
1); 1);
} else if (strcmp(interface, "wl_shm") == 0) { } else if (strcmp(interface, "wl_shm") == 0) {
d->shm = wl_registry_bind(registry, id, &wl_shm_interface, 1); d->shm = wl_registry_bind(registry, id, &wl_shm_interface, 1);
wl_shm_add_listener(d->shm, &shm_listener, d);
} else if (strcmp(interface, "wl_data_device_manager") == 0) { } else if (strcmp(interface, "wl_data_device_manager") == 0) {
display_add_data_device(d, id, version); display_add_data_device(d, id, version);
} else if (strcmp(interface, "xdg_wm_base") == 0) { } else if (strcmp(interface, "xdg_wm_base") == 0) {

@ -135,8 +135,6 @@ display_release_window_surface(struct display *display,
#define SURFACE_HINT_RESIZE 0x10 #define SURFACE_HINT_RESIZE 0x10
#define SURFACE_HINT_RGB565 0x100
cairo_surface_t * cairo_surface_t *
display_create_surface(struct display *display, display_create_surface(struct display *display,
struct wl_surface *surface, struct wl_surface *surface,
@ -508,15 +506,6 @@ window_get_title(struct window *window);
void void
window_set_text_cursor_position(struct window *window, int32_t x, int32_t y); window_set_text_cursor_position(struct window *window, int32_t x, int32_t y);
enum preferred_format {
WINDOW_PREFERRED_FORMAT_NONE,
WINDOW_PREFERRED_FORMAT_RGB565
};
void
window_set_preferred_format(struct window *window,
enum preferred_format format);
int int
widget_set_tooltip(struct widget *parent, char *entry, float x, float y); widget_set_tooltip(struct widget *parent, char *entry, float x, float y);

Loading…
Cancel
Save