README ¶
VT100
- Supports colors and attributes.
- Developed for Linux. May work on other systems, but there are no guarantees.
- Can detect the terminal size.
- Can get key-presses, including arrow keys.
- Has a Canvas struct, for drawing only the updated characters to the terminal.
- Uses the spec directly, but memoizes the commands sent to the terminal, for speed.
- Everything is ready if someone wants to use this to build a utility similar to
dialog
orwhiptail
.
Images
Screen recording of the shooter
example, where you can control a small character with the arrow keys and shoot with space
.
Screen recording of the menu
example, which uses VT100 terminal codes and demonstrates a working menu.
A physical VT100 terminal. Photo by Jason Scott, CC BY 2.0
The vt100
Go Module
Simple use
Output "hi" in blue:
fmt.Println(vt100.BrightColor("hi", "Blue"))
Erase the current line:
vt100.Do("Erase Line")
Move the cursor 3 steps up (it's a bit verbose, but it's generated directly from spec, memoized for speed and is easy to wrap in a custom function):
vt100.Set("Cursor Up", map[string]string{"{COUNT}": "3"})
The full overview of possible commands are at the top of vt100.go
.
Another example
See cmd/move
for a more advanced example, where a character can be moved around with the arrow keys.
Features and limitations
- Can detect letters, arrow keys and space. F12 and similar keys are not supported (they are supported by vt220 but not vt100).
- Resizing the terminal when using the Canvas struct may cause artifacts, for a brief moment.
- Holding down a key may trigger key repetition which may speed up the main loop.
General info
- Version: 1.2.1
- Licence: MIT
- Author: Alexander F. Rødseth <xyproto@archlinux.org>
Documentation ¶
Index ¶
- Variables
- func ASCIIOnce() int
- func AttributeAndColor(attr, name string) string
- func AttributeNumber(name string) string
- func AttributeOrColor(name string) string
- func BrightColor(text, color string) string
- func Clear()
- func Close()
- func ColorNum(colorNum int) string
- func ColorString(line, colors string) string
- func Colors() []string
- func Commands() []string
- func DarkColor(text, color string) string
- func Do(command string)
- func Down(n uint)
- func EchoOff()
- func Get(command string, replacemap map[string]string) string
- func Home()
- func Init()
- func KeyCodeOnce() int
- func KeyOnce() int
- func Left(n uint)
- func NoColor() string
- func Reset()
- func Right(n uint)
- func ScreenHeight() int
- func ScreenWidth() int
- func Set(command string, replacemap map[string]string)
- func SetAttribute(name string)
- func SetAttributeAndColor(attr, name string)
- func SetColorNum(colorNum int)
- func SetLineWrap(enable bool)
- func SetNoColor()
- func SetXY(x, y uint)
- func ShowCursor(enable bool)
- func Stop() string
- func TermSize() (uint, uint, error)
- func TrueColor(fg color.Color, text string) string
- func Up(n uint)
- func WaitForKey()
- func Words(line string, colors ...string) string
- func Write(x, y int, text string, fg, bg AttributeColor)
- func WriteRune(x, y int, r rune, fg, bg AttributeColor)
- type AttributeColor
- func (ac AttributeColor) Background() AttributeColor
- func (ac AttributeColor) Bright() AttributeColor
- func (ac AttributeColor) Combine(other AttributeColor) AttributeColor
- func (ac AttributeColor) Error(text string)
- func (ac AttributeColor) Get(text string) string
- func (ac AttributeColor) Head() byte
- func (ac AttributeColor) Ints() []int
- func (ac AttributeColor) Output(text string)
- func (ac AttributeColor) Start(text string) string
- func (ac AttributeColor) StartStop(text string) string
- func (ac AttributeColor) Stop(text string) string
- func (ac AttributeColor) String() string
- func (ac AttributeColor) Tail() []byte
- type Canvas
- func (c *Canvas) At(x, y uint) (rune, error)
- func (c *Canvas) Clear()
- func (c *Canvas) Draw()
- func (c *Canvas) Fill(fg AttributeColor)
- func (c *Canvas) FillBackground(bg AttributeColor)
- func (c *Canvas) H() uint
- func (c *Canvas) Plot(x, y uint, s rune)
- func (c *Canvas) PlotAC(x, y uint, ac AttributeColor, s rune)
- func (c *Canvas) PlotC(x, y uint, fg string, s rune)
- func (c *Canvas) PlotDC(x, y uint, fg string, s rune)
- func (c *Canvas) Redraw()
- func (c *Canvas) Resize()
- func (c *Canvas) Resized() *Canvas
- func (c *Canvas) Size() (uint, uint)
- func (c *Canvas) String() string
- func (c *Canvas) W() uint
- func (c *Canvas) Write(x, y uint, fg, bg AttributeColor, s string)
- func (c *Canvas) WriteRune(x, y uint, fg, bg AttributeColor, r rune)
- type Char
- type TTY
Constants ¶
This section is empty.
Variables ¶
var ( // Non-color attributes ResetAll = NewAttributeColor("Reset all attributes") Bright = NewAttributeColor("Bright") Dim = NewAttributeColor("Dim") Underscore = NewAttributeColor("Underscore") Blink = NewAttributeColor("Blink") Reverse = NewAttributeColor("Reverse") Hidden = NewAttributeColor("Hidden") None AttributeColor // Dark foreground colors (+ light gray) Black = NewAttributeColor("Black") Red = NewAttributeColor("Red") Green = NewAttributeColor("Green") Yellow = NewAttributeColor("Yellow") Blue = NewAttributeColor("Blue") Magenta = NewAttributeColor("Magenta") Cyan = NewAttributeColor("Cyan") LightGray = NewAttributeColor("White") // Light foreground colors (+ dark gray) DarkGray = NewAttributeColor("Bright", "Black") LightRed = NewAttributeColor("Bright", "Red") LightGreen = NewAttributeColor("Bright", "Green") LightYellow = NewAttributeColor("Bright", "Yellow") LightBlue = NewAttributeColor("Bright", "Blue") LightMagenta = NewAttributeColor("Bright", "Magenta") LightCyan = NewAttributeColor("Bright", "Cyan") White = NewAttributeColor("Bright", "White") // Aliases Pink = LightMagenta Gray = DarkGray // Dark background colors (+ light gray) BackgroundBlack = NewAttributeColor("40") BackgroundRed = NewAttributeColor("41") BackgroundGreen = NewAttributeColor("42") BackgroundYellow = NewAttributeColor("43") BackgroundBlue = NewAttributeColor("44") BackgroundMagenta = NewAttributeColor("45") BackgroundCyan = NewAttributeColor("46") BackgroundLightGray = NewAttributeColor("47") // Aliases BackgroundWhite = BackgroundLightGray BackgroundGray = BackgroundLightGray // Default colors (usually gray) Default = NewAttributeColor("39") BackgroundDefault = NewAttributeColor("49") DarkColorMap = map[string]AttributeColor{ "black": Black, "Black": Black, "red": Red, "Red": Red, "green": Green, "Green": Green, "yellow": Yellow, "Yellow": Yellow, "blue": Blue, "Blue": Blue, "magenta": Magenta, "Magenta": Magenta, "cyan": Cyan, "Cyan": Cyan, "gray": DarkGray, "Gray": DarkGray, "white": White, "White": White, "darkred": Red, "DarkRed": Red, "darkgreen": Green, "DarkGreen": Green, "darkyellow": Yellow, "DarkYellow": Yellow, "darkblue": Blue, "DarkBlue": Blue, "darkmagenta": Magenta, "DarkMagenta": Magenta, "darkcyan": Cyan, "DarkCyan": Cyan, "darkgray": DarkGray, "DarkGray": DarkGray, "lightred": LightRed, "LightRed": LightRed, "lightgreen": LightGreen, "LightGreen": LightGreen, "lightyellow": LightYellow, "LightYellow": LightYellow, "lightblue": LightBlue, "LightBlue": LightBlue, "lightmagenta": LightMagenta, "LightMagenta": LightMagenta, "lightcyan": LightCyan, "LightCyan": LightCyan, "lightgray": LightGray, "LightGray": LightGray, } LightColorMap = map[string]AttributeColor{ "black": Black, "Black": Black, "red": LightRed, "Red": LightRed, "green": LightGreen, "Green": LightGreen, "yellow": LightYellow, "Yellow": LightYellow, "blue": LightBlue, "Blue": LightBlue, "magenta": LightMagenta, "Magenta": LightMagenta, "cyan": LightCyan, "Cyan": LightCyan, "gray": LightGray, "Gray": LightGray, "white": White, "White": White, "lightred": LightRed, "LightRed": LightRed, "lightgreen": LightGreen, "LightGreen": LightGreen, "lightyellow": LightYellow, "LightYellow": LightYellow, "lightblue": LightBlue, "LightBlue": LightBlue, "lightmagenta": LightMagenta, "LightMagenta": LightMagenta, "lightcyan": LightCyan, "LightCyan": LightCyan, "lightgray": LightGray, "LightGray": LightGray, "darkred": Red, "DarkRed": Red, "darkgreen": Green, "DarkGreen": Green, "darkyellow": Yellow, "DarkYellow": Yellow, "darkblue": Blue, "DarkBlue": Blue, "darkmagenta": Magenta, "DarkMagenta": Magenta, "darkcyan": Cyan, "DarkCyan": Cyan, "darkgray": DarkGray, "DarkGray": DarkGray, } )
Functions ¶
func AttributeAndColor ¶
Get the terminal command for setting a terminal attribute and a color
func AttributeNumber ¶ added in v0.5.0
Returns the number (as a string) for a given attribute name. Returns the given string if the attribute was not found in the spec.
func AttributeOrColor ¶
Execute the terminal command for setting a given display attribute name, like "Bright" or "Blink"
func BrightColor ¶
Return text with a bright color applied
func ColorString ¶ added in v1.2.0
Takes a string with words to be colored and another string with colors with which to color the words. Example strings: "hello there" and "red blue".
func KeyCodeOnce ¶ added in v0.2.1
func KeyCodeOnce() int
func NoColor ¶
func NoColor() string
Get the terminal command for setting no colors or other display attributes
func SetAttribute ¶
func SetAttribute(name string)
Execute the terminal command for setting a given display attribute name, like "Bright" or "Blink"
func SetAttributeAndColor ¶
func SetAttributeAndColor(attr, name string)
Execute the terminal command for setting a terminal attribute and a color
func SetColorNum ¶
func SetColorNum(colorNum int)
Execute the terminal command for setting a given color number
func SetLineWrap ¶
func SetLineWrap(enable bool)
func SetNoColor ¶
func SetNoColor()
Execute the terminal command for setting no colors or other display attributes
func SetXY ¶
func SetXY(x, y uint)
Move cursor to the given position (from 0 and up, the terminal code is from 1 and up)
func ShowCursor ¶
func ShowCursor(enable bool)
func TrueColor ¶ added in v0.4.0
This is not part of the VT100 spec, but an easteregg for displaying 24-bit "true color" on some terminals. Example use: fmt.Println(vt100.TrueColor(color.RGBA{0xa0, 0xe0, 0xff, 0xff}, "TrueColor"))
func Words ¶ added in v0.7.0
Takes a string with words and several color-strings, like "blue". Color the words with the corresponding colors and return the string.
func Write ¶ added in v0.6.0
func Write(x, y int, text string, fg, bg AttributeColor)
Output a string at x, y with the given colors
func WriteRune ¶ added in v0.6.0
func WriteRune(x, y int, r rune, fg, bg AttributeColor)
Output a rune at x, y with the given colors
Types ¶
type AttributeColor ¶ added in v0.3.0
type AttributeColor []byte
func NewAttributeColor ¶ added in v0.5.0
func NewAttributeColor(attributes ...string) AttributeColor
func (AttributeColor) Background ¶ added in v0.7.0
func (ac AttributeColor) Background() AttributeColor
Modify color attributes so that they become background color attributes instead
func (AttributeColor) Bright ¶ added in v0.6.0
func (ac AttributeColor) Bright() AttributeColor
Return a new AttributeColor that has "Bright" added to the list of attributes
func (AttributeColor) Combine ¶ added in v0.5.0
func (ac AttributeColor) Combine(other AttributeColor) AttributeColor
func (AttributeColor) Error ¶ added in v1.0.1
func (ac AttributeColor) Error(text string)
Same as output, but outputs to stderr instead of stdout
func (AttributeColor) Get ¶ added in v0.3.0
func (ac AttributeColor) Get(text string) string
An alias for StartStop
func (AttributeColor) Head ¶ added in v0.6.0
func (ac AttributeColor) Head() byte
func (AttributeColor) Ints ¶ added in v0.7.0
func (ac AttributeColor) Ints() []int
func (AttributeColor) Output ¶ added in v0.3.0
func (ac AttributeColor) Output(text string)
Use this color to output the given text. Will reset the attributes at the end of the string. Outputs a newline.
func (AttributeColor) Start ¶ added in v0.6.0
func (ac AttributeColor) Start(text string) string
Get the full string needed for outputting colored text, with the text, but don't reset the attributes at the end of the string
func (AttributeColor) StartStop ¶ added in v0.6.0
func (ac AttributeColor) StartStop(text string) string
Get the full string needed for outputting colored texti, with the text and stopping the color attribute
func (AttributeColor) Stop ¶ added in v0.6.0
func (ac AttributeColor) Stop(text string) string
Get the text and the terminal codes for resetting the attributes
func (AttributeColor) String ¶ added in v0.6.0
func (ac AttributeColor) String() string
Return the VT100 terminal codes for setting this combination of attributes and color attributes
func (AttributeColor) Tail ¶ added in v0.6.0
func (ac AttributeColor) Tail() []byte
type Canvas ¶
type Canvas struct {
// contains filtered or unexported fields
}
func (*Canvas) At ¶ added in v0.2.1
At returns the rune at the given coordinates, or an error if out of bounds
func (*Canvas) Fill ¶ added in v0.6.0
func (c *Canvas) Fill(fg AttributeColor)
Change the foreground color for each character
func (*Canvas) FillBackground ¶ added in v0.6.0
func (c *Canvas) FillBackground(bg AttributeColor)
Change the background color for each character
func (*Canvas) PlotAC ¶ added in v0.6.0
func (c *Canvas) PlotAC(x, y uint, ac AttributeColor, s rune)
Plot a foreground color and a rune
func (*Canvas) Resized ¶
Check if the canvas was resized, and adjust values accordingly. Returns a new canvas, or nil.
func (*Canvas) String ¶ added in v0.2.1
Bytes returns only the characters, as a long string with a newline after each row
func (*Canvas) Write ¶ added in v0.8.0
func (c *Canvas) Write(x, y uint, fg, bg AttributeColor, s string)
Write will write a string to the canvas, without conversion of the background color bg to a background color (use bg.Background()). Beware that strings that consists of multi-byte runes may not be written correctly! For those cases, use WriteRune instead.
type TTY ¶ added in v0.2.1
type TTY struct {
// contains filtered or unexported fields
}
func (*TTY) Close ¶ added in v0.2.1
func (tty *TTY) Close()
Close will Restore and close the raw terminal
func (*TTY) NoBlock ¶ added in v0.2.1
func (tty *TTY) NoBlock()
NoBlock leaves "cooked" mode and enters "cbreak" mode
func (*TTY) RawMode ¶ added in v0.2.1
func (tty *TTY) RawMode()
RawMode will switch the terminal to raw mode
func (*TTY) SetTimeout ¶ added in v0.2.1
SetTimeout sets a timeout for reading a key