mirror of
https://github.com/status-im/consul.git
synced 2025-01-22 03:29:43 +00:00
Get JSON formatting working
This commit is contained in:
parent
e7a88d4a30
commit
208d6ebd95
@ -15,7 +15,7 @@ const (
|
||||
)
|
||||
|
||||
type Formatter interface {
|
||||
Format(*OutputFormat, *OutputFormat, bool) (string, error)
|
||||
Format(*OutputFormat, bool) (string, error)
|
||||
}
|
||||
|
||||
func GetSupportedFormats() []string {
|
||||
@ -38,7 +38,7 @@ func NewFormatter(format string) (Formatter, error) {
|
||||
}
|
||||
}
|
||||
|
||||
func (_ *prettyFormatter) Format(info *OutputFormat, kvInfo *OutputFormat, detailed bool) (string, error) {
|
||||
func (_ *prettyFormatter) Format(info *OutputFormat, detailed bool) (string, error) {
|
||||
var b bytes.Buffer
|
||||
tw := tabwriter.NewWriter(&b, 8, 8, 6, ' ', 0)
|
||||
|
||||
@ -68,11 +68,11 @@ func (_ *prettyFormatter) Format(info *OutputFormat, kvInfo *OutputFormat, detai
|
||||
fmt.Fprintln(kvtw, "\n Key Name\tCount\tSize\t")
|
||||
fmt.Fprintf(kvtw, " %s\t%s\t%s\t", "----", "----", "----")
|
||||
// For each different type generate new output
|
||||
for _, s := range kvInfo.Stats {
|
||||
for _, s := range info.KStats {
|
||||
fmt.Fprintf(kvtw, "\n %s\t%d\t%s\t", s.Name, s.Count, ByteSize(uint64(s.Sum)))
|
||||
}
|
||||
fmt.Fprintf(kvtw, "\n %s\t%s\t%s\t", "----", "----", "----")
|
||||
fmt.Fprintf(kvtw, "\n Total\t\t%s\t", ByteSize(uint64(kvInfo.TotalSize)))
|
||||
fmt.Fprintf(kvtw, "\n Total\t\t%s\t", ByteSize(uint64(info.TotalSize)))
|
||||
|
||||
if err := kvtw.Flush(); err != nil {
|
||||
return b.String(), err
|
||||
@ -88,7 +88,7 @@ func newJSONFormatter() Formatter {
|
||||
return &jsonFormatter{}
|
||||
}
|
||||
|
||||
func (_ *jsonFormatter) Format(info *OutputFormat, infoKV *OutputFormat, detailed bool) (string, error) {
|
||||
func (_ *jsonFormatter) Format(info *OutputFormat, detailed bool) (string, error) {
|
||||
b, err := json.MarshalIndent(info, "", " ")
|
||||
if err != nil {
|
||||
return "", fmt.Errorf("Failed to marshal original snapshot stats: %v", err)
|
||||
|
@ -68,6 +68,7 @@ type MetadataInfo struct {
|
||||
type OutputFormat struct {
|
||||
Meta *MetadataInfo
|
||||
Stats []typeStats
|
||||
KStats []typeStats
|
||||
TotalSize int
|
||||
}
|
||||
|
||||
@ -138,15 +139,11 @@ func (c *cmd) Run(args []string) int {
|
||||
in := &OutputFormat{
|
||||
Meta: metaformat,
|
||||
Stats: formattedStats,
|
||||
TotalSize: totalSize,
|
||||
}
|
||||
inKV := &OutputFormat{
|
||||
Meta: metaformat,
|
||||
Stats: formattedKStats,
|
||||
KStats: formattedKStats,
|
||||
TotalSize: totalSize,
|
||||
}
|
||||
|
||||
out, err := formatter.Format(in, inKV, c.detailed)
|
||||
out, err := formatter.Format(in, c.detailed)
|
||||
if err != nil {
|
||||
c.UI.Error(err.Error())
|
||||
return 1
|
||||
|
Loading…
x
Reference in New Issue
Block a user