如何使用碰杯luaapi?
How to use the Clink lua api?
据我所知,Clink (http://mridgers.github.io/clink/) 没有提供任何关于如何使用它提到的 lua API 的文档。
我查看了安装目录中 clink.lua 文件的内容,我可以大致了解它是如何工作的,但我想知道如何编写自己的 lua文件以添加新的参数自动完成(我不想直接编辑 clink.lua 因为存在破坏现有功能的风险)并让 Clink 检测并使用我的文件。
过去有人玩过这个吗?
我相信many people have the same question。
我找到的最全面的手册是this document,它在git,但不在master。写的很好,内容也很丰富。
简要总结:
文件位置
在clinkv0.4.6中,安装有一个profile/
目录。将 lua 完成文件放入该目录后,它们会在启动新进程或使用 Ctl-Q 刷新时被拾取。
该文档讨论了 c:\Documents and Settings\<username>\Local Settings\Application Data
(对于 XP)和 c:\Users\<username>\AppData\Local
(Vista 及更高版本)。我用 clink-1.0.0a1.823d84 试过了,但还没有(还)能够让它工作。
语法
这是命令 foobar 的简单解析器示例;
my_parser = clink.arg.new_parser()
my_parser:set_flags("-foo", "-bar")
my_parser:set_arguments(
{ "hello", "hi" }, -- first position
{ "world", "wombles" } -- second position
)
clink.arg.register_parser("foobar", my_parser)
在第一个位置(在foobar
之后)clink会建议hello
或hi
。
之后,在第二个位置(foobar hello
或foobar hi
之后),clink会提示world
或wombles
。
标志与位置无关。
除了调用 set_flags
和 set_arguments
,您还可以使用这种紧凑的语法:
some_parser = clink.arg.new_parser(
{ "arg1-1", "arg1-2" },
{ "arg2-1", "arg2-2" },
"-flag1", "-flag2"
)
高级语法
解析器可以嵌套,这对于采用有限数量有效值的标志很有用。
Clink 允许您使用 Lua 的 ..
连接运算符 link 解析器。例如:
local parser = clink.arg.new_parser
local my_parser = parser(
"-s" .. parser({"ruby", "webpi", "cygwin", "windowsfeatures", "python"}),
"--source" .. parser({"ruby", "webpi", "cygwin", "windowsfeatures", "python"}),
"--version",
clink.arg.register_parser("mycommand", my_parser)
这也可用于实现 "command suites"(带有子命令的命令)的完成。例如:
local parser = clink.arg.new_parser
local git_parser = parser(
{
"add" .. parser({}, -- empty {}: don't suggest any positional args
"-n", "--dry-run",
"-v", "--verbose",
"-f", "--force",
"-i", "--interactive",
"-A", "--all",
"--refresh"
),
"commit" .. parser(
"-a", "--all",
"-m", "--message=",
"-e", "--edit",
"--amend",
"-u", "--untracked-files", "--untracked-files=", -- .. parser({"no", "normal", "all"}),
"-v", "--verbose",
"-q", "--quiet",
"--"
),
"remote"..parser({
"add" ..parser(
"-t"..parser({branches}), -- defined elsewhere
"-m",
"-f",
"--mirror",
"--tags", "--no-tags"
),
"rename"..parser({remotes}),
"remove"..parser({remotes}),
"rm"..parser({remotes}),
"set-head"..parser({remotes}, {branches},
"-a", "--auto",
"-d", "--delete"
),
"set-branches"..parser("--add", {remotes}, {branches}),
"set-url"..parser(
"--add"..parser("--push", {remotes}),
"--delete"..parser("--push", {remotes})
),
"get-url"..parser({remotes}, "--push", "--all"),
"show"..parser("-n", {remotes}),
"prune"..parser("-n", "--dry-run", {remotes}),
"update"..parser({remotes}, "-p", "--prune")
}, "-v", "--verbose"),
},
"--version",
"--help",
"-c",
"--git-dir",
)
clink.arg.register_parser("git", git_parser)
这是 Vladimir Kotikov 的 git.lua 完成脚本的缩略版。有关完整来源,请参阅原文。
预建 CLink 完成
Vladimir Kotikov 创建了一个非常好的 clink-completion scripts for many common commands. He also pointed out 我之前提到的隐藏 clink 手册集。别忘了给他的 GitHub 项目打个星标! :-)
据我所知,Clink (http://mridgers.github.io/clink/) 没有提供任何关于如何使用它提到的 lua API 的文档。
我查看了安装目录中 clink.lua 文件的内容,我可以大致了解它是如何工作的,但我想知道如何编写自己的 lua文件以添加新的参数自动完成(我不想直接编辑 clink.lua 因为存在破坏现有功能的风险)并让 Clink 检测并使用我的文件。
过去有人玩过这个吗?
我相信many people have the same question。
我找到的最全面的手册是this document,它在git,但不在master。写的很好,内容也很丰富。
简要总结:
文件位置
在clinkv0.4.6中,安装有一个profile/
目录。将 lua 完成文件放入该目录后,它们会在启动新进程或使用 Ctl-Q 刷新时被拾取。
该文档讨论了 c:\Documents and Settings\<username>\Local Settings\Application Data
(对于 XP)和 c:\Users\<username>\AppData\Local
(Vista 及更高版本)。我用 clink-1.0.0a1.823d84 试过了,但还没有(还)能够让它工作。
语法
这是命令 foobar 的简单解析器示例;
my_parser = clink.arg.new_parser()
my_parser:set_flags("-foo", "-bar")
my_parser:set_arguments(
{ "hello", "hi" }, -- first position
{ "world", "wombles" } -- second position
)
clink.arg.register_parser("foobar", my_parser)
在第一个位置(在foobar
之后)clink会建议hello
或hi
。
之后,在第二个位置(foobar hello
或foobar hi
之后),clink会提示world
或wombles
。
标志与位置无关。
除了调用 set_flags
和 set_arguments
,您还可以使用这种紧凑的语法:
some_parser = clink.arg.new_parser(
{ "arg1-1", "arg1-2" },
{ "arg2-1", "arg2-2" },
"-flag1", "-flag2"
)
高级语法
解析器可以嵌套,这对于采用有限数量有效值的标志很有用。
Clink 允许您使用 Lua 的 ..
连接运算符 link 解析器。例如:
local parser = clink.arg.new_parser
local my_parser = parser(
"-s" .. parser({"ruby", "webpi", "cygwin", "windowsfeatures", "python"}),
"--source" .. parser({"ruby", "webpi", "cygwin", "windowsfeatures", "python"}),
"--version",
clink.arg.register_parser("mycommand", my_parser)
这也可用于实现 "command suites"(带有子命令的命令)的完成。例如:
local parser = clink.arg.new_parser
local git_parser = parser(
{
"add" .. parser({}, -- empty {}: don't suggest any positional args
"-n", "--dry-run",
"-v", "--verbose",
"-f", "--force",
"-i", "--interactive",
"-A", "--all",
"--refresh"
),
"commit" .. parser(
"-a", "--all",
"-m", "--message=",
"-e", "--edit",
"--amend",
"-u", "--untracked-files", "--untracked-files=", -- .. parser({"no", "normal", "all"}),
"-v", "--verbose",
"-q", "--quiet",
"--"
),
"remote"..parser({
"add" ..parser(
"-t"..parser({branches}), -- defined elsewhere
"-m",
"-f",
"--mirror",
"--tags", "--no-tags"
),
"rename"..parser({remotes}),
"remove"..parser({remotes}),
"rm"..parser({remotes}),
"set-head"..parser({remotes}, {branches},
"-a", "--auto",
"-d", "--delete"
),
"set-branches"..parser("--add", {remotes}, {branches}),
"set-url"..parser(
"--add"..parser("--push", {remotes}),
"--delete"..parser("--push", {remotes})
),
"get-url"..parser({remotes}, "--push", "--all"),
"show"..parser("-n", {remotes}),
"prune"..parser("-n", "--dry-run", {remotes}),
"update"..parser({remotes}, "-p", "--prune")
}, "-v", "--verbose"),
},
"--version",
"--help",
"-c",
"--git-dir",
)
clink.arg.register_parser("git", git_parser)
这是 Vladimir Kotikov 的 git.lua 完成脚本的缩略版。有关完整来源,请参阅原文。
预建 CLink 完成
Vladimir Kotikov 创建了一个非常好的 clink-completion scripts for many common commands. He also pointed out 我之前提到的隐藏 clink 手册集。别忘了给他的 GitHub 项目打个星标! :-)