Fix exception (getline will trigger failbit on the last line)

pull/170/head
scrawl 11 years ago
parent 9a26cf22e6
commit 7bf7daa846

@ -32,9 +32,6 @@ namespace Translation
boost::filesystem::ifstream stream ( boost::filesystem::ifstream stream (
dataFileCollections.getCollection (extension).getPath (fileName)); dataFileCollections.getCollection (extension).getPath (fileName));
// Configure the stream to throw exception upon error
stream.exceptions ( boost::filesystem::ifstream::failbit | boost::filesystem::ifstream::badbit );
if (!stream.is_open()) if (!stream.is_open())
throw std::runtime_error ("failed to open translation file: " + fileName); throw std::runtime_error ("failed to open translation file: " + fileName);
@ -44,9 +41,8 @@ namespace Translation
void Storage::loadDataFromStream(ContainerType& container, std::istream& stream) void Storage::loadDataFromStream(ContainerType& container, std::istream& stream)
{ {
// NOTE: does not handle failbit/badbit. stream must be set up beforehand to throw in these cases.
std::string line; std::string line;
while (!stream.eof()) while (!stream.eof() && !stream.fail())
{ {
std::getline( stream, line ); std::getline( stream, line );
if (!line.empty() && *line.rbegin() == '\r') if (!line.empty() && *line.rbegin() == '\r')

Loading…
Cancel
Save