aboutsummaryrefslogtreecommitdiff
path: root/cmd/podman/common/completion.go
diff options
context:
space:
mode:
authorPaul Holzinger <pholzing@redhat.com>2022-04-28 15:06:00 +0200
committerPaul Holzinger <pholzing@redhat.com>2022-04-28 15:11:25 +0200
commitcb9a45630f270f825f2285541aefbf5ded37cdae (patch)
tree92eedf8b439cfe0a24a530d1725e5050dedba142 /cmd/podman/common/completion.go
parent8be97815865ccf265923e50fe66d7739200ec20d (diff)
downloadpodman-cb9a45630f270f825f2285541aefbf5ded37cdae.tar.gz
podman-cb9a45630f270f825f2285541aefbf5ded37cdae.tar.bz2
podman-cb9a45630f270f825f2285541aefbf5ded37cdae.zip
shell completion --format: use anonymous struct field once
We should not include the anonymous twice in the suggestions. one example is `podman network ls --format {{.` it will also show `{{.Network` but since Network is the actual struct all fields are already shown so there is no need for it to be suggested. Signed-off-by: Paul Holzinger <pholzing@redhat.com>
Diffstat (limited to 'cmd/podman/common/completion.go')
-rw-r--r--cmd/podman/common/completion.go7
1 files changed, 3 insertions, 4 deletions
diff --git a/cmd/podman/common/completion.go b/cmd/podman/common/completion.go
index 6f13eb5a2..ddf922b2a 100644
--- a/cmd/podman/common/completion.go
+++ b/cmd/podman/common/completion.go
@@ -1056,13 +1056,12 @@ func getStructFields(f reflect.Value, prefix string) []string {
if kind == reflect.Struct {
suffix = "."
}
- if strings.HasPrefix(fname, prefix) {
- // add field name with suffix
- suggestions = append(suggestions, fname+suffix)
- }
// if field is anonymous add the child fields as well
if field.Anonymous {
suggestions = append(suggestions, getStructFields(f.Field(j), prefix)...)
+ } else if strings.HasPrefix(fname, prefix) {
+ // add field name with suffix
+ suggestions = append(suggestions, fname+suffix)
}
}