Commit a37720fa authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 7042854d
...@@ -196,15 +196,13 @@ overflow: ...@@ -196,15 +196,13 @@ overflow:
func (p *XXXTest) NEOEncodedLen() int { func (p *XXXTest) NEOEncodedLen() int {
var size0 int var size0 int
for i := 0; i < len(p.Zzz); i++ { for key := range p.Zzz {
a := &p.Zzz[i] for key := range p.Zzz[key] {
for i := 0; i < len((*a)); i++ { size0 += len(p.Zzz[key][key])
a := &(*a)[i]
size0 += len((*a))
} }
size0 += len((*a)) * 4 size0 += len(p.Zzz[key]) * 8
} }
return 12 + len(p.Zzz)*4 + size0 return 12 + len(p.Zzz)*8 + size0
} }
func (p *XXXTest) NEOEncode(data []byte) { func (p *XXXTest) NEOEncode(data []byte) {
...@@ -214,19 +212,29 @@ func (p *XXXTest) NEOEncode(data []byte) { ...@@ -214,19 +212,29 @@ func (p *XXXTest) NEOEncode(data []byte) {
l := uint32(len(p.Zzz)) l := uint32(len(p.Zzz))
binary.BigEndian.PutUint32(data[8:], l) binary.BigEndian.PutUint32(data[8:], l)
data = data[12:] data = data[12:]
for i := 0; uint32(i) < l; i++ { keyv := make([]int32, 0, l)
a := &p.Zzz[i] for key := range p.Zzz {
keyv = append(keyv, key)
}
sort.Slice(keyv, func(i, j int) bool { return keyv[i] < keyv[j] })
for _, key := range keyv {
binary.BigEndian.PutUint32(data[0:], uint32(key))
{ {
l := uint32(len((*a))) l := uint32(len(p.Zzz[key]))
binary.BigEndian.PutUint32(data[0:], l) binary.BigEndian.PutUint32(data[4:], l)
data = data[4:] data = data[8:]
for i := 0; uint32(i) < l; i++ { keyv := make([]int32, 0, l)
a := &(*a)[i] for key := range p.Zzz[key] {
keyv = append(keyv, key)
}
sort.Slice(keyv, func(i, j int) bool { return keyv[i] < keyv[j] })
for _, key := range keyv {
binary.BigEndian.PutUint32(data[0:], uint32(key))
{ {
l := uint32(len((*a))) l := uint32(len(p.Zzz[key][key]))
binary.BigEndian.PutUint32(data[0:], l) binary.BigEndian.PutUint32(data[4:], l)
data = data[4:] data = data[8:]
copy(data, (*a)) copy(data, p.Zzz[key][key])
data = data[l:] data = data[l:]
} }
data = data[0:] data = data[0:]
...@@ -254,36 +262,46 @@ func (p *XXXTest) NEODecode(data []byte) (int, error) { ...@@ -254,36 +262,46 @@ func (p *XXXTest) NEODecode(data []byte) (int, error) {
l := binary.BigEndian.Uint32(data[8:]) l := binary.BigEndian.Uint32(data[8:])
data = data[12:] data = data[12:]
nread0 += 12 nread0 += 12
p.Zzz = make([][]string, l) p.Zzz = make(map[int32]map[int32]string, l)
m := p.Zzz
for i := 0; uint32(i) < l; i++ { for i := 0; uint32(i) < l; i++ {
a := &p.Zzz[i] if len(data) < 4 {
goto overflow
}
key := int32(binary.BigEndian.Uint32(data[0:]))
var v map[int32]string
{ {
if len(data) < 4 { if len(data) < 8 {
goto overflow goto overflow
} }
l := binary.BigEndian.Uint32(data[0:]) l := binary.BigEndian.Uint32(data[4:])
data = data[4:] data = data[8:]
nread0 += 4 nread0 += 8
(*a) = make([]string, l) v = make(map[int32]string, l)
m := v
for i := 0; uint32(i) < l; i++ { for i := 0; uint32(i) < l; i++ {
a := &(*a)[i] if len(data) < 4 {
goto overflow
}
key := int32(binary.BigEndian.Uint32(data[0:]))
{ {
if len(data) < 4 { if len(data) < 8 {
goto overflow goto overflow
} }
l := binary.BigEndian.Uint32(data[0:]) l := binary.BigEndian.Uint32(data[4:])
data = data[4:] data = data[8:]
if uint32(len(data)) < l { if uint32(len(data)) < l {
goto overflow goto overflow
} }
(*a) = string(data[:l]) m[key] = string(data[:l])
data = data[l:] data = data[l:]
nread0 += 4 + l nread0 += 8 + l
} }
data = data[0:] data = data[0:]
nread0 += 0 nread0 += 0
} }
} }
m[key] = v
data = data[0:] data = data[0:]
nread0 += 0 nread0 += 0
} }
......
...@@ -198,7 +198,7 @@ type RowInfo struct { ...@@ -198,7 +198,7 @@ type RowInfo struct {
type XXXTest struct { type XXXTest struct {
qqq uint32 qqq uint32
aaa uint32 aaa uint32
Zzz [][]string Zzz map[int32]map[int32]string
} }
......
...@@ -579,13 +579,27 @@ func (s *sizer) genMap(path string, typ *types.Map, obj types.Object) { ...@@ -579,13 +579,27 @@ func (s *sizer) genMap(path string, typ *types.Map, obj types.Object) {
return return
} }
panic("UNTESTED")
s.size.Add(4) s.size.Add(4)
curSize := s.size
s.size = size{} // zero
// FIXME for map of map gives ...[key][key] => key -> different variables
s.emit("for key := range %s {", path) s.emit("for key := range %s {", path)
codegenType("key", typ.Key(), obj, s) codegenType("key", typ.Key(), obj, s)
codegenType(fmt.Sprintf("%s[key]", path), typ.Elem(), obj, s) codegenType(fmt.Sprintf("%s[key]", path), typ.Elem(), obj, s)
// merge-in size updates
s.emit("%v += %v", s.var_("size"), s.size.ExprString())
s.emit("}")
if s.size.num != 0 {
curSize.AddExpr("len(%v) * %v", path, s.size.num)
}
s.size = curSize
/*
s.emit("%v += %v", s.var_("size"), s.size) s.emit("%v += %v", s.var_("size"), s.size)
s.emit("}") s.emit("}")
*/
} }
func (e *encoder) genMap(path string, typ *types.Map, obj types.Object) { func (e *encoder) genMap(path string, typ *types.Map, obj types.Object) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment