-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Expand file tree
/
Copy pathData.cpp
More file actions
40 lines (32 loc) · 1.01 KB
/
Data.cpp
File metadata and controls
40 lines (32 loc) · 1.01 KB
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
// SPDX-License-Identifier: Apache-2.0
//
// Copyright © 2017 Trust Wallet.
#include "Data.h"
namespace TW {
Data subData(const Data& data, size_t startIndex, size_t length) {
if (startIndex >= data.size()) {
return Data();
}
const size_t subLength = std::min(length, data.size() - startIndex); // guard against over-length
return TW::data(data.data() + startIndex, subLength);
}
Data subData(const Data& data, size_t startIndex) {
if (startIndex >= data.size()) {
return Data();
}
const size_t subLength = data.size() - startIndex;
return TW::data(data.data() + startIndex, subLength);
}
bool isEqualConstantTime(const Data& in_a, const Data& in_b) {
if (in_a.size() != in_b.size()) {
return false;
}
const volatile unsigned char *a = in_a.data();
const volatile unsigned char *b = in_b.data();
unsigned char result = 0;
for (size_t i = 0; i < in_a.size(); i++) {
result |= a[i] ^ b[i];
}
return result == 0;
}
} // namespace TW