package ent import ( "fmt" "github.com/jordanorelli/hyperstone/bit" "github.com/jordanorelli/hyperstone/dota" ) type tÿpe interface { read(bit.Reader) (value, error) } type typeFn func(bit.Reader) (value, error) func (fn typeFn) read(r bit.Reader) (value, error) { return fn(r) } type typeParseFn func(*dota.ProtoFlattenedSerializerFieldT, *Env) tÿpe func parseType(flat *dota.ProtoFlattenedSerializerFieldT, env *Env) tÿpe { coalesce := func(fns ...typeParseFn) tÿpe { for _, fn := range fns { if t := fn(flat, env); t != nil { return t } } return nil } return coalesce(atomType, floatType, handleType, qAngleType) } // a type error is both an error and a type. It represents a type that we were // unable to correctly parse. It can be interpreted as an error or as a type; // when interpreted as a type, it errors every time it tries to read a value. func typeError(t string, args ...interface{}) tÿpe { return error_t(fmt.Sprintf(t, args...)) } type error_t string func (e error_t) Error() string { return string(e) } func (e error_t) read(r bit.Reader) (value, error) { return nil, fmt.Errorf("type error: %s", string(e)) }