Ogre: Fixed memoryleak and missing \0 at end of cstring
git-svn-id: https://assimp.svn.sourceforge.net/svnroot/assimp/trunk@1298 67173fc5-114c-0410-ac8e-9d2fd5bffc1fpull/6/merge
parent
9687531b20
commit
a038288af9
|
@ -100,7 +100,7 @@ void OgreImporter::InternReadFile(const std::string &pFile, aiScene *pScene, Ass
|
||||||
|
|
||||||
//Read the Mesh File:
|
//Read the Mesh File:
|
||||||
boost::scoped_ptr<CIrrXML_IOStreamReader> mIOWrapper( new CIrrXML_IOStreamReader( file.get()));
|
boost::scoped_ptr<CIrrXML_IOStreamReader> mIOWrapper( new CIrrXML_IOStreamReader( file.get()));
|
||||||
XmlReader* MeshFile = irr::io::createIrrXMLReader(mIOWrapper.get());
|
boost::scoped_ptr<XmlReader> MeshFile(irr::io::createIrrXMLReader(mIOWrapper.get()));
|
||||||
if(!MeshFile)//parse the xml file
|
if(!MeshFile)//parse the xml file
|
||||||
throw DeadlyImportError("Failed to create XML Reader for "+pFile);
|
throw DeadlyImportError("Failed to create XML Reader for "+pFile);
|
||||||
|
|
||||||
|
@ -108,21 +108,21 @@ void OgreImporter::InternReadFile(const std::string &pFile, aiScene *pScene, Ass
|
||||||
DefaultLogger::get()->debug("Mesh File opened");
|
DefaultLogger::get()->debug("Mesh File opened");
|
||||||
|
|
||||||
//Read root Node:
|
//Read root Node:
|
||||||
if(!(XmlRead(MeshFile) && string(MeshFile->getNodeName())=="mesh"))
|
if(!(XmlRead(MeshFile.get()) && string(MeshFile->getNodeName())=="mesh"))
|
||||||
{
|
{
|
||||||
throw DeadlyImportError("Root Node is not <mesh>! "+pFile+" "+MeshFile->getNodeName());
|
throw DeadlyImportError("Root Node is not <mesh>! "+pFile+" "+MeshFile->getNodeName());
|
||||||
}
|
}
|
||||||
|
|
||||||
//eventually load shared geometry
|
//eventually load shared geometry
|
||||||
XmlRead(MeshFile);//shared geometry is optional, so we need a reed for the next two if's
|
XmlRead(MeshFile.get());//shared geometry is optional, so we need a reed for the next two if's
|
||||||
if(MeshFile->getNodeName()==string("sharedgeometry"))
|
if(MeshFile->getNodeName()==string("sharedgeometry"))
|
||||||
{
|
{
|
||||||
unsigned int NumVertices=GetAttribute<int>(MeshFile, "vertexcount");;
|
unsigned int NumVertices=GetAttribute<int>(MeshFile.get(), "vertexcount");;
|
||||||
|
|
||||||
XmlRead(MeshFile);
|
XmlRead(MeshFile.get());
|
||||||
while(MeshFile->getNodeName()==string("vertexbuffer"))
|
while(MeshFile->getNodeName()==string("vertexbuffer"))
|
||||||
{
|
{
|
||||||
ReadVertexBuffer(m_SharedGeometry, MeshFile, NumVertices);
|
ReadVertexBuffer(m_SharedGeometry, MeshFile.get(), NumVertices);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,13 +136,13 @@ void OgreImporter::InternReadFile(const std::string &pFile, aiScene *pScene, Ass
|
||||||
//-------------------Read the submeshs and materials:-----------------------
|
//-------------------Read the submeshs and materials:-----------------------
|
||||||
std::list<boost::shared_ptr<SubMesh> > SubMeshes;
|
std::list<boost::shared_ptr<SubMesh> > SubMeshes;
|
||||||
vector<aiMaterial*> Materials;
|
vector<aiMaterial*> Materials;
|
||||||
XmlRead(MeshFile);
|
XmlRead(MeshFile.get());
|
||||||
while(MeshFile->getNodeName()==string("submesh"))
|
while(MeshFile->getNodeName()==string("submesh"))
|
||||||
{
|
{
|
||||||
SubMesh* theSubMesh=new SubMesh();
|
SubMesh* theSubMesh=new SubMesh();
|
||||||
theSubMesh->MaterialName=GetAttribute<string>(MeshFile, "material");
|
theSubMesh->MaterialName=GetAttribute<string>(MeshFile.get(), "material");
|
||||||
DefaultLogger::get()->debug("Loading Submehs with Material: "+theSubMesh->MaterialName);
|
DefaultLogger::get()->debug("Loading Submehs with Material: "+theSubMesh->MaterialName);
|
||||||
ReadSubMesh(*theSubMesh, MeshFile);
|
ReadSubMesh(*theSubMesh, MeshFile.get());
|
||||||
|
|
||||||
//just a index in a array, we add a mesh in each loop cycle, so we get indicies like 0, 1, 2 ... n;
|
//just a index in a array, we add a mesh in each loop cycle, so we get indicies like 0, 1, 2 ... n;
|
||||||
//so it is important to do this before pushing the mesh in the vector!
|
//so it is important to do this before pushing the mesh in the vector!
|
||||||
|
@ -170,9 +170,9 @@ void OgreImporter::InternReadFile(const std::string &pFile, aiScene *pScene, Ass
|
||||||
vector<Animation> Animations;
|
vector<Animation> Animations;
|
||||||
if(MeshFile->getNodeName()==string("skeletonlink"))
|
if(MeshFile->getNodeName()==string("skeletonlink"))
|
||||||
{
|
{
|
||||||
string SkeletonFile=GetAttribute<string>(MeshFile, "name");
|
string SkeletonFile=GetAttribute<string>(MeshFile.get(), "name");
|
||||||
LoadSkeleton(SkeletonFile, Bones, Animations);
|
LoadSkeleton(SkeletonFile, Bones, Animations);
|
||||||
XmlRead(MeshFile);
|
XmlRead(MeshFile.get());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -185,7 +185,7 @@ void OgreImporter::InternReadFile(const std::string &pFile, aiScene *pScene, Ass
|
||||||
//now there might be boneassignments for the shared geometry:
|
//now there might be boneassignments for the shared geometry:
|
||||||
if(MeshFile->getNodeName()==string("boneassignments"))
|
if(MeshFile->getNodeName()==string("boneassignments"))
|
||||||
{
|
{
|
||||||
ReadBoneWeights(m_SharedGeometry, MeshFile);
|
ReadBoneWeights(m_SharedGeometry, MeshFile.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -148,13 +148,23 @@ aiMaterial* OgreImporter::LoadMaterial(const std::string MaterialName) const
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//Fill the stream
|
||||||
boost::scoped_ptr<IOStream> MaterialFile(MatFilePtr);
|
boost::scoped_ptr<IOStream> MaterialFile(MatFilePtr);
|
||||||
|
if(MaterialFile->FileSize()>0)
|
||||||
|
{
|
||||||
vector<char> FileData(MaterialFile->FileSize());
|
vector<char> FileData(MaterialFile->FileSize());
|
||||||
MaterialFile->Read(&FileData[0], MaterialFile->FileSize(), 1);
|
MaterialFile->Read(&FileData[0], MaterialFile->FileSize(), 1);
|
||||||
BaseImporter::ConvertToUTF8(FileData);
|
BaseImporter::ConvertToUTF8(FileData);
|
||||||
|
|
||||||
|
FileData.push_back('\0');//terminate the string with zero, so that the ss can parse it correctly
|
||||||
ss << &FileData[0];
|
ss << &FileData[0];
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
DefaultLogger::get()->warn("Material " + MaterialName + " seams to be empty");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//create the material
|
//create the material
|
||||||
aiMaterial *NewMaterial=new aiMaterial();
|
aiMaterial *NewMaterial=new aiMaterial();
|
||||||
|
|
Loading…
Reference in New Issue