Compare commits
	
		
			5 commits
		
	
	
		
			4ee59e14ba
			...
			90bacba8d5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 90bacba8d5 | |||
| c7cca545b9 | |||
| fdabe03e91 | |||
| 1eb6a773e5 | |||
| d7e162892a | 
					 4 changed files with 19 additions and 12 deletions
				
			
		|  | @ -30,8 +30,8 @@ | |||
|             ["ctrl+l", "scroll_view_center_cycle"], | ||||
|             ["ctrl+n", "goto_next_match"], | ||||
|             ["ctrl+p", "goto_prev_match"], | ||||
|             ["ctrl+b", "move_to_char", false], | ||||
|             ["ctrl+t", "move_to_char", true], | ||||
|             ["ctrl+b", "move_to_char", "left"], | ||||
|             ["ctrl+t", "move_to_char", "right"], | ||||
|             ["ctrl+x", "cut"], | ||||
|             ["ctrl+c", "copy"], | ||||
|             ["ctrl+v", "system_paste"], | ||||
|  |  | |||
|  | @ -85,6 +85,9 @@ | |||
| 
 | ||||
|             ["<C-k>", "TODO"], | ||||
| 
 | ||||
|             ["F", "move_to_char", "left"], | ||||
|             ["f", "move_to_char", "right"], | ||||
| 
 | ||||
|             ["<C-CR>", ["move_down"], ["move_begin"]], | ||||
|             ["<CR>", ["move_down"], ["move_begin"]] | ||||
|         ] | ||||
|  |  | |||
|  | @ -2084,21 +2084,25 @@ pub const Editor = struct { | |||
|     } | ||||
| 
 | ||||
|     fn move_cursor_up(root: Buffer.Root, cursor: *Cursor, metrics: Buffer.Metrics) !void { | ||||
|         try cursor.move_up(root, metrics); | ||||
|         cursor.move_up(root, metrics) catch |e| switch (e) { | ||||
|             error.Stop => cursor.move_begin(), | ||||
|         }; | ||||
|     } | ||||
| 
 | ||||
|     fn move_cursor_up_vim(root: Buffer.Root, cursor: *Cursor, metrics: Buffer.Metrics) !void { | ||||
|         try cursor.move_up(root, metrics); | ||||
|         if(is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|         if (is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|     } | ||||
| 
 | ||||
|     fn move_cursor_down(root: Buffer.Root, cursor: *Cursor, metrics: Buffer.Metrics) !void { | ||||
|         try cursor.move_down(root, metrics); | ||||
|         cursor.move_down(root, metrics) catch |e| switch (e) { | ||||
|             error.Stop => cursor.move_end(root, metrics), | ||||
|         }; | ||||
|     } | ||||
| 
 | ||||
|     fn move_cursor_down_vim(root: Buffer.Root, cursor: *Cursor, metrics: Buffer.Metrics) !void { | ||||
|         try cursor.move_down(root, metrics); | ||||
|         if(is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|         if (is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|     } | ||||
| 
 | ||||
|     fn move_cursor_buffer_begin(_: Buffer.Root, cursor: *Cursor, _: Buffer.Metrics) !void { | ||||
|  | @ -2123,7 +2127,7 @@ pub const Editor = struct { | |||
| 
 | ||||
|     fn move_cursor_half_page_up_vim(root: Buffer.Root, cursor: *Cursor, view: *const View, metrics: Buffer.Metrics) !void { | ||||
|         cursor.move_half_page_up(root, view, metrics); | ||||
|         if(is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|         if (is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|     } | ||||
| 
 | ||||
|     fn move_cursor_half_page_down(root: Buffer.Root, cursor: *Cursor, view: *const View, metrics: Buffer.Metrics) !void { | ||||
|  | @ -2132,7 +2136,7 @@ pub const Editor = struct { | |||
| 
 | ||||
|     fn move_cursor_half_page_down_vim(root: Buffer.Root, cursor: *Cursor, view: *const View, metrics: Buffer.Metrics) !void { | ||||
|         cursor.move_half_page_down(root, view, metrics); | ||||
|         if(is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|         if (is_eol_vim(root, cursor, metrics)) try move_cursor_left_vim(root, cursor, metrics); | ||||
|     } | ||||
| 
 | ||||
|     pub fn primary_click(self: *Self, y: c_int, x: c_int) !void { | ||||
|  | @ -3481,7 +3485,7 @@ pub const Editor = struct { | |||
|         for (self.cursels.items) |*cursel_| if (cursel_.*) |*cursel| | ||||
|             try self.select_line_around_cursor(cursel); | ||||
|         self.collapse_cursors(); | ||||
|   | ||||
| 
 | ||||
|         self.clamp(); | ||||
|     } | ||||
|     pub const select_line_vim_meta: Meta = .{ .description = "Select the line around the cursor (vim)" }; | ||||
|  |  | |||
|  | @ -30,13 +30,13 @@ const Operation = enum { | |||
| }; | ||||
| 
 | ||||
| pub fn create(allocator: Allocator, ctx: command.Context) !struct { tui.Mode, tui.MiniMode } { | ||||
|     var right: bool = true; | ||||
|     var direction: Direction = undefined; | ||||
|     const select = if (tui.get_active_editor()) |editor| if (editor.get_primary().selection) |_| true else false else false; | ||||
|     _ = ctx.args.match(.{tp.extract(&right)}) catch return error.InvalidMoveToCharArgument; | ||||
|     _ = ctx.args.match(.{tp.extract(&direction)}) catch return error.InvalidMoveToCharArgument; | ||||
|     const self: *Self = try allocator.create(Self); | ||||
|     self.* = .{ | ||||
|         .allocator = allocator, | ||||
|         .direction = if (right) .right else .left, | ||||
|         .direction = direction, | ||||
|         .operation = if (select) .select else .move, | ||||
|     }; | ||||
|     try self.commands.init(self); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue