diff --git a/flang/runtime/edit-input.cpp b/flang/runtime/edit-input.cpp --- a/flang/runtime/edit-input.cpp +++ b/flang/runtime/edit-input.cpp @@ -297,7 +297,9 @@ } for (exponent = 0; next; next = io.NextInField(remaining, edit)) { if (*next >= '0' && *next <= '9') { - exponent = 10 * exponent + *next - '0'; + if (exponent < 10000) { + exponent = 10 * exponent + *next - '0'; + } } else if (*next == ' ' || *next == '\t') { if (bzMode) { exponent = 10 * exponent; @@ -392,7 +394,7 @@ const char *limit{str + maxConsume}; decimal::ConversionToBinaryResult converted{ decimal::ConvertToBinary(p, edit.modes.round, limit)}; - if (converted.flags & decimal::Invalid) { + if (converted.flags & (decimal::Invalid | decimal::Overflow)) { return false; } if (edit.digits.value_or(0) != 0) { @@ -428,9 +430,6 @@ io.HandleRelativePosition(p - str); // Set FP exception flags if (converted.flags != decimal::ConversionResultFlags::Exact) { - if (converted.flags & decimal::ConversionResultFlags::Overflow) { - return false; // let slow path deal with it - } RaiseFPExceptions(converted.flags); } return true; diff --git a/flang/runtime/io-stmt.h b/flang/runtime/io-stmt.h --- a/flang/runtime/io-stmt.h +++ b/flang/runtime/io-stmt.h @@ -136,7 +136,7 @@ std::optional PrepareInput( const DataEdit &edit, std::optional &remaining) { remaining.reset(); - if (edit.descriptor == DataEdit::ListDirected) { + if (edit.IsListDirected()) { std::size_t byteCount{0}; GetNextNonBlank(byteCount); } else {