-
Notifications
You must be signed in to change notification settings - Fork 6
/
address.go
executable file
·111 lines (99 loc) · 2.31 KB
/
address.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
package fields
import (
"bytes"
"fmt"
base58check "github.com/hacash/core/account"
"sort"
)
const (
AddressSize = 21
)
type AddressReadable = TrimString34
type Address = Bytes21
// check address is ok ?
func CheckReadableAddress(readable string) (*Address, error) {
if len(readable) > 34 {
return nil, fmt.Errorf("Address format error")
}
hashhex, e1 := base58check.Base58CheckDecode(readable)
if e1 != nil {
return nil, fmt.Errorf("Address format error")
}
version := uint8(hashhex[0])
if version > 2 {
return nil, fmt.Errorf("Address version error")
}
addr := Address(hashhex)
return &addr, nil
}
func (this Address) ToReadable() string {
return base58check.Base58CheckEncode([]byte(this))
}
// check valid
func (this Address) IsValid() bool {
if this == nil {
return false
}
if len(this) != AddressSize {
return false
}
// ok
return true
}
// check equal
func (this Address) Equal(tar Address) bool {
return bytes.Compare(this, tar) == 0
}
func (this Address) NotEqual(tar Address) bool {
return bytes.Compare(this, tar) != 0
}
// check equal
func (this Address) Copy() Address {
addr := make([]byte, AddressSize)
copy(addr, this)
return addr
}
////////////////////////////////////////////////////////////
// Alphabetical sort
type AddressListByCharacterSort []Address
func (n AddressListByCharacterSort) Len() int {
return len(n)
}
func (n AddressListByCharacterSort) Less(i, j int) bool {
a, b := n[i], n[j]
for k := 0; k < AddressSize; k++ {
if a[k] < b[k] {
return true // Character sorting
}
}
return false
}
func (n AddressListByCharacterSort) Swap(i, j int) {
n[i], n[j] = n[j], n[i]
}
// De duplication and sorting address list
func CleanAddressListByCharacterSort(addrs []Address, addradds []Address) (VarUint1, []Address) {
// duplicate removal
addrsclear := make([]Address, 0)
repeats := map[string]bool{}
if addrs != nil {
for _, v := range addrs {
if _, hav := repeats[string(v)]; hav == false {
addrsclear = append(addrsclear, v)
}
repeats[string(v)] = true
}
}
// add to
if addradds != nil {
for _, v := range addradds {
if _, hav := repeats[string(v)]; hav == false {
addrsclear = append(addrsclear, v)
}
repeats[string(v)] = true
}
}
// sort
sort.Sort(AddressListByCharacterSort(addrsclear))
return VarUint1(len(addrsclear)), addrsclear
}