5 files changed,
97 insertions(+),
2 deletions(-)
Author:
Smirnov Oleksandr
ss2316544@gmail.com
Committed by:
GitHub
noreply@github.com
Committed at:
2022-06-30 12:00:13 +0300
Parent:
40a2839
M
README.md
@@ -128,6 +128,14 @@ " Run `go generate` for current file
:GoGenerate % ``` +8. Generate doc comment + +First set a cursor on **public** package/function/interface/struct and execure: + +```vim +:GoCmt +``` + ## Thanks - [go.nvim](https://github.com/ray-x/go.nvim)
M
lua/gopher/_utils/ts/init.lua
@@ -4,6 +4,8 @@ local M = {
querys = { struct_block = [[((type_declaration (type_spec name:(type_identifier) @struct.name type: (struct_type)))@struct.declaration)]], em_struct_block = [[(field_declaration name:(field_identifier)@struct.name type: (struct_type)) @struct.declaration]], + package = [[(package_clause (package_identifier)@package.name)@package.clause]], + interface = [[((type_declaration (type_spec name:(type_identifier) @interface.name type:(interface_type)))@interface.declaration)]], 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)]], },@@ -21,7 +23,7 @@ end
---@param row string ---@param col string ----@param bufnr string +---@param bufnr string|nil ---@return table|nil function M.get_struct_node_at_pos(row, col, bufnr) local query = M.querys.struct_block .. " " .. M.querys.em_struct_block@@ -36,7 +38,7 @@ end
---@param row string ---@param col string ----@param bufnr string +---@param bufnr string|nil ---@return table|nil function M.get_func_method_node_at_pos(row, col, bufnr) local query = M.querys.func .. " " .. M.querys.method_name@@ -44,6 +46,39 @@ local bufn = bufnr or vim.api.nvim_get_current_buf()
local ns = nodes.nodes_at_cursor(query, get_name_defaults(), bufn, row, col) if ns == nil then u.notify("function not found", "warn") + else + return ns[#ns] + end +end + +---@param row string +---@param col string +---@param bufnr string|nil +---@return table|nil +function M.get_package_node_at_pos(row, col, bufnr) + -- stylua: ignore + if row > 10 then return end + local query = M.querys.package + local bufn = bufnr or vim.api.nvim_get_current_buf() + local ns = nodes.nodes_at_cursor(query, get_name_defaults(), bufn, row, col) + if ns == nil then + u.notify("package not found", "warn") + return nil + else + return ns[#ns] + end +end + +---@param row string +---@param col string +---@param bufnr string|nil +---@return table|nil +function M.get_interface_node_at_pos(row, col, bufnr) + local query = M.querys.interface + local bufn = bufnr or vim.api.nvim_get_current_buf() + local ns = nodes.nodes_at_cursor(query, get_name_defaults(), bufn, row, col) + if ns == nil then + u.notify("interface not found", "warn") else return ns[#ns] end
A
lua/gopher/comment.lua
@@ -0,0 +1,50 @@
+local ts_utils = require "gopher._utils.ts" + +local function generate(row, col) + local comment, ns = nil, nil + + ns = ts_utils.get_package_node_at_pos(row, col) + if ns ~= nil and ns ~= {} then + comment = "// Package " .. ns.name .. " provides " .. ns.name + return comment, ns + end + + ns = ts_utils.get_struct_node_at_pos(row, col) + if ns ~= nil and ns ~= {} then + comment = "// " .. ns.name .. " " .. ns.type .. " " + return comment, ns + end + + ns = ts_utils.get_func_method_node_at_pos(row, col) + if ns ~= nil and ns ~= {} then + comment = "// " .. ns.name .. " " .. ns.type .. " " + return comment, ns + end + + ns = ts_utils.get_interface_node_at_pos(row, col) + if ns ~= nil and ns ~= {} then + comment = "// " .. ns.name .. " " .. ns.type .. " " + return comment, ns + end + + return "// ", {} +end + +return function() + local row, col = unpack(vim.api.nvim_win_get_cursor(0)) + local comment, ns = generate(row + 1, col + 1) + + vim.api.nvim_win_set_cursor(0, { + ns.dim.s.r, + ns.dim.s.c, + }) + + vim.fn.append(row - 1, comment) + + vim.api.nvim_win_set_cursor(0, { + ns.dim.s.r, + #comment + 1, + }) + + vim.cmd [[startinsert!]] +end
M
lua/gopher/init.lua
@@ -9,6 +9,7 @@ gopher.mod = require "gopher.gomod"
gopher.get = require "gopher.goget" gopher.impl = require "gopher.impl" gopher.generate = require "gopher.gogenerate" +gopher.comment = require "gopher.comment" gopher.test_add = gotests.func_test gopher.test_exported = gotests.all_exported_tests gopher.tests_all = gotests.all_tests
M
plugin/gopher.vim
@@ -7,4 +7,5 @@ command! -nargs=* GoMod :lua require"gopher".mod(<f-args>)
command! -nargs=* GoGet :lua require"gopher".get(<f-args>) command! -nargs=* GoImpl :lua require"gopher".impl(<f-args>) command! -nargs=* GoGenerate :lua require"gopher".generate(<f-args>) +command! GoCmt :lua require"gopher".comment() command! GoInstallDeps :lua require"gopher".install_deps()