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 = {}
|
local utils = {}
|
||||||
|
|
||||||
---@param msg string
|
---@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)
|
function utils.notify(msg, lvl)
|
||||||
lvl = lvl or vim.log.levels.INFO
|
lvl = lvl or vim.log.levels.INFO
|
||||||
vim.notify(msg, lvl, {
|
vim.notify(msg, lvl, {
|
||||||
|
|
@ -38,4 +38,13 @@ function utils.trimend(s)
|
||||||
return r
|
return r
|
||||||
end
|
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
|
return utils
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,8 @@ local queries = {
|
||||||
]],
|
]],
|
||||||
func = [[
|
func = [[
|
||||||
[(function_declaration name: (identifier) @_name)
|
[(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 = [[
|
||||||
(package_identifier) @_name
|
(package_identifier) @_name
|
||||||
|
|
@ -67,6 +68,7 @@ end
|
||||||
---@field name string
|
---@field name string
|
||||||
---@field start integer
|
---@field start integer
|
||||||
---@field end_ integer
|
---@field end_ integer
|
||||||
|
---@field indent integer
|
||||||
---@field is_varstruct boolean
|
---@field is_varstruct boolean
|
||||||
|
|
||||||
---@param bufnr integer
|
---@param bufnr integer
|
||||||
|
|
@ -94,7 +96,8 @@ local function do_stuff(bufnr, parent_type, query)
|
||||||
local res = get_captures(q, parent_node, bufnr)
|
local res = get_captures(q, parent_node, bufnr)
|
||||||
assert(res.name ~= nil, "No capture name found")
|
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["start"] = start_row + 1
|
||||||
res["end_"] = end_row + 1
|
res["end_"] = end_row + 1
|
||||||
|
|
||||||
|
|
@ -120,7 +123,11 @@ end
|
||||||
---@param bufnr integer
|
---@param bufnr integer
|
||||||
function ts.get_func_under_cursor(bufnr)
|
function ts.get_func_under_cursor(bufnr)
|
||||||
--- since this handles both and funcs and methods we should check for both parent nodes
|
--- 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
|
end
|
||||||
|
|
||||||
---@param bufnr integer
|
---@param bufnr integer
|
||||||
|
|
|
||||||
|
|
@ -7,25 +7,27 @@
|
||||||
|
|
||||||
local ts = require "gopher._utils.ts"
|
local ts = require "gopher._utils.ts"
|
||||||
local log = require "gopher._utils.log"
|
local log = require "gopher._utils.log"
|
||||||
|
local u = require "gopher._utils"
|
||||||
local comment = {}
|
local comment = {}
|
||||||
|
|
||||||
---@param bufnr integer
|
---@param bufnr integer
|
||||||
|
---@param line string
|
||||||
---@return string
|
---@return string
|
||||||
---@dochide
|
---@dochide
|
||||||
local function generate(bufnr)
|
local function generate(bufnr, line)
|
||||||
local s_ok, s_res = pcall(ts.get_struct_under_cursor, bufnr)
|
local s_ok, s_res = pcall(ts.get_struct_under_cursor, bufnr)
|
||||||
if s_ok then
|
if s_ok then
|
||||||
return "// " .. s_res.name .. " "
|
return u.indent(line, s_res.indent) .. "// " .. s_res.name .. " "
|
||||||
end
|
end
|
||||||
|
|
||||||
local f_ok, f_res = pcall(ts.get_func_under_cursor, bufnr)
|
local f_ok, f_res = pcall(ts.get_func_under_cursor, bufnr)
|
||||||
if f_ok then
|
if f_ok then
|
||||||
return "// " .. f_res.name .. " "
|
return u.indent(line, f_res.indent) .. "// " .. f_res.name .. " "
|
||||||
end
|
end
|
||||||
|
|
||||||
local i_ok, i_res = pcall(ts.get_interface_under_cursor, bufnr)
|
local i_ok, i_res = pcall(ts.get_interface_under_cursor, bufnr)
|
||||||
if i_ok then
|
if i_ok then
|
||||||
return "// " .. i_res.name .. " "
|
return u.indent(line, i_res.indent) .. "// " .. i_res.name .. " "
|
||||||
end
|
end
|
||||||
|
|
||||||
local p_ok, p_res = pcall(ts.get_package_under_cursor, bufnr)
|
local p_ok, p_res = pcall(ts.get_package_under_cursor, bufnr)
|
||||||
|
|
@ -38,12 +40,16 @@ end
|
||||||
|
|
||||||
function comment.comment()
|
function comment.comment()
|
||||||
local bufnr = vim.api.nvim_get_current_buf()
|
local bufnr = vim.api.nvim_get_current_buf()
|
||||||
local cmt = generate(bufnr)
|
local lnum = vim.fn.getcurpos()[2]
|
||||||
log.debug("generated comment: " .. cmt)
|
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(lnum - 1, cmt)
|
||||||
vim.fn.append(pos - 1, cmt)
|
vim.fn.setpos(".", { bufnr, lnum, #cmt })
|
||||||
vim.fn.setpos(".", { 0, pos, #cmt })
|
|
||||||
vim.cmd "startinsert!"
|
vim.cmd "startinsert!"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
||||||
6
spec/fixtures/comment/interface_many_method_input.go
vendored
Normal file
6
spec/fixtures/comment/interface_many_method_input.go
vendored
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
type Testinger interface {
|
||||||
|
Get(id string) int
|
||||||
|
Set(id string, val int)
|
||||||
|
}
|
||||||
7
spec/fixtures/comment/interface_many_method_output.go
vendored
Normal file
7
spec/fixtures/comment/interface_many_method_output.go
vendored
Normal file
|
|
@ -0,0 +1,7 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
type Testinger interface {
|
||||||
|
Get(id string) int
|
||||||
|
// Set
|
||||||
|
Set(id string, val int)
|
||||||
|
}
|
||||||
5
spec/fixtures/comment/interface_method_input.go
vendored
Normal file
5
spec/fixtures/comment/interface_method_input.go
vendored
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
type Testinger interface {
|
||||||
|
Method(input string) error
|
||||||
|
}
|
||||||
6
spec/fixtures/comment/interface_method_output.go
vendored
Normal file
6
spec/fixtures/comment/interface_method_output.go
vendored
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
type Testinger interface {
|
||||||
|
// Method
|
||||||
|
Method(input string) error
|
||||||
|
}
|
||||||
|
|
@ -30,6 +30,14 @@ comment["should add comment to interface"] = function()
|
||||||
do_the_test("interface", { 3, 6 })
|
do_the_test("interface", { 3, 6 })
|
||||||
end
|
end
|
||||||
|
|
||||||
|
comment["should add comment on interface method"] = function()
|
||||||
|
do_the_test("interface_method", { 4, 2 })
|
||||||
|
end
|
||||||
|
|
||||||
|
comment["should add a comment on interface with many method"] = function()
|
||||||
|
do_the_test("interface_many_method", { 5, 2 })
|
||||||
|
end
|
||||||
|
|
||||||
comment["otherwise should add // above cursor"] = function()
|
comment["otherwise should add // above cursor"] = function()
|
||||||
do_the_test("empty", { 1, 1 })
|
do_the_test("empty", { 1, 1 })
|
||||||
end
|
end
|
||||||
|
|
|
||||||
|
|
@ -22,4 +22,28 @@ utils["should .trimend()"] = function()
|
||||||
t.eq(u.trimend " hi ", " hi")
|
t.eq(u.trimend " hi ", " hi")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
utils["should add .indent() spaces"] = function()
|
||||||
|
local u = require "gopher._utils"
|
||||||
|
local line = " func Test() error {"
|
||||||
|
local indent = 4
|
||||||
|
|
||||||
|
t.eq(" ", u.indent(line, indent))
|
||||||
|
end
|
||||||
|
|
||||||
|
utils["should add .indent() a tab"] = function()
|
||||||
|
local u = require "gopher._utils"
|
||||||
|
local line = "\tfunc Test() error {"
|
||||||
|
local indent = 1
|
||||||
|
|
||||||
|
t.eq("\t", u.indent(line, indent))
|
||||||
|
end
|
||||||
|
|
||||||
|
utils["should add .indent() 2 tabs"] = function()
|
||||||
|
local u = require "gopher._utils"
|
||||||
|
local line = "\t\tfunc Test() error {"
|
||||||
|
local indent = 2
|
||||||
|
|
||||||
|
t.eq("\t\t", u.indent(line, indent))
|
||||||
|
end
|
||||||
|
|
||||||
return T
|
return T
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue