fix: process modifier key events independtly of modifier bits
This fixes ctrl-click on latest kitty.
This commit is contained in:
		
							parent
							
								
									9343244037
								
							
						
					
					
						commit
						f12694778b
					
				
					 4 changed files with 20 additions and 8 deletions
				
			
		|  | @ -70,6 +70,11 @@ fn mapEvent(self: *Self, evtype: u32, keypress: u32, egc: u32, modifiers: u32) t | ||||||
| fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; |     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; | ||||||
|     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); |     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); | ||||||
|  |     switch (keypress) { | ||||||
|  |         key.LCTRL, key.RCTRL => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         key.LALT, key.RALT => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         else => {}, | ||||||
|  |     } | ||||||
|     return switch (modifiers) { |     return switch (modifiers) { | ||||||
|         mod.CTRL => switch (keynormal) { |         mod.CTRL => switch (keynormal) { | ||||||
|             'E' => self.cmd("enter_overlay_mode", command.fmt(.{"open_recent"})), |             'E' => self.cmd("enter_overlay_mode", command.fmt(.{"open_recent"})), | ||||||
|  | @ -200,8 +205,6 @@ fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|             key.END => self.cmd("move_end", .{}), |             key.END => self.cmd("move_end", .{}), | ||||||
|             key.PGUP => self.cmd("move_page_up", .{}), |             key.PGUP => self.cmd("move_page_up", .{}), | ||||||
|             key.PGDOWN => self.cmd("move_page_down", .{}), |             key.PGDOWN => self.cmd("move_page_down", .{}), | ||||||
|             key.LCTRL, key.RCTRL => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.LALT, key.RALT => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.TAB => self.cmd("indent", .{}), |             key.TAB => self.cmd("indent", .{}), | ||||||
|             else => if (!key.synthesized_p(keypress)) |             else => if (!key.synthesized_p(keypress)) | ||||||
|                 self.insert_code_point(egc) |                 self.insert_code_point(egc) | ||||||
|  |  | ||||||
|  | @ -73,6 +73,11 @@ fn mapEvent(self: *Self, evtype: u32, keypress: u32, egc: u32, modifiers: u32) t | ||||||
| fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; |     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; | ||||||
|     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); |     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); | ||||||
|  |     switch (keypress) { | ||||||
|  |         key.LCTRL, key.RCTRL => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         key.LALT, key.RALT => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         else => {}, | ||||||
|  |     } | ||||||
|     return switch (modifiers) { |     return switch (modifiers) { | ||||||
|         mod.CTRL => switch (keynormal) { |         mod.CTRL => switch (keynormal) { | ||||||
|             'U' => self.cmd("move_scroll_page_up", .{}), |             'U' => self.cmd("move_scroll_page_up", .{}), | ||||||
|  | @ -200,8 +205,6 @@ fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|             key.END => self.cmd("move_end", .{}), |             key.END => self.cmd("move_end", .{}), | ||||||
|             key.PGUP => self.cmd("move_page_up", .{}), |             key.PGUP => self.cmd("move_page_up", .{}), | ||||||
|             key.PGDOWN => self.cmd("move_page_down", .{}), |             key.PGDOWN => self.cmd("move_page_down", .{}), | ||||||
|             key.LCTRL, key.RCTRL => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.LALT, key.RALT => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.TAB => self.cmd("indent", .{}), |             key.TAB => self.cmd("indent", .{}), | ||||||
|             else => if (!key.synthesized_p(keypress)) |             else => if (!key.synthesized_p(keypress)) | ||||||
|                 self.insert_code_point(egc) |                 self.insert_code_point(egc) | ||||||
|  |  | ||||||
|  | @ -74,6 +74,11 @@ fn mapEvent(self: *Self, evtype: u32, keypress: u32, egc: u32, modifiers: u32) t | ||||||
| fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; |     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; | ||||||
|     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); |     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); | ||||||
|  |     switch (keypress) { | ||||||
|  |         key.LCTRL, key.RCTRL => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         key.LALT, key.RALT => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         else => {}, | ||||||
|  |     } | ||||||
|     return switch (modifiers) { |     return switch (modifiers) { | ||||||
|         mod.CTRL => switch (keynormal) { |         mod.CTRL => switch (keynormal) { | ||||||
|             'U' => self.cmd("move_scroll_page_up", .{}), |             'U' => self.cmd("move_scroll_page_up", .{}), | ||||||
|  | @ -263,8 +268,6 @@ fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|             key.END => self.cmd("move_end", .{}), |             key.END => self.cmd("move_end", .{}), | ||||||
|             key.PGUP => self.cmd("move_page_up", .{}), |             key.PGUP => self.cmd("move_page_up", .{}), | ||||||
|             key.PGDOWN => self.cmd("move_page_down", .{}), |             key.PGDOWN => self.cmd("move_page_down", .{}), | ||||||
|             key.LCTRL, key.RCTRL => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.LALT, key.RALT => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.TAB => self.cmd("indent", .{}), |             key.TAB => self.cmd("indent", .{}), | ||||||
|             else => {}, |             else => {}, | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|  | @ -74,6 +74,11 @@ fn mapEvent(self: *Self, evtype: u32, keypress: u32, egc: u32, modifiers: u32) t | ||||||
| fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; |     const keynormal = if ('a' <= keypress and keypress <= 'z') keypress - ('a' - 'A') else keypress; | ||||||
|     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); |     if (self.leader) |_| return self.mapFollower(keynormal, egc, modifiers); | ||||||
|  |     switch (keypress) { | ||||||
|  |         key.LCTRL, key.RCTRL => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         key.LALT, key.RALT => return self.cmd("enable_fast_scroll", .{}), | ||||||
|  |         else => {}, | ||||||
|  |     } | ||||||
|     return switch (modifiers) { |     return switch (modifiers) { | ||||||
|         mod.CTRL => switch (keynormal) { |         mod.CTRL => switch (keynormal) { | ||||||
|             'U' => self.cmd("move_scroll_page_up", .{}), |             'U' => self.cmd("move_scroll_page_up", .{}), | ||||||
|  | @ -259,8 +264,6 @@ fn mapPress(self: *Self, keypress: u32, egc: u32, modifiers: u32) tp.result { | ||||||
|             key.END => self.cmd("select_end", .{}), |             key.END => self.cmd("select_end", .{}), | ||||||
|             key.PGUP => self.cmd("select_page_up", .{}), |             key.PGUP => self.cmd("select_page_up", .{}), | ||||||
|             key.PGDOWN => self.cmd("select_page_down", .{}), |             key.PGDOWN => self.cmd("select_page_down", .{}), | ||||||
|             key.LCTRL, key.RCTRL => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.LALT, key.RALT => self.cmd("enable_fast_scroll", .{}), |  | ||||||
|             key.TAB => self.cmd("indent", .{}), |             key.TAB => self.cmd("indent", .{}), | ||||||
|             else => {}, |             else => {}, | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue