mirror of
https://github.com/fumiama/go-base16384.git
synced 2026-06-12 22:40:42 +08:00
优化代码结构
This commit is contained in:
12
base14.go
12
base14.go
@@ -44,7 +44,7 @@ func Encode(b []byte) (encd []byte) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func EncodeTo(b, encd []byte) error {
|
func EncodeTo(b, encd []byte) (int, error) {
|
||||||
outlen := len(b) / 7 * 8
|
outlen := len(b) / 7 * 8
|
||||||
offset := len(b) % 7
|
offset := len(b) % 7
|
||||||
switch offset { //算上偏移标志字符占用的2字节
|
switch offset { //算上偏移标志字符占用的2字节
|
||||||
@@ -60,10 +60,10 @@ func EncodeTo(b, encd []byte) error {
|
|||||||
outlen += 10
|
outlen += 10
|
||||||
}
|
}
|
||||||
if len(encd) < outlen {
|
if len(encd) < outlen {
|
||||||
return errors.New("encd too small")
|
return 0, errors.New("encd too small")
|
||||||
}
|
}
|
||||||
encode(offset, outlen, b, encd)
|
encode(offset, outlen, b, encd)
|
||||||
return nil
|
return outlen, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
//go:nosplit
|
//go:nosplit
|
||||||
@@ -111,7 +111,7 @@ func Decode(b []byte) (decd []byte) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//go:nosplit
|
//go:nosplit
|
||||||
func DecodeTo(b []byte, decd []byte) error {
|
func DecodeTo(b []byte, decd []byte) (int, error) {
|
||||||
outlen := len(b)
|
outlen := len(b)
|
||||||
offset := 0
|
offset := 0
|
||||||
if b[len(b)-2] == '=' {
|
if b[len(b)-2] == '=' {
|
||||||
@@ -131,8 +131,8 @@ func DecodeTo(b []byte, decd []byte) error {
|
|||||||
}
|
}
|
||||||
outlen = outlen/8*7 + offset
|
outlen = outlen/8*7 + offset
|
||||||
if len(decd) < outlen {
|
if len(decd) < outlen {
|
||||||
return errors.New("decd too small")
|
return 0, errors.New("decd too small")
|
||||||
}
|
}
|
||||||
decode(offset, outlen, b, decd)
|
decode(offset, outlen, b, decd)
|
||||||
return nil
|
return outlen, nil
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -121,7 +121,7 @@ func benchEncode(b *testing.B, data []byte) {
|
|||||||
b.SetBytes(int64(len(data)))
|
b.SetBytes(int64(len(data)))
|
||||||
b.ResetTimer()
|
b.ResetTimer()
|
||||||
for i := 0; i < b.N; i++ {
|
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)
|
panic(err)
|
||||||
}
|
}
|
||||||
buf := make([]byte, EncodeLen(len(data)))
|
buf := make([]byte, EncodeLen(len(data)))
|
||||||
err = EncodeTo(data, buf)
|
_, err = EncodeTo(data, buf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
b.SetBytes(int64(len(buf)))
|
b.SetBytes(int64(len(buf)))
|
||||||
b.ResetTimer()
|
b.ResetTimer()
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
_ = DecodeTo(buf, data)
|
_, _ = DecodeTo(buf, data)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
20
decoder.go
20
decoder.go
@@ -34,12 +34,7 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
|
|||||||
inlen = i + n
|
inlen = i + n
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if inlen > 0 {
|
if inlen > 0 {
|
||||||
offset := 0
|
n, _ = DecodeTo(d.b[:inlen], p)
|
||||||
if d.b[inlen-2] == '=' {
|
|
||||||
offset = int(d.b[inlen-1])
|
|
||||||
}
|
|
||||||
n = DecodeLen(inlen, offset)
|
|
||||||
_ = DecodeTo(d.b[:inlen], p)
|
|
||||||
d.b = nil
|
d.b = nil
|
||||||
d.r = nil
|
d.r = nil
|
||||||
}
|
}
|
||||||
@@ -55,13 +50,11 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
|
|||||||
offset = int(d.b[inlen-1])
|
offset = int(d.b[inlen-1])
|
||||||
}
|
}
|
||||||
if offset > 0 {
|
if offset > 0 {
|
||||||
n = DecodeLen(len(d.b[:inlen]), offset)
|
n, _ = DecodeTo(d.b[:inlen], p)
|
||||||
_ = DecodeTo(d.b[:inlen], p)
|
|
||||||
d.b = nil
|
d.b = nil
|
||||||
d.r = nil
|
d.r = nil
|
||||||
} else {
|
} else {
|
||||||
n = DecodeLen(inlen, 0)
|
n, _ = DecodeTo(d.b[:inlen], p)
|
||||||
_ = DecodeTo(d.b[:inlen], p)
|
|
||||||
d.b = d.b[:0]
|
d.b = d.b[:0]
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
@@ -75,12 +68,7 @@ func (d *Decoder) Read(p []byte) (n int, err error) {
|
|||||||
if len(d.b[inlen:]) == 2 {
|
if len(d.b[inlen:]) == 2 {
|
||||||
inlen += 2
|
inlen += 2
|
||||||
}
|
}
|
||||||
offset := 0
|
n, _ = DecodeTo(d.b[:inlen], p)
|
||||||
if d.b[inlen-2] == '=' {
|
|
||||||
offset = int(d.b[inlen-1])
|
|
||||||
}
|
|
||||||
n = DecodeLen(inlen, offset)
|
|
||||||
_ = DecodeTo(d.b[:inlen], p)
|
|
||||||
d.b = d.b[inlen:]
|
d.b = d.b[inlen:]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,22 +31,19 @@ func (e *Encoder) Read(p []byte) (n int, err error) {
|
|||||||
inlen = i + n
|
inlen = i + n
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if len(e.b) > 0 {
|
if len(e.b) > 0 {
|
||||||
n = EncodeLen(inlen)
|
n, _ = EncodeTo(e.b[:inlen], p)
|
||||||
_ = EncodeTo(e.b[:inlen], p)
|
|
||||||
}
|
}
|
||||||
e.b = nil
|
e.b = nil
|
||||||
e.r = nil
|
e.r = nil
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
n = EncodeLen(inlen)
|
n, err = EncodeTo(e.b[:inlen], p)
|
||||||
err = EncodeTo(e.b[:inlen], p)
|
|
||||||
e.b = e.b[:0]
|
e.b = e.b[:0]
|
||||||
return
|
return
|
||||||
} else if inlen > len(e.b) {
|
} else if inlen > len(e.b) {
|
||||||
inlen = len(e.b)
|
inlen = len(e.b)
|
||||||
}
|
}
|
||||||
n = EncodeLen(inlen)
|
n, err = EncodeTo(e.b[:inlen], p)
|
||||||
err = EncodeTo(e.b[:inlen], p)
|
|
||||||
e.b = e.b[inlen:]
|
e.b = e.b[inlen:]
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user