mirror of https://github.com/gdamore/tcell.git
Parse terminfo values containing numbers expressed in octal syntax.
I noticed that when running a tcell application under tmux using TERM=screen-256color, some text rendered with style attributes like bold and underline appeared preceded with "17". This seemed to come from tcell sending "AttrOff"/sgr0, which in term_screen_256xcolor.go looks like: AttrOff: "\x1b[m\x0017" infocmp screen-256color expresses sgr0 like this: sgr0=\E[m\017 This terminfo man page implies that \017 should be interpreted as the octal representation of 15 decimal. https://www.mkssoftware.com/docs/man5/terminfo.5.asp The terminfo generator mkinfo.go parses the \0 as a zero, then the following 17 as the digits 1 and 7. This patch modifies mkinfo.go and results in the following instead AttrOff: "\x1b[m\x0f" This seems to clear up the "17" problem for me. But I am not a terminal expert by any means, so perhaps my interpretation is incorrect!
This commit is contained in:
parent
5626083ca1
commit
99cec24157
|
@ -101,8 +101,13 @@ func unescape(s string) string {
|
||||||
switch c {
|
switch c {
|
||||||
case 'E', 'e':
|
case 'E', 'e':
|
||||||
buf.WriteByte(0x1b)
|
buf.WriteByte(0x1b)
|
||||||
case '0':
|
case '0', '1', '2', '3', '4', '5', '6', '7':
|
||||||
|
if i+2 < len(s) && s[i+1] >= '0' && s[i+1] <= '7' && s[i+2] >= '0' && s[i+2] <= '7' {
|
||||||
|
buf.WriteByte(((c - '0') * 64) + ((s[i+1] - '0') * 8) + (s[i+2] - '0'))
|
||||||
|
i = i + 2
|
||||||
|
} else if c == '0' {
|
||||||
buf.WriteByte(0)
|
buf.WriteByte(0)
|
||||||
|
}
|
||||||
case 'n':
|
case 'n':
|
||||||
buf.WriteByte('\n')
|
buf.WriteByte('\n')
|
||||||
case 'r':
|
case 'r':
|
||||||
|
|
Loading…
Reference in New Issue