Add powershell completions implementation
This commit is contained in:
parent
a573f722af
commit
ba90879ff0
|
@ -19,12 +19,71 @@ var powerShellTpl = template.Must(template.New("PowerShell").Funcs(tplFuncs).Par
|
||||||
{{- $progName := $rootCmd.Name -}}
|
{{- $progName := $rootCmd.Name -}}
|
||||||
{{- $varName := $rootCmd.Name | camel -}}
|
{{- $varName := $rootCmd.Name | camel -}}
|
||||||
|
|
||||||
|
{{- define "cmd" -}}
|
||||||
|
{{- $progName := .ProgName -}}
|
||||||
|
{{- if .Cmd.IsRoot }}
|
||||||
|
{{- /**/}} '{{ $progName }}' {
|
||||||
|
{{- else }}
|
||||||
|
{{- /**/}} '{{ $progName }};{{ join (split .Cmd.CommandPath " ") ";" }}' {
|
||||||
|
{{- end -}}
|
||||||
|
{{- range .Cmd.Opts -}}
|
||||||
|
{{ if ne .Name "" }}
|
||||||
|
[CompletionResult]::new('--{{ .Name }}', '{{ .Name }}', [CompletionResultType]::ParameterName, '{{ .Description }}')
|
||||||
|
{{- end -}}
|
||||||
|
{{- if ne .ShortName "" }}
|
||||||
|
[CompletionResult]::new('-{{ .ShortName }}', '{{ .ShortName }}', [CompletionResultType]::ParameterName, '{{ .Description }}')
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
||||||
|
{{- range .Cmd.Subcommands }}
|
||||||
|
[CompletionResult]::new('{{ .Name }}', '{{ .Name }}', [CompletionResultType]::ParameterValue, '{{ .ShortDescription }}')
|
||||||
|
{{- end }}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
{{- range .Cmd.Subcommands }}
|
||||||
|
{{ template "cmd" (map "Cmd" . "ProgName" $progName) }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
using namespace System.Management.Automation
|
||||||
|
using namespace System.Management.Automation.Language
|
||||||
|
|
||||||
[scriptblock]$__{{ $varName }}CompleterBlock = {
|
[scriptblock]$__{{ $varName }}CompleterBlock = {
|
||||||
param(
|
param(
|
||||||
$WordToComplete,
|
$wordToComplete,
|
||||||
$CommandAst,
|
$commandAst,
|
||||||
$CursorPosition
|
$cursorPosition
|
||||||
)
|
)
|
||||||
|
|
||||||
|
$commandElements
|
||||||
|
$command = @(
|
||||||
|
'{{ $progName }}'
|
||||||
|
for ($i = 1; $i -lt $commandElements.Count; $i++) {
|
||||||
|
$element = $commandElements[$i]
|
||||||
|
if ($element -isnot [StringConstantExpressionAst] -or
|
||||||
|
$element.StringConstantType -ne [StringConstantType]::BareWord -or
|
||||||
|
$element.Value.StartsWith('-') -or
|
||||||
|
$element.Value -eq $wordToComplete) {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
$element.Value
|
||||||
|
}
|
||||||
|
) -join ';'
|
||||||
|
|
||||||
|
$completions = @(
|
||||||
|
switch ($command) {
|
||||||
|
{{ template "cmd" (map "Cmd" $rootCmd "ProgName" $progName) }}
|
||||||
|
}
|
||||||
|
{{- range .GlobalOpts -}}
|
||||||
|
{{- if ne .Name "" }}
|
||||||
|
[CompletionResult]::new('--{{ .Name }}', '{{ .Name }}', [CompletionResultType]::ParameterName, '{{ .Description }}')
|
||||||
|
{{- end -}}
|
||||||
|
{{- if ne .ShortName "" }}
|
||||||
|
[CompletionResult]::new('-{{ .ShortName }}', '{{ .ShortName }}', [CompletionResultType]::ParameterName, '{{ .Description }}')
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
)
|
||||||
|
|
||||||
|
$completions.Where{ $_.CompletionText -like "$wordToComplete*" } |
|
||||||
|
Sort-Object -Property ListItemText
|
||||||
}
|
}
|
||||||
|
|
||||||
Register-ArgumentCompleter -CommandName {{ $progName }} -ScriptBlock $__{{ $varName }}CompleterBlock
|
Register-ArgumentCompleter -CommandName {{ $progName }} -ScriptBlock $__{{ $varName }}CompleterBlock
|
||||||
|
|
|
@ -11,6 +11,7 @@ import (
|
||||||
var tplFuncs = template.FuncMap{
|
var tplFuncs = template.FuncMap{
|
||||||
"map": tplMap,
|
"map": tplMap,
|
||||||
"cat": tplCat,
|
"cat": tplCat,
|
||||||
|
"split": tplSplit,
|
||||||
"join": tplJoin,
|
"join": tplJoin,
|
||||||
"under": tplUnder,
|
"under": tplUnder,
|
||||||
"varPrefix": tplVarPrefix,
|
"varPrefix": tplVarPrefix,
|
||||||
|
@ -41,6 +42,10 @@ func tplCat(strs ...string) string {
|
||||||
return strings.Join(strs, "")
|
return strings.Join(strs, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func tplSplit(s string, sep string) []string {
|
||||||
|
return strings.Split(s, sep)
|
||||||
|
}
|
||||||
|
|
||||||
func tplJoin(strs []string, sep string) string {
|
func tplJoin(strs []string, sep string) string {
|
||||||
return strings.Join(strs, sep)
|
return strings.Join(strs, sep)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue