File: autocompleter.go

package info (click to toggle)
golang-github-robertkrimen-otto 0.0~git20200922.ef014fd-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 1,796 kB
  • sloc: perl: 1,227; makefile: 79
file content (57 lines) | stat: -rw-r--r-- 993 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
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, ".")

	first := bits[:len(bits)-1]
	last := bits[len(bits)-1]

	var l []string

	if 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...)
			}
		}
	}

	var r [][]rune
	for _, s := range l {
		if strings.HasPrefix(s, last) {
			r = append(r, []rune(strings.TrimPrefix(s, last)))
		}
	}

	return r, len(last)
}