Skip to content

Commit eb53046

Browse files
authored
Merge pull request #5516 from thaJeztah/complete_platforms
add shell-completion for --platform flags
2 parents 55ae7d7 + d42cf96 commit eb53046

8 files changed

Lines changed: 70 additions & 0 deletions

File tree

cli/command/completion/functions.go

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -145,3 +145,47 @@ func FileNames(_ *cobra.Command, _ []string, _ string) ([]string, cobra.ShellCom
145145
func NoComplete(_ *cobra.Command, _ []string, _ string) ([]string, cobra.ShellCompDirective) {
146146
return nil, cobra.ShellCompDirectiveNoFileComp
147147
}
148+
149+
var commonPlatforms = []string{
150+
"linux",
151+
"linux/386",
152+
"linux/amd64",
153+
"linux/arm",
154+
"linux/arm/v5",
155+
"linux/arm/v6",
156+
"linux/arm/v7",
157+
"linux/arm64",
158+
"linux/arm64/v8",
159+
160+
// IBM power and z platforms
161+
"linux/ppc64le",
162+
"linux/s390x",
163+
164+
// Not yet supported
165+
"linux/riscv64",
166+
167+
"windows",
168+
"windows/amd64",
169+
170+
"wasip1",
171+
"wasip1/wasm",
172+
}
173+
174+
// Platforms offers completion for platform-strings. It provides a non-exhaustive
175+
// list of platforms to be used for completion. Platform-strings are based on
176+
// [runtime.GOOS] and [runtime.GOARCH], but with (optional) variants added. A
177+
// list of recognised os/arch combinations from the Go runtime can be obtained
178+
// through "go tool dist list".
179+
//
180+
// Some noteworthy exclusions from this list:
181+
//
182+
// - arm64 images ("windows/arm64", "windows/arm64/v8") do not yet exist for windows.
183+
// - we don't (yet) include `os-variant` for completion (as can be used for Windows images)
184+
// - we don't (yet) include platforms for which we don't build binaries, such as
185+
// BSD platforms (freebsd, netbsd, openbsd), android, macOS (darwin).
186+
// - we currently exclude architectures that may have unofficial builds,
187+
// but don't have wide adoption (and no support), such as loong64, mipsXXX,
188+
// ppc64 (non-le) to prevent confusion.
189+
func Platforms(_ *cobra.Command, _ []string, _ string) (platforms []string, _ cobra.ShellCompDirective) {
190+
return commonPlatforms, cobra.ShellCompDirectiveNoFileComp
191+
}
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
package completion
2+
3+
import (
4+
"testing"
5+
6+
"github.com/spf13/cobra"
7+
"gotest.tools/v3/assert"
8+
is "gotest.tools/v3/assert/cmp"
9+
)
10+
11+
func TestCompletePlatforms(t *testing.T) {
12+
values, directives := Platforms(nil, nil, "")
13+
assert.Check(t, is.Equal(directives&cobra.ShellCompDirectiveNoFileComp, cobra.ShellCompDirectiveNoFileComp), "Should not perform file completion")
14+
assert.Check(t, is.DeepEqual(values, commonPlatforms))
15+
}

cli/command/container/create.go

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -83,6 +83,7 @@ func NewCreateCommand(dockerCli command.Cli) *cobra.Command {
8383
_ = cmd.RegisterFlagCompletionFunc("env", completion.EnvVarNames)
8484
_ = cmd.RegisterFlagCompletionFunc("env-file", completion.FileNames)
8585
_ = cmd.RegisterFlagCompletionFunc("network", completion.NetworkNames(dockerCli))
86+
_ = cmd.RegisterFlagCompletionFunc("platform", completion.Platforms)
8687
_ = cmd.RegisterFlagCompletionFunc("pull", completion.FromList(PullImageAlways, PullImageMissing, PullImageNever))
8788
_ = cmd.RegisterFlagCompletionFunc("restart", completeRestartPolicies)
8889
_ = cmd.RegisterFlagCompletionFunc("stop-signal", completeSignals)

cli/command/container/run.go

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -74,6 +74,7 @@ func NewRunCommand(dockerCli command.Cli) *cobra.Command {
7474
_ = cmd.RegisterFlagCompletionFunc("env", completion.EnvVarNames)
7575
_ = cmd.RegisterFlagCompletionFunc("env-file", completion.FileNames)
7676
_ = cmd.RegisterFlagCompletionFunc("network", completion.NetworkNames(dockerCli))
77+
_ = cmd.RegisterFlagCompletionFunc("platform", completion.Platforms)
7778
_ = cmd.RegisterFlagCompletionFunc("pull", completion.FromList(PullImageAlways, PullImageMissing, PullImageNever))
7879
_ = cmd.RegisterFlagCompletionFunc("restart", completeRestartPolicies)
7980
_ = cmd.RegisterFlagCompletionFunc("stop-signal", completeSignals)

cli/command/image/build.go

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@ import (
1818
"github.com/docker/cli-docs-tool/annotation"
1919
"github.com/docker/cli/cli"
2020
"github.com/docker/cli/cli/command"
21+
"github.com/docker/cli/cli/command/completion"
2122
"github.com/docker/cli/cli/command/image/build"
2223
"github.com/docker/cli/opts"
2324
"github.com/docker/docker/api"
@@ -159,6 +160,8 @@ func NewBuildCommand(dockerCli command.Cli) *cobra.Command {
159160
flags.SetAnnotation("squash", "experimental", nil)
160161
flags.SetAnnotation("squash", "version", []string{"1.25"})
161162

163+
_ = cmd.RegisterFlagCompletionFunc("platform", completion.Platforms)
164+
162165
return cmd
163166
}
164167

cli/command/image/import.go

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@ import (
77

88
"github.com/docker/cli/cli"
99
"github.com/docker/cli/cli/command"
10+
"github.com/docker/cli/cli/command/completion"
1011
dockeropts "github.com/docker/cli/opts"
1112
"github.com/docker/docker/api/types/image"
1213
"github.com/docker/docker/pkg/jsonmessage"
@@ -47,6 +48,7 @@ func NewImportCommand(dockerCli command.Cli) *cobra.Command {
4748
flags.VarP(&options.changes, "change", "c", "Apply Dockerfile instruction to the created image")
4849
flags.StringVarP(&options.message, "message", "m", "", "Set commit message for imported image")
4950
command.AddPlatformFlag(flags, &options.platform)
51+
_ = cmd.RegisterFlagCompletionFunc("platform", completion.Platforms)
5052

5153
return cmd
5254
}

cli/command/image/pull.go

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -50,6 +50,8 @@ func NewPullCommand(dockerCli command.Cli) *cobra.Command {
5050
command.AddPlatformFlag(flags, &opts.platform)
5151
command.AddTrustVerificationFlags(flags, &opts.untrusted, dockerCli.ContentTrustEnabled())
5252

53+
_ = cmd.RegisterFlagCompletionFunc("platform", completion.Platforms)
54+
5355
return cmd
5456
}
5557

cli/command/image/push.go

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -68,6 +68,8 @@ Image index won't be pushed, meaning that other manifests, including attestation
6868
'os[/arch[/variant]]': Explicit platform (eg. linux/amd64)`)
6969
flags.SetAnnotation("platform", "version", []string{"1.46"})
7070

71+
_ = cmd.RegisterFlagCompletionFunc("platform", completion.Platforms)
72+
7173
return cmd
7274
}
7375

0 commit comments

Comments
 (0)