From 1c08bc0b15ffc713018dd7de5aaa90dcf8f7e92f Mon Sep 17 00:00:00 2001 From: elsid Date: Mon, 3 May 2021 21:41:47 +0200 Subject: [PATCH] Handle std::istream bad state after read --- components/nif/nifstream.hpp | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/components/nif/nifstream.hpp b/components/nif/nifstream.hpp index 1c4407afd..4d77b7326 100644 --- a/components/nif/nifstream.hpp +++ b/components/nif/nifstream.hpp @@ -7,6 +7,7 @@ #include #include #include +#include #include #include @@ -28,6 +29,9 @@ class NIFFile; template inline void readLittleEndianBufferOfType(Files::IStreamPtr &pIStream, T* dest) { pIStream->read((char*)dest, numInstances * sizeof(T)); + if (pIStream->bad()) + throw std::runtime_error("Failed to read little endian typed (" + std::string(typeid(T).name()) + ") buffer of " + + std::to_string(numInstances) + " instances"); if constexpr (Misc::IS_BIG_ENDIAN) for (std::size_t i = 0; i < numInstances; i++) Misc::swapEndiannessInplace(dest[i]); @@ -39,6 +43,8 @@ template inline void readLittleEndianBuff template inline void readLittleEndianDynamicBufferOfType(Files::IStreamPtr &pIStream, T* dest, std::size_t numInstances) { pIStream->read((char*)dest, numInstances * sizeof(T)); + if (pIStream->bad()) + throw std::runtime_error("Failed to read little endian dynamic buffer of " + std::to_string(numInstances) + " instances"); if constexpr (Misc::IS_BIG_ENDIAN) for (std::size_t i = 0; i < numInstances; i++) Misc::swapEndiannessInplace(dest[i]); @@ -144,6 +150,8 @@ public: { std::string str(length, '\0'); inp->read(str.data(), length); + if (inp->bad()) + throw std::runtime_error("Failed to read sized string of " + std::to_string(length) + " chars"); return str; } ///Read in a string of the length specified in the file @@ -165,6 +173,8 @@ public: { std::string result; std::getline(*inp, result); + if (inp->bad()) + throw std::runtime_error("Failed to read version string"); return result; }