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