}, "then": func(env Env, args ...interface{}) (Lisp, error) { ptype := reflect.TypeOf((*Parsecer)(nil)).Elem() params, err := GetArgs(env, p.UnionAll(TypeAs(ptype), TypeAs(ptype), p.EOF), args) if err != nil { return nil, err } return ParsecBox(params[0].(Parsecer).Parser.Then(params[1].(Parsecer).Parser)), nil }, "sepby1": func(env Env, args ...interface{}) (Lisp, error) { ptype := reflect.TypeOf((*Parsecer)(nil)).Elem() params, err := GetArgs(env, p.UnionAll(TypeAs(ptype), TypeAs(ptype), p.EOF), args) if err != nil { return nil, err } return ParsecBox(p.SepBy1(params[0].(Parsecer).Parser, params[1].(Parsecer).Parser)), nil }, "sepby": func(env Env, args ...interface{}) (Lisp, error) { ptype := reflect.TypeOf((*Parsecer)(nil)).Elem() params, err := GetArgs(env, p.UnionAll(TypeAs(ptype), TypeAs(ptype), p.EOF), args) if err != nil { return nil, err } return ParsecBox(p.SepBy(params[0].(Parsecer).Parser, params[1].(Parsecer).Parser)), nil }, "manytill": func(env Env, args ...interface{}) (Lisp, error) { ptype := reflect.TypeOf((*Parsecer)(nil)).Elem() params, err := GetArgs(env, p.UnionAll(TypeAs(ptype), TypeAs(ptype), p.EOF), args) if err != nil { return nil, err }
func objectBodyParser(st p.State) (interface{}, error) { return p.SepBy1(ValueParser(), p.Choice(Colon))(st) }
// BracketParserExt 在带有 Ext 的环境下解析中括号表达式 func BracketParserExt(env Env) p.P { return p.Between(p.Chr('['), p.Chr(']'), p.SepBy1(ValueParserExt(env), p.Chr(':')), ) }
func listBodyParser(st p.State) (interface{}, error) { value, err := p.SepBy1(ValueParser(), Comma)(st) fmt.Printf("type :%v, value :%v, err :%v\n", reflect.TypeOf(value), value, err) return value, err }