fix end-of-line issue with the new prompt (#582)

This commit is contained in:
Patrick Devine 2023-09-23 17:20:30 -07:00 committed by GitHub
parent 8b2ba9cab8
commit b5614f3ebc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -33,15 +33,22 @@ import (
) )
type Painter struct { type Painter struct {
HideHint bool IsMultiLine bool
} }
func (p Painter) Paint(line []rune, _ int) []rune { func (p Painter) Paint(line []rune, _ int) []rune {
termType := os.Getenv("TERM") termType := os.Getenv("TERM")
if termType == "xterm-256color" && len(line) == 0 && !p.HideHint { if termType == "xterm-256color" && len(line) == 0 {
prompt := "Send a message (/? for help)" var prompt string
if p.IsMultiLine {
prompt = "Use \"\"\" to end multi-line input"
} else {
prompt = "Send a message (/? for help)"
}
return []rune(fmt.Sprintf("\033[38;5;245m%s\033[%dD\033[0m", prompt, len(prompt))) return []rune(fmt.Sprintf("\033[38;5;245m%s\033[%dD\033[0m", prompt, len(prompt)))
} }
// add a space and a backspace to prevent the cursor from walking up the screen
line = append(line, []rune(" \b")...)
return line return line
} }
@ -579,7 +586,7 @@ func generateInteractive(cmd *cobra.Command, model string) error {
case isMultiLine: case isMultiLine:
if strings.HasSuffix(line, `"""`) { if strings.HasSuffix(line, `"""`) {
isMultiLine = false isMultiLine = false
painter.HideHint = false painter.IsMultiLine = isMultiLine
multiLineBuffer += strings.TrimSuffix(line, `"""`) multiLineBuffer += strings.TrimSuffix(line, `"""`)
line = multiLineBuffer line = multiLineBuffer
multiLineBuffer = "" multiLineBuffer = ""
@ -590,9 +597,9 @@ func generateInteractive(cmd *cobra.Command, model string) error {
} }
case strings.HasPrefix(line, `"""`): case strings.HasPrefix(line, `"""`):
isMultiLine = true isMultiLine = true
painter.IsMultiLine = isMultiLine
multiLineBuffer = strings.TrimPrefix(line, `"""`) + " " multiLineBuffer = strings.TrimPrefix(line, `"""`) + " "
scanner.SetPrompt("... ") scanner.SetPrompt("... ")
painter.HideHint = true
continue continue
case strings.HasPrefix(line, "/list"): case strings.HasPrefix(line, "/list"):
args := strings.Fields(line) args := strings.Fields(line)