fix(comment): now it works
This commit is contained in:
parent
0bbe52ed81
commit
ff209db23e
3 changed files with 53 additions and 45 deletions
|
|
@ -8,11 +8,15 @@ local queries = {
|
||||||
[(function_declaration name: (identifier) @_name)
|
[(function_declaration name: (identifier) @_name)
|
||||||
(method_declaration name: (field_identifier) @_name)]
|
(method_declaration name: (field_identifier) @_name)]
|
||||||
]],
|
]],
|
||||||
|
package = [[
|
||||||
-- package = [[(package_clause (package_identifier)@package.name)@package.clause]],
|
((package_clause
|
||||||
-- interface = [[((type_declaration (type_spec name:(type_identifier) @interface.name type:(interface_type)))@interface.declaration)]],
|
(package_identifier)) @_name)
|
||||||
-- method_name = [[((method_declaration receiver: (parameter_list)@method.receiver name: (field_identifier)@method.name body:(block))@method.declaration)]],
|
]],
|
||||||
-- func = [[((function_declaration name: (identifier)@function.name) @function.declaration)]],
|
interface = [[
|
||||||
|
(type_spec
|
||||||
|
name: (type_identifier) @_name
|
||||||
|
type: (interface_type))
|
||||||
|
]],
|
||||||
}
|
}
|
||||||
|
|
||||||
---@param parent_type string|[string]
|
---@param parent_type string|[string]
|
||||||
|
|
@ -102,4 +106,14 @@ function ts.get_func_under_cursor(bufnr)
|
||||||
return do_stuff(bufnr, { "function_declaration", "method_declaration" }, queries.func)
|
return do_stuff(bufnr, { "function_declaration", "method_declaration" }, queries.func)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---@param bufnr integer
|
||||||
|
function ts.get_package_under_cursor(bufnr)
|
||||||
|
return do_stuff(bufnr, "package_clause", queries.package)
|
||||||
|
end
|
||||||
|
|
||||||
|
---@param bufnr integer
|
||||||
|
function ts.get_interface_inder_cursor(bufnr)
|
||||||
|
return do_stuff(bufnr, "type_declaration", queries.interface)
|
||||||
|
end
|
||||||
|
|
||||||
return ts
|
return ts
|
||||||
|
|
|
||||||
|
|
@ -3,57 +3,51 @@
|
||||||
---@usage Execute `:GoCmt` to generate a comment for the current function/method/struct/etc on this line.
|
---@usage Execute `:GoCmt` to generate a comment for the current function/method/struct/etc on this line.
|
||||||
---@text This module provides a way to generate comments for Go code.
|
---@text This module provides a way to generate comments for Go code.
|
||||||
|
|
||||||
|
local ts = require "gopher._utils.ts"
|
||||||
local log = require "gopher._utils.log"
|
local log = require "gopher._utils.log"
|
||||||
|
local comment = {}
|
||||||
|
|
||||||
local function generate(row, col)
|
---@param bufnr integer
|
||||||
local ts_utils = require "gopher._utils.ts"
|
---@return string
|
||||||
local comment, ns = nil, nil
|
local function generate(bufnr)
|
||||||
|
local cmt = "// "
|
||||||
|
|
||||||
ns = ts_utils.get_package_node_at_pos(row, col, nil)
|
local ok, res = pcall(ts.get_struct_under_cursor, bufnr)
|
||||||
if ns ~= nil then
|
if ok then
|
||||||
comment = "// Package " .. ns.name .. " provides " .. ns.name
|
cmt = cmt .. res.name .. " "
|
||||||
return comment, ns
|
return cmt
|
||||||
end
|
end
|
||||||
|
|
||||||
ns = ts_utils.get_struct_under_cursor(row, col, nil)
|
ok, res = pcall(ts.get_func_under_cursor, bufnr)
|
||||||
if ns ~= nil then
|
if ok then
|
||||||
comment = "// " .. ns.name .. " " .. ns.type .. " "
|
cmt = cmt .. res.name .. " "
|
||||||
return comment, ns
|
return cmt
|
||||||
end
|
end
|
||||||
|
|
||||||
ns = ts_utils.get_func_method_node_at_pos(row, col, nil)
|
ok, res = pcall(ts.get_interface_inder_cursor, bufnr)
|
||||||
if ns ~= nil then
|
if ok then
|
||||||
comment = "// " .. ns.name .. " " .. ns.type .. " "
|
cmt = cmt .. res.name .. " "
|
||||||
return comment, ns
|
return cmt
|
||||||
end
|
end
|
||||||
|
|
||||||
ns = ts_utils.get_interface_node_at_pos(row, col, nil)
|
ok, res = pcall(ts.get_package_under_cursor, bufnr)
|
||||||
if ns ~= nil then
|
if ok then
|
||||||
comment = "// " .. ns.name .. " " .. ns.type .. " "
|
cmt = cmt .. "Package " .. res.name .. " provides "
|
||||||
return comment, ns
|
return cmt
|
||||||
end
|
end
|
||||||
|
|
||||||
return "// ", {}
|
return cmt
|
||||||
end
|
end
|
||||||
|
|
||||||
return function()
|
function comment.comment()
|
||||||
local row, col = unpack(vim.api.nvim_win_get_cursor(0))
|
local bufnr = vim.api.nvim_get_current_buf()
|
||||||
local comment, ns = generate(row + 1, col + 1)
|
local cmt = generate(bufnr)
|
||||||
|
log.debug("generated comment: " .. cmt)
|
||||||
|
|
||||||
log.debug("generated comment: " .. comment)
|
local pos = vim.fn.getcurpos()[2]
|
||||||
|
vim.fn.append(pos - 1, cmt)
|
||||||
vim.api.nvim_win_set_cursor(0, {
|
vim.fn.setpos(".", { 0, pos, #cmt })
|
||||||
ns.dim.s.r,
|
vim.cmd "startinsert!"
|
||||||
ns.dim.s.c,
|
|
||||||
})
|
|
||||||
|
|
||||||
---@diagnostic disable-next-line: param-type-mismatch
|
|
||||||
vim.fn.append(row - 1, comment)
|
|
||||||
|
|
||||||
vim.api.nvim_win_set_cursor(0, {
|
|
||||||
ns.dim.s.r,
|
|
||||||
#comment + 1,
|
|
||||||
})
|
|
||||||
|
|
||||||
vim.cmd [[startinsert!]]
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return comment
|
||||||
|
|
|
||||||
|
|
@ -38,7 +38,7 @@ gopher.install_deps = require("gopher.installer").install_deps
|
||||||
|
|
||||||
gopher.impl = require("gopher.impl").impl
|
gopher.impl = require("gopher.impl").impl
|
||||||
gopher.iferr = require("gopher.iferr").iferr
|
gopher.iferr = require("gopher.iferr").iferr
|
||||||
gopher.comment = require "gopher.comment"
|
gopher.comment = require("gopher.comment").comment
|
||||||
|
|
||||||
gopher.tags = {
|
gopher.tags = {
|
||||||
add = tags.add,
|
add = tags.add,
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue