1
0
mirror of https://github.com/fumiama/go-base16384.git synced 2026-06-06 09:10:38 +08:00

优化代码结构

This commit is contained in:
源文雨
2023-04-19 15:33:33 +08:00
parent e8419f8b75
commit d548cdd86f
4 changed files with 16 additions and 31 deletions

View File

@@ -44,7 +44,7 @@ func Encode(b []byte) (encd []byte) {
return
}
func EncodeTo(b, encd []byte) error {
func EncodeTo(b, encd []byte) (int, error) {
outlen := len(b) / 7 * 8
offset := len(b) % 7
switch offset { //算上偏移标志字符占用的2字节
@@ -60,10 +60,10 @@ func EncodeTo(b, encd []byte) error {
outlen += 10
}
if len(encd) < outlen {
return errors.New("encd too small")
return 0, errors.New("encd too small")
}
encode(offset, outlen, b, encd)
return nil
return outlen, nil
}
//go:nosplit
@@ -111,7 +111,7 @@ func Decode(b []byte) (decd []byte) {
}
//go:nosplit
func DecodeTo(b []byte, decd []byte) error {
func DecodeTo(b []byte, decd []byte) (int, error) {
outlen := len(b)
offset := 0
if b[len(b)-2] == '=' {
@@ -131,8 +131,8 @@ func DecodeTo(b []byte, decd []byte) error {
}
outlen = outlen/8*7 + offset
if len(decd) < outlen {
return errors.New("decd too small")
return 0, errors.New("decd too small")
}
decode(offset, outlen, b, decd)
return nil
return outlen, nil
}

View File

@@ -121,7 +121,7 @@ func benchEncode(b *testing.B, data []byte) {
b.SetBytes(int64(len(data)))
b.ResetTimer()
for i := 0; i < b.N; i++ {
_ = EncodeTo(data, buf)
_, _ = EncodeTo(data, buf)
}
}
@@ -131,14 +131,14 @@ func benchDecode(b *testing.B, data []byte) {
panic(err)
}
buf := make([]byte, EncodeLen(len(data)))
err = EncodeTo(data, buf)
_, err = EncodeTo(data, buf)
if err != nil {
panic(err)
}
b.SetBytes(int64(len(buf)))
b.ResetTimer()
for i := 0; i < b.N; i++ {
_ = DecodeTo(buf, data)
_, _ = DecodeTo(buf, data)
}
}

View File

@@ -34,12 +34,7 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
inlen = i + n
if err != nil {
if inlen > 0 {
offset := 0
if d.b[inlen-2] == '=' {
offset = int(d.b[inlen-1])
}
n = DecodeLen(inlen, offset)
_ = DecodeTo(d.b[:inlen], p)
n, _ = DecodeTo(d.b[:inlen], p)
d.b = nil
d.r = nil
}
@@ -55,13 +50,11 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
offset = int(d.b[inlen-1])
}
if offset > 0 {
n = DecodeLen(len(d.b[:inlen]), offset)
_ = DecodeTo(d.b[:inlen], p)
n, _ = DecodeTo(d.b[:inlen], p)
d.b = nil
d.r = nil
} else {
n = DecodeLen(inlen, 0)
_ = DecodeTo(d.b[:inlen], p)
n, _ = DecodeTo(d.b[:inlen], p)
d.b = d.b[:0]
}
return
@@ -75,12 +68,7 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
if len(d.b[inlen:]) == 2 {
inlen += 2
}
offset := 0
if d.b[inlen-2] == '=' {
offset = int(d.b[inlen-1])
}
n = DecodeLen(inlen, offset)
_ = DecodeTo(d.b[:inlen], p)
n, _ = DecodeTo(d.b[:inlen], p)
d.b = d.b[inlen:]
return
}

View File

@@ -31,22 +31,19 @@ func (e *Encoder) Read(p []byte) (n int, err error) {
inlen = i + n
if err != nil {
if len(e.b) > 0 {
n = EncodeLen(inlen)
_ = EncodeTo(e.b[:inlen], p)
n, _ = EncodeTo(e.b[:inlen], p)
}
e.b = nil
e.r = nil
return
}
n = EncodeLen(inlen)
err = EncodeTo(e.b[:inlen], p)
n, err = EncodeTo(e.b[:inlen], p)
e.b = e.b[:0]
return
} else if inlen > len(e.b) {
inlen = len(e.b)
}
n = EncodeLen(inlen)
err = EncodeTo(e.b[:inlen], p)
n, err = EncodeTo(e.b[:inlen], p)
e.b = e.b[inlen:]
return
}