mirror of
https://github.com/muun/recovery.git
synced 2025-02-23 11:32:33 -05:00
315 lines
7.3 KiB
Markdown
315 lines
7.3 KiB
Markdown
|
Aurora
|
||
|
======
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/bef92/bef926a4225b9af1753689f59eeebe76da2d36b3" alt="go.dev reference"](https://pkg.go.dev/github.com/logrusorgru/aurora?tab=doc)
|
||
|
[data:image/s3,"s3://crabby-images/8e0e3/8e0e36e1c8377fb8c106cd69e6c38c81b684a25a" alt="Unlicense"](http://unlicense.org/)
|
||
|
[data:image/s3,"s3://crabby-images/9bbd5/9bbd5473014048f91c87034961a78f0b51eb7d39" alt="Build Status"](https://travis-ci.org/logrusorgru/aurora)
|
||
|
[data:image/s3,"s3://crabby-images/fdada/fdadad1042e61bc97a71fdf3137b523b9f83de8e" alt="Coverage Status"](https://coveralls.io/r/logrusorgru/aurora?branch=master)
|
||
|
[data:image/s3,"s3://crabby-images/80dc2/80dc29190a5beb5f3cdc9a19f2821a22edd8af95" alt="GoReportCard"](https://goreportcard.com/report/logrusorgru/aurora)
|
||
|
[data:image/s3,"s3://crabby-images/e7586/e75864a98c6f9b1c073c0851d10fdde2dd2f1b9e" alt="Gitter"](https://gitter.im/logrusorgru/aurora)
|
||
|
|
||
|
Ultimate ANSI colors for Golang. The package supports Printf/Sprintf etc.
|
||
|
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/6060c/6060c9e3f115dc6501b7b548fb80168a959a6dfc" alt="aurora logo"
|
||
|
|
||
|
# TOC
|
||
|
|
||
|
- [Installation](#installation)
|
||
|
- [Usage](#usage)
|
||
|
+ [Simple](#simple)
|
||
|
+ [Printf](#printf)
|
||
|
+ [aurora.Sprintf](#aurorasprintf)
|
||
|
+ [Enable/Disable colors](#enabledisable-colors)
|
||
|
- [Chains](#chains)
|
||
|
- [Colorize](#colorize)
|
||
|
- [Grayscale](#grayscale)
|
||
|
- [8-bit colors](#8-bit-colors)
|
||
|
- [Supported Colors & Formats](#supported-colors--formats)
|
||
|
+ [All colors](#all-colors)
|
||
|
+ [Standard and bright colors](#standard-and-bright-colors)
|
||
|
+ [Formats are likely supported](#formats-are-likely-supported)
|
||
|
+ [Formats are likely unsupported](#formats-are-likely-unsupported)
|
||
|
- [Limitations](#limitations)
|
||
|
+ [Windows](#windows)
|
||
|
+ [TTY](#tty)
|
||
|
- [Licensing](#licensing)
|
||
|
|
||
|
# Installation
|
||
|
|
||
|
Get
|
||
|
```
|
||
|
go get -u github.com/logrusorgru/aurora
|
||
|
```
|
||
|
Test
|
||
|
```
|
||
|
go test -cover github.com/logrusorgru/aurora
|
||
|
```
|
||
|
|
||
|
# Usage
|
||
|
|
||
|
### Simple
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
. "github.com/logrusorgru/aurora"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
fmt.Println("Hello,", Magenta("Aurora"))
|
||
|
fmt.Println(Bold(Cyan("Cya!")))
|
||
|
}
|
||
|
|
||
|
```
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/d94da/d94da2c7ea9259e9a6c186936206bd5980de90a1" alt="simple png"
|
||
|
|
||
|
### Printf
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
. "github.com/logrusorgru/aurora"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
fmt.Printf("Got it %d times\n", Green(1240))
|
||
|
fmt.Printf("PI is %+1.2e\n", Cyan(3.14))
|
||
|
}
|
||
|
|
||
|
```
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/968bc/968bc0db58dccac206b764a1aa2fde8adb905c37" alt="printf png"
|
||
|
|
||
|
### aurora.Sprintf
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
. "github.com/logrusorgru/aurora"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
fmt.Println(Sprintf(Magenta("Got it %d times"), Green(1240)))
|
||
|
}
|
||
|
|
||
|
```
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/895b6/895b636995bec2019fbbe6f3de67de3d360179c6" alt="sprintf png"
|
||
|
|
||
|
### Enable/Disable colors
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"flag"
|
||
|
|
||
|
"github.com/logrusorgru/aurora"
|
||
|
)
|
||
|
|
||
|
// colorizer
|
||
|
var au aurora.Aurora
|
||
|
|
||
|
var colors = flag.Bool("colors", false, "enable or disable colors")
|
||
|
|
||
|
func init() {
|
||
|
flag.Parse()
|
||
|
au = aurora.NewAurora(*colors)
|
||
|
}
|
||
|
|
||
|
func main() {
|
||
|
// use colorizer
|
||
|
fmt.Println(au.Green("Hello"))
|
||
|
}
|
||
|
|
||
|
```
|
||
|
Without flags:
|
||
|
data:image/s3,"s3://crabby-images/455cb/455cb1113df548523787d32c6c26fe46ade5061f" alt="disable png"
|
||
|
|
||
|
With `-colors` flag:
|
||
|
data:image/s3,"s3://crabby-images/135c9/135c9726b917c155b3ece6d26533146e9504c414" alt="enable png"
|
||
|
|
||
|
# Chains
|
||
|
|
||
|
The following samples are equal
|
||
|
|
||
|
```go
|
||
|
x := BgMagenta(Bold(Red("x")))
|
||
|
```
|
||
|
|
||
|
```go
|
||
|
x := Red("x").Bold().BgMagenta()
|
||
|
```
|
||
|
|
||
|
The second is more readable
|
||
|
|
||
|
# Colorize
|
||
|
|
||
|
There is `Colorize` function that allows to choose some colors and
|
||
|
format from a side
|
||
|
|
||
|
```go
|
||
|
|
||
|
func getColors() Color {
|
||
|
// some stuff that returns appropriate colors and format
|
||
|
}
|
||
|
|
||
|
// [...]
|
||
|
|
||
|
func main() {
|
||
|
fmt.Println(Colorize("Greeting", getColors()))
|
||
|
}
|
||
|
|
||
|
```
|
||
|
Less complicated example
|
||
|
|
||
|
```go
|
||
|
x := Colorize("Greeting", GreenFg|GrayBg|BoldFm)
|
||
|
```
|
||
|
|
||
|
Unlike other color functions and methods (such as Red/BgBlue etc)
|
||
|
a `Colorize` clears previous colors
|
||
|
|
||
|
```go
|
||
|
x := Red("x").Colorize(BgGreen) // will be with green background only
|
||
|
```
|
||
|
|
||
|
# Grayscale
|
||
|
|
||
|
```go
|
||
|
fmt.Println(" ",
|
||
|
Gray(1-1, " 00-23 ").BgGray(24-1),
|
||
|
Gray(4-1, " 03-19 ").BgGray(20-1),
|
||
|
Gray(8-1, " 07-15 ").BgGray(16-1),
|
||
|
Gray(12-1, " 11-11 ").BgGray(12-1),
|
||
|
Gray(16-1, " 15-07 ").BgGray(8-1),
|
||
|
Gray(20-1, " 19-03 ").BgGray(4-1),
|
||
|
Gray(24-1, " 23-00 ").BgGray(1-1),
|
||
|
)
|
||
|
```
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/f17f5/f17f53cfd35350fbb9fdbf115b20bdc7d0618369" alt="grayscale png"
|
||
|
|
||
|
# 8-bit colors
|
||
|
|
||
|
Methods `Index` and `BgIndex` implements 8-bit colors.
|
||
|
|
||
|
| Index/BgIndex | Meaning | Foreground | Background |
|
||
|
| -------------- | --------------- | ---------- | ---------- |
|
||
|
| 0- 7 | standard colors | 30- 37 | 40- 47 |
|
||
|
| 8- 15 | bright colors | 90- 97 | 100-107 |
|
||
|
| 16-231 | 216 colors | 38;5;n | 48;5;n |
|
||
|
| 232-255 | 24 grayscale | 38;5;n | 48;5;n |
|
||
|
|
||
|
|
||
|
# Supported colors & formats
|
||
|
|
||
|
- formats
|
||
|
+ bold (1)
|
||
|
+ faint (2)
|
||
|
+ doubly-underline (21)
|
||
|
+ fraktur (20)
|
||
|
+ italic (3)
|
||
|
+ underline (4)
|
||
|
+ slow blink (5)
|
||
|
+ rapid blink (6)
|
||
|
+ reverse video (7)
|
||
|
+ conceal (8)
|
||
|
+ crossed out (9)
|
||
|
+ framed (51)
|
||
|
+ encircled (52)
|
||
|
+ overlined (53)
|
||
|
- background and foreground colors, including bright
|
||
|
+ black
|
||
|
+ red
|
||
|
+ green
|
||
|
+ yellow (brown)
|
||
|
+ blue
|
||
|
+ magenta
|
||
|
+ cyan
|
||
|
+ white
|
||
|
+ 24 grayscale colors
|
||
|
+ 216 8-bit colors
|
||
|
|
||
|
### All colors
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/44c47/44c4749dd13139be71925a9d65c3ee577e36a99b" alt="linux png"
|
||
|
data:image/s3,"s3://crabby-images/0b561/0b56126a228522a28325a662d7bed3ef3dfbe848" alt="white png"
|
||
|
|
||
|
### Standard and bright colors
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/09c22/09c220bd42fea2e8d31e09eb5fe74d871ec9b7a5" alt="linux black standard png"
|
||
|
data:image/s3,"s3://crabby-images/c4b90/c4b9023e8d93062b8b046c903884d750acccbcc4" alt="linux white standard png"
|
||
|
|
||
|
### Formats are likely supported
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/7e4e2/7e4e22b8f9dfc6a96a89a0eff7269233381a2bc9" alt="formats supported gif"
|
||
|
|
||
|
### Formats are likely unsupported
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/cf58e/cf58eaa409e663bf9f2d5f02826e3af791e7eee5" alt="formats rarely supported png"
|
||
|
|
||
|
# Limitations
|
||
|
|
||
|
There is no way to represent `%T` and `%p` with colors using
|
||
|
a standard approach
|
||
|
|
||
|
```go
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
|
||
|
. "github.com/logrusorgru/aurora"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
r := Red("red")
|
||
|
var i int
|
||
|
fmt.Printf("%T %p\n", r, Green(&i))
|
||
|
}
|
||
|
```
|
||
|
|
||
|
Output will be without colors
|
||
|
|
||
|
```
|
||
|
aurora.value %!p(aurora.value={0xc42000a310 768 0})
|
||
|
```
|
||
|
|
||
|
The obvious workaround is `Red(fmt.Sprintf("%T", some))`
|
||
|
|
||
|
### Windows
|
||
|
|
||
|
The Aurora provides ANSI colors only, so there is no support for Windows. That said, there are workarounds available.
|
||
|
Check out these comments to learn more:
|
||
|
|
||
|
- [Using go-colorable](https://github.com/logrusorgru/aurora/issues/2#issuecomment-299014211).
|
||
|
- [Using registry for Windows 10](https://github.com/logrusorgru/aurora/issues/10#issue-476361247).
|
||
|
|
||
|
### TTY
|
||
|
|
||
|
The Aurora has no internal TTY detectors by design. Take a look
|
||
|
[this comment](https://github.com/logrusorgru/aurora/issues/2#issuecomment-299030108) if you want turn
|
||
|
on colors for a terminal only, and turn them off for a file.
|
||
|
|
||
|
### Licensing
|
||
|
|
||
|
Copyright © 2016-2020 The Aurora Authors. This work is free.
|
||
|
It comes without any warranty, to the extent permitted by applicable
|
||
|
law. You can redistribute it and/or modify it under the terms of the
|
||
|
the Unlicense. See the LICENSE file for more details.
|
||
|
|
||
|
|