forked from Alexays/Waybar
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This patch adds a new module to show the current keyboard layout. Signed-off-by: Harish Krupo <harishkrupo@gmail.com>
- Loading branch information
1 parent
7733549
commit 4493871
Showing
11 changed files
with
177 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
#pragma once | ||
|
||
#include <fmt/format.h> | ||
#include <algorithm> | ||
#include "ALabel.hpp" | ||
#include <xkbcommon/xkbcommon.h> | ||
#include <wayland-client.h> | ||
#include <sys/mman.h> | ||
|
||
namespace waybar::modules { | ||
|
||
class KbdLayout : public ALabel { | ||
public: | ||
KbdLayout(const Json::Value&); | ||
~KbdLayout(); | ||
auto update() -> void; | ||
void handleSeat(struct wl_seat* seat, uint32_t caps); | ||
struct wl_keyboard *wl_kbd_ = nullptr; | ||
struct xkb_context *xkb_ctx_ = nullptr; | ||
struct xkb_keymap *keymap_ = nullptr; | ||
struct xkb_state *xkb_state_ = nullptr; | ||
uint32_t current_group_ = 0; | ||
|
||
private: | ||
|
||
static void kbdKeymap(void *data, struct wl_keyboard *wl_kbd, uint32_t format, | ||
int fd, uint32_t size); | ||
static void kbdEnter(void *data, struct wl_keyboard *wl_kbd, uint32_t serial, | ||
struct wl_surface *surf, struct wl_array *keys) {} | ||
static void kbdLeave(void *data, struct wl_keyboard *wl_kbd, uint32_t serial, struct wl_surface *surf) {} | ||
|
||
static void kbdKey(void *data, struct wl_keyboard *wl_kbd, uint32_t serial, uint32_t time, | ||
uint32_t key, uint32_t state) {} | ||
|
||
static void kbdModifiers(void *data, struct wl_keyboard *wl_kbd, uint32_t serial, | ||
uint32_t mods_depressed, uint32_t mods_latched, | ||
uint32_t mods_locked, uint32_t group); | ||
|
||
static void kbdRepeatInfo(void *data, struct wl_keyboard *wl_kbd, int32_t rate, | ||
int32_t delay) {} | ||
std::string layout_ = "EN"; | ||
}; | ||
|
||
} // namespace waybar::modules |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
#include "modules/kbdlayout.hpp" | ||
|
||
waybar::modules::KbdLayout::KbdLayout(const Json::Value &config) | ||
: ALabel(config, "{layout}"), current_group_(0) { | ||
label_.set_name("kbdlayout"); | ||
enum xkb_context_flags ctx_flags = static_cast<enum xkb_context_flags>(XKB_CONTEXT_NO_DEFAULT_INCLUDES | XKB_CONTEXT_NO_ENVIRONMENT_NAMES); | ||
xkb_ctx_ = xkb_context_new(ctx_flags); | ||
} | ||
|
||
waybar::modules::KbdLayout::~KbdLayout() { | ||
xkb_context_unref(xkb_ctx_); | ||
} | ||
|
||
void waybar::modules::KbdLayout::handleSeat(struct wl_seat* seat, uint32_t caps) { | ||
static const struct wl_keyboard_listener kbd_listener = { | ||
kbdKeymap, | ||
kbdEnter, | ||
kbdLeave, | ||
kbdKey, | ||
kbdModifiers, | ||
kbdRepeatInfo | ||
}; | ||
|
||
if (!wl_kbd_ && (caps & WL_SEAT_CAPABILITY_KEYBOARD)) { | ||
wl_kbd_ = wl_seat_get_keyboard(seat); | ||
wl_keyboard_add_listener(wl_kbd_, &kbd_listener, this); | ||
} else if (wl_kbd_ && !(caps & WL_SEAT_CAPABILITY_KEYBOARD)) { | ||
wl_keyboard_destroy(wl_kbd_); | ||
wl_kbd_ = NULL; | ||
xkb_keymap_unref(keymap_); | ||
keymap_ = NULL; | ||
} | ||
} | ||
|
||
auto waybar::modules::KbdLayout::update() -> void | ||
{ | ||
auto format = format_; | ||
|
||
xkb_keycode_t keycode = 38; | ||
xkb_layout_index_t layout = xkb_state_key_get_layout(xkb_state_, keycode); | ||
layout_ = xkb_keymap_layout_get_name(keymap_, layout); | ||
|
||
label_.set_label(fmt::format(format, fmt::arg("layout", layout_))); | ||
} | ||
|
||
void waybar::modules::KbdLayout::kbdKeymap(void *data, struct wl_keyboard *wl_kbd, uint32_t format, int fd, uint32_t size) { | ||
auto o = static_cast<waybar::modules::KbdLayout *>(data); | ||
void *buf; | ||
|
||
buf = mmap(NULL, size, PROT_READ, MAP_PRIVATE, fd, 0); | ||
if (buf == MAP_FAILED) { | ||
printf("Failed to mmap keymap: %d\n", errno); | ||
close(fd); | ||
return; | ||
} | ||
|
||
o->keymap_ = xkb_keymap_new_from_buffer(o->xkb_ctx_, static_cast<const char*>(buf), size - 1, | ||
XKB_KEYMAP_FORMAT_TEXT_V1, static_cast<enum xkb_keymap_compile_flags>(0)); | ||
munmap(buf, size); | ||
close(fd); | ||
if (!o->keymap_) { | ||
printf("Failed to compile keymap!\n"); | ||
return; | ||
} | ||
|
||
o->xkb_state_ = xkb_state_new(o->keymap_); | ||
if (!o->xkb_state_) { | ||
printf("Failed to create XKB state!\n"); | ||
return; | ||
} | ||
|
||
o->dp.emit(); | ||
} | ||
|
||
void waybar::modules::KbdLayout::kbdModifiers(void *data, struct wl_keyboard *wl_kbd, uint32_t serial, | ||
uint32_t mods_depressed, uint32_t mods_latched, | ||
uint32_t mods_locked, uint32_t group) { | ||
|
||
auto o = static_cast<waybar::modules::KbdLayout *>(data); | ||
|
||
xkb_state_update_mask(o->xkb_state_, mods_depressed, mods_latched, | ||
mods_locked, 0, 0, group); | ||
if (o->current_group_ != group) { | ||
o->current_group_ = group; | ||
o->dp.emit(); | ||
} | ||
} |
4493871
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not right away :(
This patch depends on a new protocol which is being discussed at swaywm/wlr-protocols#31.
Right now, I am busy with other work so I am unable to focus on this. Also with the inclusion of this patch: swaywm/sway@d8ad429, the interest to add a new "specific" protocol for this seems luke warm. If people change their mind or more people show interest, I will take this up again :)