Merge branch 'refs/heads/master' into minbranch

This commit is contained in:
Laukka 2025-01-12 17:55:50 +01:00
commit a785c7df3b
2 changed files with 20 additions and 9 deletions

View File

@ -81,7 +81,7 @@ func input_str(env *environment.Env) string {
for {
r_rune, _, err := reader.ReadRune()
if err != nil {
fmt.Print(fmt.Sprintf("Error reading user input: ", err.Error()))
fmt.Print(fmt.Sprintf("Error reading user input: %s", err.Error()))
}
switch r_rune {
case 3: // ^C
@ -90,10 +90,9 @@ func input_str(env *environment.Env) string {
case 4: // ^D
input = "exit"
goto loop_exit
case 65: // UPP
if history_index > 0 {
history_index--
input = env.History[history_index]
case 27: // UPP
if r, _, _ := reader.ReadRune(); r != 91 {
break
}
case 66: // DOWN
if history_index < len(env.History)-2 {
@ -102,9 +101,21 @@ func input_str(env *environment.Env) string {
} else {
history_index = len(env.History)-1
input = ""
if r, _, _ := reader.ReadRune(); r == 65 { // UPP
if history_index > 0 {
history_index--
input = env.History[history_index]
}
}
if r, _, _ := reader.ReadRune(); r != 66 { //DOWN
if history_index < len(env.History)-1 {
history_index++
input = env.History[history_index]
} else {
input = ""
}
}
}
case 67: // LEFT
case 68: // RIGHT
case 127: //packspace
if len(input) > 0 {
input = input[:len(input)-1]