diff --git a/flang-rt/lib/runtime/descriptor-io.cpp b/flang-rt/lib/runtime/descriptor-io.cpp index a60d0b90da467..668190febf397 100644 --- a/flang-rt/lib/runtime/descriptor-io.cpp +++ b/flang-rt/lib/runtime/descriptor-io.cpp @@ -170,6 +170,8 @@ static RT_API_ATTRS Fortran::common::optional DefinedFormattedIo( io.GotChar(io.InquirePos() - *startPos); } return handler.GetIoStat() == IostatOk; + } else if (peek && peek->descriptor == DataEdit::ListDirectedNullValue) { + return false; } else { // There's a defined I/O subroutine, but there's a FORMAT present and // it does not have a DT data edit descriptor, so apply default formatting diff --git a/flang/docs/Extensions.md b/flang/docs/Extensions.md index b20503e542fb8..cf528b8231d56 100644 --- a/flang/docs/Extensions.md +++ b/flang/docs/Extensions.md @@ -910,6 +910,13 @@ print *, [(j,j=1,10)] `ALLOCATE` and `DEALLOCATE` statements with error recovery for multiple variables. +* When a "null" value is encountered in list-directed input, the + corresponding effective item in the data list is left unchanged, + even when it has a derived type with a defined `READ(FORMATTED)` + subroutine. This is the most literal reading of F'2023 13.10.3.2p2 + and the portable interpretation across the most common Fortran + compilers. + ## De Facto Standard Features * `EXTENDS_TYPE_OF()` returns `.TRUE.` if both of its arguments have the