all repos

gopher.nvim @ 7ebe190

Minimalistic plugin for Go development
6 files changed, 101 insertions(+), 103 deletions(-)
refactor/comamnds dont require .setup (#101)

* refactor(commands)!: change the way of disabling commands

BREAKING CHANGE: not it does not require calling .setup()

* docs: update docs
Author: Smirnov Oleksandr ss2316544@gmail.com
Committed by: Oleksandr Smirnov olexsmir@gmail.com
Committed at: 2025-03-22 21:19:59 +0200
Parent: ab68a58
M doc/gopher.nvim.txt

@@ -11,6 +11,7 @@ Table of Contents

Setup....................................................|gopher.nvim-setup| Install dependencies..............................|gopher.nvim-install-deps| Configuration...........................................|gopher.nvim-config| + Commands..............................................|gopher.nvim-commands| Modify struct tags.................................|gopher.nvim-struct-tags| Auto implementation of interface methods..................|gopher.nvim-impl| Generating unit tests boilerplate......................|gopher.nvim-gotests|

@@ -36,7 +37,8 @@ `gopher.install_deps`

Gopher.nvim implements most of its features using third-party tools. To install these tools, you can run `:GoInstallDeps` command or call `require("gopher").install_deps()` if you want to use lua api. -By default dependencies will be installed asynchronously, to install them synchronously pass `{sync = true}` as an argument. +By default dependencies will be installed asynchronously, +to install them synchronously pass `{sync = true}` as an argument. ==============================================================================

@@ -60,10 +62,6 @@

-- timeout for running internal commands ---@type number timeout = 2000, - - --- whether to setup plugin commands or not - ---@type boolean - setup_commands = true, -- user specified paths to binaries ---@class gopher.ConfigCommand

@@ -101,6 +99,14 @@ }

< Class ~ {gopher.Config} + + +============================================================================== +------------------------------------------------------------------------------ + *gopher.nvim-commands* + +If don't want to automatically register plugins' commands, +you can set `vim.g.gopher_register_commands` to `false`, before loading the plugin. ==============================================================================
D

@@ -1,82 +0,0 @@

-local commands = {} - ----@param name string ----@param fn fun(args: table) ----@param nargs? number|"*"|"?" -local function cmd(name, fn, nargs) - nargs = nargs or 0 - vim.api.nvim_create_user_command(name, fn, { nargs = nargs }) -end - -function commands.register() - cmd("GopherLog", function() - vim.cmd("tabnew " .. require("gopher._utils.log").get_outfile()) - end) - - cmd("GoIfErr", function() - require("gopher").iferr() - end) - - cmd("GoCmt", function() - require("gopher").comment() - end) - - cmd("GoImpl", function(args) - require("gopher").impl(unpack(args.fargs)) - end, "*") - - -- :GoInstall - cmd("GoInstallDeps", function() - require("gopher").install_deps() - end) - - cmd("GoInstallDepsSync", function() - require("gopher").install_deps { sync = true } - end) - - --- :GoTag - cmd("GoTagAdd", function(opts) - require("gopher").tags.add(unpack(opts.fargs)) - end, "*") - - cmd("GoTagRm", function(opts) - require("gopher").tags.rm(unpack(opts.fargs)) - end, "*") - - cmd("GoTagClear", function() - require("gopher").tags.clear() - end) - - --- :GoTest - cmd("GoTestAdd", function() - require("gopher").test.add() - end) - - cmd("GoTestsAll", function() - require("gopher").test.all() - end) - - cmd("GoTestsExp", function() - require("gopher").test.exported() - end) - - -- :Go - cmd("GoMod", function(opts) - require("gopher").mod(opts.fargs) - end, "*") - - cmd("GoGet", function(opts) - vim.print(opts) - require("gopher").get(opts.fargs) - end, "*") - - cmd("GoWork", function(opts) - require("gopher").get(opts.fargs) - end, "*") - - cmd("GoGenerate", function(opts) - require("gopher").generate(opts.fargs or "") - end, "?") -end - -return commands
M lua/gopher/config.lua

@@ -37,10 +37,6 @@ -- timeout for running internal commands

---@type number timeout = 2000, - --- whether to setup plugin commands or not - ---@type boolean - setup_commands = true, - -- user specified paths to binaries ---@class gopher.ConfigCommand commands = {

@@ -97,7 +93,6 @@

vim.validate { log_level = { _config.log_level, "number" }, timeout = { _config.timeout, "number" }, - setup_commands = { _config.setup_commands, "boolean" }, ["commands"] = { _config.commands, "table" }, ["commands.go"] = { _config.commands.go, "string" }, ["commands.gomodifytags"] = { _config.commands.gomodifytags, "string" },

@@ -114,16 +109,6 @@ ["gotag.default_tag"] = { _config.gotag.default_tag, "string" },

["iferr"] = { _config.iferr, "table" }, ["iferr.message"] = { _config.iferr.message, "string", true }, } - - if _config.setup_commands then - require("gopher.commands").register() - end -end - ----@return boolean ----@private -function config.should_setup_commands() - return config.setup_commands end setmetatable(config, {
M lua/gopher/init.lua

@@ -35,7 +35,8 @@ ---@tag gopher.nvim-install-deps

---@text Gopher.nvim implements most of its features using third-party tools. --- To install these tools, you can run `:GoInstallDeps` command --- or call `require("gopher").install_deps()` if you want to use lua api. ---- By default dependencies will be installed asynchronously, to install them synchronously pass `{sync = true}` as an argument. +--- By default dependencies will be installed asynchronously, +--- to install them synchronously pass `{sync = true}` as an argument. gopher.install_deps = require("gopher.installer").install_deps gopher.impl = require("gopher.impl").impl
A plugin/gopher.lua

@@ -0,0 +1,87 @@

+---@toc_entry Commands +---@tag gopher.nvim-commands +---@text +--- If don't want to automatically register plugins' commands, +--- you can set `vim.g.gopher_register_commands` to `false`, before loading the plugin. + +if vim.g.gopher_register_commands == false then + return +end + +---@param name string +---@param fn fun(args: table) +---@param nargs? number|"*"|"?" +---@private +local function cmd(name, fn, nargs) + nargs = nargs or 0 + vim.api.nvim_create_user_command(name, fn, { nargs = nargs }) +end + +cmd("GopherLog", function() + vim.cmd("tabnew " .. require("gopher._utils.log").get_outfile()) +end) + +cmd("GoIfErr", function() + require("gopher").iferr() +end) + +cmd("GoCmt", function() + require("gopher").comment() +end) + +cmd("GoImpl", function(args) + require("gopher").impl(unpack(args.fargs)) +end, "*") + +-- :GoInstall +cmd("GoInstallDeps", function() + require("gopher").install_deps() +end) + +cmd("GoInstallDepsSync", function() + require("gopher").install_deps { sync = true } +end) + +-- :GoTag +cmd("GoTagAdd", function(opts) + require("gopher").tags.add(unpack(opts.fargs)) +end, "*") + +cmd("GoTagRm", function(opts) + require("gopher").tags.rm(unpack(opts.fargs)) +end, "*") + +cmd("GoTagClear", function() + require("gopher").tags.clear() +end) + +-- :GoTest +cmd("GoTestAdd", function() + require("gopher").test.add() +end) + +cmd("GoTestsAll", function() + require("gopher").test.all() +end) + +cmd("GoTestsExp", function() + require("gopher").test.exported() +end) + +-- :Go +cmd("GoMod", function(opts) + require("gopher").mod(opts.fargs) +end, "*") + +cmd("GoGet", function(opts) + vim.print(opts) + require("gopher").get(opts.fargs) +end, "*") + +cmd("GoWork", function(opts) + require("gopher").get(opts.fargs) +end, "*") + +cmd("GoGenerate", function(opts) + require("gopher").generate(opts.fargs or "") +end, "?")
M scripts/docgen.lua

@@ -10,6 +10,7 @@

local files = { "lua/gopher/init.lua", "lua/gopher/config.lua", + "plugin/gopher.lua", "lua/gopher/struct_tags.lua", "lua/gopher/impl.lua", "lua/gopher/gotests.lua",