Explorar o código

Fix Heap-buffer-overflow READ in Assimp::ObjFileParser::getFace

Alex %!s(int64=2) %!d(string=hai) anos
pai
achega
c3e69b5b82
Modificáronse 1 ficheiros con 2 adicións e 2 borrados
  1. 2 2
      code/AssetLib/Obj/ObjFileParser.cpp

+ 2 - 2
code/AssetLib/Obj/ObjFileParser.cpp

@@ -456,8 +456,8 @@ void ObjFileParser::getFace(aiPrimitiveType type) {
             iPos = 0;
         } else {
             //OBJ USES 1 Base ARRAYS!!!!
-            const char *token = &(*m_DataIt);
-            const int iVal = ::atoi(token);
+            std::string number(&(*m_DataIt), m_DataItEnd - m_DataIt);
+            const int iVal(::atoi(number.c_str()));
 
             // increment iStep position based off of the sign and # of digits
             int tmp = iVal;