Procházet zdrojové kódy

Check input token length before copy

Max Vollmer před 5 roky
rodič
revize
0d672efa90
1 změnil soubory, kde provedl 5 přidání a 2 odebrání
  1. 5 2
      code/FBX/FBXParser.cpp

+ 5 - 2
code/FBX/FBXParser.cpp

@@ -367,9 +367,12 @@ float ParseTokenAsFloat(const Token& t, const char*& err_out)
     // first - next in the fbx token stream comes ',',
     // which fast_atof could interpret as decimal point.
 #define MAX_FLOAT_LENGTH 31
-    char temp[MAX_FLOAT_LENGTH + 1];
     const size_t length = static_cast<size_t>(t.end()-t.begin());
-    std::copy(t.begin(),t.end(),temp);
+    if (length > MAX_FLOAT_LENGTH)
+        return 0.f;
+
+    char temp[MAX_FLOAT_LENGTH + 1];
+    std::copy(t.begin(), t.end(), temp);
     temp[std::min(static_cast<size_t>(MAX_FLOAT_LENGTH),length)] = '\0';
 
     return fast_atof(temp);