aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorerdii <me@erdii.engineering>2025-04-20 11:30:40 +0200
committerIvan Molodetskikh <yalterz@gmail.com>2025-04-30 09:54:19 -0700
commit82dabc21f3c2379a7bed320574ff468869d59a18 (patch)
tree170f198475819f02cd8b161641fa12680234c9fa /src
parent39b3d6287377c18042f9c96d272f3a8b7597c13e (diff)
downloadniri-82dabc21f3c2379a7bed320574ff468869d59a18.tar.gz
niri-82dabc21f3c2379a7bed320574ff468869d59a18.tar.bz2
niri-82dabc21f3c2379a7bed320574ff468869d59a18.zip
feat: implement support to enable numlock at startup
Signed-off-by: erdii <me@erdii.engineering>
Diffstat (limited to 'src')
-rw-r--r--src/niri.rs30
1 files changed, 19 insertions, 11 deletions
diff --git a/src/niri.rs b/src/niri.rs
index 69e48962..ab7371dc 100644
--- a/src/niri.rs
+++ b/src/niri.rs
@@ -2248,22 +2248,30 @@ impl Niri {
let single_pixel_buffer_state = SinglePixelBufferState::new::<State>(&display_handle);
let mut seat: Seat<State> = seat_state.new_wl_seat(&display_handle, backend.seat_name());
- if let Err(err) = seat.add_keyboard(
+ let keyboard = match seat.add_keyboard(
config_.input.keyboard.xkb.to_xkb_config(),
config_.input.keyboard.repeat_delay.into(),
config_.input.keyboard.repeat_rate.into(),
) {
- if let smithay::input::keyboard::Error::BadKeymap = err {
- warn!("error loading the configured xkb keymap, trying default");
- } else {
- warn!("error adding keyboard: {err:?}");
+ Err(err) => {
+ if let smithay::input::keyboard::Error::BadKeymap = err {
+ warn!("error loading the configured xkb keymap, trying default");
+ } else {
+ warn!("error adding keyboard: {err:?}");
+ }
+ seat.add_keyboard(
+ Default::default(),
+ config_.input.keyboard.repeat_delay.into(),
+ config_.input.keyboard.repeat_rate.into(),
+ )
+ .unwrap()
}
- seat.add_keyboard(
- Default::default(),
- config_.input.keyboard.repeat_delay.into(),
- config_.input.keyboard.repeat_rate.into(),
- )
- .unwrap();
+ Ok(keyboard) => keyboard,
+ };
+ if config_.input.keyboard.numlock {
+ let mut modifier_state = keyboard.modifier_state();
+ modifier_state.num_lock = true;
+ keyboard.set_modifier_state(modifier_state);
}
seat.add_pointer();