mirror of
https://github.com/junegunn/fzf.git
synced 2025-12-06 12:54:26 +08:00
feat: add alt-gutter color option (#4602)
* Add alt-gutter color option * Simplify the code --------- Co-authored-by: Junegunn Choi <junegunn.c@gmail.com>
This commit is contained in:
@@ -272,6 +272,7 @@ color mappings. Each entry is separated by a comma and/or whitespaces.
|
|||||||
\fBgutter \fRGutter on the left
|
\fBgutter \fRGutter on the left
|
||||||
\fBcurrent\-hl (hl+) \fRHighlighted substrings (current line)
|
\fBcurrent\-hl (hl+) \fRHighlighted substrings (current line)
|
||||||
\fBalt\-bg \fRAlternate background color to create striped lines
|
\fBalt\-bg \fRAlternate background color to create striped lines
|
||||||
|
\fBalt\-gutter \fRAlternate gutter color to create the striped pattern
|
||||||
\fBquery (input\-fg) \fRQuery string
|
\fBquery (input\-fg) \fRQuery string
|
||||||
\fBghost \fRGhost text (\fB\-\-ghost\fR, \fBdim\fR applied by default)
|
\fBghost \fRGhost text (\fB\-\-ghost\fR, \fBdim\fR applied by default)
|
||||||
\fBdisabled \fRQuery string when search is disabled (\fB\-\-disabled\fR)
|
\fBdisabled \fRQuery string when search is disabled (\fB\-\-disabled\fR)
|
||||||
|
|||||||
@@ -1476,6 +1476,8 @@ func parseTheme(defaultTheme *tui.ColorTheme, str string) (*tui.ColorTheme, *tui
|
|||||||
mergeAttr(&theme.Nomatch)
|
mergeAttr(&theme.Nomatch)
|
||||||
case "gutter":
|
case "gutter":
|
||||||
mergeAttr(&theme.Gutter)
|
mergeAttr(&theme.Gutter)
|
||||||
|
case "alt-gutter":
|
||||||
|
mergeAttr(&theme.AltGutter)
|
||||||
case "hl":
|
case "hl":
|
||||||
mergeAttr(&theme.Match)
|
mergeAttr(&theme.Match)
|
||||||
case "current-hl", "hl+":
|
case "current-hl", "hl+":
|
||||||
|
|||||||
@@ -3202,15 +3202,23 @@ func (t *Terminal) renderEmptyLine(line int, barRange [2]int) {
|
|||||||
t.renderBar(line, barRange)
|
t.renderBar(line, barRange)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Terminal) gutter(current bool) {
|
func (t *Terminal) gutter(current bool, alt bool) {
|
||||||
var color tui.ColorPair
|
var color tui.ColorPair
|
||||||
if current {
|
if current {
|
||||||
color = tui.ColCurrentCursorEmpty
|
color = tui.ColCurrentCursorEmpty
|
||||||
} else if !t.raw && t.gutterReverse || t.raw && t.gutterRawReverse {
|
} else if !t.raw && t.gutterReverse || t.raw && t.gutterRawReverse {
|
||||||
|
if alt {
|
||||||
|
color = tui.ColAltCursorEmpty
|
||||||
|
} else {
|
||||||
color = tui.ColCursorEmpty
|
color = tui.ColCursorEmpty
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if alt {
|
||||||
|
color = tui.ColAltCursorEmptyChar
|
||||||
} else {
|
} else {
|
||||||
color = tui.ColCursorEmptyChar
|
color = tui.ColCursorEmptyChar
|
||||||
}
|
}
|
||||||
|
}
|
||||||
gutter := t.pointerEmpty
|
gutter := t.pointerEmpty
|
||||||
if t.raw {
|
if t.raw {
|
||||||
gutter = t.pointerEmptyRaw
|
gutter = t.pointerEmptyRaw
|
||||||
@@ -3220,7 +3228,7 @@ func (t *Terminal) gutter(current bool) {
|
|||||||
|
|
||||||
func (t *Terminal) renderGapLine(line int, barRange [2]int, drawLine bool) {
|
func (t *Terminal) renderGapLine(line int, barRange [2]int, drawLine bool) {
|
||||||
t.move(line, 0, false)
|
t.move(line, 0, false)
|
||||||
t.gutter(false)
|
t.gutter(false, false)
|
||||||
t.window.Print(t.markerEmpty)
|
t.window.Print(t.markerEmpty)
|
||||||
x := t.pointerLen + t.markerLen
|
x := t.pointerLen + t.markerLen
|
||||||
|
|
||||||
@@ -3394,7 +3402,7 @@ func (t *Terminal) printItem(result Result, line int, maxLine int, index int, cu
|
|||||||
return indentSize
|
return indentSize
|
||||||
}
|
}
|
||||||
if len(label) == 0 {
|
if len(label) == 0 {
|
||||||
t.gutter(true)
|
t.gutter(true, false)
|
||||||
} else {
|
} else {
|
||||||
t.window.CPrint(tui.ColCurrentCursor, label)
|
t.window.CPrint(tui.ColCurrentCursor, label)
|
||||||
}
|
}
|
||||||
@@ -3416,7 +3424,7 @@ func (t *Terminal) printItem(result Result, line int, maxLine int, index int, cu
|
|||||||
return indentSize
|
return indentSize
|
||||||
}
|
}
|
||||||
if len(label) == 0 {
|
if len(label) == 0 {
|
||||||
t.gutter(false)
|
t.gutter(false, index%2 == 1)
|
||||||
} else {
|
} else {
|
||||||
t.window.CPrint(tui.ColCursor, label)
|
t.window.CPrint(tui.ColCursor, label)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -456,6 +456,7 @@ type ColorTheme struct {
|
|||||||
PreviewBg ColorAttr
|
PreviewBg ColorAttr
|
||||||
DarkBg ColorAttr
|
DarkBg ColorAttr
|
||||||
Gutter ColorAttr
|
Gutter ColorAttr
|
||||||
|
AltGutter ColorAttr
|
||||||
Prompt ColorAttr
|
Prompt ColorAttr
|
||||||
InputBg ColorAttr
|
InputBg ColorAttr
|
||||||
InputBorder ColorAttr
|
InputBorder ColorAttr
|
||||||
@@ -826,6 +827,8 @@ var (
|
|||||||
ColCursor ColorPair
|
ColCursor ColorPair
|
||||||
ColCursorEmpty ColorPair
|
ColCursorEmpty ColorPair
|
||||||
ColCursorEmptyChar ColorPair
|
ColCursorEmptyChar ColorPair
|
||||||
|
ColAltCursorEmpty ColorPair
|
||||||
|
ColAltCursorEmptyChar ColorPair
|
||||||
ColMarker ColorPair
|
ColMarker ColorPair
|
||||||
ColSelected ColorPair
|
ColSelected ColorPair
|
||||||
ColSelectedMatch ColorPair
|
ColSelectedMatch ColorPair
|
||||||
@@ -891,6 +894,7 @@ func init() {
|
|||||||
PreviewFg: defaultColor,
|
PreviewFg: defaultColor,
|
||||||
PreviewBg: defaultColor,
|
PreviewBg: defaultColor,
|
||||||
Gutter: undefined,
|
Gutter: undefined,
|
||||||
|
AltGutter: undefined,
|
||||||
PreviewBorder: defaultColor,
|
PreviewBorder: defaultColor,
|
||||||
PreviewScrollbar: defaultColor,
|
PreviewScrollbar: defaultColor,
|
||||||
PreviewLabel: defaultColor,
|
PreviewLabel: defaultColor,
|
||||||
@@ -943,6 +947,7 @@ func init() {
|
|||||||
PreviewFg: undefined,
|
PreviewFg: undefined,
|
||||||
PreviewBg: undefined,
|
PreviewBg: undefined,
|
||||||
Gutter: undefined,
|
Gutter: undefined,
|
||||||
|
AltGutter: undefined,
|
||||||
PreviewBorder: undefined,
|
PreviewBorder: undefined,
|
||||||
PreviewScrollbar: undefined,
|
PreviewScrollbar: undefined,
|
||||||
PreviewLabel: undefined,
|
PreviewLabel: undefined,
|
||||||
@@ -991,6 +996,7 @@ func init() {
|
|||||||
PreviewFg: undefined,
|
PreviewFg: undefined,
|
||||||
PreviewBg: undefined,
|
PreviewBg: undefined,
|
||||||
Gutter: undefined,
|
Gutter: undefined,
|
||||||
|
AltGutter: undefined,
|
||||||
PreviewBorder: undefined,
|
PreviewBorder: undefined,
|
||||||
PreviewScrollbar: undefined,
|
PreviewScrollbar: undefined,
|
||||||
PreviewLabel: undefined,
|
PreviewLabel: undefined,
|
||||||
@@ -1041,6 +1047,7 @@ func init() {
|
|||||||
PreviewFg: undefined,
|
PreviewFg: undefined,
|
||||||
PreviewBg: undefined,
|
PreviewBg: undefined,
|
||||||
Gutter: undefined,
|
Gutter: undefined,
|
||||||
|
AltGutter: undefined,
|
||||||
PreviewBorder: undefined,
|
PreviewBorder: undefined,
|
||||||
PreviewScrollbar: undefined,
|
PreviewScrollbar: undefined,
|
||||||
PreviewLabel: undefined,
|
PreviewLabel: undefined,
|
||||||
@@ -1091,6 +1098,7 @@ func init() {
|
|||||||
PreviewFg: undefined,
|
PreviewFg: undefined,
|
||||||
PreviewBg: undefined,
|
PreviewBg: undefined,
|
||||||
Gutter: undefined,
|
Gutter: undefined,
|
||||||
|
AltGutter: undefined,
|
||||||
PreviewBorder: undefined,
|
PreviewBorder: undefined,
|
||||||
PreviewScrollbar: undefined,
|
PreviewScrollbar: undefined,
|
||||||
PreviewLabel: undefined,
|
PreviewLabel: undefined,
|
||||||
@@ -1208,6 +1216,7 @@ func InitTheme(theme *ColorTheme, baseTheme *ColorTheme, boldify bool, forceBlac
|
|||||||
gutter.Attr = Dim
|
gutter.Attr = Dim
|
||||||
}
|
}
|
||||||
theme.Gutter = o(theme.DarkBg, gutter)
|
theme.Gutter = o(theme.DarkBg, gutter)
|
||||||
|
theme.AltGutter = o(theme.Gutter, theme.AltGutter)
|
||||||
theme.PreviewFg = o(theme.Fg, theme.PreviewFg)
|
theme.PreviewFg = o(theme.Fg, theme.PreviewFg)
|
||||||
theme.PreviewBg = o(theme.Bg, theme.PreviewBg)
|
theme.PreviewBg = o(theme.Bg, theme.PreviewBg)
|
||||||
theme.PreviewLabel = o(theme.BorderLabel, theme.PreviewLabel)
|
theme.PreviewLabel = o(theme.BorderLabel, theme.PreviewLabel)
|
||||||
@@ -1277,6 +1286,8 @@ func initPalette(theme *ColorTheme) {
|
|||||||
ColCursor = pair(theme.Cursor, theme.Gutter)
|
ColCursor = pair(theme.Cursor, theme.Gutter)
|
||||||
ColCursorEmpty = pair(blank, theme.Gutter)
|
ColCursorEmpty = pair(blank, theme.Gutter)
|
||||||
ColCursorEmptyChar = pair(theme.Gutter, theme.ListBg)
|
ColCursorEmptyChar = pair(theme.Gutter, theme.ListBg)
|
||||||
|
ColAltCursorEmpty = pair(blank, theme.AltGutter)
|
||||||
|
ColAltCursorEmptyChar = pair(theme.AltGutter, theme.ListBg)
|
||||||
if theme.SelectedBg.Color != theme.ListBg.Color {
|
if theme.SelectedBg.Color != theme.ListBg.Color {
|
||||||
ColMarker = pair(theme.Marker, theme.SelectedBg)
|
ColMarker = pair(theme.Marker, theme.SelectedBg)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
Reference in New Issue
Block a user