diff options
author | Felix Lange <fjl@twurst.com> | 2015-03-19 19:15:43 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2015-03-19 19:15:43 +0800 |
commit | 965c9babe336cfa8d5c740d5356acbc5f9ba4a72 (patch) | |
tree | 2d72947f28b4fe420b12ff76988e9cf692de126b | |
parent | 064279c0ec2f048cbdd965c095ea332bb8666f94 (diff) | |
download | dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.tar dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.tar.gz dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.tar.bz2 dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.tar.lz dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.tar.xz dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.tar.zst dexon-965c9babe336cfa8d5c740d5356acbc5f9ba4a72.zip |
rlp: fix encoding of one element strings and byte slices
The encoder was missing a special case for one element strings whose
element is below 0x7f. Such strings must be encoded as a single byte
without a string header.
-rw-r--r-- | rlp/encode.go | 21 | ||||
-rw-r--r-- | rlp/encode_test.go | 6 |
2 files changed, 20 insertions, 7 deletions
diff --git a/rlp/encode.go b/rlp/encode.go index 42bbb876c..7ac74d8fb 100644 --- a/rlp/encode.go +++ b/rlp/encode.go @@ -203,8 +203,13 @@ func (w *encbuf) encodeStringHeader(size int) { } func (w *encbuf) encodeString(b []byte) { - w.encodeStringHeader(len(b)) - w.str = append(w.str, b...) + if len(b) == 1 && b[0] <= 0x7F { + // fits single byte, no string header + w.str = append(w.str, b[0]) + } else { + w.encodeStringHeader(len(b)) + w.str = append(w.str, b...) + } } func (w *encbuf) list() *listhead { @@ -404,9 +409,6 @@ func writeBigInt(i *big.Int, w *encbuf) error { return fmt.Errorf("rlp: cannot encode negative *big.Int") } else if cmp == 0 { w.str = append(w.str, 0x80) - } else if bits := i.BitLen(); bits < 8 { - // fits single byte - w.str = append(w.str, byte(i.Uint64())) } else { w.encodeString(i.Bytes()) } @@ -434,8 +436,13 @@ func writeByteArray(val reflect.Value, w *encbuf) error { func writeString(val reflect.Value, w *encbuf) error { s := val.String() - w.encodeStringHeader(len(s)) - w.str = append(w.str, s...) + if len(s) == 1 && s[0] <= 0x7f { + // fits single byte, no string header + w.str = append(w.str, s[0]) + } else { + w.encodeStringHeader(len(s)) + w.str = append(w.str, s...) + } return nil } diff --git a/rlp/encode_test.go b/rlp/encode_test.go index 852cb6f59..611514bda 100644 --- a/rlp/encode_test.go +++ b/rlp/encode_test.go @@ -103,12 +103,18 @@ var encTests = []encTest{ // byte slices, strings {val: []byte{}, output: "80"}, + {val: []byte{0x7E}, output: "7E"}, + {val: []byte{0x7F}, output: "7F"}, + {val: []byte{0x80}, output: "8180"}, {val: []byte{1, 2, 3}, output: "83010203"}, {val: []namedByteType{1, 2, 3}, output: "83010203"}, {val: [...]namedByteType{1, 2, 3}, output: "83010203"}, {val: "", output: "80"}, + {val: "\x7E", output: "7E"}, + {val: "\x7F", output: "7F"}, + {val: "\x80", output: "8180"}, {val: "dog", output: "83646F67"}, { val: "Lorem ipsum dolor sit amet, consectetur adipisicing eli", |