diff options
author | Drew DeVault <sir@cmpwn.com> | 2017-06-21 09:58:15 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-21 09:58:15 -0400 |
commit | fd5ad1589460db3e8663efb1b09eacae1fb5e760 (patch) | |
tree | ab935777fb413666dab388b67be6c37e45cfca88 /example | |
parent | d1493b23918f5558a0f6a24c9a7a2bb34207a6ed (diff) | |
parent | d87574948e839afe6ec0224183c59b633ad0c9a0 (diff) | |
download | wlroots-fd5ad1589460db3e8663efb1b09eacae1fb5e760.tar.xz |
Merge pull request #18 from ascent12/session
Fix VT switching with libinput backend
Diffstat (limited to 'example')
-rw-r--r-- | example/pointer.c | 2 | ||||
-rw-r--r-- | example/rotation.c | 4 | ||||
-rw-r--r-- | example/simple.c | 2 | ||||
-rw-r--r-- | example/tablet.c | 2 | ||||
-rw-r--r-- | example/touch.c | 2 |
5 files changed, 12 insertions, 0 deletions
diff --git a/example/pointer.c b/example/pointer.c index 8735c61e..9aeb41a7 100644 --- a/example/pointer.c +++ b/example/pointer.c @@ -50,6 +50,8 @@ static void handle_keyboard_key(struct keyboard_state *kbstate, xkb_keysym_t sym, enum wlr_key_state key_state) { if (sym == XKB_KEY_Escape) { kbstate->compositor->exit = true; + } else if (key_state == WLR_KEY_PRESSED && sym >= XKB_KEY_F1 && sym <= XKB_KEY_F12) { + wlr_session_change_vt(kbstate->compositor->session, sym - XKB_KEY_F1 + 1); } } diff --git a/example/rotation.c b/example/rotation.c index d7b6b169..412a81ca 100644 --- a/example/rotation.c +++ b/example/rotation.c @@ -123,6 +123,10 @@ static void handle_keyboard_key(struct keyboard_state *kbstate, update_velocities(kbstate->compositor, 0, 16); break; } + + if (sym >= XKB_KEY_F1 && sym <= XKB_KEY_F12) { + wlr_session_change_vt(kbstate->compositor->session, sym - XKB_KEY_F1 + 1); + } } } diff --git a/example/simple.c b/example/simple.c index f3a66db9..34d9c9b1 100644 --- a/example/simple.c +++ b/example/simple.c @@ -42,6 +42,8 @@ static void handle_keyboard_key(struct keyboard_state *kbstate, xkb_keysym_t sym, enum wlr_key_state key_state) { if (sym == XKB_KEY_Escape) { kbstate->compositor->exit = true; + } else if (key_state == WLR_KEY_PRESSED && sym >= XKB_KEY_F1 && sym <= XKB_KEY_F12) { + wlr_session_change_vt(kbstate->compositor->session, sym - XKB_KEY_F1 + 1); } } diff --git a/example/tablet.c b/example/tablet.c index 6be006f0..4d64b638 100644 --- a/example/tablet.c +++ b/example/tablet.c @@ -78,6 +78,8 @@ static void handle_keyboard_key(struct keyboard_state *kbstate, xkb_keysym_t sym, enum wlr_key_state key_state) { if (sym == XKB_KEY_Escape) { kbstate->compositor->exit = true; + } else if (key_state == WLR_KEY_PRESSED && sym >= XKB_KEY_F1 && sym <= XKB_KEY_F12) { + wlr_session_change_vt(kbstate->compositor->session, sym - XKB_KEY_F1 + 1); } } diff --git a/example/touch.c b/example/touch.c index 1b4233bb..2b6cb173 100644 --- a/example/touch.c +++ b/example/touch.c @@ -59,6 +59,8 @@ static void handle_keyboard_key(struct keyboard_state *kbstate, xkb_keysym_t sym, enum wlr_key_state key_state) { if (sym == XKB_KEY_Escape) { kbstate->compositor->exit = true; + } else if (key_state == WLR_KEY_PRESSED && sym >= XKB_KEY_F1 && sym <= XKB_KEY_F12) { + wlr_session_change_vt(kbstate->compositor->session, sym - XKB_KEY_F1 + 1); } } |