mirror of https://github.com/gdamore/tcell.git
175 lines
4.5 KiB
Go
175 lines
4.5 KiB
Go
// Copyright 2015 The Tcell Authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use file except in compliance with the License.
|
|
// You may obtain a copy of the license at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package views
|
|
|
|
import (
|
|
"github.com/gdamore/tcell"
|
|
)
|
|
|
|
// SimpleStyledText is a form of Text that offers highlighting of the text
|
|
// using simple in-line markup. Its intention is to make it easier to mark
|
|
// up hot // keys for menubars, etc.
|
|
type SimpleStyledText struct {
|
|
styleN tcell.Style
|
|
styleA tcell.Style
|
|
styleB tcell.Style
|
|
styleS tcell.Style
|
|
styleU tcell.Style
|
|
markup []rune
|
|
init bool
|
|
Text
|
|
}
|
|
|
|
// SetMarkup sets the text used for the string. It applies markup as follows
|
|
// (modeled on tcsh style prompt markup):
|
|
//
|
|
// * %% - emit a single % in current style
|
|
// * %N - normal style
|
|
// * %A - alternate style
|
|
// * %S - start standout (reverse) style
|
|
// * %B - start bold style
|
|
// * %U - start underline style
|
|
//
|
|
// Note that for simplicity, combining styles is not supported. By default
|
|
// the alternate style is the same as standout (reverse) mode.
|
|
//
|
|
// Arguably we could have used Markdown syntax instead, but properly doing all
|
|
// of Markdown is not trivial, and these escape sequences make it clearer that
|
|
// we are not even attempting to do that.
|
|
func (t *SimpleStyledText) SetMarkup(s string) {
|
|
|
|
markup := []rune(s)
|
|
styl := make([]tcell.Style, 0, len(markup))
|
|
text := make([]rune, 0, len(markup))
|
|
|
|
style := t.StyleN()
|
|
esc := false
|
|
for _, r := range markup {
|
|
if esc {
|
|
esc = false
|
|
switch r {
|
|
case '%':
|
|
text = append(text, '%')
|
|
styl = append(styl, style)
|
|
case 'N':
|
|
style = t.StyleN()
|
|
case 'A':
|
|
style = t.StyleA()
|
|
case 'B':
|
|
style = t.StyleB()
|
|
case 'S':
|
|
style = t.StyleS()
|
|
case 'U':
|
|
style = t.StyleU()
|
|
default:
|
|
text = append(append(text, '%'), r)
|
|
styl = append(append(styl, style), style)
|
|
}
|
|
continue
|
|
}
|
|
switch r {
|
|
case '%':
|
|
esc = true
|
|
continue
|
|
default:
|
|
text = append(text, r)
|
|
styl = append(styl, style)
|
|
}
|
|
}
|
|
|
|
t.Text.SetText(string(text))
|
|
for i, s := range styl {
|
|
t.SetStyleAt(i, s)
|
|
}
|
|
t.markup = markup
|
|
}
|
|
|
|
// Markup returns the text that was set, including markup.
|
|
func (t *SimpleStyledText) Markup() string {
|
|
return string(t.markup)
|
|
}
|
|
|
|
// SetStyleN sets the style used for N (normal).
|
|
func (t *SimpleStyledText) SetStyleN(style tcell.Style) {
|
|
t.styleN = style
|
|
t.Text.SetStyle(style)
|
|
}
|
|
|
|
// SetStyleA sets the style used for A (alternate). Existing text is not
|
|
// changed, so call this before doing SetText.
|
|
func (t *SimpleStyledText) SetStyleA(style tcell.Style) {
|
|
t.styleA = style
|
|
}
|
|
|
|
// SetStyleB sets the style used for B (bold). Existing text is not
|
|
// changed, so call this before doing SetText.
|
|
func (t *SimpleStyledText) SetStyleB(style tcell.Style) {
|
|
t.styleB = style
|
|
}
|
|
|
|
// SetStyleU sets the style used for U (underline). Existing text is not
|
|
// changed, so call this before doing SetText.
|
|
func (t *SimpleStyledText) SetStyleU(style tcell.Style) {
|
|
t.styleU = style
|
|
}
|
|
|
|
// SetStyleS sets the style used for S (standout). Existing text is not
|
|
// changed, so call this before doing SetText.
|
|
func (t *SimpleStyledText) SetStyleS(style tcell.Style) {
|
|
t.styleS = style
|
|
}
|
|
|
|
// StyleN returns the previously set N (normal) style.
|
|
func (t *SimpleStyledText) StyleN() tcell.Style {
|
|
return t.styleN
|
|
}
|
|
|
|
// StyleA returns the previously set A (alternate) style.
|
|
func (t *SimpleStyledText) StyleA() tcell.Style {
|
|
if t.styleA == tcell.StyleDefault {
|
|
return t.styleN.Reverse(true).Bold(true)
|
|
}
|
|
return t.styleA
|
|
}
|
|
|
|
// StyleB returns the previously set B (bold) style.
|
|
func (t *SimpleStyledText) StyleB() tcell.Style {
|
|
if t.styleB == tcell.StyleDefault {
|
|
return t.styleN.Bold(true)
|
|
}
|
|
return t.styleB
|
|
}
|
|
|
|
// StyleS returns the previously set S (standout) style.
|
|
func (t *SimpleStyledText) StyleS() tcell.Style {
|
|
if t.styleS == tcell.StyleDefault {
|
|
return t.styleN.Reverse(true)
|
|
}
|
|
return t.styleS
|
|
}
|
|
|
|
// StyleU returns the previously set U (underline) style.
|
|
func (t *SimpleStyledText) StyleU() tcell.Style {
|
|
if t.styleU == tcell.StyleDefault {
|
|
return t.styleN.Underline(true)
|
|
}
|
|
return t.styleU
|
|
}
|
|
|
|
// NewSimpleStyledText creates an empty Text.
|
|
func NewSimpleStyledText() *SimpleStyledText {
|
|
return &SimpleStyledText{}
|
|
}
|