Compare commits
	
		
			2 Commits
		
	
	
		
			23210af0c3
			...
			dd1ea7c276
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| dd1ea7c276 | |||
| 8c9af693e7 | 
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| ) | ) | ||||||
| @@ -102,7 +103,7 @@ func BreatheCmd(ctx Context) (int, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	p = NewPrinter(format) | 	p = NewPrinter(format) | ||||||
| 	p.Results(r.Results) | 	fmt.Print(p.Results(r.Results)) | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								cmd/help.go
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								cmd/help.go
									
									
									
									
									
								
							| @@ -3,6 +3,7 @@ package lumecmd | |||||||
| import ( | import ( | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"sort" | 	"sort" | ||||||
|  | 	"strings" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func NewCmdHelp() Command { | func NewCmdHelp() Command { | ||||||
| @@ -16,15 +17,21 @@ func NewCmdHelp() Command { | |||||||
|  |  | ||||||
| func HelpCmd(ctx Context) (int, error) { | func HelpCmd(ctx Context) (int, error) { | ||||||
| 	if len(ctx.Args) == 0 { | 	if len(ctx.Args) == 0 { | ||||||
| 		printHelp(commandRegistry) | 		fmt.Print(printHelp(commandRegistry)) | ||||||
| 	} else if len(ctx.Args) >= 1 { | 	} else if len(ctx.Args) >= 1 { | ||||||
| 		printCmdHelp(ctx.Args[0]) | 		if cmdHelp, err := printCmdHelp(ctx.Args[0]); err == nil { | ||||||
|  | 			fmt.Print(cmdHelp) | ||||||
|  | 		} else { | ||||||
|  | 			fmt.Print(err) | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|  |  | ||||||
| func printHelp(commands map[string]Command) { | func printHelp(commands map[string]Command) string { | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	var maxLen, cmdLen int | 	var maxLen, cmdLen int | ||||||
| 	var keys []string | 	var keys []string | ||||||
|  |  | ||||||
| @@ -36,34 +43,45 @@ func printHelp(commands map[string]Command) { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	fmt.Printf("usage:\n  lume <command> [<args...>]") | 	fmt.Fprintf(&b, "usage:\n  lume <command> [<args...>]") | ||||||
| 	fmt.Println() | 	fmt.Fprintln(&b) | ||||||
| 	fmt.Println("\ncommands:") | 	fmt.Fprintln(&b, "\ncommands:") | ||||||
|  |  | ||||||
| 	sort.Strings(keys) | 	sort.Strings(keys) | ||||||
|  |  | ||||||
| 	for _, k := range keys { | 	for _, k := range keys { | ||||||
| 		c := commands[k] | 		c := commands[k] | ||||||
| 		fmt.Printf("  %-*s    %s\n", maxLen, c.Name, c.Short) | 		fmt.Fprintf(&b, "  %-*s    %s\n", maxLen, c.Name, c.Short) | ||||||
| 	} |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| func printCmdHelp(name string) error { | 	return b.String() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func printCmdHelp(name string) (string, error) { | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	subCmd, ok := commandRegistry[name] | 	subCmd, ok := commandRegistry[name] | ||||||
|  |  | ||||||
| 	if !ok { | 	if !ok { | ||||||
| 		return fmt.Errorf("unknown commnnd: %s\n", name) | 		return "", fmt.Errorf("unknown commnnd: %s\n", name) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if subCmd.Use != "" { | 	if subCmd.Use != "" { | ||||||
| 		fmt.Printf("usage:\n  lume %s %s\n", subCmd.Name, subCmd.Use) | 		fmt.Fprintf(&b, "usage:\n  lume %s %s\n", subCmd.Name, subCmd.Use) | ||||||
| 	} else { | 	} else { | ||||||
| 		fmt.Printf("usage:\n  lume %s\n", subCmd.Name) | 		fmt.Fprintf(&b, "usage:\n  lume %s\n", subCmd.Name) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if subCmd.Flags != nil { | 	if subCmd.Flags != nil { | ||||||
| 		fmt.Println() | 		out := subCmd.Flags.Output() | ||||||
| 		fmt.Print("flags:\n") | 		defer subCmd.Flags.SetOutput(out) | ||||||
|  |  | ||||||
|  | 		fmt.Fprintln(&b) | ||||||
|  | 		fmt.Fprint(&b, "flags:\n") | ||||||
|  |  | ||||||
|  | 		subCmd.Flags.SetOutput(&b) | ||||||
| 		subCmd.Flags.PrintDefaults() | 		subCmd.Flags.PrintDefaults() | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return nil | 	return b.String(), nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func NewCmdLs() Command { | func NewCmdLs() Command { | ||||||
| @@ -42,7 +43,7 @@ func LsCmd(ctx Context) (int, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	p = NewPrinter(format) | 	p = NewPrinter(format) | ||||||
| 	p.Lights(lights) | 	fmt.Print(p.Lights(lights)) | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| ) | ) | ||||||
| @@ -48,7 +49,7 @@ func PoweroffCmd(ctx Context) (int, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	p = NewPrinter(format) | 	p = NewPrinter(format) | ||||||
| 	p.Results(r.Results) | 	fmt.Print(p.Results(r.Results)) | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| ) | ) | ||||||
| @@ -48,7 +49,7 @@ func PoweronCmd(ctx Context) (int, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	p = NewPrinter(format) | 	p = NewPrinter(format) | ||||||
| 	p.Results(r.Results) | 	fmt.Print(p.Results(r.Results)) | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								cmd/print.go
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								cmd/print.go
									
									
									
									
									
								
							| @@ -2,7 +2,8 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"os" | 	"io" | ||||||
|  | 	"strings" | ||||||
| 	"time" | 	"time" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| @@ -11,8 +12,8 @@ import ( | |||||||
| ) | ) | ||||||
|  |  | ||||||
| type Printer interface { | type Printer interface { | ||||||
| 	Results(results []lifx.Result) | 	Results(results []lifx.Result) string | ||||||
| 	Lights(lights []lifx.Light) | 	Lights(lights []lifx.Light) string | ||||||
| } | } | ||||||
|  |  | ||||||
| type defaultPrinter struct{} | type defaultPrinter struct{} | ||||||
| @@ -28,17 +29,19 @@ func NewPrinter(format string) Printer { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (dp *defaultPrinter) Results(results []lifx.Result) { | func (dp *defaultPrinter) Results(results []lifx.Result) string { | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	sortResults(results) | 	sortResults(results) | ||||||
|  |  | ||||||
| 	table := tablewriter.NewWriter(os.Stdout) | 	table := tablewriter.NewWriter(&b) | ||||||
| 	_, rows := makeResultsTable(results) | 	_, rows := makeResultsTable(results) | ||||||
|  |  | ||||||
| 	for _, v := range rows { | 	for _, v := range rows { | ||||||
| 		table.Append(v) | 		table.Append(v) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	fmt.Printf("total %d\n", len(results)) | 	fmt.Fprintf(&b, "total %d\n", len(results)) | ||||||
| 	table.SetAlignment(tablewriter.ALIGN_LEFT) | 	table.SetAlignment(tablewriter.ALIGN_LEFT) | ||||||
| 	table.SetAutoWrapText(false) | 	table.SetAutoWrapText(false) | ||||||
| 	table.SetBorder(false) | 	table.SetBorder(false) | ||||||
| @@ -49,12 +52,16 @@ func (dp *defaultPrinter) Results(results []lifx.Result) { | |||||||
| 	table.SetRowSeparator("") | 	table.SetRowSeparator("") | ||||||
| 	table.SetTablePadding(" ") | 	table.SetTablePadding(" ") | ||||||
| 	table.Render() | 	table.Render() | ||||||
|  |  | ||||||
|  | 	return b.String() | ||||||
| } | } | ||||||
|  |  | ||||||
| func (tp *tablePrinter) Results(results []lifx.Result) { | func (tp *tablePrinter) Results(results []lifx.Result) string { | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	sortResults(results) | 	sortResults(results) | ||||||
|  |  | ||||||
| 	table := tablewriter.NewWriter(os.Stdout) | 	table := tablewriter.NewWriter(&b) | ||||||
| 	hdr, rows := makeResultsTable(results) | 	hdr, rows := makeResultsTable(results) | ||||||
|  |  | ||||||
| 	for _, v := range rows { | 	for _, v := range rows { | ||||||
| @@ -63,19 +70,23 @@ func (tp *tablePrinter) Results(results []lifx.Result) { | |||||||
|  |  | ||||||
| 	table.SetHeader(hdr) | 	table.SetHeader(hdr) | ||||||
| 	table.Render() | 	table.Render() | ||||||
|  |  | ||||||
|  | 	return b.String() | ||||||
| } | } | ||||||
|  |  | ||||||
| func (dp *defaultPrinter) Lights(lights []lifx.Light) { | func (dp *defaultPrinter) Lights(lights []lifx.Light) string { | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	sortLights(lights) | 	sortLights(lights) | ||||||
|  |  | ||||||
| 	table := tablewriter.NewWriter(os.Stdout) | 	table := tablewriter.NewWriter(&b) | ||||||
| 	_, rows := makeLightsTable(lights) | 	_, rows := makeLightsTable(lights) | ||||||
|  |  | ||||||
| 	for _, v := range rows { | 	for _, v := range rows { | ||||||
| 		table.Append(v) | 		table.Append(v) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	fmt.Printf("total %d\n", len(lights)) | 	fmt.Fprintf(&b, "total %d\n", len(lights)) | ||||||
| 	table.SetAlignment(tablewriter.ALIGN_LEFT) | 	table.SetAlignment(tablewriter.ALIGN_LEFT) | ||||||
| 	table.SetAutoWrapText(false) | 	table.SetAutoWrapText(false) | ||||||
| 	table.SetBorder(false) | 	table.SetBorder(false) | ||||||
| @@ -86,12 +97,16 @@ func (dp *defaultPrinter) Lights(lights []lifx.Light) { | |||||||
| 	table.SetRowSeparator("") | 	table.SetRowSeparator("") | ||||||
| 	table.SetTablePadding(" ") | 	table.SetTablePadding(" ") | ||||||
| 	table.Render() | 	table.Render() | ||||||
|  |  | ||||||
|  | 	return b.String() | ||||||
| } | } | ||||||
|  |  | ||||||
| func (tp *tablePrinter) Lights(lights []lifx.Light) { | func (tp *tablePrinter) Lights(lights []lifx.Light) string { | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	sortLights(lights) | 	sortLights(lights) | ||||||
|  |  | ||||||
| 	table := tablewriter.NewWriter(os.Stdout) | 	table := tablewriter.NewWriter(&b) | ||||||
| 	hdr, rows := makeLightsTable(lights) | 	hdr, rows := makeLightsTable(lights) | ||||||
|  |  | ||||||
| 	for _, v := range rows { | 	for _, v := range rows { | ||||||
| @@ -100,6 +115,8 @@ func (tp *tablePrinter) Lights(lights []lifx.Light) { | |||||||
|  |  | ||||||
| 	table.SetHeader(hdr) | 	table.SetHeader(hdr) | ||||||
| 	table.Render() | 	table.Render() | ||||||
|  |  | ||||||
|  | 	return b.String() | ||||||
| } | } | ||||||
|  |  | ||||||
| func ColorizeIndicator(s string) string { | func ColorizeIndicator(s string) string { | ||||||
| @@ -138,6 +155,11 @@ func PrintfWithIndent(indent int, format string, a ...interface{}) (n int, err e | |||||||
| 	return fmt.Printf(format, a...) | 	return fmt.Printf(format, a...) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func FprintfWithIndent(w io.Writer, indent int, format string, a ...interface{}) (n int, err error) { | ||||||
|  | 	format = fmt.Sprintf("%*s%s", indent, "", format) | ||||||
|  | 	return fmt.Fprintf(w, format, a...) | ||||||
|  | } | ||||||
|  |  | ||||||
| func makeLightsTable(lights []lifx.Light) (hdr []string, rows [][]string) { | func makeLightsTable(lights []lifx.Light) (hdr []string, rows [][]string) { | ||||||
| 	hdr = []string{"", "ID", "Location", "Group", "Label", "Last Seen", "Power"} | 	hdr = []string{"", "ID", "Location", "Group", "Label", "Last Seen", "Power"} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -130,7 +130,7 @@ func SetColorCmd(ctx Context) (int, error) { | |||||||
|  |  | ||||||
| 	if !fast { | 	if !fast { | ||||||
| 		p = NewPrinter(format) | 		p = NewPrinter(format) | ||||||
| 		p.Results(r.Results) | 		fmt.Print(p.Results(r.Results)) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| ) | ) | ||||||
| @@ -96,7 +97,7 @@ func SetStateCmd(ctx Context) (int, error) { | |||||||
|  |  | ||||||
| 	if !fast { | 	if !fast { | ||||||
| 		p = NewPrinter(format) | 		p = NewPrinter(format) | ||||||
| 		p.Results(r.Results) | 		fmt.Print(p.Results(r.Results)) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| ) | ) | ||||||
| @@ -114,7 +115,7 @@ func SetWhiteCmd(ctx Context) (int, error) { | |||||||
|  |  | ||||||
| 	if !fast { | 	if !fast { | ||||||
| 		p = NewPrinter(format) | 		p = NewPrinter(format) | ||||||
| 		p.Results(r.Results) | 		fmt.Print(p.Results(r.Results)) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								cmd/show.go
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								cmd/show.go
									
									
									
									
									
								
							| @@ -3,6 +3,7 @@ package lumecmd | |||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
| 	"fmt" | 	"fmt" | ||||||
|  | 	"strings" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| const Tabstop int = 2 | const Tabstop int = 2 | ||||||
| @@ -26,6 +27,8 @@ func NewCmdShow() Command { | |||||||
|  |  | ||||||
| func ShowCmd(ctx Context) (int, error) { | func ShowCmd(ctx Context) (int, error) { | ||||||
| 	var indent int | 	var indent int | ||||||
|  | 	var b strings.Builder | ||||||
|  |  | ||||||
| 	c := ctx.Client | 	c := ctx.Client | ||||||
| 	selector := ctx.Flags.String("selector") | 	selector := ctx.Flags.String("selector") | ||||||
| 	lights, err := c.ListLights(selector) | 	lights, err := c.ListLights(selector) | ||||||
| @@ -38,7 +41,8 @@ func ShowCmd(ctx Context) (int, error) { | |||||||
|  |  | ||||||
| 	for i, l := range lights { | 	for i, l := range lights { | ||||||
| 		indent = 0 | 		indent = 0 | ||||||
| 		fmt.Printf( | 		fmt.Fprintf( | ||||||
|  | 			&b, | ||||||
| 			"%s Light ID: %s, %s, Power: %s\n", | 			"%s Light ID: %s, %s, Power: %s\n", | ||||||
| 			ColorizeIndicator(l.Power), | 			ColorizeIndicator(l.Power), | ||||||
| 			l.Id, | 			l.Id, | ||||||
| @@ -46,41 +50,43 @@ func ShowCmd(ctx Context) (int, error) { | |||||||
| 			ColorizePower(l.Power), | 			ColorizePower(l.Power), | ||||||
| 		) | 		) | ||||||
| 		indent += Tabstop + 2 | 		indent += Tabstop + 2 | ||||||
| 		PrintfWithIndent(indent, "Label: %s, ID: %s\n", l.Label, l.Id) | 		FprintfWithIndent(&b, indent, "Label: %s, ID: %s\n", l.Label, l.Id) | ||||||
| 		PrintfWithIndent(indent, "UUID: %s\n", l.UUID) | 		FprintfWithIndent(&b, indent, "UUID: %s\n", l.UUID) | ||||||
| 		PrintfWithIndent(indent, "Location: %s, ID: %s\n", l.Location.Name, l.Location.Id) | 		FprintfWithIndent(&b, indent, "Location: %s, ID: %s\n", l.Location.Name, l.Location.Id) | ||||||
| 		PrintfWithIndent(indent, "Group: %s, ID: %s\n", l.Group.Name, l.Group.Id) | 		FprintfWithIndent(&b, indent, "Group: %s, ID: %s\n", l.Group.Name, l.Group.Id) | ||||||
| 		PrintfWithIndent(indent, "Color: Hue: %.1f, Saturation: %.1f%%, Kelvin: %d\n", | 		FprintfWithIndent(&b, indent, "Color: Hue: %.1f, Saturation: %.1f%%, Kelvin: %d\n", | ||||||
| 			*l.Color.H, *l.Color.S, *l.Color.K) | 			*l.Color.H, *l.Color.S, *l.Color.K) | ||||||
| 		PrintfWithIndent(indent, "Brightness: %.1f%%\n", l.Brightness*100) | 		FprintfWithIndent(&b, indent, "Brightness: %.1f%%\n", l.Brightness*100) | ||||||
| 		if l.Effect != "" { | 		if l.Effect != "" { | ||||||
| 			PrintfWithIndent(indent, "Effect: %s\n", l.Effect) | 			FprintfWithIndent(&b, indent, "Effect: %s\n", l.Effect) | ||||||
| 		} | 		} | ||||||
| 		PrintfWithIndent(indent, "Product: %s\n", l.Product.Name) | 		FprintfWithIndent(&b, indent, "Product: %s\n", l.Product.Name) | ||||||
| 		PrintfWithIndent(indent, "Capabilities: ") | 		FprintfWithIndent(&b, indent, "Capabilities: ") | ||||||
| 		fmt.Printf("Color: %s, ", YesNo(l.Product.Capabilities.HasColor)) | 		fmt.Fprintf(&b, "Color: %s, ", YesNo(l.Product.Capabilities.HasColor)) | ||||||
| 		fmt.Printf("Variable Color Temp: %s, ", YesNo(l.Product.Capabilities.HasVariableColorTemp)) | 		fmt.Fprintf(&b, "Variable Color Temp: %s, ", YesNo(l.Product.Capabilities.HasVariableColorTemp)) | ||||||
| 		fmt.Printf("IR: %s, ", YesNo(l.Product.Capabilities.HasIR)) | 		fmt.Fprintf(&b, "IR: %s, ", YesNo(l.Product.Capabilities.HasIR)) | ||||||
| 		fmt.Printf("Chain: %s, ", YesNo(l.Product.Capabilities.HasChain)) | 		fmt.Fprintf(&b, "Chain: %s, ", YesNo(l.Product.Capabilities.HasChain)) | ||||||
| 		fmt.Printf("Multizone: %s, ", YesNo(l.Product.Capabilities.HasMultizone)) | 		fmt.Fprintf(&b, "Multizone: %s, ", YesNo(l.Product.Capabilities.HasMultizone)) | ||||||
| 		fmt.Printf("Min Kelvin: %.1f, ", l.Product.Capabilities.MinKelvin) | 		fmt.Fprintf(&b, "Min Kelvin: %.1f, ", l.Product.Capabilities.MinKelvin) | ||||||
| 		fmt.Printf("Max Kelvin: %.1f ", l.Product.Capabilities.MaxKelvin) | 		fmt.Fprintf(&b, "Max Kelvin: %.1f ", l.Product.Capabilities.MaxKelvin) | ||||||
| 		fmt.Println() | 		fmt.Fprintln(&b) | ||||||
| 		// List applicable selectors (most to least specific) | 		// List applicable selectors (most to least specific) | ||||||
| 		PrintfWithIndent(indent, "Selectors:\n") | 		FprintfWithIndent(&b, indent, "Selectors:\n") | ||||||
| 		indent += Tabstop | 		indent += Tabstop | ||||||
| 		PrintfWithIndent(indent, "id:%s\n", l.Id) | 		FprintfWithIndent(&b, indent, "id:%s\n", l.Id) | ||||||
| 		PrintfWithIndent(indent, "label:%s\n", l.Label) | 		FprintfWithIndent(&b, indent, "label:%s\n", l.Label) | ||||||
| 		PrintfWithIndent(indent, "group_id:%s\n", l.Group.Id) | 		FprintfWithIndent(&b, indent, "group_id:%s\n", l.Group.Id) | ||||||
| 		PrintfWithIndent(indent, "group:%s\n", l.Group.Name) | 		FprintfWithIndent(&b, indent, "group:%s\n", l.Group.Name) | ||||||
| 		PrintfWithIndent(indent, "location_id:%s\n", l.Location.Id) | 		FprintfWithIndent(&b, indent, "location_id:%s\n", l.Location.Id) | ||||||
| 		PrintfWithIndent(indent, "location:%s\n", l.Location.Name) | 		FprintfWithIndent(&b, indent, "location:%s\n", l.Location.Name) | ||||||
| 		indent -= Tabstop | 		indent -= Tabstop | ||||||
| 		PrintfWithIndent(indent, "Last Seen: %s (%.1fs ago)\n", l.LastSeen, l.SecondsLastSeen) | 		FprintfWithIndent(&b, indent, "Last Seen: %s (%.1fs ago)\n", l.LastSeen, l.SecondsLastSeen) | ||||||
|  |  | ||||||
| 		if i < len(lights)-1 { | 		if i < len(lights)-1 { | ||||||
| 			fmt.Println() | 			fmt.Fprintln(&b) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		fmt.Print(b.String()) | ||||||
| 	} | 	} | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package lumecmd | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"flag" | 	"flag" | ||||||
|  | 	"fmt" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func NewCmdToggle() Command { | func NewCmdToggle() Command { | ||||||
| @@ -45,7 +46,7 @@ func ToggleCmd(ctx Context) (int, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	p = NewPrinter(format) | 	p = NewPrinter(format) | ||||||
| 	p.Results(r.Results) | 	fmt.Print(p.Results(r.Results)) | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ import ( | |||||||
| 	"errors" | 	"errors" | ||||||
| 	"flag" | 	"flag" | ||||||
| 	"fmt" | 	"fmt" | ||||||
|  | 	"strings" | ||||||
|  |  | ||||||
| 	"git.kill0.net/chill9/lifx-go" | 	"git.kill0.net/chill9/lifx-go" | ||||||
| ) | ) | ||||||
| @@ -23,10 +24,11 @@ func NewCmdValidate() Command { | |||||||
| } | } | ||||||
|  |  | ||||||
| func ValidateCmd(ctx Context) (int, error) { | func ValidateCmd(ctx Context) (int, error) { | ||||||
|  | 	var b strings.Builder | ||||||
| 	c := ctx.Client | 	c := ctx.Client | ||||||
|  |  | ||||||
| 	if len(ctx.Args) != 1 { | 	if len(ctx.Args) != 1 { | ||||||
| 		printCmdHelp(ctx.Name) | 		fmt.Print(printCmdHelp(ctx.Name)) | ||||||
| 		return ExitFailure, nil | 		return ExitFailure, nil | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -38,11 +40,12 @@ func ValidateCmd(ctx Context) (int, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if validColor, ok := i.(*lifx.HSBKColor); ok { | 	if validColor, ok := i.(*lifx.HSBKColor); ok { | ||||||
| 		fmt.Print(validColor) | 		fmt.Fprintln(&b, validColor) | ||||||
| 	} else { | 	} else { | ||||||
| 		return ExitFailure, errors.New("go type %T but wanted *HSBKColor") | 		return ExitFailure, errors.New("go type %T but wanted *HSBKColor") | ||||||
| 	} | 	} | ||||||
| 	fmt.Println() |  | ||||||
|  | 	fmt.Print(b.String()) | ||||||
|  |  | ||||||
| 	return ExitSuccess, nil | 	return ExitSuccess, nil | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @@ -3,7 +3,7 @@ module git.kill0.net/chill9/lume | |||||||
| go 1.15 | go 1.15 | ||||||
|  |  | ||||||
| require ( | require ( | ||||||
| 	git.kill0.net/chill9/lifx-go v0.0.0-20210329222320-2107a0586447 | 	git.kill0.net/chill9/lifx-go v0.0.0-20210418161634-4c1678b62c73 | ||||||
| 	github.com/BurntSushi/toml v0.3.1 | 	github.com/BurntSushi/toml v0.3.1 | ||||||
| 	github.com/fatih/color v1.10.0 | 	github.com/fatih/color v1.10.0 | ||||||
| 	github.com/mattn/go-runewidth v0.0.10 // indirect | 	github.com/mattn/go-runewidth v0.0.10 // indirect | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.sum
									
									
									
									
									
								
							| @@ -4,6 +4,8 @@ git.kill0.net/chill9/lifx-go v0.0.0-20210323044657-dbe1c40e1621 h1:koWq2W08Hjmvs | |||||||
| git.kill0.net/chill9/lifx-go v0.0.0-20210323044657-dbe1c40e1621/go.mod h1:jInpjEqTBhrFpQKk7zPIWISvgjjfS2djXeKB3yB/8dY= | git.kill0.net/chill9/lifx-go v0.0.0-20210323044657-dbe1c40e1621/go.mod h1:jInpjEqTBhrFpQKk7zPIWISvgjjfS2djXeKB3yB/8dY= | ||||||
| git.kill0.net/chill9/lifx-go v0.0.0-20210329222320-2107a0586447 h1:tN+zR5aszesrZRrhS3uOqAIWLcADCIH7GFJ6SOQS9r0= | git.kill0.net/chill9/lifx-go v0.0.0-20210329222320-2107a0586447 h1:tN+zR5aszesrZRrhS3uOqAIWLcADCIH7GFJ6SOQS9r0= | ||||||
| git.kill0.net/chill9/lifx-go v0.0.0-20210329222320-2107a0586447/go.mod h1:jInpjEqTBhrFpQKk7zPIWISvgjjfS2djXeKB3yB/8dY= | git.kill0.net/chill9/lifx-go v0.0.0-20210329222320-2107a0586447/go.mod h1:jInpjEqTBhrFpQKk7zPIWISvgjjfS2djXeKB3yB/8dY= | ||||||
|  | git.kill0.net/chill9/lifx-go v0.0.0-20210418161634-4c1678b62c73 h1:fteCAelwAcfam2Q8eeJFyK4+sXGOpR6Me5YMKBi+MYY= | ||||||
|  | git.kill0.net/chill9/lifx-go v0.0.0-20210418161634-4c1678b62c73/go.mod h1:jInpjEqTBhrFpQKk7zPIWISvgjjfS2djXeKB3yB/8dY= | ||||||
| github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ= | github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ= | ||||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||||
| github.com/fatih/color v1.10.0 h1:s36xzo75JdqLaaWoiEHk767eHiwo0598uUxyfiPkDsg= | github.com/fatih/color v1.10.0 h1:s36xzo75JdqLaaWoiEHk767eHiwo0598uUxyfiPkDsg= | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user