Compare commits
No commits in common. "9403da4ca0bde0186a63be9da410bfa33dbb8a37" and "7108e71b9608002435fab0fe44a2d46506235972" have entirely different histories.
9403da4ca0
...
7108e71b96
|
@ -202,6 +202,7 @@ namespace CLI {
|
||||||
}
|
}
|
||||||
|
|
||||||
ArgumentsParser::~ArgumentsParser() {
|
ArgumentsParser::~ArgumentsParser() {
|
||||||
|
//TODO: check that this actually runs
|
||||||
for (auto const& [shortName, flag]: this->flagsByShortName) {
|
for (auto const& [shortName, flag]: this->flagsByShortName) {
|
||||||
delete flag;
|
delete flag;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,7 @@ namespace VarInt {
|
||||||
// up to 5 bytes, least significant byte first, most significant bit
|
// up to 5 bytes, least significant byte first, most significant bit
|
||||||
// indicates whether the next byte is still part of the number
|
// indicates whether the next byte is still part of the number
|
||||||
ErrorOr<int32_t> fromVar32(std::vector<uint8_t> data, uint64_t initialPosition=0, uint8_t* processedBytes=nullptr) {
|
ErrorOr<int32_t> fromVar32(std::vector<uint8_t> data, uint64_t initialPosition=0, uint8_t* processedBytes=nullptr) {
|
||||||
if (initialPosition >= data.size()) {
|
if (initialPosition > data.size()) {
|
||||||
return ErrorOr<int32_t>(true, ErrorCodes::OUT_OF_RANGE);
|
return ErrorOr<int32_t>(true, ErrorCodes::OUT_OF_RANGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ namespace VarInt {
|
||||||
bits += 7;
|
bits += 7;
|
||||||
currentPosition++;
|
currentPosition++;
|
||||||
// check after increasing so we don't need to check outside the loop
|
// check after increasing so we don't need to check outside the loop
|
||||||
if (currentPosition >= data.size()) {
|
if (currentPosition > data.size()) {
|
||||||
return ErrorOr<int32_t>(true, ErrorCodes::OVERRUN);
|
return ErrorOr<int32_t>(true, ErrorCodes::OVERRUN);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,7 +57,7 @@ namespace VarInt {
|
||||||
// up to 10 bytes, least significant byte first, most significant bit
|
// up to 10 bytes, least significant byte first, most significant bit
|
||||||
// indicates whether the next byte is still part of the number
|
// indicates whether the next byte is still part of the number
|
||||||
ErrorOr<int64_t> fromVar64(std::vector<uint8_t> data, uint64_t initialPosition=0, uint8_t* processedBytes=nullptr) {
|
ErrorOr<int64_t> fromVar64(std::vector<uint8_t> data, uint64_t initialPosition=0, uint8_t* processedBytes=nullptr) {
|
||||||
if (initialPosition >= data.size()) {
|
if (initialPosition > data.size()) {
|
||||||
return ErrorOr<int64_t>(true, ErrorCodes::OUT_OF_RANGE);
|
return ErrorOr<int64_t>(true, ErrorCodes::OUT_OF_RANGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ namespace VarInt {
|
||||||
bits += 7;
|
bits += 7;
|
||||||
currentPosition++;
|
currentPosition++;
|
||||||
// check after increasing so we don't need to check outside the loop
|
// check after increasing so we don't need to check outside the loop
|
||||||
if (currentPosition >= data.size()) {
|
if (currentPosition > data.size()) {
|
||||||
return ErrorOr<int64_t>(true, ErrorCodes::OVERRUN);
|
return ErrorOr<int64_t>(true, ErrorCodes::OVERRUN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,30 +42,6 @@ int main() {
|
||||||
// 1000 0000 0100 0000 0010 0000 0001 0000 0000 1000 0000 0100 0000 0010 0000 0001 = -9205322385119247871 -> 1000 0001 1000 0100 1001 0000 1100 0000 1000 0000 1000 0010 1000 1000 1010 0000 1000 0000 0000 0001
|
// 1000 0000 0100 0000 0010 0000 0001 0000 0000 1000 0000 0100 0000 0010 0000 0001 = -9205322385119247871 -> 1000 0001 1000 0100 1001 0000 1100 0000 1000 0000 1000 0010 1000 1000 1010 0000 1000 0000 0000 0001
|
||||||
// 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 = -1 (unsigned int64 max) -> 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 0000 0001
|
// 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 = -1 (unsigned int64 max) -> 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 0000 0001
|
||||||
|
|
||||||
{
|
|
||||||
std::vector<uint8_t> data = std::vector<uint8_t>();
|
|
||||||
uint8_t processedBytes;
|
|
||||||
ErrorOr<int32_t> result = VarInt::fromVar32(data, 0, &processedBytes);
|
|
||||||
ASSERT(result.isError);
|
|
||||||
ASSERT(result.errorCode == ErrorCodes::OUT_OF_RANGE);
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
std::vector<uint8_t> data = { 0x84 };
|
|
||||||
uint8_t processedBytes;
|
|
||||||
ErrorOr<int32_t> result = VarInt::fromVar32(data, 0, &processedBytes);
|
|
||||||
ASSERT(result.isError);
|
|
||||||
ASSERT(result.errorCode == ErrorCodes::OVERRUN);
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
std::vector<uint8_t> data = { 0xff, 0xff, 0xff, 0xff, 0xff, 0x01 };
|
|
||||||
uint8_t processedBytes;
|
|
||||||
ErrorOr<int32_t> result = VarInt::fromVar32(data, 0, &processedBytes);
|
|
||||||
ASSERT(result.isError);
|
|
||||||
ASSERT(result.errorCode == ErrorCodes::OVERFLOW);
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t zeroProcessedBytes = 0;
|
uint8_t zeroProcessedBytes = 0;
|
||||||
std::vector<uint8_t> zeroData;
|
std::vector<uint8_t> zeroData;
|
||||||
zeroData.push_back(0);
|
zeroData.push_back(0);
|
||||||
|
@ -114,30 +90,6 @@ int main() {
|
||||||
|
|
||||||
std::cout << "Passed fromVar32 test." << std::endl;
|
std::cout << "Passed fromVar32 test." << std::endl;
|
||||||
|
|
||||||
{
|
|
||||||
std::vector<uint8_t> data = std::vector<uint8_t>();
|
|
||||||
uint8_t processedBytes;
|
|
||||||
ErrorOr<int64_t> result = VarInt::fromVar64(data, 0, &processedBytes);
|
|
||||||
ASSERT(result.isError);
|
|
||||||
ASSERT(result.errorCode == ErrorCodes::OUT_OF_RANGE);
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
std::vector<uint8_t> data = { 0x84 };
|
|
||||||
uint8_t processedBytes;
|
|
||||||
ErrorOr<int64_t> result = VarInt::fromVar64(data, 0, &processedBytes);
|
|
||||||
ASSERT(result.isError);
|
|
||||||
ASSERT(result.errorCode == ErrorCodes::OVERRUN);
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
|
||||||
std::vector<uint8_t> data = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x01 };
|
|
||||||
uint8_t processedBytes;
|
|
||||||
ErrorOr<int64_t> result = VarInt::fromVar64(data, 0, &processedBytes);
|
|
||||||
ASSERT(result.isError);
|
|
||||||
ASSERT(result.errorCode == ErrorCodes::OVERFLOW);
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t zero64ProcessedBytes = 0;
|
uint8_t zero64ProcessedBytes = 0;
|
||||||
std::vector<uint8_t> zero64Data;
|
std::vector<uint8_t> zero64Data;
|
||||||
zero64Data.push_back(0);
|
zero64Data.push_back(0);
|
||||||
|
|
Loading…
Reference in New Issue