While updating, also addressed some redundant fmt.Sprintf()
opts/throttledevice.go:86:2: Consider pre-allocating `out` (prealloc)
var out []string
^
opts/ulimit.go:37:2: Consider pre-allocating `out` (prealloc)
var out []string
^
opts/ulimit.go:47:2: Consider pre-allocating `ulimits` (prealloc)
var ulimits []*units.Ulimit
^
opts/weightdevice.go:68:2: Consider pre-allocating `out` (prealloc)
var out []string
^
cli/context/store/metadatastore.go:96:2: Consider pre-allocating `res` (prealloc)
var res []Metadata
^
cli/context/store/store.go:127:2: Consider pre-allocating `names` (prealloc)
var names []string
^
cli/compose/loader/loader.go:223:2: Consider pre-allocating `keys` (prealloc)
var keys []string
^
cli/compose/loader/loader.go:397:2: Consider pre-allocating `services` (prealloc)
var services []types.ServiceConfig
^
cli/command/stack/loader/loader.go:63:2: Consider pre-allocating `msgs` (prealloc)
var msgs []string
^
cli/command/stack/loader/loader.go:118:2: Consider pre-allocating `configFiles` (prealloc)
var configFiles []composetypes.ConfigFile
^
cli/command/formatter/container.go:245:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/formatter/container.go:265:2: Consider pre-allocating `mounts` (prealloc)
var mounts []string
^
cli/command/formatter/container.go:316:2: Consider pre-allocating `result` (prealloc)
var result []string
^
cli/command/formatter/displayutils.go:43:2: Consider pre-allocating `display` (prealloc)
var (
^
cli/command/formatter/volume.go:103:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli-plugins/manager/manager_test.go:49:2: Consider pre-allocating `dirs` (prealloc)
var dirs []string
^
cli/command/swarm/init.go:69:2: Consider pre-allocating `defaultAddrPool` (prealloc)
var defaultAddrPool []string
^
cli/command/manifest/push.go:195:2: Consider pre-allocating `blobReqs` (prealloc)
var blobReqs []manifestBlob
^
cli/command/secret/formatter.go:111:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/network/formatter.go:104:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/context/list.go:52:2: Consider pre-allocating `contexts` (prealloc)
var contexts []*formatter.ClientContext
^
cli/command/config/formatter.go:104:2: Consider pre-allocating `joinLabels` (prealloc)
var joinLabels []string
^
cli/command/trust/common_test.go:23:2: Consider pre-allocating `targetNames` (prealloc)
var targetNames []string
^
cli/command/service/generic_resource_opts.go:55:2: Consider pre-allocating `generic` (prealloc)
var generic []swarm.GenericResource
^
cli/command/service/generic_resource_opts.go:98:2: Consider pre-allocating `l` (prealloc)
var l []swarm.GenericResource
^
cli/command/service/opts.go:378:2: Consider pre-allocating `netAttach` (prealloc)
var netAttach []swarm.NetworkAttachmentConfig
^
cli/command/service/update.go:731:2: Consider pre-allocating `limits` (prealloc)
var limits []*units.Ulimit
^
cli/command/service/update.go:1315:2: Consider pre-allocating `newNetworks` (prealloc)
var newNetworks []swarm.NetworkAttachmentConfig
^
cli/command/service/update.go:1514:2: Consider pre-allocating `out` (prealloc)
var out []string
^
cli/compose/convert/service.go:713:2: Consider pre-allocating `ulimits` (prealloc)
var ulimits []*units.Ulimit
^
cli/compose/convert/volume.go:13:2: Consider pre-allocating `mounts` (prealloc)
var mounts []mount.Mount
^
cli/command/stack/swarm/list.go:39:2: Consider pre-allocating `stacks` (prealloc)
var stacks []*formatter.Stack
^
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
173 lines
4.2 KiB
Go
173 lines
4.2 KiB
Go
package config
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/docker/cli/cli/command"
|
|
"github.com/docker/cli/cli/command/formatter"
|
|
"github.com/docker/cli/cli/command/inspect"
|
|
"github.com/docker/docker/api/types/swarm"
|
|
units "github.com/docker/go-units"
|
|
)
|
|
|
|
const (
|
|
defaultConfigTableFormat = "table {{.ID}}\t{{.Name}}\t{{.CreatedAt}}\t{{.UpdatedAt}}"
|
|
configIDHeader = "ID"
|
|
configCreatedHeader = "CREATED"
|
|
configUpdatedHeader = "UPDATED"
|
|
configInspectPrettyTemplate formatter.Format = `ID: {{.ID}}
|
|
Name: {{.Name}}
|
|
{{- if .Labels }}
|
|
Labels:
|
|
{{- range $k, $v := .Labels }}
|
|
- {{ $k }}{{if $v }}={{ $v }}{{ end }}
|
|
{{- end }}{{ end }}
|
|
Created at: {{.CreatedAt}}
|
|
Updated at: {{.UpdatedAt}}
|
|
Data:
|
|
{{.Data}}`
|
|
)
|
|
|
|
// NewFormat returns a Format for rendering using a config Context
|
|
func NewFormat(source string, quiet bool) formatter.Format {
|
|
switch source {
|
|
case formatter.PrettyFormatKey:
|
|
return configInspectPrettyTemplate
|
|
case formatter.TableFormatKey:
|
|
if quiet {
|
|
return formatter.DefaultQuietFormat
|
|
}
|
|
return defaultConfigTableFormat
|
|
}
|
|
return formatter.Format(source)
|
|
}
|
|
|
|
// FormatWrite writes the context
|
|
func FormatWrite(ctx formatter.Context, configs []swarm.Config) error {
|
|
render := func(format func(subContext formatter.SubContext) error) error {
|
|
for _, config := range configs {
|
|
configCtx := &configContext{c: config}
|
|
if err := format(configCtx); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
return ctx.Write(newConfigContext(), render)
|
|
}
|
|
|
|
func newConfigContext() *configContext {
|
|
cCtx := &configContext{}
|
|
|
|
cCtx.Header = formatter.SubHeaderContext{
|
|
"ID": configIDHeader,
|
|
"Name": formatter.NameHeader,
|
|
"CreatedAt": configCreatedHeader,
|
|
"UpdatedAt": configUpdatedHeader,
|
|
"Labels": formatter.LabelsHeader,
|
|
}
|
|
return cCtx
|
|
}
|
|
|
|
type configContext struct {
|
|
formatter.HeaderContext
|
|
c swarm.Config
|
|
}
|
|
|
|
func (c *configContext) MarshalJSON() ([]byte, error) {
|
|
return formatter.MarshalJSON(c)
|
|
}
|
|
|
|
func (c *configContext) ID() string {
|
|
return c.c.ID
|
|
}
|
|
|
|
func (c *configContext) Name() string {
|
|
return c.c.Spec.Annotations.Name
|
|
}
|
|
|
|
func (c *configContext) CreatedAt() string {
|
|
return units.HumanDuration(time.Now().UTC().Sub(c.c.Meta.CreatedAt)) + " ago"
|
|
}
|
|
|
|
func (c *configContext) UpdatedAt() string {
|
|
return units.HumanDuration(time.Now().UTC().Sub(c.c.Meta.UpdatedAt)) + " ago"
|
|
}
|
|
|
|
func (c *configContext) Labels() string {
|
|
mapLabels := c.c.Spec.Annotations.Labels
|
|
if mapLabels == nil {
|
|
return ""
|
|
}
|
|
joinLabels := make([]string, 0, len(mapLabels))
|
|
for k, v := range mapLabels {
|
|
joinLabels = append(joinLabels, k+"="+v)
|
|
}
|
|
return strings.Join(joinLabels, ",")
|
|
}
|
|
|
|
func (c *configContext) Label(name string) string {
|
|
if c.c.Spec.Annotations.Labels == nil {
|
|
return ""
|
|
}
|
|
return c.c.Spec.Annotations.Labels[name]
|
|
}
|
|
|
|
// InspectFormatWrite renders the context for a list of configs
|
|
func InspectFormatWrite(ctx formatter.Context, refs []string, getRef inspect.GetRefFunc) error {
|
|
if ctx.Format != configInspectPrettyTemplate {
|
|
return inspect.Inspect(ctx.Output, refs, string(ctx.Format), getRef)
|
|
}
|
|
render := func(format func(subContext formatter.SubContext) error) error {
|
|
for _, ref := range refs {
|
|
configI, _, err := getRef(ref)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
config, ok := configI.(swarm.Config)
|
|
if !ok {
|
|
return fmt.Errorf("got wrong object to inspect :%v", ok)
|
|
}
|
|
if err := format(&configInspectContext{Config: config}); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
return ctx.Write(&configInspectContext{}, render)
|
|
}
|
|
|
|
type configInspectContext struct {
|
|
swarm.Config
|
|
formatter.SubContext
|
|
}
|
|
|
|
func (ctx *configInspectContext) ID() string {
|
|
return ctx.Config.ID
|
|
}
|
|
|
|
func (ctx *configInspectContext) Name() string {
|
|
return ctx.Config.Spec.Name
|
|
}
|
|
|
|
func (ctx *configInspectContext) Labels() map[string]string {
|
|
return ctx.Config.Spec.Labels
|
|
}
|
|
|
|
func (ctx *configInspectContext) CreatedAt() string {
|
|
return command.PrettyPrint(ctx.Config.CreatedAt)
|
|
}
|
|
|
|
func (ctx *configInspectContext) UpdatedAt() string {
|
|
return command.PrettyPrint(ctx.Config.UpdatedAt)
|
|
}
|
|
|
|
func (ctx *configInspectContext) Data() string {
|
|
if ctx.Config.Spec.Data == nil {
|
|
return ""
|
|
}
|
|
return string(ctx.Config.Spec.Data)
|
|
}
|