Fix broken JSON support in cli/command/formatter

How to test (it should not print `{}`, and just returns JSON with the actual data):

   $ docker images --format '{{json .}}'
   $ docker container stats --format '{{json .}}'

Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
This commit is contained in:
Akihiro Suda 2017-01-19 09:50:28 +00:00
parent 7d0041f9e5
commit 26013fcdd6
3 changed files with 20 additions and 0 deletions

View File

@ -158,6 +158,10 @@ type diskUsageImagesContext struct {
images []*types.ImageSummary
}
func (c *diskUsageImagesContext) MarshalJSON() ([]byte, error) {
return marshalJSON(c)
}
func (c *diskUsageImagesContext) Type() string {
c.AddHeader(typeHeader)
return "Images"
@ -209,6 +213,10 @@ type diskUsageContainersContext struct {
containers []*types.Container
}
func (c *diskUsageContainersContext) MarshalJSON() ([]byte, error) {
return marshalJSON(c)
}
func (c *diskUsageContainersContext) Type() string {
c.AddHeader(typeHeader)
return "Containers"
@ -273,6 +281,10 @@ type diskUsageVolumesContext struct {
volumes []*types.Volume
}
func (c *diskUsageVolumesContext) MarshalJSON() ([]byte, error) {
return marshalJSON(c)
}
func (c *diskUsageVolumesContext) Type() string {
c.AddHeader(typeHeader)
return "Local Volumes"

View File

@ -190,6 +190,10 @@ type imageContext struct {
digest string
}
func (c *imageContext) MarshalJSON() ([]byte, error) {
return marshalJSON(c)
}
func (c *imageContext) ID() string {
c.AddHeader(imageIDHeader)
if c.trunc {

View File

@ -138,6 +138,10 @@ type containerStatsContext struct {
s StatsEntry
}
func (c *containerStatsContext) MarshalJSON() ([]byte, error) {
return marshalJSON(c)
}
func (c *containerStatsContext) Container() string {
c.AddHeader(containerHeader)
return c.s.Container