feat(comment): add comment on on interface method
This commit is contained in:
parent
26207b1928
commit
3cd45c45a3
9 changed files with 91 additions and 13 deletions
|
|
@ -3,7 +3,7 @@ local log = require "gopher._utils.log"
|
|||
local utils = {}
|
||||
|
||||
---@param msg string
|
||||
---@param lvl? number by default `vim.log.levels.INFO`
|
||||
---@param lvl? integer by default `vim.log.levels.INFO`
|
||||
function utils.notify(msg, lvl)
|
||||
lvl = lvl or vim.log.levels.INFO
|
||||
vim.notify(msg, lvl, {
|
||||
|
|
@ -38,4 +38,13 @@ function utils.trimend(s)
|
|||
return r
|
||||
end
|
||||
|
||||
-- Since indentation can be spaces or tab, that's my hack around it
|
||||
---@param line string
|
||||
---@param indent integer
|
||||
---@return string
|
||||
function utils.indent(line, indent)
|
||||
local char = string.sub(line, 1, 1)
|
||||
return string.rep(char, indent)
|
||||
end
|
||||
|
||||
return utils
|
||||
|
|
|
|||
|
|
@ -13,7 +13,8 @@ local queries = {
|
|||
]],
|
||||
func = [[
|
||||
[(function_declaration name: (identifier) @_name)
|
||||
(method_declaration name: (field_identifier) @_name)]
|
||||
(method_declaration name: (field_identifier) @_name)
|
||||
(method_elem name: (field_identifier) @_name)]
|
||||
]],
|
||||
package = [[
|
||||
(package_identifier) @_name
|
||||
|
|
@ -67,6 +68,7 @@ end
|
|||
---@field name string
|
||||
---@field start integer
|
||||
---@field end_ integer
|
||||
---@field indent integer
|
||||
---@field is_varstruct boolean
|
||||
|
||||
---@param bufnr integer
|
||||
|
|
@ -94,7 +96,8 @@ local function do_stuff(bufnr, parent_type, query)
|
|||
local res = get_captures(q, parent_node, bufnr)
|
||||
assert(res.name ~= nil, "No capture name found")
|
||||
|
||||
local start_row, _, end_row, _ = parent_node:range()
|
||||
local start_row, start_col, end_row, _ = parent_node:range()
|
||||
res["indent"] = start_col
|
||||
res["start"] = start_row + 1
|
||||
res["end_"] = end_row + 1
|
||||
|
||||
|
|
@ -120,7 +123,11 @@ end
|
|||
---@param bufnr integer
|
||||
function ts.get_func_under_cursor(bufnr)
|
||||
--- since this handles both and funcs and methods we should check for both parent nodes
|
||||
return do_stuff(bufnr, { "function_declaration", "method_declaration" }, queries.func)
|
||||
return do_stuff(bufnr, {
|
||||
"method_elem",
|
||||
"function_declaration",
|
||||
"method_declaration",
|
||||
}, queries.func)
|
||||
end
|
||||
|
||||
---@param bufnr integer
|
||||
|
|
|
|||
|
|
@ -7,25 +7,27 @@
|
|||
|
||||
local ts = require "gopher._utils.ts"
|
||||
local log = require "gopher._utils.log"
|
||||
local u = require "gopher._utils"
|
||||
local comment = {}
|
||||
|
||||
---@param bufnr integer
|
||||
---@param line string
|
||||
---@return string
|
||||
---@dochide
|
||||
local function generate(bufnr)
|
||||
local function generate(bufnr, line)
|
||||
local s_ok, s_res = pcall(ts.get_struct_under_cursor, bufnr)
|
||||
if s_ok then
|
||||
return "// " .. s_res.name .. " "
|
||||
return u.indent(line, s_res.indent) .. "// " .. s_res.name .. " "
|
||||
end
|
||||
|
||||
local f_ok, f_res = pcall(ts.get_func_under_cursor, bufnr)
|
||||
if f_ok then
|
||||
return "// " .. f_res.name .. " "
|
||||
return u.indent(line, f_res.indent) .. "// " .. f_res.name .. " "
|
||||
end
|
||||
|
||||
local i_ok, i_res = pcall(ts.get_interface_under_cursor, bufnr)
|
||||
if i_ok then
|
||||
return "// " .. i_res.name .. " "
|
||||
return u.indent(line, i_res.indent) .. "// " .. i_res.name .. " "
|
||||
end
|
||||
|
||||
local p_ok, p_res = pcall(ts.get_package_under_cursor, bufnr)
|
||||
|
|
@ -38,12 +40,16 @@ end
|
|||
|
||||
function comment.comment()
|
||||
local bufnr = vim.api.nvim_get_current_buf()
|
||||
local cmt = generate(bufnr)
|
||||
log.debug("generated comment: " .. cmt)
|
||||
local lnum = vim.fn.getcurpos()[2]
|
||||
local line = vim.fn.getline(lnum)
|
||||
local cmt = generate(bufnr, line)
|
||||
log.debug("generated comment:", {
|
||||
comment = cmt,
|
||||
line = line,
|
||||
})
|
||||
|
||||
local pos = vim.fn.getcurpos()[2]
|
||||
vim.fn.append(pos - 1, cmt)
|
||||
vim.fn.setpos(".", { 0, pos, #cmt })
|
||||
vim.fn.append(lnum - 1, cmt)
|
||||
vim.fn.setpos(".", { bufnr, lnum, #cmt })
|
||||
vim.cmd "startinsert!"
|
||||
end
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue