diff options
author | Paul Holzinger <pholzing@redhat.com> | 2022-04-28 15:06:00 +0200 |
---|---|---|
committer | Paul Holzinger <pholzing@redhat.com> | 2022-04-28 15:11:25 +0200 |
commit | cb9a45630f270f825f2285541aefbf5ded37cdae (patch) | |
tree | 92eedf8b439cfe0a24a530d1725e5050dedba142 /cmd/podman/common/completion.go | |
parent | 8be97815865ccf265923e50fe66d7739200ec20d (diff) | |
download | podman-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.go | 7 |
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) } } |