-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutil.cpp
58 lines (52 loc) · 1.78 KB
/
util.cpp
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
#include <iostream>
#include <iomanip>
#include <string.h>
void print_bytes(const unsigned char *data, size_t dataLen, bool format = true) {
for(size_t i = 0; i < dataLen; ++i) {
std::cout << std::hex << std::setw(2) << (int)data[i];
if (format) {
std::cout << (((i + 1) % 16 == 0) ? "\n" : " ");
}
}
std::cout << std::endl;
}
void print_bytes_reversed(const unsigned char *data, size_t dataLen, bool format = true) {
for(size_t i = dataLen; i > 0; i--) {
std::cout << std::hex << std::setw(2) << (int)data[i - 1];
if (format) {
std::cout << (((i - 1) % 16 == 0) ? "\n" : " ");
}
}
std::cout << std::endl;
}
uint32_t Reverse32(uint32_t value)
{
return (((value & 0x000000FF) << 24) |
((value & 0x0000FF00) << 8) |
((value & 0x00FF0000) >> 8) |
((value & 0xFF000000) >> 24));
}
unsigned char* hexstr_to_char(const char* hexstr)
{
size_t len = strlen(hexstr);
size_t final_len = len / 2;
unsigned char* chars = (unsigned char*)malloc((final_len + 1));
for(size_t i = 0, j = 0; j < final_len; i += 2, j++)
chars[j] = (hexstr[i] % 32 + 9) % 25 * 16 + (hexstr[i+1] % 32 + 9) % 25;
chars[final_len] = '\0';
return chars;
}
void hexstr_to_intarray(const char* hexstr, uint32_t* outputloc)
{
size_t len = strlen(hexstr);
size_t intlen = (len + 7) / 8; // +7 ensures that we do a ceiling divide
unsigned char* bytes = hexstr_to_char(hexstr);
for(size_t i = 0; i < intlen; i++)
{
uint32_t a = (uint32_t)bytes[i * 4 + 3] << 24;
*(outputloc + i) = ((uint32_t)bytes[i * 4])
+ ((uint32_t)bytes[i * 4 + 1] << 8)
+ ((uint32_t)bytes[i * 4 + 2] << 16)
+ ((uint32_t)bytes[i * 4 + 3] << 24);
}
}