diff options
Diffstat (limited to 'sway/input')
| -rw-r--r-- | sway/input/cursor.c | 3 | ||||
| -rw-r--r-- | sway/input/keyboard.c | 2 | ||||
| -rw-r--r-- | sway/input/seat.c | 41 | 
3 files changed, 28 insertions, 18 deletions
| diff --git a/sway/input/cursor.c b/sway/input/cursor.c index 307eedd4..7a9f3ed7 100644 --- a/sway/input/cursor.c +++ b/sway/input/cursor.c @@ -10,6 +10,7 @@  #include <wlr/types/wlr_idle.h>  #include "list.h"  #include "log.h" +#include "sway/desktop/transaction.h"  #include "sway/input/cursor.h"  #include "sway/layers.h"  #include "sway/output.h" @@ -219,6 +220,7 @@ void cursor_send_pointer_motion(struct sway_cursor *cursor, uint32_t time_msec,  		struct sway_drag_icon *drag_icon = wlr_drag_icon->data;  		drag_icon_update_position(drag_icon);  	} +	transaction_commit_dirty();  }  static void handle_cursor_motion(struct wl_listener *listener, void *data) { @@ -278,6 +280,7 @@ void dispatch_cursor_button(struct sway_cursor *cursor,  	wlr_seat_pointer_notify_button(cursor->seat->wlr_seat,  			time_msec, button, state); +	transaction_commit_dirty();  }  static void handle_cursor_button(struct wl_listener *listener, void *data) { diff --git a/sway/input/keyboard.c b/sway/input/keyboard.c index 580c0d4b..ede38519 100644 --- a/sway/input/keyboard.c +++ b/sway/input/keyboard.c @@ -3,6 +3,7 @@  #include <wlr/backend/multi.h>  #include <wlr/backend/session.h>  #include <wlr/types/wlr_idle.h> +#include "sway/desktop/transaction.h"  #include "sway/input/seat.h"  #include "sway/input/keyboard.h"  #include "sway/input/input-manager.h" @@ -126,6 +127,7 @@ static void keyboard_execute_command(struct sway_keyboard *keyboard,  		binding->command);  	config->handler_context.seat = keyboard->seat_device->sway_seat;  	struct cmd_results *results = execute_command(binding->command, NULL); +	transaction_commit_dirty();  	if (results->status != CMD_SUCCESS) {  		wlr_log(WLR_DEBUG, "could not run command for binding: %s (%s)",  			binding->command, results->error); diff --git a/sway/input/seat.c b/sway/input/seat.c index 5e65ca70..12b1fab5 100644 --- a/sway/input/seat.c +++ b/sway/input/seat.c @@ -594,6 +594,12 @@ static void seat_send_unfocus(struct sway_container *container,  	}  } +static int handle_urgent_timeout(void *data) { +	struct sway_view *view = data; +	view_set_urgent(view, false); +	return 0; +} +  void seat_set_focus_warp(struct sway_seat *seat,  		struct sway_container *container, bool warp) {  	if (seat->focused_layer) { @@ -649,6 +655,7 @@ void seat_set_focus_warp(struct sway_seat *seat,  		while (parent) {  			wl_list_remove(&parent->link);  			wl_list_insert(&seat->focus_stack, &parent->link); +			container_set_dirty(parent->container);  			parent =  				seat_container_from_container(seat, @@ -661,9 +668,23 @@ void seat_set_focus_warp(struct sway_seat *seat,  		if (last_focus) {  			seat_send_unfocus(last_focus, seat);  		} -  		seat_send_focus(container, seat); -		container_damage_whole(container->parent); + +		container_set_dirty(container); +		container_set_dirty(container->parent); // for focused_inactive_child +		if (last_focus) { +			container_set_dirty(last_focus); +		} +	} + +	// If urgent, start a timer to unset it +	if (container && container->type == C_VIEW && +			view_is_urgent(container->sway_view) && +			!container->sway_view->urgent_timer) { +		struct sway_view *view = container->sway_view; +		view->urgent_timer = wl_event_loop_add_timer(server.wl_event_loop, +				handle_urgent_timeout, view); +		wl_event_source_timer_update(view->urgent_timer, 1000);  	}  	// If we've focused a floating container, bring it to the front. @@ -717,10 +738,6 @@ void seat_set_focus_warp(struct sway_seat *seat,  		}  	} -	if (last_focus) { -		container_damage_whole(last_focus); -	} -  	if (last_workspace && last_workspace != new_workspace) {  		cursor_send_pointer_motion(seat->cursor, 0, true);  	} @@ -840,18 +857,6 @@ struct sway_container *seat_get_active_child(struct sway_seat *seat,  	return NULL;  } -struct sway_container *seat_get_active_current_child(struct sway_seat *seat, -		struct sway_container *container) { -	struct sway_seat_container *current = NULL; -	wl_list_for_each(current, &seat->focus_stack, link) { -		if (current->container->current.parent == container && -				current->container->current.layout != L_FLOATING) { -			return current->container; -		} -	} -	return NULL; -} -  struct sway_container *seat_get_focus(struct sway_seat *seat) {  	if (!seat->has_focus) {  		return NULL; | 
