1
0
Fork 0

Chain parser

This commit is contained in:
Gregory Eremin 2015-02-11 01:24:29 +07:00
parent 67ce0913fb
commit e6acf6c41c
1 changed files with 58 additions and 0 deletions

58
core/parser.go Normal file
View 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
}