|  | @@ -56,16 +56,14 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
											
												
													
														|  |  #include <memory>
 |  |  #include <memory>
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  using namespace Assimp;
 |  |  using namespace Assimp;
 | 
											
												
													
														|  | -//using namespace irr;
 |  | 
 | 
											
												
													
														|  | -//using namespace irr::io;
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // zlib is needed for compressed XGL files
 |  |  // zlib is needed for compressed XGL files
 | 
											
												
													
														|  |  #ifndef ASSIMP_BUILD_NO_COMPRESSED_XGL
 |  |  #ifndef ASSIMP_BUILD_NO_COMPRESSED_XGL
 | 
											
												
													
														|  | -#ifdef ASSIMP_BUILD_NO_OWN_ZLIB
 |  | 
 | 
											
												
													
														|  | -#include <zlib.h>
 |  | 
 | 
											
												
													
														|  | -#else
 |  | 
 | 
											
												
													
														|  | -#include <contrib/zlib/zlib.h>
 |  | 
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#  ifdef ASSIMP_BUILD_NO_OWN_ZLIB
 | 
											
												
													
														|  | 
 |  | +#    include <zlib.h>
 | 
											
												
													
														|  | 
 |  | +#  else
 | 
											
												
													
														|  | 
 |  | +#    include <contrib/zlib/zlib.h>
 | 
											
												
													
														|  | 
 |  | +#  endif
 | 
											
												
													
														|  |  #endif
 |  |  #endif
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  namespace Assimp { // this has to be in here because LogFunctions is in ::Assimp
 |  |  namespace Assimp { // this has to be in here because LogFunctions is in ::Assimp
 | 
											
										
											
												
													
														|  | @@ -133,8 +131,7 @@ const aiImporterDesc *XGLImporter::GetInfo() const {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // ------------------------------------------------------------------------------------------------
 |  |  // ------------------------------------------------------------------------------------------------
 | 
											
												
													
														|  |  // Imports the given file into the given scene structure.
 |  |  // Imports the given file into the given scene structure.
 | 
											
												
													
														|  | -void XGLImporter::InternReadFile(const std::string &pFile,
 |  | 
 | 
											
												
													
														|  | -		aiScene *pScene, IOSystem *pIOHandler) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +void XGLImporter::InternReadFile(const std::string &pFile, aiScene *pScene, IOSystem *pIOHandler) {
 | 
											
												
													
														|  |  #ifndef ASSIMP_BUILD_NO_COMPRESSED_XGL
 |  |  #ifndef ASSIMP_BUILD_NO_COMPRESSED_XGL
 | 
											
												
													
														|  |  	std::vector<Bytef> uncompressed;
 |  |  	std::vector<Bytef> uncompressed;
 | 
											
												
													
														|  |  #endif
 |  |  #endif
 | 
											
										
											
												
													
														|  | @@ -207,8 +204,9 @@ void XGLImporter::InternReadFile(const std::string &pFile,
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      XmlNode root = mXmlParser->getRootNode();
 |  |      XmlNode root = mXmlParser->getRootNode();
 | 
											
												
													
														|  |  	TempScope scope;
 |  |  	TempScope scope;
 | 
											
												
													
														|  | -	if (!ASSIMP_stricmp(root.name(), "world")) {
 |  | 
 | 
											
												
													
														|  | -		ReadWorld(scope);
 |  | 
 | 
											
												
													
														|  | 
 |  | +    XmlNode *worldNode = mXmlParser->findNode("WORLD");
 | 
											
												
													
														|  | 
 |  | +    if (nullptr != worldNode) {
 | 
											
												
													
														|  | 
 |  | +		ReadWorld(*worldNode, scope);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	std::vector<aiMesh *> &meshes = scope.meshes_linear;
 |  |  	std::vector<aiMesh *> &meshes = scope.meshes_linear;
 | 
											
										
											
												
													
														|  | @@ -239,20 +237,20 @@ void XGLImporter::InternReadFile(const std::string &pFile,
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // ------------------------------------------------------------------------------------------------
 |  |  // ------------------------------------------------------------------------------------------------
 | 
											
												
													
														|  | -void XGLImporter::ReadWorld(TempScope &scope) {
 |  | 
 | 
											
												
													
														|  | -    XmlNode root = mXmlParser->getRootNode();
 |  | 
 | 
											
												
													
														|  | -	for (XmlNode &node : root.children()) {
 |  | 
 | 
											
												
													
														|  | -		const std::string &s = node.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +void XGLImporter::ReadWorld(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  | 
 |  | +    for (XmlNode ¤tNode : node.children()) {
 | 
											
												
													
														|  | 
 |  | +        const std::string &s = ai_stdStrToLower(currentNode.name());
 | 
											
												
													
														|  | 
 |  | +        
 | 
											
												
													
														|  |  		// XXX right now we'd skip <lighting> if it comes after
 |  |  		// XXX right now we'd skip <lighting> if it comes after
 | 
											
												
													
														|  |  		// <object> or <mesh>
 |  |  		// <object> or <mesh>
 | 
											
												
													
														|  |  		if (s == "lighting") {
 |  |  		if (s == "lighting") {
 | 
											
												
													
														|  | -			ReadLighting(node, scope);
 |  | 
 | 
											
												
													
														|  | 
 |  | +            ReadLighting(currentNode, scope);
 | 
											
												
													
														|  |  		} else if (s == "object" || s == "mesh" || s == "mat") {
 |  |  		} else if (s == "object" || s == "mesh" || s == "mat") {
 | 
											
												
													
														|  |  			break;
 |  |  			break;
 | 
											
												
													
														|  |  		}
 |  |  		}
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	aiNode *const nd = ReadObject(root, scope, true);
 |  | 
 | 
											
												
													
														|  | 
 |  | +	aiNode *const nd = ReadObject(node, scope, true);
 | 
											
												
													
														|  |  	if (!nd) {
 |  |  	if (!nd) {
 | 
											
												
													
														|  |  		ThrowException("failure reading <world>");
 |  |  		ThrowException("failure reading <world>");
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
										
											
												
													
														|  | @@ -265,7 +263,7 @@ void XGLImporter::ReadWorld(TempScope &scope) {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // ------------------------------------------------------------------------------------------------
 |  |  // ------------------------------------------------------------------------------------------------
 | 
											
												
													
														|  |  void XGLImporter::ReadLighting(XmlNode &node, TempScope &scope) {
 |  |  void XGLImporter::ReadLighting(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  | -	const std::string &s = node.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const std::string &s = ai_stdStrToLower(node.name());
 | 
											
												
													
														|  |  	if (s == "directionallight") {
 |  |  	if (s == "directionallight") {
 | 
											
												
													
														|  |  		scope.light = ReadDirectionalLight(node);
 |  |  		scope.light = ReadDirectionalLight(node);
 | 
											
												
													
														|  |  	} else if (s == "ambient") {
 |  |  	} else if (s == "ambient") {
 | 
											
										
											
												
													
														|  | @@ -285,7 +283,7 @@ aiLight *XGLImporter::ReadDirectionalLight(XmlNode &node) {
 | 
											
												
													
														|  |  		return nullptr;
 |  |  		return nullptr;
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	const std::string &s = child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +	const std::string &s = ai_stdStrToLower(child.name());
 | 
											
												
													
														|  |  	if (s == "direction") {
 |  |  	if (s == "direction") {
 | 
											
												
													
														|  |  		l->mDirection = ReadVec3(child);
 |  |  		l->mDirection = ReadVec3(child);
 | 
											
												
													
														|  |  	} else if (s == "diffuse") {
 |  |  	} else if (s == "diffuse") {
 | 
											
										
											
												
													
														|  | @@ -308,7 +306,7 @@ aiNode *XGLImporter::ReadObject(XmlNode &node, TempScope &scope, bool skipFirst/
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  			skipFirst = false;
 |  |  			skipFirst = false;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -			const std::string &s = child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +			const std::string &s = ai_stdStrToLower(child.name());
 | 
											
												
													
														|  |  			if (s == "mesh") {
 |  |  			if (s == "mesh") {
 | 
											
												
													
														|  |  				const size_t prev = scope.meshes_linear.size();
 |  |  				const size_t prev = scope.meshes_linear.size();
 | 
											
												
													
														|  |  				if (ReadMesh(child, scope)) {
 |  |  				if (ReadMesh(child, scope)) {
 | 
											
										
											
												
													
														|  | @@ -389,13 +387,13 @@ aiMatrix4x4 XGLImporter::ReadTrafo(XmlNode &node) {
 | 
											
												
													
														|  |  	float scale = 1.0f;
 |  |  	float scale = 1.0f;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	aiMatrix4x4 m;
 |  |  	aiMatrix4x4 m;
 | 
											
												
													
														|  | -	XmlNode child = node.child("transform");
 |  | 
 | 
											
												
													
														|  | 
 |  | +	XmlNode child = node.child("TRANSFORM");
 | 
											
												
													
														|  |  	if (child.empty()) {
 |  |  	if (child.empty()) {
 | 
											
												
													
														|  |  		return m;
 |  |  		return m;
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	for (XmlNode &sub_child : child.children()) {
 |  |  	for (XmlNode &sub_child : child.children()) {
 | 
											
												
													
														|  | -		const std::string &s = sub_child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +        const std::string &s = ai_stdStrToLower(sub_child.name());
 | 
											
												
													
														|  |  		if (s == "forward") {
 |  |  		if (s == "forward") {
 | 
											
												
													
														|  |  			forward = ReadVec3(sub_child);
 |  |  			forward = ReadVec3(sub_child);
 | 
											
												
													
														|  |  		} else if (s == "up") {
 |  |  		} else if (s == "up") {
 | 
											
										
											
												
													
														|  | @@ -502,7 +500,7 @@ bool XGLImporter::ReadMesh(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  |      const unsigned int mesh_id = ReadIDAttr(node);
 |  |      const unsigned int mesh_id = ReadIDAttr(node);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	for (XmlNode &child : node.children()) {
 |  |  	for (XmlNode &child : node.children()) {
 | 
											
												
													
														|  | -		const std::string &s = child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +        const std::string &s = ai_stdStrToLower(child.name());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		if (s == "mat") {
 |  |  		if (s == "mat") {
 | 
											
												
													
														|  |  			ReadMaterial(child, scope);
 |  |  			ReadMaterial(child, scope);
 | 
											
										
											
												
													
														|  | @@ -537,7 +535,7 @@ bool XGLImporter::ReadMesh(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  |  			TempFace tf[3];
 |  |  			TempFace tf[3];
 | 
											
												
													
														|  |  			bool has[3] = { false };
 |  |  			bool has[3] = { false };
 | 
											
												
													
														|  |  			for (XmlNode &sub_child : child.children()) {
 |  |  			for (XmlNode &sub_child : child.children()) {
 | 
											
												
													
														|  | -				const std::string &scn = sub_child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +                const std::string &scn = ai_stdStrToLower(sub_child.name());
 | 
											
												
													
														|  |                  if (scn == "fv1" || scn == "lv1" || scn == "pv1") {
 |  |                  if (scn == "fv1" || scn == "lv1" || scn == "pv1") {
 | 
											
												
													
														|  |  					ReadFaceVertex(sub_child, t, tf[0]);
 |  |  					ReadFaceVertex(sub_child, t, tf[0]);
 | 
											
												
													
														|  |  					has[0] = true;
 |  |  					has[0] = true;
 | 
											
										
											
												
													
														|  | @@ -631,7 +629,7 @@ unsigned int XGLImporter::ResolveMaterialRef(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	// ok, this is n^2 and should get optimized one day
 |  |  	// ok, this is n^2 and should get optimized one day
 | 
											
												
													
														|  | -	aiMaterial *const m = (*it).second;
 |  | 
 | 
											
												
													
														|  | 
 |  | +	aiMaterial *const m = it->second;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	unsigned int i = 0, mcount = static_cast<unsigned int>(scope.materials_linear.size());
 |  |  	unsigned int i = 0, mcount = static_cast<unsigned int>(scope.materials_linear.size());
 | 
											
												
													
														|  |  	for (; i < mcount; ++i) {
 |  |  	for (; i < mcount; ++i) {
 | 
											
										
											
												
													
														|  | @@ -651,7 +649,7 @@ void XGLImporter::ReadMaterial(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	aiMaterial *mat(new aiMaterial);
 |  |  	aiMaterial *mat(new aiMaterial);
 | 
											
												
													
														|  |  	for (XmlNode &child : node.children()) {
 |  |  	for (XmlNode &child : node.children()) {
 | 
											
												
													
														|  | -		const std::string &s = child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +        const std::string &s = ai_stdStrToLower(child.name());
 | 
											
												
													
														|  |  		if (s == "amb") {
 |  |  		if (s == "amb") {
 | 
											
												
													
														|  |  			const aiColor3D c = ReadCol3(child);
 |  |  			const aiColor3D c = ReadCol3(child);
 | 
											
												
													
														|  |  			mat->AddProperty(&c, 1, AI_MATKEY_COLOR_AMBIENT);
 |  |  			mat->AddProperty(&c, 1, AI_MATKEY_COLOR_AMBIENT);
 | 
											
										
											
												
													
														|  | @@ -681,7 +679,7 @@ void XGLImporter::ReadMaterial(XmlNode &node, TempScope &scope) {
 | 
											
												
													
														|  |  void XGLImporter::ReadFaceVertex(XmlNode &node, const TempMesh &t, TempFace &out) {
 |  |  void XGLImporter::ReadFaceVertex(XmlNode &node, const TempMesh &t, TempFace &out) {
 | 
											
												
													
														|  |  	bool havep = false;
 |  |  	bool havep = false;
 | 
											
												
													
														|  |  	for (XmlNode &child : node.children()) {
 |  |  	for (XmlNode &child : node.children()) {
 | 
											
												
													
														|  | -		const std::string &s = child.name();
 |  | 
 | 
											
												
													
														|  | 
 |  | +        const std::string &s = ai_stdStrToLower(child.name());
 | 
											
												
													
														|  |  		if (s == "pref") {
 |  |  		if (s == "pref") {
 | 
											
												
													
														|  |  			const unsigned int id = ReadIndexFromText(child);
 |  |  			const unsigned int id = ReadIndexFromText(child);
 | 
											
												
													
														|  |  			std::map<unsigned int, aiVector3D>::const_iterator it = t.points.find(id);
 |  |  			std::map<unsigned int, aiVector3D>::const_iterator it = t.points.find(id);
 |