From 0175d52eca7fcd4a72183a1e58364f0be19998a1 Mon Sep 17 00:00:00 2001 From: Wijnand Modderman-Lenstra Date: Fri, 11 Dec 2015 23:57:57 +0100 Subject: [PATCH] bit: more efficient; debits --- bit/bit.go | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/bit/bit.go b/bit/bit.go index 67e0cea..1ffd824 100644 --- a/bit/bit.go +++ b/bit/bit.go @@ -1,5 +1,7 @@ package bit +import "fmt" + type Bit byte func (b *Bit) Flip() { @@ -38,6 +40,33 @@ func (bits *Bits) Bytes() []byte { return o } +func (bits Bits) Debits() Debits { + var debits = make(Debits, (len(bits)+1)/2) + for i := 0; i < len(bits); i += 2 { + debits[i/2] = Debit((bits[i] << 1) | (bits[i+1])) + } + return debits +} + +func (bits Bits) Dump() string { + var ( + s string + bytes = bits.Bytes() + ) + + for i, b := range bytes { + if i%7 == 0 { + if i != 0 { + s += "\n" + } + s += fmt.Sprintf("%08x ", i) + } + s += fmt.Sprintf("%08b ", b) + } + s += "\n" + return s +} + func (bits Bits) Equal(other Bits) bool { var l = bits.Len() if l != other.Len() {