forked from AltTechTools/gomule-tst
/
util.go
118 lines (108 loc) · 2.84 KB
/
util.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
112
113
114
115
116
117
118
/*
* Copyright (C) 2013 Deepin, Inc.
* 2013 Leslie Zhai <zhaixiang@linuxdeepin.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package emule
import (
"bytes"
"encoding/binary"
"fmt"
"math"
)
func SliceBuf(buf []byte, from int, to int, newbuf *[]byte) bool {
if len(buf) < to {
return false
}
*newbuf = buf[from:to]
return true
}
/*//type ErrorFunc func(int, int)int
type ErrorFunc func()
func SliceBufOrErr(buf []byte, from int, to int, errf ErrorFunc) []byte {
tmpbuf := make([]byte,0)
if !SliceBuf(buf,from,to,&tmpbuf) {
errf()
}
return
}*/
func ByteToInt32(data []byte) (ret int32) {
buf := bytes.NewBuffer(data)
binary.Read(buf, binary.LittleEndian, &ret)
return
}
func ByteToUint32(data []byte) (ret uint32) {
buf := bytes.NewBuffer(data)
binary.Read(buf, binary.LittleEndian, &ret)
return
}
func ByteToInt16(data []byte) (ret int16) {
buf := bytes.NewBuffer(data)
binary.Read(buf, binary.LittleEndian, &ret)
return
}
func ByteToUint16(data []byte) (ret uint16) {
buf := bytes.NewBuffer(data)
binary.Read(buf, binary.LittleEndian, &ret)
return
}
func ByteToFloat32(data []byte) (ret float32) {
buf := bytes.NewBuffer(data)
binary.Read(buf, binary.LittleEndian, &ret)
return
}
func Float32ToByte(data float32) (ret []byte) {
ret = []byte{}
buf := new(bytes.Buffer)
binary.Write(buf, binary.LittleEndian, data)
ret = buf.Bytes()
return
}
func Int16ToByte(data int16) (ret []byte) {
ret = []byte{}
buf := new(bytes.Buffer)
binary.Write(buf, binary.LittleEndian, data)
ret = buf.Bytes()
return
}
func UInt16ToByte(data uint16) (ret []byte) {
ret = []byte{}
buf := new(bytes.Buffer)
binary.Write(buf, binary.LittleEndian, data)
ret = buf.Bytes()
return
}
func Int32ToByte(data int32) (ret []byte) {
ret = []byte{}
buf := new(bytes.Buffer)
binary.Write(buf, binary.LittleEndian, data)
ret = buf.Bytes()
return
}
func UInt32ToByte(data uint32) (ret []byte) {
ret = []byte{}
buf := new(bytes.Buffer)
binary.Write(buf, binary.LittleEndian, data)
ret = buf.Bytes()
return
}
func HighId(addr string) (ret uint32) {
ret = 0
var ip1, ip2, ip3, ip4, port uint32
fmt.Sscanf(addr, "%d.%d.%d.%d:%d", &ip1, &ip2, &ip3, &ip4, &port)
ret = ip1 + uint32(math.Pow(2, 8))*ip2 + uint32(math.Pow(2, 16))*ip3 +
uint32(math.Pow(2, 24))*ip4
return
}