diff --git a/clients/desktop-shell.c b/clients/desktop-shell.c
index ed6ea400..cc1028f6 100644
--- a/clients/desktop-shell.c
+++ b/clients/desktop-shell.c
@@ -669,10 +669,9 @@ unlock_dialog_create(struct desktop *desktop)
return NULL;
memset(dialog, 0, sizeof *dialog);
- dialog->window = window_create(display);
+ dialog->window = window_create_custom(display);
dialog->widget = frame_create(dialog->window, dialog);
window_set_title(dialog->window, "Unlock your desktop");
- window_set_custom(dialog->window);
window_set_user_data(dialog->window, dialog);
window_set_keyboard_focus_handler(dialog->window,
@@ -688,7 +687,7 @@ unlock_dialog_create(struct desktop *desktop)
unlock_dialog_button_handler);
desktop_shell_set_lock_surface(desktop->shell,
- window_get_wl_shell_surface(dialog->window));
+ window_get_wl_surface(dialog->window));
window_schedule_resize(dialog->window, 260, 230);
diff --git a/protocol/desktop-shell.xml b/protocol/desktop-shell.xml
index 1edd011d..65c97eff 100644
--- a/protocol/desktop-shell.xml
+++ b/protocol/desktop-shell.xml
@@ -18,7 +18,7 @@
-
+
diff --git a/src/shell.c b/src/shell.c
index f995f03d..95b010da 100644
--- a/src/shell.c
+++ b/src/shell.c
@@ -92,7 +92,7 @@ struct desktop_shell {
bool locked;
bool prepare_event_sent;
- struct shell_surface *lock_surface;
+ struct weston_surface *lock_surface;
struct wl_listener lock_surface_listener;
struct {
@@ -129,7 +129,6 @@ struct desktop_shell {
enum shell_surface_type {
SHELL_SURFACE_NONE,
- SHELL_SURFACE_LOCK,
SHELL_SURFACE_SCREENSAVER,
SHELL_SURFACE_INPUT_PANEL,
@@ -1228,7 +1227,6 @@ reset_shell_surface_type(struct shell_surface *surface)
wl_list_init(&surface->link);
break;
case SHELL_SURFACE_SCREENSAVER:
- case SHELL_SURFACE_LOCK:
wl_resource_post_error(&surface->resource,
WL_DISPLAY_ERROR_INVALID_METHOD,
"cannot reassign surface type");
@@ -1858,7 +1856,7 @@ show_screensaver(struct desktop_shell *shell, struct shell_surface *surface)
struct wl_list *list;
if (shell->lock_surface)
- list = &shell->lock_surface->surface->layer_link;
+ list = &shell->lock_surface->layer_link;
else
list = &shell->lock_layer.surface_list;
@@ -1990,6 +1988,21 @@ desktop_shell_set_panel(struct wl_client *client,
surface->output->current->height);
}
+static void
+lock_surface_configure(struct weston_surface *surface, int32_t sx, int32_t sy)
+{
+ struct desktop_shell *shell = surface->private;
+
+ center_on_output(surface, get_default_output(shell->compositor));
+
+ if (!weston_surface_is_mapped(surface)) {
+ wl_list_insert(&shell->lock_layer.surface_list,
+ &surface->layer_link);
+ weston_surface_assign_output(surface);
+ weston_compositor_wake(shell->compositor);
+ }
+}
+
static void
handle_lock_surface_destroy(struct wl_listener *listener, void *data)
{
@@ -2006,7 +2019,7 @@ desktop_shell_set_lock_surface(struct wl_client *client,
struct wl_resource *surface_resource)
{
struct desktop_shell *shell = resource->data;
- struct shell_surface *surface = surface_resource->data;
+ struct weston_surface *surface = surface_resource->data;
shell->prepare_event_sent = false;
@@ -2019,7 +2032,8 @@ desktop_shell_set_lock_surface(struct wl_client *client,
wl_signal_add(&surface_resource->destroy_signal,
&shell->lock_surface_listener);
- shell->lock_surface->next_type = SHELL_SURFACE_LOCK;
+ surface->configure = lock_surface_configure;
+ surface->private = shell;
}
static void
@@ -2445,7 +2459,6 @@ activate(struct desktop_shell *shell, struct weston_surface *es,
weston_surface_activate(es, seat);
switch (get_shell_surface_type(es)) {
- case SHELL_SURFACE_LOCK:
case SHELL_SURFACE_INPUT_PANEL:
break;
@@ -2453,7 +2466,7 @@ activate(struct desktop_shell *shell, struct weston_surface *es,
/* always below lock surface */
if (shell->lock_surface)
weston_surface_restack(es,
- &shell->lock_surface->surface->layer_link);
+ &shell->lock_surface->layer_link);
break;
case SHELL_SURFACE_FULLSCREEN:
/* should on top of panels */
@@ -2504,6 +2517,7 @@ click_to_activate_binding(struct wl_seat *seat, uint32_t time, uint32_t button,
switch (get_shell_surface_type(focus)) {
case SHELL_SURFACE_SCREENSAVER:
case SHELL_SURFACE_INPUT_PANEL:
+ case SHELL_SURFACE_NONE:
return;
default:
break;
@@ -2616,10 +2630,12 @@ static void
center_on_output(struct weston_surface *surface, struct weston_output *output)
{
struct weston_mode *mode = output->current;
- GLfloat x = (mode->width - surface->geometry.width) / 2;
- GLfloat y = (mode->height - surface->geometry.height) / 2;
+ GLfloat x = (mode->width - surface->buffer->width) / 2;
+ GLfloat y = (mode->height - surface->buffer->height) / 2;
- weston_surface_set_position(surface, output->x + x, output->y + y);
+ weston_surface_configure(surface, output->x + x, output->y + y,
+ surface->buffer->width,
+ surface->buffer->height);
}
@@ -2667,9 +2683,6 @@ map(struct desktop_shell *shell, struct weston_surface *surface,
weston_surface_set_position(surface, surface->output->x,
surface->output->y + panel_height);
break;
- case SHELL_SURFACE_LOCK:
- center_on_output(surface, get_default_output(compositor));
- break;
case SHELL_SURFACE_INPUT_PANEL:
bottom_center_on_output(surface, get_default_output(compositor));
/* Don't map the input panel here, wait for
@@ -2688,12 +2701,6 @@ map(struct desktop_shell *shell, struct weston_surface *surface,
/* surface stacking order, see also activate() */
switch (surface_type) {
- case SHELL_SURFACE_LOCK:
- /* lock surface always visible, on top */
- wl_list_insert(&shell->lock_layer.surface_list,
- &surface->layer_link);
- weston_compositor_wake(compositor);
- break;
case SHELL_SURFACE_SCREENSAVER:
/* If locked, show it. */
if (shell->locked) {