packer-cn/packer/ui.go

101 lines
2.1 KiB
Go
Raw Normal View History

package packer
import (
"fmt"
"io"
2013-05-21 14:40:07 -04:00
"log"
)
2013-06-03 16:35:43 -04:00
type UiColor uint
const (
UiColorRed UiColor = 31
UiColorGreen = 32
UiColorYellow = 33
UiColorBlue = 34
UiColorMagenta = 35
UiColorCyan = 36
)
// The Ui interface handles all communication for Packer with the outside
// world. This sort of control allows us to strictly control how output
// is formatted and various levels of output.
type Ui interface {
Say(string)
2013-06-03 14:30:38 -04:00
Message(string)
Error(string)
}
2013-06-03 16:35:43 -04:00
// ColoredUi is a UI that is colored using terminal colors.
type ColoredUi struct {
Color UiColor
Ui Ui
}
2013-05-21 16:20:51 -04:00
// PrefixedUi is a UI that wraps another UI implementation and adds a
// prefix to all the messages going out.
type PrefixedUi struct {
2013-06-03 14:30:38 -04:00
SayPrefix string
MessagePrefix string
Ui Ui
2013-05-21 16:20:51 -04:00
}
// The ReaderWriterUi is a UI that writes and reads from standard Go
// io.Reader and io.Writer.
type ReaderWriterUi struct {
Reader io.Reader
Writer io.Writer
}
2013-06-03 16:35:43 -04:00
func (u *ColoredUi) Say(message string) {
u.Ui.Say(u.colorize(message))
}
func (u *ColoredUi) Message(message string) {
u.Ui.Message(u.colorize(message))
}
func (u *ColoredUi) Error(message string) {
u.Ui.Error(u.colorize(message))
}
func (u *ColoredUi) colorize(message string) string {
return fmt.Sprintf("\033[0;%d;40m%s\033[0m", u.Color, message)
}
func (u *PrefixedUi) Say(message string) {
2013-06-03 14:30:38 -04:00
u.Ui.Say(fmt.Sprintf("%s: %s", u.SayPrefix, message))
}
func (u *PrefixedUi) Message(message string) {
u.Ui.Say(fmt.Sprintf("%s: %s", u.MessagePrefix, message))
2013-05-21 16:20:51 -04:00
}
func (u *PrefixedUi) Error(message string) {
2013-06-03 14:30:38 -04:00
u.Ui.Error(fmt.Sprintf("%s: %s", u.SayPrefix, message))
2013-05-21 16:20:51 -04:00
}
func (rw *ReaderWriterUi) Say(message string) {
log.Printf("ui: %s", message)
_, err := fmt.Fprint(rw.Writer, message+"\n")
2013-05-08 20:09:10 -04:00
if err != nil {
panic(err)
}
}
2013-05-08 18:12:48 -04:00
2013-06-03 14:30:38 -04:00
func (rw *ReaderWriterUi) Message(message string) {
log.Printf("ui: %s", message)
_, err := fmt.Fprintf(rw.Writer, message+"\n")
if err != nil {
panic(err)
}
}
func (rw *ReaderWriterUi) Error(message string) {
log.Printf("ui error: %s", message)
_, err := fmt.Fprint(rw.Writer, message+"\n")
2013-05-08 20:09:10 -04:00
if err != nil {
panic(err)
}
2013-05-08 18:12:48 -04:00
}