mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 04:17:01 +00:00 
			
		
		
		
	fix(api): allow negative column arguments for nvim_buf_set_text (#23501)
This commit is contained in:
		| @@ -547,6 +547,7 @@ void nvim_buf_set_text(uint64_t channel_id, Buffer buffer, Integer start_row, In | |||||||
|   // Another call to ml_get_buf() may free the line, so make a copy. |   // Another call to ml_get_buf() may free the line, so make a copy. | ||||||
|   str_at_start = xstrdup(ml_get_buf(buf, (linenr_T)start_row, false)); |   str_at_start = xstrdup(ml_get_buf(buf, (linenr_T)start_row, false)); | ||||||
|   size_t len_at_start = strlen(str_at_start); |   size_t len_at_start = strlen(str_at_start); | ||||||
|  |   start_col = start_col < 0 ? (int64_t)len_at_start + start_col + 1 : start_col; | ||||||
|   VALIDATE_RANGE((start_col >= 0 && (size_t)start_col <= len_at_start), "start_col", { |   VALIDATE_RANGE((start_col >= 0 && (size_t)start_col <= len_at_start), "start_col", { | ||||||
|     goto early_end; |     goto early_end; | ||||||
|   }); |   }); | ||||||
| @@ -554,6 +555,7 @@ void nvim_buf_set_text(uint64_t channel_id, Buffer buffer, Integer start_row, In | |||||||
|   // Another call to ml_get_buf() may free the line, so make a copy. |   // Another call to ml_get_buf() may free the line, so make a copy. | ||||||
|   str_at_end = xstrdup(ml_get_buf(buf, (linenr_T)end_row, false)); |   str_at_end = xstrdup(ml_get_buf(buf, (linenr_T)end_row, false)); | ||||||
|   size_t len_at_end = strlen(str_at_end); |   size_t len_at_end = strlen(str_at_end); | ||||||
|  |   end_col = end_col < 0 ? (int64_t)len_at_end + end_col + 1 : end_col; | ||||||
|   VALIDATE_RANGE((end_col >= 0 && (size_t)end_col <= len_at_end), "end_col", { |   VALIDATE_RANGE((end_col >= 0 && (size_t)end_col <= len_at_end), "end_col", { | ||||||
|     goto early_end; |     goto early_end; | ||||||
|   }); |   }); | ||||||
|   | |||||||
| @@ -437,6 +437,10 @@ describe('api/buf', function() | |||||||
|       -- can append to a line |       -- can append to a line | ||||||
|       set_text(1, 4, -1, 4, {' and', 'more'}) |       set_text(1, 4, -1, 4, {' and', 'more'}) | ||||||
|       eq({'goodbye bar', 'text and', 'more'}, get_lines(0, 3, true)) |       eq({'goodbye bar', 'text and', 'more'}, get_lines(0, 3, true)) | ||||||
|  |  | ||||||
|  |       -- can use negative column numbers | ||||||
|  |       set_text(0, -5, 0, -1, {'!'}) | ||||||
|  |       eq({'goodbye!'}, get_lines(0, 1, true)) | ||||||
|     end) |     end) | ||||||
|  |  | ||||||
|     it('works with undo', function() |     it('works with undo', function() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 notomo
					notomo