X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fshell.c;h=f5dc3e3458e022733b20ca61a23b572e221a4948;hb=refs%2Fchanges%2F69%2F29069%2F2;hp=2ce6ac40a5458566bb78b6c3270d8bf3a6742713;hpb=2edba91d3eab0d7b3c490c12be1f9bc3b5255aa8;p=src%2Fagl-compositor.git diff --git a/src/shell.c b/src/shell.c index 2ce6ac4..f5dc3e3 100644 --- a/src/shell.c +++ b/src/shell.c @@ -1678,6 +1678,21 @@ shell_set_app_position(struct wl_client *client, struct wl_resource *res, weston_compositor_schedule_repaint(ivi->compositor); } +static void +shell_set_app_scale(struct wl_client *client, struct wl_resource *res, + const char *app_id, int32_t width, int32_t height) +{ + + struct ivi_compositor *ivi = wl_resource_get_user_data(res); + struct ivi_surface *surf = ivi_find_app(ivi, app_id); + + if (!surf || !app_id || surf->role != IVI_SURFACE_ROLE_POPUP) + return; + + weston_desktop_surface_set_size(surf->dsurface, width, height); + weston_compositor_schedule_repaint(ivi->compositor); +} + static void shell_ext_destroy(struct wl_client *client, struct wl_resource *res) { @@ -1707,6 +1722,7 @@ static const struct agl_shell_interface agl_shell_implementation = { .set_app_fullscreen = shell_set_app_fullscreen, .set_app_output = shell_set_app_output, .set_app_position = shell_set_app_position, + .set_app_scale = shell_set_app_scale, }; static const struct agl_shell_ext_interface agl_shell_ext_implementation = { @@ -2008,7 +2024,7 @@ int ivi_shell_create_global(struct ivi_compositor *ivi) { ivi->agl_shell = wl_global_create(ivi->compositor->wl_display, - &agl_shell_interface, 9, + &agl_shell_interface, 10, ivi, bind_agl_shell); if (!ivi->agl_shell) { weston_log("Failed to create wayland global.\n");