6 runewidth "github.com/mattn/go-runewidth"
7 "github.com/zyedidia/micro/cmd/micro/buffer"
8 "github.com/zyedidia/micro/cmd/micro/config"
9 "github.com/zyedidia/micro/cmd/micro/info"
10 "github.com/zyedidia/micro/cmd/micro/screen"
11 "github.com/zyedidia/micro/cmd/micro/util"
12 "github.com/zyedidia/tcell"
15 type InfoWindow struct {
26 func NewInfoWindow(b *info.InfoBuf) *InfoWindow {
31 iw.defStyle = config.DefStyle
33 if _, ok := config.Colorscheme["message"]; ok {
34 iw.defStyle = config.Colorscheme["message"]
37 iw.errStyle = config.DefStyle.
38 Foreground(tcell.ColorBlack).
39 Background(tcell.ColorMaroon)
41 if _, ok := config.Colorscheme["error-message"]; ok {
42 iw.errStyle = config.Colorscheme["error-message"]
45 iw.width, iw.y = screen.Screen.Size()
51 func (i *InfoWindow) Resize(w, h int) {
56 // func (i *InfoWindow) YesNoPrompt() (bool, bool) {
60 // screen.Screen.ShowCursor(utf8.RuneCountInString(i.Msg), i.y)
64 // switch e := event.(type) {
65 // case *tcell.EventKey:
67 // case tcell.KeyRune:
68 // if e.Rune() == 'y' || e.Rune() == 'Y' {
69 // i.HasPrompt = false
71 // } else if e.Rune() == 'n' || e.Rune() == 'N' {
72 // i.HasPrompt = false
73 // return false, false
75 // case tcell.KeyCtrlC, tcell.KeyCtrlQ, tcell.KeyEscape:
78 // i.HasPrompt = false
85 func (i *InfoWindow) Relocate() bool { return false }
86 func (i *InfoWindow) GetView() *View { return i.View }
87 func (i *InfoWindow) SetView(v *View) {}
88 func (i *InfoWindow) SetActive(b bool) {}
90 func (i *InfoWindow) GetMouseLoc(vloc buffer.Loc) buffer.Loc {
91 c := i.Buffer.GetActiveCursor()
92 l := i.Buffer.LineBytes(0)
93 n := utf8.RuneCountInString(i.Msg)
94 return buffer.Loc{c.GetCharPosInLine(l, vloc.X-n), 0}
97 func (i *InfoWindow) Clear() {
98 for x := 0; x < i.width; x++ {
99 screen.Screen.SetContent(x, i.y, ' ', nil, config.DefStyle)
103 func (i *InfoWindow) displayBuffer() {
105 line := b.LineBytes(0)
106 activeC := b.GetActiveCursor()
109 vlocX := utf8.RuneCountInString(i.Msg)
112 line, nColsBeforeStart, bslice := util.SliceVisualEnd(line, blocX, tabsize)
115 draw := func(r rune, style tcell.Style) {
116 if nColsBeforeStart <= 0 {
117 bloc := buffer.Loc{X: blocX, Y: 0}
118 if activeC.HasSelection() &&
119 (bloc.GreaterEqual(activeC.CurSelection[0]) && bloc.LessThan(activeC.CurSelection[1]) ||
120 bloc.LessThan(activeC.CurSelection[0]) && bloc.GreaterEqual(activeC.CurSelection[1])) {
121 // The current character is selected
122 style = config.DefStyle.Reverse(true)
124 if s, ok := config.Colorscheme["selection"]; ok {
130 screen.Screen.SetContent(vlocX, i.y, r, nil, style)
136 totalwidth := blocX - nColsBeforeStart
138 if activeC.X == blocX {
139 screen.Screen.ShowCursor(vlocX, i.y)
142 r, size := utf8.DecodeRune(line)
151 ts := tabsize - (totalwidth % tabsize)
154 width = runewidth.RuneWidth(r)
161 // Draw any extra characters either spaces for tabs or @ for incomplete wide runes
163 for j := 1; j < width; j++ {
164 draw(char, i.defStyle)
168 if vlocX >= i.width {
172 if activeC.X == blocX {
173 screen.Screen.ShowCursor(vlocX, i.y)
177 func (i *InfoWindow) Display() {
179 if i.HasPrompt || config.GlobalSettings["infobar"].(bool) {
180 if !i.HasPrompt && !i.HasMessage && !i.HasError {
190 for _, c := range display {
191 screen.Screen.SetContent(x, i.y, c, nil, style)
192 x += runewidth.RuneWidth(c)