mirror of
https://github.com/minetest/irrlicht.git
synced 2025-01-23 14:31:29 +01:00
COBJMeshFileLoader: fix buffer overruns
This commit is contained in:
parent
4506d23dc3
commit
80e160935d
@ -72,8 +72,8 @@ IAnimatedMesh* COBJMeshFileLoader::createMesh(io::IReadFile* file)
|
|||||||
|
|
||||||
const io::path fullName = file->getFileName();
|
const io::path fullName = file->getFileName();
|
||||||
|
|
||||||
c8* buf = new c8[filesize];
|
c8* buf = new c8[filesize+1]; // plus null-terminator
|
||||||
memset(buf, 0, filesize);
|
memset(buf, 0, filesize+1);
|
||||||
file->read((void*)buf, filesize);
|
file->read((void*)buf, filesize);
|
||||||
const c8* const bufEnd = buf+filesize;
|
const c8* const bufEnd = buf+filesize;
|
||||||
|
|
||||||
@ -100,7 +100,7 @@ IAnimatedMesh* COBJMeshFileLoader::createMesh(io::IReadFile* file)
|
|||||||
c8 name[WORD_BUFFER_LENGTH];
|
c8 name[WORD_BUFFER_LENGTH];
|
||||||
bufPtr = goAndCopyNextWord(name, bufPtr, WORD_BUFFER_LENGTH, bufEnd);
|
bufPtr = goAndCopyNextWord(name, bufPtr, WORD_BUFFER_LENGTH, bufEnd);
|
||||||
#ifdef _IRR_DEBUG_OBJ_LOADER_
|
#ifdef _IRR_DEBUG_OBJ_LOADER_
|
||||||
os::Printer::log("Reading material file",name);
|
os::Printer::log("Ignoring material file",name);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -226,6 +226,7 @@ IAnimatedMesh* COBJMeshFileLoader::createMesh(io::IReadFile* file)
|
|||||||
{
|
{
|
||||||
os::Printer::log("Invalid vertex index in this line", wordBuffer.c_str(), ELL_ERROR);
|
os::Printer::log("Invalid vertex index in this line", wordBuffer.c_str(), ELL_ERROR);
|
||||||
delete [] buf;
|
delete [] buf;
|
||||||
|
cleanUp();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if ( -1 != Idx[1] && Idx[1] < (irr::s32)textureCoordBuffer.size() )
|
if ( -1 != Idx[1] && Idx[1] < (irr::s32)textureCoordBuffer.size() )
|
||||||
@ -259,6 +260,14 @@ IAnimatedMesh* COBJMeshFileLoader::createMesh(io::IReadFile* file)
|
|||||||
linePtr = goNextWord(linePtr, endPtr);
|
linePtr = goNextWord(linePtr, endPtr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (faceCorners.size() < 3)
|
||||||
|
{
|
||||||
|
os::Printer::log("Too few vertices in this line", wordBuffer.c_str(), ELL_ERROR);
|
||||||
|
delete [] buf;
|
||||||
|
cleanUp();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
// triangulate the face
|
// triangulate the face
|
||||||
const int c = faceCorners[0];
|
const int c = faceCorners[0];
|
||||||
for ( u32 i = 1; i < faceCorners.size() - 1; ++i )
|
for ( u32 i = 1; i < faceCorners.size() - 1; ++i )
|
||||||
|
Loading…
Reference in New Issue
Block a user