aboutsummaryrefslogtreecommitdiff
path: root/sway/handlers.c
diff options
context:
space:
mode:
Diffstat (limited to 'sway/handlers.c')
-rw-r--r--sway/handlers.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/sway/handlers.c b/sway/handlers.c
index b166b7a6..5c673697 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -13,6 +13,8 @@
#include "container.h"
static struct wlc_origin mouse_origin;
+//Keyboard input is being overrided by window (dmenu)
+static bool override_redirect = false;
static bool pointer_test(swayc_t *view, void *_origin) {
const struct wlc_origin *origin = _origin;
@@ -36,7 +38,7 @@ swayc_t *focus_pointer(void) {
if (pointer && focused != pointer) {
unfocus_all(&root_container);
focus_view(pointer);
- } else if (!focused){
+ } else if (!focused) {
focus_view(active_workspace);
}
focused = pointer;
@@ -98,6 +100,7 @@ static bool handle_view_created(wlc_handle handle) {
}
// For things like Dmenu
if (type & WLC_BIT_OVERRIDE_REDIRECT) {
+ override_redirect = true;
wlc_view_focus(handle);
}
@@ -140,8 +143,8 @@ static void handle_view_destroyed(wlc_handle handle) {
}
if (type & WLC_BIT_OVERRIDE_REDIRECT) {
+ override_redirect = false;
focus_view(focus_pointer());
- arrange_windows(active_workspace, -1, -1);
return;
}
if (type & WLC_BIT_POPUP) {
@@ -221,6 +224,9 @@ static void handle_view_state_request(wlc_handle view, enum wlc_view_state_bit s
static bool handle_key(wlc_handle view, uint32_t time, const struct wlc_modifiers
*modifiers, uint32_t key, uint32_t sym, enum wlc_key_state state) {
enum { QSIZE = 32 };
+ if (override_redirect) {
+ return false;
+ }
static uint8_t head = 0;
static uint32_t array[QSIZE];
bool cmd_success = false;