This commit is contained in:
Tnze
2020-11-30 14:29:15 +08:00
parent ff161afd50
commit 67806abcdb
3 changed files with 60 additions and 3 deletions

View File

@ -33,7 +33,7 @@ type jsonChat struct {
Translate string `json:"translate,omitempty"`
With []json.RawMessage `json:"with,omitempty"` // How can go handle an JSON array with Object and String?
Extra []jsonChat `json:"extra,omitempty"`
Extra []Message `json:"extra,omitempty"`
}
//UnmarshalJSON decode json to Message
@ -73,12 +73,12 @@ func (m *Message) Append(extraMsg ...Message) {
finalLen := origLen + len(extraMsg)
if cap(m.Extra) < len(m.Extra)+len(extraMsg) {
// pre expansion
extra := make([]jsonChat, finalLen)
extra := make([]Message, finalLen)
copy(extra, m.Extra)
m.Extra = extra
}
for _, v := range extraMsg {
m.Extra = append(m.Extra, jsonChat(v))
m.Extra = append(m.Extra, v)
}
}

View File

@ -34,6 +34,8 @@ var jsons = []string{
`"Tnze"`,
`"§0Tnze"`,
`"§list"`,
`{"extra":[" "],"text":""}`,
}
var texts = []string{
@ -49,6 +51,8 @@ var texts = []string{
"Tnze",
"\033[30mTnze\033[0m",
"\033[1mist\033[0m",
" ",
}
var ctexts = []string{
@ -64,6 +68,8 @@ var ctexts = []string{
"Tnze",
"Tnze",
"ist",
" ",
}
func TestChatMsgFormatString(t *testing.T) {

51
net/packet/util.go Normal file
View File

@ -0,0 +1,51 @@
package packet
import (
"reflect"
)
type Ary struct {
Len Field
Ary interface{}
}
func (a Ary) Encode() (data []byte) {
length := int(reflect.ValueOf(a.Len).Int())
array := reflect.ValueOf(a.Ary).Elem()
for i := 0; i < length; i++ {
elem := array.Index(i)
data = append(data, elem.Interface().(FieldEncoder).Encode()...)
}
return
}
func (a Ary) Decode(r DecodeReader) error {
length := int(reflect.ValueOf(a.Len).Int())
array := reflect.ValueOf(a.Ary).Elem()
for i := 0; i < length; i++ {
elem := array.Index(i)
if err := elem.Interface().(FieldDecoder).Decode(r); err != nil {
return err
}
}
return nil
}
type Opt struct {
Has func() bool
Field interface{}
}
func (o Opt) Encode() []byte {
if o.Has() {
return nil
}
return o.Field.(FieldEncoder).Encode()
}
func (o Opt) Decode(r DecodeReader) error {
if o.Has() {
return nil
}
return o.Field.(FieldDecoder).Decode(r)
}