Compare commits
No commits in common. "434c976cc5e74c5dc9ffbfb85921551f0b858a76" and "10b1d9fa0c0c3d31efbcfa58f6d062967ef0073e" have entirely different histories.
434c976cc5
...
10b1d9fa0c
|
@ -777,72 +777,6 @@ namespace NBT {
|
||||||
this->value = value;
|
this->value = value;
|
||||||
this->mutex.unlock();
|
this->mutex.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
Int8Array::Int8Array() {
|
|
||||||
this->type = TagType::INT8_ARRAY;
|
|
||||||
}
|
|
||||||
|
|
||||||
Int8Array::Int8Array(tiny_utf8::string name, std::vector<int8_t> data) {
|
|
||||||
this->type = TagType::INT8_ARRAY;
|
|
||||||
this->name = name;
|
|
||||||
this->data = data;
|
|
||||||
}
|
|
||||||
Int8Array::Int8Array(tiny_utf8::string name, uint64_t length, int8_t data[]){
|
|
||||||
this->type = TagType::INT8_ARRAY;
|
|
||||||
this->name = name;
|
|
||||||
this->data = std::vector<int8_t>(data, data+length);
|
|
||||||
}
|
|
||||||
|
|
||||||
ErrorOrVoid Int8Array::toRawData(std::vector<uint8_t>* rawData) {
|
|
||||||
rawData->push_back(this->type);
|
|
||||||
|
|
||||||
if (Helper::writeString(rawData, this->name).isError) {
|
|
||||||
return ErrorOrVoid(true, ErrorCodes::OVERRUN);
|
|
||||||
}
|
|
||||||
|
|
||||||
Helper::writeInt8Array(rawData, this->data);
|
|
||||||
|
|
||||||
return ErrorOrVoid();
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<int8_t> Int8Array::getData() {
|
|
||||||
return this->data;
|
|
||||||
}
|
|
||||||
|
|
||||||
ErrorOr<int8_t> Int8Array::getValue(uint64_t position) {
|
|
||||||
if (this->data.size() <= position) {
|
|
||||||
return ErrorOr<int8_t>(this->data.at(position));
|
|
||||||
}
|
|
||||||
|
|
||||||
return ErrorOr<int8_t>(true, ErrorCodes::OUT_OF_RANGE);
|
|
||||||
}
|
|
||||||
|
|
||||||
void Int8Array::setData(std::vector<int8_t> newData) {
|
|
||||||
this->data = newData;
|
|
||||||
}
|
|
||||||
|
|
||||||
ErrorOrVoid Int8Array::setValue(uint64_t position, int8_t value) {
|
|
||||||
if (this->data.size() <= position) {
|
|
||||||
return ErrorOrVoid(true, ErrorCodes::OUT_OF_RANGE);
|
|
||||||
}
|
|
||||||
|
|
||||||
this->data[position] = value;
|
|
||||||
|
|
||||||
return ErrorOrVoid();
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t Int8Array::length() {
|
|
||||||
return this->data.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
void Int8Array::addElement(int8_t element) {
|
|
||||||
this->data.push_back(element);
|
|
||||||
}
|
|
||||||
|
|
||||||
ErrorOrVoid Int8Array::removeElement(uint64_t position) {
|
|
||||||
//TODO: implement
|
|
||||||
//this->data.erase(position);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool validateRawListContents(uint8_t data[], uint64_t dataSize, uint64_t initialPosition, uint64_t* processedDataSize) {
|
bool validateRawListContents(uint8_t data[], uint64_t dataSize, uint64_t initialPosition, uint64_t* processedDataSize) {
|
||||||
|
|
108
src/lib/nbt.hpp
108
src/lib/nbt.hpp
|
@ -185,114 +185,6 @@ namespace NBT {
|
||||||
double getValue();
|
double getValue();
|
||||||
void setValue(double value);
|
void setValue(double value);
|
||||||
};
|
};
|
||||||
|
|
||||||
class Int8Array: public Generic {
|
|
||||||
private:
|
|
||||||
std::vector<int8_t> data;
|
|
||||||
public:
|
|
||||||
Int8Array();
|
|
||||||
Int8Array(tiny_utf8::string name, std::vector<int8_t> data);
|
|
||||||
Int8Array(tiny_utf8::string name, uint64_t length, int8_t data[]);
|
|
||||||
|
|
||||||
ErrorOrVoid toRawData(std::vector<uint8_t>* rawData) override;
|
|
||||||
|
|
||||||
std::vector<int8_t> getData();
|
|
||||||
ErrorOr<int8_t> getValue(uint64_t position);
|
|
||||||
void setData(std::vector<int8_t> newData);
|
|
||||||
ErrorOrVoid setValue(uint64_t position, int8_t value);
|
|
||||||
uint64_t length();
|
|
||||||
void addElement(int8_t element);
|
|
||||||
ErrorOrVoid removeElement(uint64_t position);
|
|
||||||
};
|
|
||||||
|
|
||||||
class String: public Generic {
|
|
||||||
private:
|
|
||||||
tiny_utf8::string value;
|
|
||||||
public:
|
|
||||||
String();
|
|
||||||
String(tiny_utf8::string name, tiny_utf8::string value);
|
|
||||||
|
|
||||||
ErrorOrVoid toRawData(std::vector<uint8_t>* rawData) override;
|
|
||||||
tiny_utf8::string getValue();
|
|
||||||
void setValue(tiny_utf8::string value);
|
|
||||||
};
|
|
||||||
|
|
||||||
class List: public Generic {
|
|
||||||
private:
|
|
||||||
std::vector<Generic*> tags;
|
|
||||||
uint8_t type;
|
|
||||||
public:
|
|
||||||
List();
|
|
||||||
List(tiny_utf8::string name, uint8_t type);
|
|
||||||
List(tiny_utf8::string name, std::vector<Generic*> data);
|
|
||||||
|
|
||||||
~List() override;
|
|
||||||
|
|
||||||
ErrorOrVoid toRawData(std::vector<uint8_t>* rawData) override;
|
|
||||||
|
|
||||||
ErrorOr<Generic*> getElementPointer(uint64_t position);
|
|
||||||
ErrorOrVoid setElementPointerAt(uint64_t position, Generic*);
|
|
||||||
ErrorOrVoid appendPointer(Generic*);
|
|
||||||
ErrorOrVoid deleteElement(uint64_t position);
|
|
||||||
uint64_t length();
|
|
||||||
};
|
|
||||||
|
|
||||||
class Compound: public Generic {
|
|
||||||
private:
|
|
||||||
std::vector<Generic*> tags;
|
|
||||||
public:
|
|
||||||
Compound();
|
|
||||||
Compound(tiny_utf8::string name);
|
|
||||||
Compound(tiny_utf8::string name, std::vector<Generic*> data);
|
|
||||||
|
|
||||||
~Compound() override;
|
|
||||||
|
|
||||||
ErrorOrVoid toRawData(std::vector<uint8_t>* rawData) override;
|
|
||||||
|
|
||||||
ErrorOr<Generic*> getElementPointer(uint64_t position);
|
|
||||||
ErrorOrVoid setElementPointerAt(uint64_t position, Generic*);
|
|
||||||
ErrorOrVoid appendPointer(Generic*);
|
|
||||||
ErrorOrVoid deleteElement(uint64_t position);
|
|
||||||
uint64_t length();
|
|
||||||
};
|
|
||||||
|
|
||||||
class Int32Array: public Generic {
|
|
||||||
private:
|
|
||||||
std::vector<int32_t> data;
|
|
||||||
public:
|
|
||||||
Int32Array();
|
|
||||||
Int32Array(tiny_utf8::string name, std::vector<int32_t> data);
|
|
||||||
Int32Array(tiny_utf8::string name, uint64_t length, int32_t data[]);
|
|
||||||
|
|
||||||
ErrorOrVoid toRawData(std::vector<uint8_t>* rawData) override;
|
|
||||||
|
|
||||||
std::vector<int32_t> getData();
|
|
||||||
ErrorOr<int32_t> getValue(uint64_t position);
|
|
||||||
void setData(std::vector<int32_t> newData);
|
|
||||||
ErrorOrVoid setValue(uint64_t position, int32_t value);
|
|
||||||
uint64_t length();
|
|
||||||
void addElement(int32_t element);
|
|
||||||
ErrorOrVoid removeElement(uint64_t position);
|
|
||||||
};
|
|
||||||
|
|
||||||
class Int64Array: public Generic {
|
|
||||||
private:
|
|
||||||
std::vector<int64_t> data;
|
|
||||||
public:
|
|
||||||
Int64Array();
|
|
||||||
Int64Array(tiny_utf8::string name, std::vector<int64_t> data);
|
|
||||||
Int64Array(tiny_utf8::string name, uint64_t length, int64_t data[]);
|
|
||||||
|
|
||||||
ErrorOrVoid toRawData(std::vector<uint8_t>* rawData) override;
|
|
||||||
|
|
||||||
std::vector<int64_t> getData();
|
|
||||||
ErrorOr<int64_t> getValue(uint64_t position);
|
|
||||||
void setData(std::vector<int64_t> newData);
|
|
||||||
ErrorOrVoid setValue(uint64_t position, int64_t value);
|
|
||||||
uint64_t length();
|
|
||||||
void addElement(int64_t element);
|
|
||||||
ErrorOrVoid removeElement(uint64_t position);
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool validateRawNBTData(uint8_t data[], uint64_t dataSize, uint64_t initialPosition=0, uint64_t* processedDataSize=nullptr);
|
bool validateRawNBTData(uint8_t data[], uint64_t dataSize, uint64_t initialPosition=0, uint64_t* processedDataSize=nullptr);
|
||||||
|
|
|
@ -574,7 +574,7 @@ int main(){
|
||||||
ASSERT(javaStdString1 == *exportedString);
|
ASSERT(javaStdString1 == *exportedString);
|
||||||
|
|
||||||
//check that we get an error when trying to write a string that is too long
|
//check that we get an error when trying to write a string that is too long
|
||||||
std::string overrunString = std::string(0x10000, '.');
|
std::string overrunString = std::string(0xFFFFF, '.');
|
||||||
ASSERT(NBT::Helper::writeString(exportedString, tiny_utf8::string(overrunString)).isError);
|
ASSERT(NBT::Helper::writeString(exportedString, tiny_utf8::string(overrunString)).isError);
|
||||||
ASSERT(NBT::Helper::writeString(exportedString, tiny_utf8::string(overrunString)).errorCode == ErrorCodes::OVERRUN);
|
ASSERT(NBT::Helper::writeString(exportedString, tiny_utf8::string(overrunString)).errorCode == ErrorCodes::OVERRUN);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue