ansi

package
v0.0.0-...-054dfe1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 8, 2015 License: MIT, MIT Imports: 2 Imported by: 0

README

ansi

[go, golang]

Small, fast library to create ANSI colored strings and codes.

Example

	import "github.com/mgutz/ansi"

	// colorize a string, slowest method
	msg := ansi.Color("foo", "red+b:white")

	// create a closure to avoid escape code compilation
	phosphorize := ansi.ColorFunc("green+h:black")
	msg := phosphorize("Bring back the 80s!")

	// cache escape codes and build strings manually, faster than closure
	lime := ansi.ColorCode("green+h:black")
	reset := ansi.ColorCode("reset")

	msg := lime + "Bring back the 80s!" + reset

Other examples

	Color(s, "red")            // red
	Color(s, "red+b")          // red bold
	Color(s, "red+B")          // red blinking
	Color(s, "red+u")          // red underline
	Color(s, "red+bh")         // red bold bright
	Color(s, "red:white")      // red on white
	Color(s, "red+b:white+h")  // red bold on white bright
	Color(s, "red+B:white+h")  // red blink on white bright

To view color combinations, from terminal.

cd $GOPATH/src/github.com/mgutz/ansi
go test

Style format

"foregroundColor+attributes:backgroundColor+attributes"

Colors

  • black
  • red
  • green
  • yellow
  • blue
  • magenta
  • cyan
  • white

Attributes

  • b = bold foreground
  • B = Blink foreground
  • u = underline foreground
  • h = high intensity (bright) foreground, background
  • i = inverse

References

Wikipedia ANSI escape codes Colors

MIT License

Copyright (c) 2013 Mario Gutierrez mario@mgutz.com

See the file LICENSE for copying permission.

Documentation

Overview

Small, fast library to create ANSI colored strings and codes.

Example

// colorize a string, slowest method
msg := ansi.Color("foo", "red+b:white")

// create a closure to avoid escape code compilation
phosphorize := ansi.ColorFunc("green+h:black")
msg := phosphorize("Bring back the 80s!")

// cache escape codes and build strings manually, faster than closure
lime := ansi.ColorCode("green+h:black")
reset := ansi.ColorCode("reset")

msg := lime + "Bring back the 80s!" + reset

Other examples

Color(s, "red")            // red
Color(s, "red+b")          // red bold
Color(s, "red+B")          // red blinking
Color(s, "red+u")          // red underline
Color(s, "red+bh")         // red bold bright
Color(s, "red:white")      // red on white
Color(s, "red+b:white+h")  // red bold on white bright
Color(s, "red+B:white+h")  // red blink on white bright

To view color combinations, from terminal

cd $GOPATH/src/github.com/mgutz/ansi
go test

Style format

"foregroundColor+attributes:backgroundColor+attributes"

Colors

black
red
green
yellow
blue
magenta
cyan
white

Attributes

b = bold foreground
B = Blink foreground
u = underline foreground
h = high intensity (bright) foreground, background
i = inverse

Wikipedia ANSI escape codes [Colors](http://en.wikipedia.org/wiki/ANSI_escape_code#Colors)

Index

Examples

Constants

View Source
const (
	Reset = "\033[0m"
)

Variables

This section is empty.

Functions

func Color

func Color(s, style string) string

Surrounds `s` with ANSI color and reset code.

func ColorCode

func ColorCode(style string) string

Gets the ANSI escape code for a color style.

func ColorFunc

func ColorFunc(style string) func(string) string

Creates a fast closure.

Prefer ColorFunc over Color as it does not recompute ANSI codes.

Example
brightGreen := ColorFunc("green+h")
fmt.Println(brightGreen("lime"))
Output:

func DisableColors

func DisableColors(disable bool)

Disables ANSI color codes. On by default.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL