a 2aab8f496c
rlp2 (#8643)
rlp2 is a package that aims to replace the existing erigon-lib/rlp
package and the erigon/common/rlp

it is called rlp2 for now because it requires breaking changes to
erigon-lib/rlp and i do not have the time right now to test all current
uses of such functions

however, the encoder/decoder characteristics of rlp2 might be desirable
for caplin, and also for execution layer parsing blob txns, so im
putting it in a folder called rlp2 (note that it exports package rlp for
easier switching later)

importantly, rlp2 is designed for single-pass decoding with the ability
to skip elements one does not care about. it also is zero alloc.
2023-11-04 09:22:11 +07:00

85 lines
1.6 KiB
Go

package rlp
type Token int32
func (T Token) String() string {
switch T {
case TokenDecimal:
return "decimal"
case TokenShortBlob:
return "short_blob"
case TokenLongBlob:
return "long_blob"
case TokenShortList:
return "short_list"
case TokenLongList:
return "long_list"
case TokenEOF:
return "eof"
case TokenUnknown:
return "unknown"
default:
return "nan"
}
}
func (T Token) Plus(n byte) byte {
return byte(T) + n
}
func (T Token) Diff(n byte) byte {
return n - byte(T)
}
func (T Token) IsListType() bool {
return T == TokenLongList || T == TokenShortList
}
func (T Token) IsBlobType() bool {
return T == TokenLongBlob || T == TokenShortBlob
}
const (
TokenDecimal Token = 0x00
TokenShortBlob Token = 0x80
TokenLongBlob Token = 0xb7
TokenShortList Token = 0xc0
TokenLongList Token = 0xf7
TokenUnknown Token = 0xff01
TokenEOF Token = 0xdead
)
func identifyToken(b byte) Token {
switch {
case b <= 127:
return TokenDecimal
case b >= 128 && b <= 183:
return TokenShortBlob
case b >= 184 && b <= 191:
return TokenLongBlob
case b >= 192 && b <= 247:
return TokenShortList
case b >= 248 && b <= 255:
return TokenLongList
}
return TokenUnknown
}
// BeInt parses Big Endian representation of an integer from given payload at given position
func nextBeInt(w *buf, length int) (int, error) {
dat, err := nextFull(w, length)
if err != nil {
return 0, ErrUnexpectedEOF
}
return BeInt(dat, 0, length)
}
func nextFull(dat *buf, size int) ([]byte, error) {
d := dat.Next(size)
if len(d) != size {
return nil, ErrUnexpectedEOF
}
return d, nil
}