summaryrefslogtreecommitdiffstats
path: root/src/core.go
diff options
context:
space:
mode:
authorJunegunn Choi <junegunn.c@gmail.com>2019-03-06 19:05:05 +0900
committerJunegunn Choi <junegunn.c@gmail.com>2019-03-06 19:05:05 +0900
commitef577a65094a38f82b2c18dfd3e524eb50748503 (patch)
tree54b4cb94db71b31e781ab2405732f812e6dd0df2 /src/core.go
parentb7c6838e4574fc07699fd7ea52e893021853cb42 (diff)
Preserve the original color of each token when using --with-nth with --ansi
Close #1500
Diffstat (limited to 'src/core.go')
-rw-r--r--src/core.go22
1 files changed, 19 insertions, 3 deletions
diff --git a/src/core.go b/src/core.go
index 1653e6fd..c4b0dacb 100644
--- a/src/core.go
+++ b/src/core.go
@@ -63,12 +63,14 @@ func Run(opts *Options, revision string) {
ansiProcessor := func(data []byte) (util.Chars, *[]ansiOffset) {
return util.ToChars(data), nil
}
+
+ var lineAnsiState, prevLineAnsiState *ansiState
if opts.Ansi {
if opts.Theme != nil {
- var state *ansiState
ansiProcessor = func(data []byte) (util.Chars, *[]ansiOffset) {
- trimmed, offsets, newState := extractColor(string(data), state, nil)
- state = newState
+ prevLineAnsiState = lineAnsiState
+ trimmed, offsets, newState := extractColor(string(data), lineAnsiState, nil)
+ lineAnsiState = newState
return util.ToChars([]byte(trimmed)), offsets
}
} else {
@@ -100,6 +102,20 @@ func Run(opts *Options, revision string) {
} else {
chunkList = NewChunkList(func(item *Item, data []byte) bool {
tokens := Tokenize(string(data), opts.Delimiter)
+ if opts.Ansi && len(tokens) > 1 {
+ var ansiState *ansiState
+ if prevLineAnsiState != nil {
+ ansiStateDup := *prevLineAnsiState
+ ansiState = &ansiStateDup
+ }
+ for _, token := range tokens {
+ prevAnsiState := ansiState
+ _, _, ansiState = extractColor(token.text.ToString(), ansiState, nil)
+ if prevAnsiState != nil {
+ token.text.Wrap(prevAnsiState.ToString(), "\x1b[m")
+ }
+ }
+ }
trans := Transform(tokens, opts.WithNth)
transformed := joinTokens(trans)
if len(header) < opts.HeaderLines {