AMFImporter: fix some review findings.
parent
f2817587ab
commit
a80d7346d8
|
@ -188,15 +188,15 @@ void AMFImporter::XML_CheckNode_MustHaveChildren()
|
||||||
|
|
||||||
void AMFImporter::XML_CheckNode_SkipUnsupported(const std::string& pParentNodeName)
|
void AMFImporter::XML_CheckNode_SkipUnsupported(const std::string& pParentNodeName)
|
||||||
{
|
{
|
||||||
const size_t Uns_Skip_Len = 3;
|
static const size_t Uns_Skip_Len = 3;
|
||||||
const char* Uns_Skip[Uns_Skip_Len] = { "composite", "edge", "normal" };
|
const char* Uns_Skip[Uns_Skip_Len] = { "composite", "edge", "normal" };
|
||||||
|
|
||||||
static bool skipped_before[Uns_Skip_Len] = { false, false, false };
|
static bool skipped_before[Uns_Skip_Len] = { false, false, false };
|
||||||
|
|
||||||
std::string nn(mReader->getNodeName());
|
std::string nn(mReader->getNodeName());
|
||||||
bool found = false;
|
bool found = false;
|
||||||
bool close_found = false;
|
bool close_found = false;
|
||||||
size_t sk_idx;
|
size_t sk_idx;
|
||||||
|
|
||||||
for(sk_idx = 0; sk_idx < Uns_Skip_Len; sk_idx++)
|
for(sk_idx = 0; sk_idx < Uns_Skip_Len; sk_idx++)
|
||||||
{
|
{
|
||||||
|
@ -245,7 +245,7 @@ bool AMFImporter::XML_SearchNode(const std::string& pNodeName)
|
||||||
|
|
||||||
bool AMFImporter::XML_ReadNode_GetAttrVal_AsBool(const int pAttrIdx)
|
bool AMFImporter::XML_ReadNode_GetAttrVal_AsBool(const int pAttrIdx)
|
||||||
{
|
{
|
||||||
std::string val(mReader->getAttributeValue(pAttrIdx));
|
std::string val(mReader->getAttributeValue(pAttrIdx));
|
||||||
|
|
||||||
if((val == "false") || (val == "0"))
|
if((val == "false") || (val == "0"))
|
||||||
return false;
|
return false;
|
||||||
|
@ -257,8 +257,8 @@ std::string val(mReader->getAttributeValue(pAttrIdx));
|
||||||
|
|
||||||
float AMFImporter::XML_ReadNode_GetAttrVal_AsFloat(const int pAttrIdx)
|
float AMFImporter::XML_ReadNode_GetAttrVal_AsFloat(const int pAttrIdx)
|
||||||
{
|
{
|
||||||
std::string val;
|
std::string val;
|
||||||
float tvalf;
|
float tvalf;
|
||||||
|
|
||||||
ParseHelper_FixTruncatedFloatString(mReader->getAttributeValue(pAttrIdx), val);
|
ParseHelper_FixTruncatedFloatString(mReader->getAttributeValue(pAttrIdx), val);
|
||||||
fast_atoreal_move(val.c_str(), tvalf, false);
|
fast_atoreal_move(val.c_str(), tvalf, false);
|
||||||
|
@ -273,8 +273,8 @@ uint32_t AMFImporter::XML_ReadNode_GetAttrVal_AsU32(const int pAttrIdx)
|
||||||
|
|
||||||
float AMFImporter::XML_ReadNode_GetVal_AsFloat()
|
float AMFImporter::XML_ReadNode_GetVal_AsFloat()
|
||||||
{
|
{
|
||||||
std::string val;
|
std::string val;
|
||||||
float tvalf;
|
float tvalf;
|
||||||
|
|
||||||
if(!mReader->read()) throw DeadlyImportError("XML_ReadNode_GetVal_AsFloat. No data, seems file is corrupt.");
|
if(!mReader->read()) throw DeadlyImportError("XML_ReadNode_GetVal_AsFloat. No data, seems file is corrupt.");
|
||||||
if(mReader->getNodeType() != irr::io::EXN_TEXT) throw DeadlyImportError("XML_ReadNode_GetVal_AsFloat. Invalid type of XML element, seems file is corrupt.");
|
if(mReader->getNodeType() != irr::io::EXN_TEXT) throw DeadlyImportError("XML_ReadNode_GetVal_AsFloat. Invalid type of XML element, seems file is corrupt.");
|
||||||
|
@ -320,7 +320,7 @@ void AMFImporter::ParseHelper_Node_Exit()
|
||||||
|
|
||||||
void AMFImporter::ParseHelper_FixTruncatedFloatString(const char* pInStr, std::string& pOutString)
|
void AMFImporter::ParseHelper_FixTruncatedFloatString(const char* pInStr, std::string& pOutString)
|
||||||
{
|
{
|
||||||
size_t instr_len;
|
size_t instr_len;
|
||||||
|
|
||||||
pOutString.clear();
|
pOutString.clear();
|
||||||
instr_len = strlen(pInStr);
|
instr_len = strlen(pInStr);
|
||||||
|
@ -352,12 +352,12 @@ static bool ParseHelper_Decode_Base64_IsBase64(const char pChar)
|
||||||
|
|
||||||
void AMFImporter::ParseHelper_Decode_Base64(const std::string& pInputBase64, std::vector<uint8_t>& pOutputData) const
|
void AMFImporter::ParseHelper_Decode_Base64(const std::string& pInputBase64, std::vector<uint8_t>& pOutputData) const
|
||||||
{
|
{
|
||||||
// With help from
|
// With help from
|
||||||
// RenИ Nyffenegger http://www.adp-gmbh.ch/cpp/common/base64.html
|
// RenИ Nyffenegger http://www.adp-gmbh.ch/cpp/common/base64.html
|
||||||
const std::string base64_chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
const std::string base64_chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
||||||
|
|
||||||
uint8_t tidx = 0;
|
uint8_t tidx = 0;
|
||||||
uint8_t arr4[4], arr3[3];
|
uint8_t arr4[4], arr3[3];
|
||||||
|
|
||||||
// check input data
|
// check input data
|
||||||
if(pInputBase64.size() % 4) throw DeadlyImportError("Base64-encoded data must have size multiply of four.");
|
if(pInputBase64.size() % 4) throw DeadlyImportError("Base64-encoded data must have size multiply of four.");
|
||||||
|
@ -402,8 +402,8 @@ uint8_t arr4[4], arr3[3];
|
||||||
|
|
||||||
void AMFImporter::ParseFile(const std::string& pFile, IOSystem* pIOHandler)
|
void AMFImporter::ParseFile(const std::string& pFile, IOSystem* pIOHandler)
|
||||||
{
|
{
|
||||||
irr::io::IrrXMLReader* OldReader = mReader;// store current XMLreader.
|
irr::io::IrrXMLReader* OldReader = mReader;// store current XMLreader.
|
||||||
std::unique_ptr<IOStream> file(pIOHandler->Open(pFile, "rb"));
|
std::unique_ptr<IOStream> file(pIOHandler->Open(pFile, "rb"));
|
||||||
|
|
||||||
// Check whether we can read from the file
|
// Check whether we can read from the file
|
||||||
if(file.get() == NULL) throw DeadlyImportError("Failed to open AMF file " + pFile + ".");
|
if(file.get() == NULL) throw DeadlyImportError("Failed to open AMF file " + pFile + ".");
|
||||||
|
@ -434,8 +434,8 @@ std::unique_ptr<IOStream> file(pIOHandler->Open(pFile, "rb"));
|
||||||
// Multi elements - No.
|
// Multi elements - No.
|
||||||
void AMFImporter::ParseNode_Root()
|
void AMFImporter::ParseNode_Root()
|
||||||
{
|
{
|
||||||
std::string unit, version;
|
std::string unit, version;
|
||||||
CAMFImporter_NodeElement* ne;
|
CAMFImporter_NodeElement *ne( nullptr );
|
||||||
|
|
||||||
// Read attributes for node <amf>.
|
// Read attributes for node <amf>.
|
||||||
MACRO_ATTRREAD_LOOPBEG;
|
MACRO_ATTRREAD_LOOPBEG;
|
||||||
|
@ -481,8 +481,8 @@ CAMFImporter_NodeElement* ne;
|
||||||
// Parent element - <amf>.
|
// Parent element - <amf>.
|
||||||
void AMFImporter::ParseNode_Constellation()
|
void AMFImporter::ParseNode_Constellation()
|
||||||
{
|
{
|
||||||
std::string id;
|
std::string id;
|
||||||
CAMFImporter_NodeElement* ne;
|
CAMFImporter_NodeElement* ne( nullptr );
|
||||||
|
|
||||||
// Read attributes for node <constellation>.
|
// Read attributes for node <constellation>.
|
||||||
MACRO_ATTRREAD_LOOPBEG;
|
MACRO_ATTRREAD_LOOPBEG;
|
||||||
|
@ -522,8 +522,8 @@ CAMFImporter_NodeElement* ne;
|
||||||
// Parent element - <amf>.
|
// Parent element - <amf>.
|
||||||
void AMFImporter::ParseNode_Instance()
|
void AMFImporter::ParseNode_Instance()
|
||||||
{
|
{
|
||||||
std::string objectid;
|
std::string objectid;
|
||||||
CAMFImporter_NodeElement* ne;
|
CAMFImporter_NodeElement* ne( nullptr );
|
||||||
|
|
||||||
// Read attributes for node <constellation>.
|
// Read attributes for node <constellation>.
|
||||||
MACRO_ATTRREAD_LOOPBEG;
|
MACRO_ATTRREAD_LOOPBEG;
|
||||||
|
@ -577,8 +577,8 @@ CAMFImporter_NodeElement* ne;
|
||||||
// Parent element - <amf>.
|
// Parent element - <amf>.
|
||||||
void AMFImporter::ParseNode_Object()
|
void AMFImporter::ParseNode_Object()
|
||||||
{
|
{
|
||||||
std::string id;
|
std::string id;
|
||||||
CAMFImporter_NodeElement* ne;
|
CAMFImporter_NodeElement* ne( nullptr );
|
||||||
|
|
||||||
// Read attributes for node <object>.
|
// Read attributes for node <object>.
|
||||||
MACRO_ATTRREAD_LOOPBEG;
|
MACRO_ATTRREAD_LOOPBEG;
|
||||||
|
@ -642,8 +642,8 @@ CAMFImporter_NodeElement* ne;
|
||||||
// "Volume" - specifies the total volume of the entity, in the entity's unit system, to be used for verification (object and volume only)
|
// "Volume" - specifies the total volume of the entity, in the entity's unit system, to be used for verification (object and volume only)
|
||||||
void AMFImporter::ParseNode_Metadata()
|
void AMFImporter::ParseNode_Metadata()
|
||||||
{
|
{
|
||||||
std::string type, value;
|
std::string type, value;
|
||||||
CAMFImporter_NodeElement* ne;
|
CAMFImporter_NodeElement* ne( nullptr );
|
||||||
|
|
||||||
// read attribute
|
// read attribute
|
||||||
MACRO_ATTRREAD_LOOPBEG;
|
MACRO_ATTRREAD_LOOPBEG;
|
||||||
|
@ -665,9 +665,11 @@ CAMFImporter_NodeElement* ne;
|
||||||
|
|
||||||
bool AMFImporter::CanRead(const std::string& pFile, IOSystem* pIOHandler, bool pCheckSig) const
|
bool AMFImporter::CanRead(const std::string& pFile, IOSystem* pIOHandler, bool pCheckSig) const
|
||||||
{
|
{
|
||||||
const std::string extension = GetExtension(pFile);
|
const std::string extension = GetExtension(pFile);
|
||||||
|
|
||||||
if(extension == "amf") return true;
|
if ( extension == "amf" ) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if(!extension.length() || pCheckSig)
|
if(!extension.length() || pCheckSig)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue