Move print functions
This commit is contained in:
parent
3c9137816d
commit
2d2efd4431
99
cmd/print.go
99
cmd/print.go
@ -1,6 +1,9 @@
|
|||||||
package lumecmd
|
package lumecmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
"git.kill0.net/chill9/lifx-go"
|
"git.kill0.net/chill9/lifx-go"
|
||||||
"github.com/fatih/color"
|
"github.com/fatih/color"
|
||||||
)
|
)
|
||||||
@ -22,3 +25,99 @@ func ColorizeStatus(s lifx.Status) string {
|
|||||||
|
|
||||||
return c.Sprint(s)
|
return c.Sprint(s)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func PrintWithIndent(indent int, s string) {
|
||||||
|
fmt.Printf("%*s%s", indent, "", s)
|
||||||
|
}
|
||||||
|
|
||||||
|
func PrintfWithIndent(indent int, format string, a ...interface{}) (n int, err error) {
|
||||||
|
format = fmt.Sprintf("%*s%s", indent, "", format)
|
||||||
|
return fmt.Printf(format, a...)
|
||||||
|
}
|
||||||
|
|
||||||
|
func PrintResults(res []lifx.Result) {
|
||||||
|
var length int
|
||||||
|
var widths map[string]int
|
||||||
|
|
||||||
|
widths = make(map[string]int)
|
||||||
|
|
||||||
|
for _, r := range res {
|
||||||
|
length = len(r.Id)
|
||||||
|
if widths["id"] < length {
|
||||||
|
widths["id"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(r.Label)
|
||||||
|
if widths["label"] < length {
|
||||||
|
widths["label"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(r.Status)
|
||||||
|
if widths["status"] < length {
|
||||||
|
widths["status"] = length
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sortResults(res)
|
||||||
|
|
||||||
|
for _, r := range res {
|
||||||
|
fmt.Printf("%*s %*s %*s\n",
|
||||||
|
widths["id"], r.Id,
|
||||||
|
widths["label"], r.Label,
|
||||||
|
widths["status"], ColorizeStatus(r.Status))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func PrintLights(lights []lifx.Light) {
|
||||||
|
var length int
|
||||||
|
var widths map[string]int
|
||||||
|
|
||||||
|
widths = make(map[string]int)
|
||||||
|
|
||||||
|
for _, l := range lights {
|
||||||
|
length = len(l.Id)
|
||||||
|
if widths["id"] < length {
|
||||||
|
widths["id"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(l.Location.Name)
|
||||||
|
if widths["location"] < length {
|
||||||
|
widths["location"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(l.Group.Name)
|
||||||
|
if widths["group"] < length {
|
||||||
|
widths["group"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(l.Label)
|
||||||
|
if widths["label"] < length {
|
||||||
|
widths["label"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(l.LastSeen.Local().Format(time.RFC3339))
|
||||||
|
if widths["last_seen"] < length {
|
||||||
|
widths["last_seen"] = length
|
||||||
|
}
|
||||||
|
|
||||||
|
length = len(l.Power)
|
||||||
|
if widths["power"] < length {
|
||||||
|
widths["power"] = length
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sortLights(lights)
|
||||||
|
|
||||||
|
fmt.Printf("total %d\n", len(lights))
|
||||||
|
for _, l := range lights {
|
||||||
|
fmt.Printf(
|
||||||
|
"%*s %*s %*s %*s %*s %-*s\n",
|
||||||
|
widths["id"], l.Id,
|
||||||
|
widths["loction"], l.Location.Name,
|
||||||
|
widths["group"], l.Group.Name,
|
||||||
|
widths["label"], l.Label,
|
||||||
|
widths["last_seen"], l.LastSeen.Local().Format(time.RFC3339),
|
||||||
|
widths["power"], ColorizePower(l.Power),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
97
cmd/util.go
97
cmd/util.go
@ -6,98 +6,10 @@ import (
|
|||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
|
||||||
|
|
||||||
"git.kill0.net/chill9/lifx-go"
|
"git.kill0.net/chill9/lifx-go"
|
||||||
)
|
)
|
||||||
|
|
||||||
func PrintResults(res []lifx.Result) {
|
|
||||||
var length int
|
|
||||||
var widths map[string]int
|
|
||||||
|
|
||||||
widths = make(map[string]int)
|
|
||||||
|
|
||||||
for _, r := range res {
|
|
||||||
length = len(r.Id)
|
|
||||||
if widths["id"] < length {
|
|
||||||
widths["id"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(r.Label)
|
|
||||||
if widths["label"] < length {
|
|
||||||
widths["label"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(r.Status)
|
|
||||||
if widths["status"] < length {
|
|
||||||
widths["status"] = length
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sortResults(res)
|
|
||||||
|
|
||||||
for _, r := range res {
|
|
||||||
fmt.Printf("%*s %*s %*s\n",
|
|
||||||
widths["id"], r.Id,
|
|
||||||
widths["label"], r.Label,
|
|
||||||
widths["status"], ColorizeStatus(r.Status))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func PrintLights(lights []lifx.Light) {
|
|
||||||
var length int
|
|
||||||
var widths map[string]int
|
|
||||||
|
|
||||||
widths = make(map[string]int)
|
|
||||||
|
|
||||||
for _, l := range lights {
|
|
||||||
length = len(l.Id)
|
|
||||||
if widths["id"] < length {
|
|
||||||
widths["id"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(l.Location.Name)
|
|
||||||
if widths["location"] < length {
|
|
||||||
widths["location"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(l.Group.Name)
|
|
||||||
if widths["group"] < length {
|
|
||||||
widths["group"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(l.Label)
|
|
||||||
if widths["label"] < length {
|
|
||||||
widths["label"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(l.LastSeen.Local().Format(time.RFC3339))
|
|
||||||
if widths["last_seen"] < length {
|
|
||||||
widths["last_seen"] = length
|
|
||||||
}
|
|
||||||
|
|
||||||
length = len(l.Power)
|
|
||||||
if widths["power"] < length {
|
|
||||||
widths["power"] = length
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sortLights(lights)
|
|
||||||
|
|
||||||
fmt.Printf("total %d\n", len(lights))
|
|
||||||
for _, l := range lights {
|
|
||||||
fmt.Printf(
|
|
||||||
"%*s %*s %*s %*s %*s %-*s\n",
|
|
||||||
widths["id"], l.Id,
|
|
||||||
widths["loction"], l.Location.Name,
|
|
||||||
widths["group"], l.Group.Name,
|
|
||||||
widths["label"], l.Label,
|
|
||||||
widths["last_seen"], l.LastSeen.Local().Format(time.RFC3339),
|
|
||||||
widths["power"], ColorizePower(l.Power),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func parseRGB(s string) (lifx.RGBColor, error) {
|
func parseRGB(s string) (lifx.RGBColor, error) {
|
||||||
var c lifx.RGBColor
|
var c lifx.RGBColor
|
||||||
rgb := strings.SplitN(s, ",", 3)
|
rgb := strings.SplitN(s, ",", 3)
|
||||||
@ -148,12 +60,3 @@ func YesNo(v bool) string {
|
|||||||
}
|
}
|
||||||
return "no"
|
return "no"
|
||||||
}
|
}
|
||||||
|
|
||||||
func PrintWithIndent(indent int, s string) {
|
|
||||||
fmt.Printf("%*s%s", indent, "", s)
|
|
||||||
}
|
|
||||||
|
|
||||||
func PrintfWithIndent(indent int, format string, a ...interface{}) (n int, err error) {
|
|
||||||
format = fmt.Sprintf("%*s%s", indent, "", format)
|
|
||||||
return fmt.Printf(format, a...)
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user