1
0
mirror of https://github.com/robertkrimen/otto synced 2025-10-12 20:27:30 +08:00
otto/repl/autocompleter.go
Steven Hartland 026a1d9a9c
chore: lint and naming refactor (#475)
Enable more linters, address the issues and do a major naming refactor
to use golang lower camelCase identifiers for types, functions, methods
and variable names.

Also: 
* Clean up inline generation so it doesn't rely on temporary variables.
* Remove unused functions generated by inline.pl.
2022-12-04 21:49:38 +00:00

55 lines
1010 B
Go

package repl
import (
"regexp"
"strings"
"github.com/robertkrimen/otto"
)
type autoCompleter struct {
vm *otto.Otto
}
var lastExpressionRegex = regexp.MustCompile(`[a-zA-Z0-9]([a-zA-Z0-9\.]*[a-zA-Z0-9])?\.?$`)
func (a *autoCompleter) Do(line []rune, pos int) ([][]rune, int) {
lastExpression := lastExpressionRegex.FindString(string(line))
bits := strings.Split(lastExpression, ".")
var l []string
if first := bits[:len(bits)-1]; len(first) == 0 {
c := a.vm.Context()
l = make([]string, len(c.Symbols))
i := 0
for k := range c.Symbols {
l[i] = k
i++
}
} else {
r, err := a.vm.Eval(strings.Join(bits[:len(bits)-1], "."))
if err != nil {
return nil, 0
}
if o := r.Object(); o != nil {
for _, v := range o.KeysByParent() {
l = append(l, v...) //nolint: makezero
}
}
}
last := bits[len(bits)-1]
var r [][]rune
for _, s := range l {
if strings.HasPrefix(s, last) {
r = append(r, []rune(strings.TrimPrefix(s, last)))
}
}
return r, len(last)
}