Added DockerCompose completion + fixes
This commit is contained in:
parent
b5b5702b17
commit
d441492cf0
|
@ -35,14 +35,10 @@ process {
|
|||
}
|
||||
$p = $p -replace '#C-A#','*' -replace '#C-Q#','?' -replace '#C-#','#C-'
|
||||
|
||||
if( $Expand ) {
|
||||
$p = $p | ForEach-Object {
|
||||
if( Test-Path $p ) {
|
||||
$p | Get-Item -Force | Select-Object -ExpandProperty FullName
|
||||
} elseif( -not $Expand ) {
|
||||
$p
|
||||
}
|
||||
}
|
||||
if( $p -match '\*|\?' -and $Expand ) {
|
||||
$p = $p | Where-Object { Test-Path $_ } |
|
||||
Get-Item -Force |
|
||||
Select-Object -ExpandProperty FullName
|
||||
}
|
||||
|
||||
$p
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
env ls $args
|
|
@ -0,0 +1 @@
|
|||
Get-ChildItem -Force $args
|
|
@ -1,36 +0,0 @@
|
|||
class DockerContainer { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
docker ps -a --no-trunc --format "{{.Names}}"
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerContainer]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
class DockerComposeDirs { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[string]$Path,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
Get-ChildItem -LiteralPath $Path -Directory -Depth 3 |
|
||||
Where-Object { $_ |
|
||||
Get-ChildItem -Include 'docker-compose.y*l' |
|
||||
Where-Object Extension -in '.yml','.yaml'
|
||||
} | ForEach-Object {
|
||||
$_.FullName.Replace($(Join-Path $PWD ""),'')
|
||||
}
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
return [DockerComposeDirs]::_GetValidValues($wordToComplete,'.',$true)
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerComposeDirs]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,6 @@
|
|||
function cd-{cd -}
|
||||
function cd..{cd ..}
|
||||
function cd...{cd ../..}
|
||||
|
||||
Set-Alias '..' 'cd..'
|
||||
Set-Alias '...' 'cd...'
|
|
@ -0,0 +1 @@
|
|||
Copy-Item
|
|
@ -0,0 +1 @@
|
|||
Move-Item
|
|
@ -0,0 +1 @@
|
|||
Remove-Item
|
|
@ -1,13 +1,5 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[switch]$Force,
|
||||
[string[]]$AdditionalFiles
|
||||
|
|
|
@ -1,19 +1,12 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath,
|
||||
[switch]$Recurse,
|
||||
[int]$Depth=1,
|
||||
[switch]$Force,
|
||||
[switch]$OneLine,
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true, mandatory)]
|
||||
[Parameter(Position = 0, mandatory, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList $args})]
|
||||
[array]$CliParams
|
||||
)
|
||||
|
||||
|
@ -110,7 +103,7 @@ foreach( $local:p in $CliParams ) {
|
|||
}
|
||||
|
||||
$local:dcParams=@()
|
||||
$local:dcParams = $p | Where-Object { $_ } | ForEach-Object {
|
||||
$local:dcParams += $p | Where-Object { $_ } | ForEach-Object {
|
||||
if( $_ -match "(?:^'[^']+'$)|(?:^`"[^`"]+`"$)|(?:^[^\s]+$)" ) { $_ }
|
||||
else { "'$($_.Replace( "'", "''" ))'" }
|
||||
}
|
||||
|
|
|
@ -1,13 +1,5 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[switch]$TestOnly
|
||||
)
|
||||
|
|
|
@ -1,22 +1,15 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath,
|
||||
[switch]$Recurse,
|
||||
[int]$Depth=1,
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('down'))})]
|
||||
[array]$CliParams=@('--timeout=3','--volumes','--remove-orphans')
|
||||
)
|
||||
|
||||
if( -not $CliParams -or $CliParams[0] -is [string] ) { $CliParams = @($CliParams,@($null)) }
|
||||
$CliParams[0] = @('&','down') + $CliParams[0]
|
||||
$CliParams[0] = @('&') + $CliParams[0]
|
||||
|
||||
Invoke-DockerCompose -ProjectPath $ProjectPath -CliParams $CliParams -Recurse:$Recurse -Depth $Depth
|
||||
Invoke-DockerCompose -ProjectPath $ProjectPath -dcCommand 'down' -CliParams $CliParams -Recurse:$Recurse -Depth $Depth
|
||||
|
||||
|
|
|
@ -1,15 +1,8 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@("logs"))})]
|
||||
[array]$CliParams
|
||||
)
|
||||
|
||||
|
|
|
@ -1,15 +1,8 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('logs'))})]
|
||||
[array]$CliParams
|
||||
)
|
||||
|
||||
|
|
|
@ -1,15 +1,8 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('run'))})]
|
||||
[array]$CliParams=@('--rm')
|
||||
)
|
||||
|
||||
|
|
|
@ -1,15 +1,8 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('restart'))})]
|
||||
[array]$CliParams
|
||||
)
|
||||
|
||||
|
|
|
@ -1,22 +1,18 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath,
|
||||
[switch]$Recurse,
|
||||
[int]$Depth=1,
|
||||
[switch]$NoLogs,
|
||||
[switch]$NoPull,
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('pull'))})]
|
||||
[array]$PullParams,
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('logs'))})]
|
||||
[array]$LogsParams,
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('up'))})]
|
||||
[array]$UpParams=@('-d','--remove-orphans'),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('up'))})]
|
||||
[array]$Containers
|
||||
)
|
||||
|
||||
|
|
|
@ -1,22 +1,18 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath,
|
||||
[switch]$Recurse,
|
||||
[int]$Depth=1,
|
||||
[switch]$NoLogs,
|
||||
[switch]$NoPull,
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('pull'))})]
|
||||
[array]$PullParams,
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('logs'))})]
|
||||
[array]$LogsParams,
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('up'))})]
|
||||
[array]$UpParams=@('--detach','--remove-orphans'),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('up'))})]
|
||||
[array]$Containers
|
||||
)
|
||||
|
||||
|
|
|
@ -1,15 +1,8 @@
|
|||
[CmdletBinding(SupportsShouldProcess)]param(
|
||||
[ArgumentCompleter({ param (
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
})]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeDirsCompleter -ArgumentList $args})]
|
||||
[string[]]$ProjectPath=@($PWD),
|
||||
[Parameter(Position = 0, ValueFromRemainingArguments = $true)]
|
||||
[ArgumentCompleter({Invoke-Command -ScriptBlock $_DockerComposeCompleter -ArgumentList ($args+@('exec'))})]
|
||||
[array]$CliParams
|
||||
)
|
||||
|
||||
|
|
|
@ -0,0 +1,162 @@
|
|||
class DockerContainers { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
docker container ls -a --no-trunc --format "{{.Names}}"
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerContainers]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
class DockerImages { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
docker image ls --format "{{.Repository}}"
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerImages]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
class DockerNetworks {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
docker network ls --no-trunc --format "{{.Name}}"
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerNetworks]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
class DockerComposeCommands { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] $cachedCommands = @()
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[string]$subcommand,[bool]$Strict) {
|
||||
$local:gate = $false
|
||||
|
||||
$local:possibleValues = $(
|
||||
docker-compose $subcommand --help | Out-String -Stream |
|
||||
ForEach-Object {
|
||||
if( $wordToComplete -match '^-' ) {
|
||||
if( $_ -match "^ *(-.*) (\w.*)$" ) {
|
||||
$matches[1] -split ', ' | ForEach-Object { $_ -split ' ' | Select-Object -First 1 }
|
||||
}
|
||||
} elseif( -not $gate ) {
|
||||
if ( $_.trim() -eq 'Commands:' ) { $gate = $true }
|
||||
} else {
|
||||
$null = $_ -match '^\W+(\w+)\W+(.+)$';
|
||||
$Matches[1];
|
||||
}
|
||||
}
|
||||
)
|
||||
[DockerComposeCommands]::cachedCommands = $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
return [DockerComposeCommands]::cachedCommands;
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerComposeCommands]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
$global:_DockerComposeCommandCompleter = [ScriptBlock]{
|
||||
param(
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeCommands]::_GetValidValues($wordToComplete,"",$true)
|
||||
}
|
||||
|
||||
class DockerComposeServices { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[string]$Path,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
dco -ProjectPath $Path config --services
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
return [DockerComposeServices]::_GetValidValues($wordToComplete,'.',$true)
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerComposeServices]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
$null = [DockerComposeCommands]::_GetValidValues("","",$true)
|
||||
$global:_DockerComposeCompleter = [ScriptBlock]{
|
||||
param(
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters,
|
||||
$subCommand
|
||||
)
|
||||
$local:cmd = $subCommand
|
||||
if( -not $cmd ) {
|
||||
$cmd = $commandAst.CommandElements |
|
||||
Where-Object Value -in ([DockerComposeCommands]::cachedCommands) |
|
||||
Select-Object -First 1
|
||||
}
|
||||
$local:ProjectPath = $fakeBoundParameters.ProjectPath
|
||||
if( -not $ProjectPath ) { $ProjectPath=@($PWD) }
|
||||
if( -not $cmd -or $wordToComplete -match '^-' ) {
|
||||
[DockerComposeCommands]::_GetValidValues($wordToComplete,$cmd,$true)
|
||||
} else {
|
||||
switch($cmd){
|
||||
'down' {}
|
||||
'images' {}
|
||||
'config' {}
|
||||
default {
|
||||
[DockerComposeServices]::_GetValidValues($wordToComplete,$ProjectPath,$true)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
class DockerComposeDirs { #: System.Management.Automation.IValidateSetValuesGenerator {
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[string]$Path,[bool]$Strict) {
|
||||
$local:possibleValues = $(
|
||||
Get-ChildItem -LiteralPath $Path -Directory -Depth 3 |
|
||||
Where-Object { $_ |
|
||||
Get-ChildItem -Include 'docker-compose.y*l' |
|
||||
Where-Object Extension -in '.yml','.yaml'
|
||||
} | ForEach-Object {
|
||||
$_.FullName.Replace($(Join-Path $PWD ""),'')
|
||||
}
|
||||
)
|
||||
return $(Get-PossibleArguments -WordToComplete $wordToComplete -FullValueSet $possibleValues -Strict:$Strict );
|
||||
}
|
||||
|
||||
static [string[]] _GetValidValues([string]$wordToComplete,[bool]$Strict) {
|
||||
return [DockerComposeDirs]::_GetValidValues($wordToComplete,'.',$true)
|
||||
}
|
||||
|
||||
[String[]] GetValidValues() {
|
||||
return [DockerComposeDirs]::_GetValidValues('',$true)
|
||||
}
|
||||
}
|
||||
|
||||
$global:_DockerComposeDirsCompleter = [ScriptBlock]{
|
||||
param(
|
||||
$commandName,
|
||||
$parameterName,
|
||||
$wordToComplete,
|
||||
$commandAst,
|
||||
$fakeBoundParameters
|
||||
)
|
||||
[DockerComposeDirs]::_GetValidValues($wordToComplete,$true)
|
||||
}
|
||||
|
Loading…
Reference in New Issue