summaryrefslogtreecommitdiff
path: root/internal/mapr/funcs/function.go
blob: 418d86f60310aa199663e4de7e847ae2307b3e89 (plain)
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
58
59
60
61
62
63
64
package funcs

import (
	"fmt"
	"strings"
)

// CallbackFunc is a function which can be executed by the mapreduce engine
type CallbackFunc func(text string) string

// Function embeddes the function name to the callback function
type Function struct {
	// Name of the callback function
	Name string
	// The Go-callback function to call for this DTail function.
	call CallbackFunc
}

// FunctionStack is a list of functions stacked each other
type FunctionStack []Function

// NewFunctionStack parses the input string, e.g. foo(bar("arg")) and returns
// a corresponding function stack.
func NewFunctionStack(in string) (FunctionStack, string, error) {
	var fs FunctionStack
	getCallback := func(name string) (CallbackFunc, error) {
		var cb CallbackFunc
		switch name {
		case "md5sum":
			return Md5Sum, nil
		case "maskdigits":
			return MaskDigits, nil
		default:
			return cb, fmt.Errorf("unknown function '%s'", name)
		}
	}

	aux := in
	for strings.HasSuffix(aux, ")") {
		index := strings.Index(aux, "(")
		if index <= 0 {
			return fs, "", fmt.Errorf("unable to parse function '%s' at '%s'", in, aux)
		}
		name := aux[0:index]

		call, err := getCallback(name)
		if err != nil {
			return fs, "", err
		}
		fs = append(fs, Function{name, call})
		aux = aux[index+1 : len(aux)-1]
	}
	return fs, aux, nil
}

// Call the function stack.
func (fs FunctionStack) Call(str string) string {
	for i := len(fs) - 1; i >= 0; i-- {
		//dlog.Common.Debug("Call", fs[i].Name, str)
		str = fs[i].call(str)
		//dlog.Common.Debug("Call.result", fs[i].Name, str)
	}
	return str
}