mirror of
https://github.com/wader/fq.git
synced 2024-11-23 18:56:52 +03:00
164 lines
4.0 KiB
Go
164 lines
4.0 KiB
Go
package bitio_test
|
|
|
|
import (
|
|
"bytes"
|
|
"io"
|
|
"log"
|
|
"testing"
|
|
|
|
"github.com/wader/fq/pkg/bitio"
|
|
)
|
|
|
|
type shortBitReader struct {
|
|
bitio.BitReaderAt
|
|
}
|
|
|
|
func (b shortBitReader) ReadBitsAt(p []byte, nBits int, bitOff int64) (n int, err error) {
|
|
if nBits > 3 {
|
|
nBits = 3
|
|
}
|
|
return b.BitReaderAt.ReadBitsAt(p, nBits, bitOff)
|
|
}
|
|
|
|
func TestReader(t *testing.T) {
|
|
|
|
bb, bbBits := bitio.BytesFromBitString("011011110")
|
|
|
|
br := bitio.NewReaderFromReadSeeker(bytes.NewReader(bb))
|
|
sbr := bitio.NewSectionBitReader(br, 0, int64(bbBits))
|
|
sbr2 := bitio.NewSectionBitReader(sbr, 0, 4)
|
|
|
|
ob := make([]byte, 2)
|
|
|
|
obBits, _ := sbr2.ReadBits(ob, 4)
|
|
|
|
obs := bitio.BitStringFromBytes(ob, obBits)
|
|
|
|
log.Printf("obs: %#+v\n", obs)
|
|
}
|
|
|
|
func TestIOCopy(t *testing.T) {
|
|
|
|
br := bitio.NewReaderFromReadSeeker(bytes.NewReader([]byte{0xf0, 0xff, 0xff}))
|
|
sbr := bitio.NewSectionBitReader(br, 0, 8*3-1)
|
|
|
|
b := &bytes.Buffer{}
|
|
|
|
n, err := io.Copy(b, sbr)
|
|
log.Printf("n: %d err: %v b=%v\n", n, err, b.Bytes())
|
|
|
|
}
|
|
|
|
func TestReadFull(t *testing.T) {
|
|
|
|
bb, bbBits := bitio.BytesFromBitString("011011110")
|
|
|
|
br := bitio.NewReaderFromReadSeeker(bytes.NewReader(bb))
|
|
|
|
ob := make([]byte, 2)
|
|
|
|
obBits, _ := bitio.ReadAtFull(shortBitReader{br}, ob, bbBits, 0)
|
|
|
|
obs := bitio.BitStringFromBytes(ob, obBits)
|
|
|
|
log.Printf("obs: %#+v\n", obs)
|
|
|
|
}
|
|
|
|
func TestMultiBitReader(t *testing.T) {
|
|
|
|
bb1, bb1Bits := bitio.BytesFromBitString("101")
|
|
br1 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb1)), 0, int64(bb1Bits))
|
|
bb2, bb2Bits := bitio.BytesFromBitString("0001")
|
|
br2 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb2)), 0, int64(bb2Bits))
|
|
|
|
mb, _ := bitio.NewMultiBitReader([]bitio.BitReadAtSeeker{br1, br2})
|
|
|
|
ob := make([]byte, 2)
|
|
|
|
obBits, _ := bitio.ReadAtFull(mb, ob, 7, 0)
|
|
|
|
obs := bitio.BitStringFromBytes(ob, obBits)
|
|
|
|
log.Printf("obs: %#+v\n", obs)
|
|
|
|
}
|
|
|
|
func TestMultiBitReader11(t *testing.T) {
|
|
|
|
bb1, bb1Bits := bitio.BytesFromBitString("11111111")
|
|
br1 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb1)), 0, int64(bb1Bits))
|
|
bb2, bb2Bits := bitio.BytesFromBitString("11111111")
|
|
br2 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb2)), 0, int64(bb2Bits))
|
|
|
|
mb, _ := bitio.NewMultiBitReader([]bitio.BitReadAtSeeker{br1, br2})
|
|
|
|
ob := make([]byte, 2)
|
|
|
|
obBits, _ := bitio.ReadAtFull(mb, ob, 11, 0)
|
|
|
|
obs := bitio.BitStringFromBytes(ob, obBits)
|
|
|
|
log.Printf("obs: %#+v\n", obs)
|
|
|
|
}
|
|
|
|
type testBW struct{}
|
|
|
|
func (testBW) WriteBits(p []byte, nBits int) (n int, err error) {
|
|
log.Printf("WriteBits p: %#+v nBits=%d\n", len(p), nBits)
|
|
|
|
for i := 0; i < nBits; i++ {
|
|
if bitio.Read64(p, i, 1) != 0 {
|
|
log.Print("1")
|
|
} else {
|
|
log.Print("0")
|
|
}
|
|
log.Println()
|
|
}
|
|
|
|
return nBits, nil
|
|
}
|
|
|
|
func TestCopy(t *testing.T) {
|
|
bb1, bb1Bits := bitio.BytesFromBitString("101")
|
|
br1 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb1)), 0, int64(bb1Bits))
|
|
bb2, bb2Bits := bitio.BytesFromBitString("0001")
|
|
br2 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb2)), 0, int64(bb2Bits))
|
|
|
|
mb, _ := bitio.NewMultiBitReader([]bitio.BitReadAtSeeker{br1, br2})
|
|
|
|
n, err := bitio.Copy(testBW{}, mb)
|
|
log.Printf("n: %#+v\n", n)
|
|
log.Printf("err: %#+v\n", err)
|
|
}
|
|
|
|
func TestAlignBitWriter(t *testing.T) {
|
|
bb1, bb1Bits := bitio.BytesFromBitString("101")
|
|
br1 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb1)), 0, int64(bb1Bits))
|
|
bb2, bb2Bits := bitio.BytesFromBitString("0001")
|
|
br2 := bitio.NewSectionBitReader(bitio.NewReaderFromReadSeeker(bytes.NewReader(bb2)), 0, int64(bb2Bits))
|
|
|
|
mb, _ := bitio.NewMultiBitReader([]bitio.BitReadAtSeeker{br1, br2})
|
|
|
|
mbEnd, _ := bitio.EndPos(mb)
|
|
|
|
alignN := int64(8)
|
|
|
|
b := make([]byte, alignN/8+1)
|
|
bLeft := (alignN - mbEnd%alignN) % alignN
|
|
|
|
log.Printf("bLeft: %#+v\n", bLeft)
|
|
|
|
mb, _ = bitio.NewMultiBitReader([]bitio.BitReadAtSeeker{mb, bitio.NewBufferFromBytes(b, bLeft)})
|
|
|
|
bw := testBW{}
|
|
// ab := &bitio.AlignBitWriter{N: 8, W: bw}
|
|
|
|
n, err := bitio.Copy(bw, mb)
|
|
// ab.Close()
|
|
|
|
log.Printf("n: %#+v\n", n)
|
|
log.Printf("err: %#+v\n", err)
|
|
}
|