Compare commits
3 Commits
93fdcb7b65
...
92cf81c1b4
Author | SHA1 | Date |
---|---|---|
BodgeMaster | 92cf81c1b4 | |
BodgeMaster | df35243ee9 | |
BodgeMaster | 36dcf0a0f5 |
|
@ -3,6 +3,8 @@
|
||||||
#############################################################################
|
#############################################################################
|
||||||
|
|
||||||
[0: End]:
|
[0: End]:
|
||||||
|
|–Header: 1 byte
|
||||||
|
|–Payload: 0 bytes
|
||||||
'–Total: 1 byte
|
'–Total: 1 byte
|
||||||
|
|
||||||
[0: 8 Bit Integer] name:
|
[0: 8 Bit Integer] name:
|
||||||
|
@ -104,6 +106,8 @@
|
||||||
| '–Value: 0
|
| '–Value: 0
|
||||||
|
|
|
|
||||||
'–[31: End]:
|
'–[31: End]:
|
||||||
|
|–Header: 1 byte
|
||||||
|
|–Payload: 0 bytes
|
||||||
'–Total: 1 byte
|
'–Total: 1 byte
|
||||||
|
|
||||||
[0: Array of 32 Bit Integers] name:
|
[0: Array of 32 Bit Integers] name:
|
||||||
|
@ -161,6 +165,8 @@
|
||||||
| | '–Value: eat a cookie
|
| | '–Value: eat a cookie
|
||||||
| |
|
| |
|
||||||
| '–[147: End]:
|
| '–[147: End]:
|
||||||
|
| |–Header: 1 byte
|
||||||
|
| |–Payload: 0 bytes
|
||||||
| '–Total: 1 byte
|
| '–Total: 1 byte
|
||||||
|
|
|
|
||||||
|–[148: Double] double:
|
|–[148: Double] double:
|
||||||
|
@ -343,4 +349,6 @@
|
||||||
| '–Value: Hello World!
|
| '–Value: Hello World!
|
||||||
|
|
|
|
||||||
'–[477: End]:
|
'–[477: End]:
|
||||||
|
|–Header: 1 byte
|
||||||
|
|–Payload: 0 bytes
|
||||||
'–Total: 1 byte
|
'–Total: 1 byte
|
||||||
|
|
|
@ -867,6 +867,10 @@ namespace NBT {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint8_t List::getContainedType() {
|
||||||
|
return this->containedType;
|
||||||
|
}
|
||||||
|
|
||||||
ErrorOrVoid List::serializeWithoutHeader(std::vector<uint8_t>* rawData) {
|
ErrorOrVoid List::serializeWithoutHeader(std::vector<uint8_t>* rawData) {
|
||||||
if (this->containedType == TagType::INVALID) {
|
if (this->containedType == TagType::INVALID) {
|
||||||
return ErrorOrVoid(true, ErrorCodes::INVALID_TYPE);
|
return ErrorOrVoid(true, ErrorCodes::INVALID_TYPE);
|
||||||
|
|
|
@ -234,6 +234,7 @@ namespace NBT {
|
||||||
|
|
||||||
ErrorOrVoid serializeWithoutHeader(std::vector<uint8_t>* rawData) override;
|
ErrorOrVoid serializeWithoutHeader(std::vector<uint8_t>* rawData) override;
|
||||||
|
|
||||||
|
uint8_t getContainedType();
|
||||||
ErrorOr<Generic*> getElementPointer(uint64_t position);
|
ErrorOr<Generic*> getElementPointer(uint64_t position);
|
||||||
ErrorOrVoid setElementPointerAt(uint64_t position, Generic* pointer);
|
ErrorOrVoid setElementPointerAt(uint64_t position, Generic* pointer);
|
||||||
ErrorOrVoid appendPointer(Generic* pointer);
|
ErrorOrVoid appendPointer(Generic* pointer);
|
||||||
|
|
|
@ -784,6 +784,7 @@ int main(){
|
||||||
ASSERT(list_0.serialize(&vector).errorCode == ErrorCodes::INVALID_TYPE);
|
ASSERT(list_0.serialize(&vector).errorCode == ErrorCodes::INVALID_TYPE);
|
||||||
vector.clear();
|
vector.clear();
|
||||||
NBT::Tag::List list_1 = NBT::Tag::List("list_1", NBT::TagType::INT8);
|
NBT::Tag::List list_1 = NBT::Tag::List("list_1", NBT::TagType::INT8);
|
||||||
|
ASSERT(list_1.getContainedType() == NBT::TagType::INT8);
|
||||||
ASSERT(!list_1.appendPointer(pointer_1_0).isError);
|
ASSERT(!list_1.appendPointer(pointer_1_0).isError);
|
||||||
ASSERT(!list_1.appendPointer(pointer_1_1).isError);
|
ASSERT(!list_1.appendPointer(pointer_1_1).isError);
|
||||||
ASSERT(!list_1.appendPointer(pointer_1_2).isError);
|
ASSERT(!list_1.appendPointer(pointer_1_2).isError);
|
||||||
|
@ -794,6 +795,7 @@ int main(){
|
||||||
//TODO: Check that constructing with a vector of mixed tags
|
//TODO: Check that constructing with a vector of mixed tags
|
||||||
// results in a clearly defined failure mode (issue #60)
|
// results in a clearly defined failure mode (issue #60)
|
||||||
NBT::Tag::List list_2 = NBT::Tag::List("list_2", listDataVector);
|
NBT::Tag::List list_2 = NBT::Tag::List("list_2", listDataVector);
|
||||||
|
ASSERT(list_2.getContainedType() == NBT::TagType::INT8);
|
||||||
ASSERT(list_1.length() == 4 && list_2.length() == 4);
|
ASSERT(list_1.length() == 4 && list_2.length() == 4);
|
||||||
ASSERT(!list_2.deleteElement(1).isError);
|
ASSERT(!list_2.deleteElement(1).isError);
|
||||||
ASSERT(list_2.deleteElement(3).isError && list_2.deleteElement(3).errorCode == ErrorCodes::OUT_OF_RANGE);
|
ASSERT(list_2.deleteElement(3).isError && list_2.deleteElement(3).errorCode == ErrorCodes::OUT_OF_RANGE);
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <tinyutf8/tinyutf8.h>
|
||||||
|
|
||||||
#include "../lib/nbt.hpp"
|
#include "../lib/nbt.hpp"
|
||||||
#include "../lib/cli.hpp"
|
#include "../lib/cli.hpp"
|
||||||
|
@ -25,6 +26,265 @@
|
||||||
#define EXIT_USAGE 2
|
#define EXIT_USAGE 2
|
||||||
#define EXIT_UNIMPLEMENTED 3
|
#define EXIT_UNIMPLEMENTED 3
|
||||||
|
|
||||||
|
void printTagTypeName(NBT::Tag::Generic* tag, uint64_t offsetBytes) {
|
||||||
|
std::cout << "[" << offsetBytes << ": ";
|
||||||
|
switch (tag->getTagType()) {
|
||||||
|
case NBT::TagType::END:
|
||||||
|
std::cout << "End";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT8:
|
||||||
|
std::cout << "8 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT16:
|
||||||
|
std::cout << "16 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT32:
|
||||||
|
std::cout << "32 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT64:
|
||||||
|
std::cout << "64 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::FLOAT:
|
||||||
|
std::cout << "Float";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::DOUBLE:
|
||||||
|
std::cout << "Double";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT8_ARRAY:
|
||||||
|
std::cout << "Array of 8 Bit Integers";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::STRING:
|
||||||
|
std::cout << "String";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::LIST:
|
||||||
|
std::cout << "List";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::COMPOUND:
|
||||||
|
std::cout << "Compound";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT32_ARRAY:
|
||||||
|
std::cout << "Array of 32 Bit Integers";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT64_ARRAY:
|
||||||
|
std::cout << "Array of 64 Bit Integers";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// WTF? How'd you even get here?
|
||||||
|
std::cout << "Unknown Type";
|
||||||
|
}
|
||||||
|
std::cout << "]";
|
||||||
|
if (tag->name == "") {
|
||||||
|
std::cout << ":";
|
||||||
|
} else {
|
||||||
|
std::cout << " " << tag->name << ":";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void printNBytes(uint64_t bytes) {
|
||||||
|
std::cout << bytes << (bytes==1? " byte":" bytes");
|
||||||
|
}
|
||||||
|
|
||||||
|
void drawTree(NBT::Tag::Generic* tag, tiny_utf8::string prefix, uint64_t offsetBytes, bool listMode=false) {
|
||||||
|
std::vector<uint8_t> serialized;
|
||||||
|
uint64_t headerSize = 0;
|
||||||
|
if (listMode) {
|
||||||
|
tag->serializeWithoutHeader(&serialized);
|
||||||
|
|
||||||
|
std::cout << prefix << "|–Payload: ";
|
||||||
|
printNBytes(serialized.size());
|
||||||
|
std::cout << std::endl;
|
||||||
|
} else {
|
||||||
|
tag->serialize(&serialized);
|
||||||
|
if (tag->getTagType() == NBT::TagType::END) {
|
||||||
|
headerSize = 1;
|
||||||
|
} else {
|
||||||
|
headerSize = (uint64_t) NBT::Helper::readInt16(serialized.data(), serialized.size(), 1).value+3;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::cout << prefix << "|–Header: ";
|
||||||
|
printNBytes(headerSize);
|
||||||
|
std::cout << std::endl;
|
||||||
|
std::cout << prefix << "|–Payload: ";
|
||||||
|
printNBytes(serialized.size() - headerSize);
|
||||||
|
std::cout << std::endl;
|
||||||
|
}
|
||||||
|
if (tag->getTagType() == NBT::TagType::END) {
|
||||||
|
std::cout << prefix << "'–Total: ";
|
||||||
|
} else {
|
||||||
|
std::cout << prefix << "|–Total: ";
|
||||||
|
}
|
||||||
|
printNBytes(serialized.size());
|
||||||
|
std::cout << std::endl;
|
||||||
|
|
||||||
|
switch (tag->getTagType()) {
|
||||||
|
case NBT::TagType::END:
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT8:
|
||||||
|
std::cout << prefix << "'–Value: " << (int32_t) reinterpret_cast<NBT::Tag::Int8*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT16:
|
||||||
|
std::cout << prefix << "'–Value: " << (int32_t) reinterpret_cast<NBT::Tag::Int16*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT32:
|
||||||
|
std::cout << prefix << "'–Value: " << reinterpret_cast<NBT::Tag::Int32*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT64:
|
||||||
|
std::cout << prefix << "'–Value: " << reinterpret_cast<NBT::Tag::Int64*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::FLOAT:
|
||||||
|
std::cout << prefix << "'–Value: " << reinterpret_cast<NBT::Tag::Float*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::DOUBLE:
|
||||||
|
std::cout << prefix << "'–Value: " << reinterpret_cast<NBT::Tag::Double*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT8_ARRAY: {
|
||||||
|
NBT::Tag::Int8Array* array = reinterpret_cast<NBT::Tag::Int8Array*>(tag);
|
||||||
|
std::cout << prefix << "|–Length: " << array->length() << std::endl;
|
||||||
|
std::cout << prefix << "'–Values: " << std::endl;
|
||||||
|
for (uint64_t i=0; i<array->length(); i++) {
|
||||||
|
if (i == array->length()-1) {
|
||||||
|
std::cout << prefix << " '–" << (int64_t) array->getValue(i).value << std::endl;
|
||||||
|
} else {
|
||||||
|
std::cout << prefix << " |–" << (int64_t) array->getValue(i).value << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case NBT::TagType::STRING:
|
||||||
|
std::cout << prefix << "'–Value: " << reinterpret_cast<NBT::Tag::String*>(tag)->getValue() << std::endl;
|
||||||
|
break;
|
||||||
|
case NBT::TagType::LIST: {
|
||||||
|
NBT::Tag::List* list = reinterpret_cast<NBT::Tag::List*>(tag);
|
||||||
|
|
||||||
|
std::cout << prefix << "|–Contained Type: ";
|
||||||
|
switch (list->getContainedType()) {
|
||||||
|
case NBT::TagType::END:
|
||||||
|
std::cout << "End";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT8:
|
||||||
|
std::cout << "8 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT16:
|
||||||
|
std::cout << "16 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT32:
|
||||||
|
std::cout << "32 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT64:
|
||||||
|
std::cout << "64 Bit Integer";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::FLOAT:
|
||||||
|
std::cout << "Float";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::DOUBLE:
|
||||||
|
std::cout << "Double";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT8_ARRAY:
|
||||||
|
std::cout << "Array of 8 Bit Integers";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::STRING:
|
||||||
|
std::cout << "String";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::LIST:
|
||||||
|
std::cout << "List";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::COMPOUND:
|
||||||
|
std::cout << "Compound";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT32_ARRAY:
|
||||||
|
std::cout << "Array of 32 Bit Integers";
|
||||||
|
break;
|
||||||
|
case NBT::TagType::INT64_ARRAY:
|
||||||
|
std::cout << "Array of 64 Bit Integers";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
// WTF? How'd you even get here?
|
||||||
|
std::cout << "Unknown Type";
|
||||||
|
}
|
||||||
|
std::cout << std::endl;
|
||||||
|
|
||||||
|
std::cout << prefix << "|–Length: " << list->length() << std::endl;
|
||||||
|
std::cout << prefix << "|" << std::endl;
|
||||||
|
|
||||||
|
offsetBytes = offsetBytes + headerSize + 5;
|
||||||
|
for (uint64_t i=0; i<list->length(); i++) {
|
||||||
|
if (i == list->length()-1) {
|
||||||
|
std::cout << prefix << "'–";
|
||||||
|
printTagTypeName(list->getElementPointer(i).value, offsetBytes);
|
||||||
|
std::cout << std::endl;
|
||||||
|
drawTree(list->getElementPointer(i).value, prefix+" ", offsetBytes, true);
|
||||||
|
} else {
|
||||||
|
std::cout << prefix << "|–";
|
||||||
|
printTagTypeName(list->getElementPointer(i).value, offsetBytes);
|
||||||
|
std::cout << std::endl;
|
||||||
|
drawTree(list->getElementPointer(i).value, prefix+"| ", offsetBytes, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<uint8_t> serializedElement;
|
||||||
|
list->getElementPointer(i).value->serializeWithoutHeader(&serializedElement);
|
||||||
|
offsetBytes += serializedElement.size();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case NBT::TagType::COMPOUND: {
|
||||||
|
NBT::Tag::Compound* compound = reinterpret_cast<NBT::Tag::Compound*>(tag);
|
||||||
|
|
||||||
|
std::cout << prefix << "|–Length: " << compound->length() << std::endl;
|
||||||
|
std::cout << prefix << "|" << std::endl;
|
||||||
|
|
||||||
|
offsetBytes = offsetBytes + headerSize;
|
||||||
|
for (uint64_t i=0; i<compound->length(); i++) {
|
||||||
|
if (i == compound->length()-1) {
|
||||||
|
std::cout << prefix << "'–";
|
||||||
|
printTagTypeName(compound->getElementPointer(i).value, offsetBytes);
|
||||||
|
std::cout << std::endl;
|
||||||
|
drawTree(compound->getElementPointer(i).value, prefix+" ", offsetBytes);
|
||||||
|
} else {
|
||||||
|
std::cout << prefix << "|–";
|
||||||
|
printTagTypeName(compound->getElementPointer(i).value, offsetBytes);
|
||||||
|
std::cout << std::endl;
|
||||||
|
drawTree(compound->getElementPointer(i).value, prefix+"| ", offsetBytes);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<uint8_t> serializedElement;
|
||||||
|
compound->getElementPointer(i).value->serialize(&serializedElement);
|
||||||
|
offsetBytes += serializedElement.size();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case NBT::TagType::INT32_ARRAY: {
|
||||||
|
NBT::Tag::Int32Array* array = reinterpret_cast<NBT::Tag::Int32Array*>(tag);
|
||||||
|
std::cout << prefix << "|–Length: " << array->length() << std::endl;
|
||||||
|
std::cout << prefix << "'–Values: " << std::endl;
|
||||||
|
for (uint64_t i=0; i<array->length(); i++) {
|
||||||
|
if (i == array->length()-1) {
|
||||||
|
std::cout << prefix << " '–" << array->getValue(i).value << std::endl;
|
||||||
|
} else {
|
||||||
|
std::cout << prefix << " |–" << array->getValue(i).value << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case NBT::TagType::INT64_ARRAY: {
|
||||||
|
NBT::Tag::Int64Array* array = reinterpret_cast<NBT::Tag::Int64Array*>(tag);
|
||||||
|
std::cout << prefix << "|–Length: " << array->length() << std::endl;
|
||||||
|
std::cout << prefix << "'–Values: " << std::endl;
|
||||||
|
for (uint64_t i=0; i<array->length(); i++) {
|
||||||
|
if (i == array->length()-1) {
|
||||||
|
std::cout << prefix << " '–" << array->getValue(i).value << std::endl;
|
||||||
|
} else {
|
||||||
|
std::cout << prefix << " |–" << array->getValue(i).value << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
// WTF? How'd you even get here?
|
||||||
|
std::cout << prefix << "'–???" << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::cout << prefix << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char* argv[]) {
|
int main(int argc, char* argv[]) {
|
||||||
std::vector<CLI::Flag> flags;
|
std::vector<CLI::Flag> flags;
|
||||||
|
@ -93,7 +353,16 @@ int main(int argc, char* argv[]) {
|
||||||
return EXIT_RUNTIME;
|
return EXIT_RUNTIME;
|
||||||
}
|
}
|
||||||
|
|
||||||
//TODO: print things here
|
uint64_t offsetBytes = 0;
|
||||||
|
for (uint64_t i=0; i<tags.value.size(); i++) {
|
||||||
|
printTagTypeName(tags.value[i], offsetBytes);
|
||||||
|
std::cout << std::endl;
|
||||||
|
drawTree(tags.value[i], "", offsetBytes);
|
||||||
|
|
||||||
|
std::vector<uint8_t> serialized;
|
||||||
|
tags.value[i]->serialize(&serialized);
|
||||||
|
offsetBytes += serialized.size();
|
||||||
|
}
|
||||||
|
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue