From: Daniel Stone Date: Wed, 30 May 2012 15:31:56 +0000 (+0100) Subject: shell: Reset focus for all seats on activation X-Git-Tag: 20120702.1049~53 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b21046836faafc0a3743e64436fcb5b6b8c4838e;p=profile%2Fivi%2Fweston.git shell: Reset focus for all seats on activation Rather than using a single hardcoded seat to activate new windows within a compositor, reset the focus for all seats. Signed-off-by: Daniel Stone --- diff --git a/src/shell.c b/src/shell.c index bca7afc..fe7b982 100644 --- a/src/shell.c +++ b/src/shell.c @@ -2054,6 +2054,7 @@ map(struct desktop_shell *shell, struct weston_surface *surface, struct shell_surface *shsurf; enum shell_surface_type surface_type = SHELL_SURFACE_NONE; struct weston_surface *parent; + struct weston_seat *seat; int panel_height = 0; shsurf = get_shell_surface(surface); @@ -2152,9 +2153,10 @@ map(struct desktop_shell *shell, struct weston_surface *surface, case SHELL_SURFACE_TOPLEVEL: case SHELL_SURFACE_FULLSCREEN: case SHELL_SURFACE_MAXIMIZED: - if (!shell->locked) - activate(shell, surface, - (struct weston_seat *) compositor->seat); + if (!shell->locked) { + wl_list_for_each(seat, &compositor->seat_list, link) + activate(shell, surface, seat); + } break; default: break;