Compare commits

..

No commits in common. "9403da4ca0bde0186a63be9da410bfa33dbb8a37" and "7108e71b9608002435fab0fe44a2d46506235972" have entirely different histories.

3 changed files with 5 additions and 52 deletions

View File

@ -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;
} }

View File

@ -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);
} }
} }

View File

@ -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);