[PATCH] D83112: Added missing runtime I/O definitions
Tim Keith via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jul 7 12:55:44 PDT 2020
This revision was not accepted when it landed; it landed in state "Needs Review".
This revision was automatically updated to reflect the committed changes.
Closed by commit rG4b9b64d561e9: [flang] Added missing runtime I/O definitions (authored by zacharyselk, committed by tskeith).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D83112/new/
https://reviews.llvm.org/D83112
Files:
flang/runtime/io-api.cpp
Index: flang/runtime/io-api.cpp
===================================================================
--- flang/runtime/io-api.cpp
+++ flang/runtime/io-api.cpp
@@ -843,6 +843,35 @@
return false;
}
+bool IONAME(OutputReal32)(Cookie cookie, float x) {
+ IoStatementState &io{*cookie};
+ if (!io.get_if<OutputStatementState>()) {
+ io.GetIoErrorHandler().Crash(
+ "OutputReal32() called for a non-output I/O statement");
+ return false;
+ }
+ if (auto edit{io.GetNextDataEdit()}) {
+ return RealOutputEditing<24>{io, x}.Edit(*edit);
+ }
+ return false;
+}
+
+bool IONAME(InputReal32)(Cookie cookie, float &x) {
+ IoStatementState &io{*cookie};
+ if (!io.get_if<InputStatementState>()) {
+ io.GetIoErrorHandler().Crash(
+ "InputReal32() called for a non-input I/O statement");
+ return false;
+ }
+ if (auto edit{io.GetNextDataEdit()}) {
+ if (edit->descriptor == DataEdit::ListDirectedNullValue) {
+ return true;
+ }
+ return EditRealInput<24>(io, *edit, reinterpret_cast<void *>(&x));
+ }
+ return false;
+}
+
bool IONAME(OutputReal64)(Cookie cookie, double x) {
IoStatementState &io{*cookie};
if (!io.get_if<OutputStatementState>()) {
@@ -872,6 +901,18 @@
return false;
}
+bool IONAME(OutputComplex32)(Cookie cookie, float r, float z) {
+ IoStatementState &io{*cookie};
+ if (io.get_if<ListDirectedStatementState<Direction::Output>>()) {
+ DataEdit real, imaginary;
+ real.descriptor = DataEdit::ListDirectedRealPart;
+ imaginary.descriptor = DataEdit::ListDirectedImaginaryPart;
+ return RealOutputEditing<24>{io, r}.Edit(real) &&
+ RealOutputEditing<24>{io, z}.Edit(imaginary);
+ }
+ return IONAME(OutputReal32)(cookie, r) && IONAME(OutputReal32)(cookie, z);
+}
+
bool IONAME(OutputComplex64)(Cookie cookie, double r, double z) {
IoStatementState &io{*cookie};
if (io.get_if<ListDirectedStatementState<Direction::Output>>()) {
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D83112.275684.patch
Type: text/x-patch
Size: 1930 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200707/3c28d026/attachment.bin>
More information about the llvm-commits
mailing list