Chain parser
This commit is contained in:
parent
67ce0913fb
commit
e6acf6c41c
58
core/parser.go
Normal file
58
core/parser.go
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
package core
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"reflect"
|
||||||
|
)
|
||||||
|
|
||||||
|
func ParseChains(b []byte) (map[string]*Chain, error) {
|
||||||
|
var schema map[string]interface{}
|
||||||
|
if err := json.Unmarshal(b, &schema); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
chains := map[string]*Chain{}
|
||||||
|
for name, chain := range schema {
|
||||||
|
chains[name] = buildChain(interface{}(chain))
|
||||||
|
}
|
||||||
|
|
||||||
|
return chains, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func buildChain(conf interface{}) *Chain {
|
||||||
|
c := &Chain{
|
||||||
|
Links: []Caller{},
|
||||||
|
}
|
||||||
|
|
||||||
|
for flow, links := range conf.(map[string]interface{}) {
|
||||||
|
if f, ok := FlowMap[flow]; ok {
|
||||||
|
c.Flow = f
|
||||||
|
} else {
|
||||||
|
panic("Unknown chain flow: " + flow)
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, link := range links.([]interface{}) {
|
||||||
|
val := reflect.ValueOf(link)
|
||||||
|
|
||||||
|
switch val.Kind() {
|
||||||
|
case reflect.Map:
|
||||||
|
subchain := buildChain(interface{}(link))
|
||||||
|
if len(subchain.Links) > 0 {
|
||||||
|
c.Links = append(c.Links, Caller(subchain))
|
||||||
|
}
|
||||||
|
case reflect.String:
|
||||||
|
unit, ok := Units[link.(string)]
|
||||||
|
if !ok {
|
||||||
|
fmt.Println("Unknown unit `" + link.(string) + "`")
|
||||||
|
} else {
|
||||||
|
c.Links = append(c.Links, unit)
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
panic("Unexpected chain element: " + val.Kind().String())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return c
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user