2017-03-01 01:10:33 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"reflect"
|
2017-03-06 00:23:44 +00:00
|
|
|
|
|
|
|
ui "github.com/gizak/termui"
|
2017-03-01 01:10:33 +00:00
|
|
|
)
|
|
|
|
|
2017-03-06 00:23:44 +00:00
|
|
|
func logEvent(e ui.Event) {
|
|
|
|
var s string
|
|
|
|
s += fmt.Sprintf("Type=%s", quote(e.Type))
|
|
|
|
s += fmt.Sprintf(" Path=%s", quote(e.Path))
|
|
|
|
s += fmt.Sprintf(" From=%s", quote(e.From))
|
|
|
|
if e.To != "" {
|
|
|
|
s += fmt.Sprintf(" To=%s", quote(e.To))
|
|
|
|
}
|
|
|
|
log.Debugf("new event: %s", s)
|
|
|
|
}
|
|
|
|
|
2017-03-06 07:36:13 +00:00
|
|
|
// log container, metrics, and widget state
|
|
|
|
func dumpContainer(c *Container) {
|
|
|
|
msg := fmt.Sprintf("logging state for container: %s\n", c.Id)
|
2017-03-06 08:25:59 +00:00
|
|
|
for k, v := range c.Meta {
|
|
|
|
msg += fmt.Sprintf("Meta.%s = %s\n", k, v)
|
|
|
|
}
|
2017-03-06 07:36:13 +00:00
|
|
|
msg += inspect(&c.Metrics)
|
|
|
|
log.Infof(msg)
|
|
|
|
}
|
|
|
|
|
2017-03-01 01:10:33 +00:00
|
|
|
func inspect(i interface{}) (s string) {
|
|
|
|
val := reflect.ValueOf(i)
|
|
|
|
elem := val.Type().Elem()
|
|
|
|
|
|
|
|
eName := elem.String()
|
|
|
|
for i := 0; i < elem.NumField(); i++ {
|
|
|
|
field := elem.Field(i)
|
|
|
|
fieldVal := reflect.Indirect(val).FieldByName(field.Name)
|
|
|
|
s += fmt.Sprintf("%s.%s = ", eName, field.Name)
|
|
|
|
s += fmt.Sprintf("%v (%s)\n", fieldVal, field.Type)
|
|
|
|
}
|
|
|
|
return s
|
|
|
|
}
|
2017-03-06 00:23:44 +00:00
|
|
|
|
|
|
|
func quote(s string) string {
|
|
|
|
return fmt.Sprintf("\"%s\"", s)
|
|
|
|
}
|