mirror of
https://github.com/monero-project/monero.git
synced 2025-01-24 19:46:01 +00:00
Merge pull request #6360
533d85d
Fixed string_ref usage bug in epee::from_hex::vector (vtnerd)
This commit is contained in:
commit
26107dc4cd
2 changed files with 7 additions and 4 deletions
|
@ -84,7 +84,7 @@ namespace epee
|
||||||
return write_hex(out, src);
|
return write_hex(out, src);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<uint8_t> from_hex::vector(boost::string_ref src)
|
std::vector<uint8_t> from_hex::vector(const boost::string_ref src)
|
||||||
{
|
{
|
||||||
// should we include a specific character
|
// should we include a specific character
|
||||||
auto include = [](char input) {
|
auto include = [](char input) {
|
||||||
|
@ -104,7 +104,7 @@ namespace epee
|
||||||
result.reserve(count / 2);
|
result.reserve(count / 2);
|
||||||
|
|
||||||
// the data to work with (std::string is always null-terminated)
|
// the data to work with (std::string is always null-terminated)
|
||||||
auto data = src.data();
|
auto data = src.begin();
|
||||||
|
|
||||||
// convert a single hex character to an unsigned integer
|
// convert a single hex character to an unsigned integer
|
||||||
auto char_to_int = [](const char *input) {
|
auto char_to_int = [](const char *input) {
|
||||||
|
@ -130,9 +130,9 @@ namespace epee
|
||||||
};
|
};
|
||||||
|
|
||||||
// keep going until we reach the end
|
// keep going until we reach the end
|
||||||
while (data[0] != '\0') {
|
while (data != src.end()) {
|
||||||
// skip unwanted characters
|
// skip unwanted characters
|
||||||
if (!include(data[0])) {
|
if (!include(*data)) {
|
||||||
++data;
|
++data;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -840,6 +840,9 @@ TEST(FromHex, String)
|
||||||
// decoding it this way also, ignoring spaces and colons between the numbers
|
// decoding it this way also, ignoring spaces and colons between the numbers
|
||||||
hex.assign("00:ff 0f:f0");
|
hex.assign("00:ff 0f:f0");
|
||||||
EXPECT_EQ(source, epee::from_hex::vector(hex));
|
EXPECT_EQ(source, epee::from_hex::vector(hex));
|
||||||
|
|
||||||
|
hex.append("f0");
|
||||||
|
EXPECT_EQ(source, epee::from_hex::vector(boost::string_ref{hex.data(), hex.size() - 2}));
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(ToHex, Array)
|
TEST(ToHex, Array)
|
||||||
|
|
Loading…
Reference in a new issue