refactor: llm tool parameters (#2449)
This commit is contained in:
@@ -55,19 +55,24 @@ M.returns = {
|
||||
}
|
||||
|
||||
---@type AvanteLLMToolFunc<{ path: string, insert_line: integer, new_str: string }>
|
||||
function M.func(opts, on_log, on_complete, session_ctx)
|
||||
if on_log then on_log("path: " .. opts.path) end
|
||||
local abs_path = Helpers.get_abs_path(opts.path)
|
||||
function M.func(input, opts)
|
||||
local on_log = opts.on_log
|
||||
local on_complete = opts.on_complete
|
||||
local session_ctx = opts.session_ctx
|
||||
if not on_complete then return false, "on_complete not provided" end
|
||||
|
||||
if on_log then on_log("path: " .. input.path) end
|
||||
local abs_path = Helpers.get_abs_path(input.path)
|
||||
if not Helpers.has_permission_to_access(abs_path) then return false, "No permission to access path: " .. abs_path end
|
||||
if not Path:new(abs_path):exists() then return false, "File not found: " .. abs_path end
|
||||
if not Path:new(abs_path):is_file() then return false, "Path is not a file: " .. abs_path end
|
||||
if opts.insert_line == nil then return false, "insert_line not provided" end
|
||||
if opts.new_str == nil then return false, "new_str not provided" end
|
||||
if input.insert_line == nil then return false, "insert_line not provided" end
|
||||
if input.new_str == nil then return false, "new_str not provided" end
|
||||
local ns_id = vim.api.nvim_create_namespace("avante_insert_diff")
|
||||
local bufnr, err = Helpers.get_bufnr(abs_path)
|
||||
if err then return false, err end
|
||||
local function clear_highlights() vim.api.nvim_buf_clear_namespace(bufnr, ns_id, 0, -1) end
|
||||
local new_lines = vim.split(opts.new_str, "\n")
|
||||
local new_lines = vim.split(input.new_str, "\n")
|
||||
local max_col = vim.o.columns
|
||||
local virt_lines = vim
|
||||
.iter(new_lines)
|
||||
@@ -78,8 +83,8 @@ function M.func(opts, on_log, on_complete, session_ctx)
|
||||
end)
|
||||
:totable()
|
||||
local line_count = vim.api.nvim_buf_line_count(bufnr)
|
||||
if opts.insert_line > line_count - 1 then opts.insert_line = line_count - 1 end
|
||||
vim.api.nvim_buf_set_extmark(bufnr, ns_id, opts.insert_line, 0, {
|
||||
if input.insert_line > line_count - 1 then input.insert_line = line_count - 1 end
|
||||
vim.api.nvim_buf_set_extmark(bufnr, ns_id, input.insert_line, 0, {
|
||||
virt_lines = virt_lines,
|
||||
hl_eol = true,
|
||||
hl_mode = "combine",
|
||||
@@ -90,9 +95,9 @@ function M.func(opts, on_log, on_complete, session_ctx)
|
||||
on_complete(false, "User declined, reason: " .. (reason or "unknown"))
|
||||
return
|
||||
end
|
||||
vim.api.nvim_buf_set_lines(bufnr, opts.insert_line, opts.insert_line, false, new_lines)
|
||||
vim.api.nvim_buf_set_lines(bufnr, input.insert_line, input.insert_line, false, new_lines)
|
||||
vim.api.nvim_buf_call(bufnr, function() vim.cmd("noautocmd write") end)
|
||||
if session_ctx then Helpers.mark_as_not_viewed(opts.path, session_ctx) end
|
||||
if session_ctx then Helpers.mark_as_not_viewed(input.path, session_ctx) end
|
||||
on_complete(true, nil)
|
||||
end, { focus = true }, session_ctx, M.name)
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user