mirror of https://github.com/liamg/aminal.git
#147 Hyperlinks, corrected set/unset
This commit is contained in:
parent
70b95a71ef
commit
52aedb077c
|
@ -12,18 +12,28 @@ func oscHandler(pty chan rune, terminal *Terminal) error {
|
|||
params := []string{}
|
||||
param := ""
|
||||
|
||||
for {
|
||||
b := <-pty
|
||||
if terminal.IsOSCTerminator(b) {
|
||||
params = append(params, param)
|
||||
break
|
||||
{
|
||||
isEscaped := false // flag if the previous character was escape
|
||||
|
||||
for {
|
||||
b := <-pty
|
||||
if terminal.IsOSCTerminator(b, isEscaped) {
|
||||
params = append(params, param)
|
||||
break
|
||||
}
|
||||
if isEscaped {
|
||||
isEscaped = false
|
||||
} else if b == 0x1b {
|
||||
isEscaped = true
|
||||
continue
|
||||
}
|
||||
if b == ';' {
|
||||
params = append(params, param)
|
||||
param = ""
|
||||
continue
|
||||
}
|
||||
param = fmt.Sprintf("%s%c", param, b)
|
||||
}
|
||||
if b == ';' {
|
||||
params = append(params, param)
|
||||
param = ""
|
||||
continue
|
||||
}
|
||||
param = fmt.Sprintf("%s%c", param, b)
|
||||
}
|
||||
|
||||
if len(params) == 0 {
|
||||
|
@ -42,8 +52,8 @@ func oscHandler(pty chan rune, terminal *Terminal) error {
|
|||
case "0", "2":
|
||||
terminal.SetTitle(pT)
|
||||
case "8": // hyperlink
|
||||
if len(pS) > 2 {
|
||||
terminal.terminalState.CurrentHyperlink = &buffer.Hyperlink{Uri: pS[2]}
|
||||
if len(params) > 2 && len(params[2]) > 0 {
|
||||
terminal.terminalState.CurrentHyperlink = &buffer.Hyperlink{Uri: params[2]}
|
||||
} else {
|
||||
terminal.terminalState.CurrentHyperlink = nil
|
||||
}
|
||||
|
|
|
@ -11,14 +11,20 @@ import (
|
|||
"github.com/liamg/aminal/sixel"
|
||||
)
|
||||
|
||||
type boolFormRuneFunc func(rune) bool
|
||||
type boolFormRuneFunc func(rune, bool) bool
|
||||
|
||||
func swallowByFunction(pty chan rune, isTerminator boolFormRuneFunc) {
|
||||
isEscaped := false
|
||||
for {
|
||||
b := <-pty
|
||||
if isTerminator(b) {
|
||||
if isTerminator(b, isEscaped) {
|
||||
break
|
||||
}
|
||||
if isEscaped {
|
||||
isEscaped = false
|
||||
} else if b == 0x1b {
|
||||
isEscaped = true
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -134,7 +134,8 @@ func (terminal *Terminal) GetMouseExtMode() MouseExtMode {
|
|||
return terminal.mouseExtMode
|
||||
}
|
||||
|
||||
func (terminal *Terminal) IsOSCTerminator(char rune) bool {
|
||||
func (terminal *Terminal) IsOSCTerminator(char rune, isEscaped bool) bool {
|
||||
// @todo handle isEscaped flag
|
||||
_, ok := terminal.platformDependentSettings.OSCTerminators[char]
|
||||
return ok
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue