diff options
author | obscuren <obscuren@obscura.com> | 2014-01-01 10:06:52 +0800 |
---|---|---|
committer | obscuren <obscuren@obscura.com> | 2014-01-01 10:06:52 +0800 |
commit | 34d62c380ef6327c170639af6221a82610efa25c (patch) | |
tree | 3c519214bb48628a3b68fa49d18f5b5c9def4f8e | |
parent | 276fa6c799b08bc41efd2d26a83eef678e8c943b (diff) | |
download | dexon-34d62c380ef6327c170639af6221a82610efa25c.tar.gz dexon-34d62c380ef6327c170639af6221a82610efa25c.tar.zst dexon-34d62c380ef6327c170639af6221a82610efa25c.zip |
Encoding helpers for trie
-rw-r--r-- | encoding.go | 16 | ||||
-rw-r--r-- | encoding_test.go | 12 |
2 files changed, 16 insertions, 12 deletions
diff --git a/encoding.go b/encoding.go index ca30b47c9..d77303817 100644 --- a/encoding.go +++ b/encoding.go @@ -4,6 +4,7 @@ import ( "bytes" "encoding/hex" "strings" + _"fmt" ) func CompactEncode(hexSlice []int) string { @@ -32,6 +33,21 @@ func CompactEncode(hexSlice []int) string { return buff.String() } +func CompactDecode(str string) []int { + base := CompactHexDecode(str) + base = base[:len(base)-1] + if base[0] >= 2 {// && base[len(base)-1] != 16 { + base = append(base, 16) + } + if base[0] % 2 == 1 { + base = base[1:] + } else { + base = base[2:] + } + + return base +} + func CompactHexDecode(str string) []int { base := "0123456789abcdef" hexSlice := make([]int, 0) diff --git a/encoding_test.go b/encoding_test.go index 63f7878bf..b66f702ac 100644 --- a/encoding_test.go +++ b/encoding_test.go @@ -27,18 +27,6 @@ func TestCompactEncode(t *testing.T) { } } -// Helper function for comparing slices -func CompareIntSlice(a, b []int) bool { - if len(a) != len(b) { - return false - } - for i, v := range a { - if v != b[i] { - return false - } - } - return true -} func TestCompactHexDecode(t *testing.T) { exp := []int{7, 6, 6, 5, 7, 2, 6, 2, 16} |