peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1 | // Generates Fortran from the content of a parse tree, using the |
| 2 | // traversal templates in parse-tree-visitor.h. |
| 3 | |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 4 | #include "unparse.h" |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 5 | #include "characters.h" |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 6 | #include "idioms.h" |
| 7 | #include "indirection.h" |
| 8 | #include "parse-tree-visitor.h" |
| 9 | #include "parse-tree.h" |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 10 | #include <algorithm> |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 11 | #include <cinttypes> |
| 12 | #include <cstddef> |
peter klausler | 4e354d8 | 2018-03-30 22:23:37 | [diff] [blame] | 13 | #include <set> |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 14 | |
| 15 | namespace Fortran { |
| 16 | namespace parser { |
| 17 | |
| 18 | class UnparseVisitor { |
| 19 | public: |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 20 | UnparseVisitor(std::ostream &out, int indentationAmount, Encoding encoding, |
| 21 | bool capitalize) |
| 22 | : out_{out}, indentationAmount_{indentationAmount}, encoding_{encoding}, |
| 23 | capitalizeKeywords_{capitalize} {} |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 24 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 25 | // In nearly all cases, this code avoids defining Boolean-valued Pre() |
| 26 | // callbacks for the parse tree walking framework in favor of two void |
| 27 | // functions, Before() and Unparse(), which imply true and false return |
| 28 | // values for Pre() respectively. |
| 29 | template<typename T> void Before(const T &) {} |
| 30 | template<typename T> double Unparse(const T &); // not void, never used |
| 31 | |
peter klausler | 022a91b | 2018-04-26 22:44:29 | [diff] [blame^] | 32 | template<typename T> bool Pre(const T &x) { |
| 33 | if constexpr (std::is_void_v<decltype(Unparse(x))>) { |
| 34 | // There is a local definition of Unparse() for this type. It |
| 35 | // overrides the parse tree walker's default Walk() over the descendents. |
| 36 | Before(x); |
| 37 | Unparse(x); |
| 38 | Post(x); |
| 39 | return false; // Walk() does not visit descendents |
| 40 | } else { |
| 41 | Before(x); |
| 42 | return true; // there's no Unparse() defined here, Walk() the descendents |
| 43 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 44 | } |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 45 | template<typename T> void Post(const T &) {} |
| 46 | |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 47 | // Emit simple types as-is. |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 48 | void Unparse(const std::string &x) { Put(x); } |
| 49 | void Unparse(int x) { Put(std::to_string(x)); } |
| 50 | void Unparse(std::uint64_t x) { Put(std::to_string(x)); } |
| 51 | void Unparse(std::int64_t x) { Put(std::to_string(x)); } |
| 52 | void Unparse(char x) { Put(x); } |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 53 | |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 54 | // Statement labels and ends of lines |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 55 | template<typename T> void Before(const Statement<T> &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 56 | Walk(x.label, " "); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 57 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 58 | template<typename T> void Post(const Statement<T> &) { Put('\n'); } |
| 59 | |
| 60 | // The special-case formatting functions for these productions are |
| 61 | // ordered to correspond roughly to their order of appearance in |
| 62 | // the Fortran 2018 standard (and parse-tree.h). |
| 63 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 64 | void Unparse(const Program &x) { // R501 |
| 65 | Walk("", x.v, "\n"); // put blank lines between ProgramUnits |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 66 | } |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 67 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 68 | void Unparse(const Name &x) { // R603 |
peter klausler | 938d1eb | 2018-03-23 21:18:59 | [diff] [blame] | 69 | Put(x.ToString()); |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 70 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 71 | void Unparse(const DefinedOperator::IntrinsicOperator &x) { // R608 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 72 | switch (x) { |
| 73 | case DefinedOperator::IntrinsicOperator::Power: Put("**"); break; |
| 74 | case DefinedOperator::IntrinsicOperator::Multiply: Put('*'); break; |
| 75 | case DefinedOperator::IntrinsicOperator::Divide: Put('/'); break; |
| 76 | case DefinedOperator::IntrinsicOperator::Add: Put('+'); break; |
| 77 | case DefinedOperator::IntrinsicOperator::Subtract: Put('-'); break; |
| 78 | case DefinedOperator::IntrinsicOperator::Concat: Put("//"); break; |
| 79 | case DefinedOperator::IntrinsicOperator::LT: Put('<'); break; |
| 80 | case DefinedOperator::IntrinsicOperator::LE: Put("<="); break; |
| 81 | case DefinedOperator::IntrinsicOperator::EQ: Put("=="); break; |
| 82 | case DefinedOperator::IntrinsicOperator::NE: Put("/="); break; |
| 83 | case DefinedOperator::IntrinsicOperator::GE: Put(">="); break; |
| 84 | case DefinedOperator::IntrinsicOperator::GT: Put('>'); break; |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 85 | default: Put('.'), Word(DefinedOperator::EnumToString(x)), Put('.'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 86 | } |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 87 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 88 | void Post(const Star &) { Put('*'); } // R701 &c. |
| 89 | void Post(const TypeParamValue::Deferred &) { Put(':'); } // R701 |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 90 | void Unparse(const DeclarationTypeSpec::Type &x) { // R703 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 91 | Word("TYPE("), Walk(x.derived), Put(')'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 92 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 93 | void Unparse(const DeclarationTypeSpec::Class &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 94 | Word("CLASS("), Walk(x.derived), Put(')'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 95 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 96 | void Post(const DeclarationTypeSpec::ClassStar &) { Word("CLASS(*)"); } |
| 97 | void Post(const DeclarationTypeSpec::TypeStar &) { Word("TYPE(*)"); } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 98 | void Unparse(const DeclarationTypeSpec::Record &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 99 | Word("RECORD/"), Walk(x.v), Put('/'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 100 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 101 | void Before(const IntrinsicTypeSpec::Real &x) { // R704 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 102 | Word("REAL"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 103 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 104 | void Before(const IntrinsicTypeSpec::Complex &x) { Word("COMPLEX"); } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 105 | void Post(const IntrinsicTypeSpec::DoublePrecision &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 106 | Word("DOUBLE PRECISION"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 107 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 108 | void Before(const IntrinsicTypeSpec::Character &x) { Word("CHARACTER"); } |
| 109 | void Before(const IntrinsicTypeSpec::Logical &x) { Word("LOGICAL"); } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 110 | void Post(const IntrinsicTypeSpec::DoubleComplex &) { |
| 111 | Word("DOUBLE COMPLEX"); |
| 112 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 113 | void Before(const IntrinsicTypeSpec::NCharacter &x) { Word("NCHARACTER"); } |
| 114 | void Before(const IntegerTypeSpec &x) { // R705 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 115 | Word("INTEGER"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 116 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 117 | void Unparse(const KindSelector &x) { // R706 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 118 | std::visit( |
| 119 | visitors{[&](const ScalarIntConstantExpr &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 120 | Put('('), Word("KIND="), Walk(y), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 121 | }, |
| 122 | [&](const KindSelector::StarSize &y) { Put('*'), Walk(y.v); }}, |
| 123 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 124 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 125 | void Unparse(const SignedIntLiteralConstant &x) { // R707 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 126 | Walk(std::get<std::int64_t>(x.t)); |
| 127 | Walk("_", std::get<std::optional<KindParam>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 128 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 129 | void Unparse(const IntLiteralConstant &x) { // R708 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 130 | Walk(std::get<std::uint64_t>(x.t)); |
| 131 | Walk("_", std::get<std::optional<KindParam>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 132 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 133 | void Unparse(const Sign &x) { // R712 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 134 | Put(x == Sign::Negative ? '-' : '+'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 135 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 136 | void Unparse(const RealLiteralConstant &x) { // R714, R715 |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 137 | Put(x.real.source.ToString()), Walk("_", x.kind); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 138 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 139 | void Unparse(const ComplexLiteralConstant &x) { // R718 - R720 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 140 | Put('('), Walk(x.t, ","), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 141 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 142 | void Unparse(const CharSelector::LengthAndKind &x) { // R721 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 143 | Put('('), Word("KIND="), Walk(x.kind); |
| 144 | Walk(", LEN=", x.length), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 145 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 146 | void Unparse(const LengthSelector &x) { // R722 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 147 | std::visit(visitors{[&](const TypeParamValue &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 148 | Put('('), Word("LEN="), Walk(y), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 149 | }, |
| 150 | [&](const CharLength &y) { Put('*'), Walk(y); }}, |
| 151 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 152 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 153 | void Unparse(const CharLength &x) { // R723 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 154 | std::visit( |
| 155 | visitors{[&](const TypeParamValue &y) { Put('('), Walk(y), Put(')'); }, |
| 156 | [&](const std::int64_t &y) { Walk(y); }}, |
| 157 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 158 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 159 | void Unparse(const CharLiteralConstant &x) { // R724 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 160 | if (const auto &k = std::get<std::optional<KindParam>>(x.t)) { |
| 161 | if (std::holds_alternative<KindParam::Kanji>(k->u)) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 162 | Word("NC"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 163 | } else { |
| 164 | Walk(*k), Put('_'); |
| 165 | } |
| 166 | } |
| 167 | PutQuoted(std::get<std::string>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 168 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 169 | void Before(const HollerithLiteralConstant &x) { |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 170 | std::optional<std::size_t> chars{CountCharacters(x.v.data(), x.v.size(), |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 171 | encoding_ == Encoding::EUC_JP ? EUC_JPCharacterBytes |
| 172 | : UTF8CharacterBytes)}; |
| 173 | if (chars.has_value()) { |
| 174 | Pre(*chars); |
| 175 | } else { |
| 176 | Pre(x.v.size()); |
| 177 | } |
| 178 | Put('H'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 179 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 180 | void Unparse(const LogicalLiteralConstant &x) { // R725 |
peter klausler | 42b72c4 | 2018-03-15 17:59:46 | [diff] [blame] | 181 | Put(std::get<bool>(x.t) ? ".TRUE." : ".FALSE."); |
| 182 | Walk("_", std::get<std::optional<KindParam>>(x.t)); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 183 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 184 | void Unparse(const DerivedTypeStmt &x) { // R727 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 185 | Word("TYPE"), Walk(", ", std::get<std::list<TypeAttrSpec>>(x.t), ", "); |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 186 | Put(" :: "), Walk(std::get<Name>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 187 | Walk("(", std::get<std::list<Name>>(x.t), ", ", ")"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 188 | Indent(); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 189 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 190 | void Unparse(const Abstract &x) { // R728, &c. |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 191 | Word("ABSTRACT"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 192 | } |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 193 | void Post(const TypeAttrSpec::BindC &) { Word("BIND(C)"); } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 194 | void Unparse(const TypeAttrSpec::Extends &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 195 | Word("EXTENDS("), Walk(x.v), Put(')'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 196 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 197 | void Unparse(const EndTypeStmt &x) { // R730 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 198 | Outdent(), Word("END TYPE"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 199 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 200 | void Unparse(const SequenceStmt &x) { // R731 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 201 | Word("SEQUENCE"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 202 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 203 | void Unparse(const TypeParamDefStmt &x) { // R732 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 204 | Walk(std::get<IntegerTypeSpec>(x.t)); |
| 205 | Put(", "), Walk(std::get<TypeParamDefStmt::KindOrLen>(x.t)); |
| 206 | Put(" :: "), Walk(std::get<std::list<TypeParamDecl>>(x.t), ", "); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 207 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 208 | void Unparse(const TypeParamDecl &x) { // R733 |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 209 | Walk(std::get<Name>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 210 | Walk("=", std::get<std::optional<ScalarIntConstantExpr>>(x.t)); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 211 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 212 | void Unparse(const DataComponentDefStmt &x) { // R737 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 213 | const auto &dts = std::get<DeclarationTypeSpec>(x.t); |
| 214 | const auto &attrs = std::get<std::list<ComponentAttrSpec>>(x.t); |
| 215 | const auto &decls = std::get<std::list<ComponentDecl>>(x.t); |
| 216 | Walk(dts), Walk(", ", attrs, ", "); |
| 217 | if (!attrs.empty() || |
| 218 | (!std::holds_alternative<DeclarationTypeSpec::Record>(dts.u) && |
| 219 | std::none_of( |
| 220 | decls.begin(), decls.end(), [](const ComponentDecl &d) { |
| 221 | const auto &init = |
| 222 | std::get<std::optional<Initialization>>(d.t); |
| 223 | return init.has_value() && |
| 224 | std::holds_alternative< |
| 225 | std::list<Indirection<DataStmtValue>>>(init->u); |
| 226 | }))) { |
| 227 | Put(" ::"); |
| 228 | } |
| 229 | Put(' '), Walk(decls, ", "); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 230 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 231 | void Unparse(const Allocatable &x) { // R738 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 232 | Word("ALLOCATABLE"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 233 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 234 | void Unparse(const Pointer &x) { Word("POINTER"); } |
| 235 | void Unparse(const Contiguous &x) { Word("CONTIGUOUS"); } |
| 236 | void Before(const ComponentAttrSpec &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 237 | std::visit(visitors{[&](const CoarraySpec &) { Word("CODIMENSION["); }, |
| 238 | [&](const ComponentArraySpec &) { Word("DIMENSION("); }, |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 239 | [](const auto &) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 240 | x.u); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 241 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 242 | void Post(const ComponentAttrSpec &x) { |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 243 | std::visit( |
| 244 | visitors{[&](const CoarraySpec &) { Put(']'); }, |
| 245 | [&](const ComponentArraySpec &) { Put(')'); }, [](const auto &) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 246 | x.u); |
| 247 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 248 | void Unparse(const ComponentDecl &x) { // R739 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 249 | Walk(std::get<ObjectName>(x.t)); |
| 250 | Walk("(", std::get<std::optional<ComponentArraySpec>>(x.t), ")"); |
| 251 | Walk("[", std::get<std::optional<CoarraySpec>>(x.t), "]"); |
| 252 | Walk("*", std::get<std::optional<CharLength>>(x.t)); |
| 253 | Walk(std::get<std::optional<Initialization>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 254 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 255 | void Unparse(const ComponentArraySpec &x) { // R740 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 256 | std::visit( |
| 257 | visitors{[&](const std::list<ExplicitShapeSpec> &y) { Walk(y, ","); }, |
| 258 | [&](const DeferredShapeSpecList &y) { Walk(y); }}, |
| 259 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 260 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 261 | void Unparse(const ProcComponentDefStmt &x) { // R741 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 262 | Word("PROCEDURE("); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 263 | Walk(std::get<std::optional<ProcInterface>>(x.t)), Put(')'); |
| 264 | Walk(", ", std::get<std::list<ProcComponentAttrSpec>>(x.t), ", "); |
| 265 | Put(" :: "), Walk(std::get<std::list<ProcDecl>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 266 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 267 | void Unparse(const NoPass &x) { // R742 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 268 | Word("NOPASS"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 269 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 270 | void Unparse(const Pass &x) { Word("PASS"), Walk("(", x.v, ")"); } |
| 271 | void Unparse(const Initialization &x) { // R743 & R805 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 272 | std::visit(visitors{[&](const ConstantExpr &y) { Put(" = "), Walk(y); }, |
| 273 | [&](const NullInit &y) { Put(" => "), Walk(y); }, |
| 274 | [&](const InitialDataTarget &y) { Put(" => "), Walk(y); }, |
| 275 | [&](const std::list<Indirection<DataStmtValue>> &y) { |
| 276 | Walk("/", y, ", ", "/"); |
| 277 | }}, |
| 278 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 279 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 280 | void Unparse(const PrivateStmt &x) { // R745 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 281 | Word("PRIVATE"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 282 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 283 | void Unparse(const TypeBoundProcedureStmt::WithoutInterface &x) { // R749 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 284 | Word("PROCEDURE"), Walk(", ", x.attributes, ", "); |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 285 | Put(" :: "), Walk(x.declarations, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 286 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 287 | void Unparse(const TypeBoundProcedureStmt::WithInterface &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 288 | Word("PROCEDURE("), Walk(x.interfaceName), Put("), "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 289 | Walk(x.attributes); |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 290 | Put(" :: "), Walk(x.bindingNames, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 291 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 292 | void Unparse(const TypeBoundProcDecl &x) { // R750 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 293 | Walk(std::get<Name>(x.t)); |
| 294 | Walk(" => ", std::get<std::optional<Name>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 295 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 296 | void Unparse(const TypeBoundGenericStmt &x) { // R751 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 297 | Word("GENERIC"), Walk(", ", std::get<std::optional<AccessSpec>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 298 | Put(" :: "), Walk(std::get<Indirection<GenericSpec>>(x.t)); |
| 299 | Put(" => "), Walk(std::get<std::list<Name>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 300 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 301 | void Post(const BindAttr::Deferred &) { Word("DEFERRED"); } // R752 |
| 302 | void Post(const BindAttr::Non_Overridable &) { Word("NON_OVERRIDABLE"); } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 303 | void Unparse(const FinalProcedureStmt &x) { // R753 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 304 | Word("FINAL :: "), Walk(x.v, ", "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 305 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 306 | void Unparse(const DerivedTypeSpec &x) { // R754 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 307 | Walk(std::get<Name>(x.t)); |
| 308 | Walk("(", std::get<std::list<TypeParamSpec>>(x.t), ",", ")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 309 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 310 | void Unparse(const TypeParamSpec &x) { // R755 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 311 | Walk(std::get<std::optional<Keyword>>(x.t), "="); |
| 312 | Walk(std::get<TypeParamValue>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 313 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 314 | void Unparse(const StructureConstructor &x) { // R756 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 315 | Walk(std::get<DerivedTypeSpec>(x.t)); |
| 316 | Put('('), Walk(std::get<std::list<ComponentSpec>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 317 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 318 | void Unparse(const ComponentSpec &x) { // R757 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 319 | Walk(std::get<std::optional<Keyword>>(x.t), "="); |
| 320 | Walk(std::get<ComponentDataSource>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 321 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 322 | void Unparse(const EnumDefStmt &) { // R760 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 323 | Word("ENUM, BIND(C)"), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 324 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 325 | void Unparse(const EnumeratorDefStmt &x) { // R761 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 326 | Word("ENUMERATOR :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 327 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 328 | void Unparse(const Enumerator &x) { // R762 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 329 | Walk(std::get<NamedConstant>(x.t)); |
| 330 | Walk(" = ", std::get<std::optional<ScalarIntConstantExpr>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 331 | } |
| 332 | void Post(const EndEnumStmt &) { // R763 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 333 | Outdent(), Word("END ENUM"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 334 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 335 | void Unparse(const BOZLiteralConstant &x) { // R764 - R767 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 336 | Put("Z'"); |
| 337 | out_ << std::hex << x.v << std::dec << '\''; |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 338 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 339 | void Unparse(const AcValue::Triplet &x) { // R773 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 340 | Walk(std::get<0>(x.t)), Put(':'), Walk(std::get<1>(x.t)); |
| 341 | Walk(":", std::get<std::optional<ScalarIntExpr>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 342 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 343 | void Unparse(const ArrayConstructor &x) { // R769 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 344 | Put('['), Walk(x.v), Put(']'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 345 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 346 | void Unparse(const AcSpec &x) { // R770 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 347 | Walk(x.type, "::"), Walk(x.values, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 348 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 349 | template<typename A> void Unparse(const LoopBounds<A> &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 350 | Walk(x.name), Put('='), Walk(x.lower), Put(','), Walk(x.upper); |
| 351 | Walk(",", x.step); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 352 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 353 | void Unparse(const AcImpliedDo &x) { // R774 |
peter klausler | 46c3538 | 2018-03-14 00:11:26 | [diff] [blame] | 354 | Put('('), Walk(std::get<std::list<AcValue>>(x.t), ", "); |
| 355 | Put(", "), Walk(std::get<AcImpliedDoControl>(x.t)), Put(')'); |
peter klausler | 46c3538 | 2018-03-14 00:11:26 | [diff] [blame] | 356 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 357 | void Unparse(const AcImpliedDoControl &x) { // R775 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 358 | Walk(std::get<std::optional<IntegerTypeSpec>>(x.t), "::"); |
| 359 | Walk(std::get<LoopBounds<ScalarIntExpr>>(x.t)); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 360 | } |
| 361 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 362 | void Unparse(const TypeDeclarationStmt &x) { // R801 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 363 | const auto &dts = std::get<DeclarationTypeSpec>(x.t); |
| 364 | const auto &attrs = std::get<std::list<AttrSpec>>(x.t); |
| 365 | const auto &decls = std::get<std::list<EntityDecl>>(x.t); |
| 366 | Walk(dts), Walk(", ", attrs, ", "); |
peter klausler | 92bcb7ce | 2018-03-19 23:17:23 | [diff] [blame] | 367 | |
| 368 | static const auto isInitializerOldStyle = [](const Initialization &i) { |
| 369 | return std::holds_alternative<std::list<Indirection<DataStmtValue>>>(i.u); |
| 370 | }; |
| 371 | static const auto hasAssignmentInitializer = [](const EntityDecl &d) { |
| 372 | // Does a declaration have a new-style =x initializer? |
| 373 | const auto &init = std::get<std::optional<Initialization>>(d.t); |
| 374 | return init.has_value() && !isInitializerOldStyle(*init); |
| 375 | }; |
| 376 | static const auto hasSlashDelimitedInitializer = [](const EntityDecl &d) { |
| 377 | // Does a declaration have an old-style /x/ initializer? |
| 378 | const auto &init = std::get<std::optional<Initialization>>(d.t); |
| 379 | return init.has_value() && isInitializerOldStyle(*init); |
| 380 | }; |
| 381 | const auto useDoubledColons = [&]() { |
| 382 | bool isRecord{std::holds_alternative<DeclarationTypeSpec::Record>(dts.u)}; |
| 383 | if (!attrs.empty()) { |
| 384 | // Attributes after the type require :: before the entities. |
| 385 | CHECK(!isRecord); |
| 386 | return true; |
| 387 | } |
| 388 | if (std::any_of(decls.begin(), decls.end(), hasAssignmentInitializer)) { |
| 389 | // Always use :: with new style standard initializers (=x), |
| 390 | // since the standard requires them to appear (even in free form, |
| 391 | // where mandatory spaces already disambiguate INTEGER J=666). |
| 392 | CHECK(!isRecord); |
| 393 | return true; |
| 394 | } |
| 395 | if (isRecord) { |
| 396 | // Never put :: in a legacy extension RECORD// statement. |
| 397 | return false; |
| 398 | } |
| 399 | // The :: is optional for this declaration. Avoid usage that can |
| 400 | // crash the pgf90 compiler. |
| 401 | if (std::any_of( |
| 402 | decls.begin(), decls.end(), hasSlashDelimitedInitializer)) { |
| 403 | // Don't use :: when a declaration uses legacy DATA-statement-like |
| 404 | // /x/ initialization. |
| 405 | return false; |
| 406 | } |
| 407 | // Don't use :: with intrinsic types. Otherwise, use it. |
| 408 | return !std::holds_alternative<IntrinsicTypeSpec>(dts.u); |
| 409 | }; |
| 410 | |
| 411 | if (useDoubledColons()) { |
| 412 | Put(" ::"); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 413 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 414 | Put(' '), Walk(std::get<std::list<EntityDecl>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 415 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 416 | void Before(const AttrSpec &x) { // R802 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 417 | std::visit(visitors{[&](const CoarraySpec &y) { Word("CODIMENSION["); }, |
| 418 | [&](const ArraySpec &y) { Word("DIMENSION("); }, |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 419 | [](const auto &) {}}, |
peter klausler | d39a33f | 2018-03-13 23:59:30 | [diff] [blame] | 420 | x.u); |
peter klausler | d39a33f | 2018-03-13 23:59:30 | [diff] [blame] | 421 | } |
| 422 | void Post(const AttrSpec &x) { |
| 423 | std::visit(visitors{[&](const CoarraySpec &y) { Put(']'); }, |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 424 | [&](const ArraySpec &y) { Put(')'); }, [](const auto &) {}}, |
peter klausler | d39a33f | 2018-03-13 23:59:30 | [diff] [blame] | 425 | x.u); |
| 426 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 427 | void Unparse(const EntityDecl &x) { // R803 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 428 | Walk(std::get<ObjectName>(x.t)); |
| 429 | Walk("(", std::get<std::optional<ArraySpec>>(x.t), ")"); |
| 430 | Walk("[", std::get<std::optional<CoarraySpec>>(x.t), "]"); |
| 431 | Walk("*", std::get<std::optional<CharLength>>(x.t)); |
| 432 | Walk(std::get<std::optional<Initialization>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 433 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 434 | void Unparse(const NullInit &x) { // R806 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 435 | Word("NULL()"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 436 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 437 | void Unparse(const LanguageBindingSpec &x) { // R808 & R1528 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 438 | Word("BIND(C"), Walk(", NAME=", x.v), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 439 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 440 | void Unparse(const CoarraySpec &x) { // R809 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 441 | std::visit(visitors{[&](const DeferredCoshapeSpecList &y) { Walk(y); }, |
| 442 | [&](const ExplicitCoshapeSpec &y) { Walk(y); }}, |
| 443 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 444 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 445 | void Unparse(const DeferredCoshapeSpecList &x) { // R810 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 446 | for (auto j = x.v; j > 0; --j) { |
| 447 | Put(':'); |
| 448 | if (j > 1) { |
| 449 | Put(','); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 450 | } |
| 451 | } |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 452 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 453 | void Unparse(const ExplicitCoshapeSpec &x) { // R811 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 454 | Walk(std::get<std::list<ExplicitShapeSpec>>(x.t), ",", ","); |
| 455 | Walk(std::get<std::optional<SpecificationExpr>>(x.t), ":"), Put('*'); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 456 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 457 | void Unparse(const ExplicitShapeSpec &x) { // R812 - R813 & R816 - R818 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 458 | Walk(std::get<std::optional<SpecificationExpr>>(x.t), ":"); |
| 459 | Walk(std::get<SpecificationExpr>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 460 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 461 | void Unparse(const ArraySpec &x) { // R815 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 462 | std::visit( |
| 463 | visitors{[&](const std::list<ExplicitShapeSpec> &y) { Walk(y, ","); }, |
| 464 | [&](const std::list<AssumedShapeSpec> &y) { Walk(y, ","); }, |
| 465 | [&](const DeferredShapeSpecList &y) { Walk(y); }, |
| 466 | [&](const AssumedSizeSpec &y) { Walk(y); }, |
| 467 | [&](const ImpliedShapeSpec &y) { Walk(y); }, |
| 468 | [&](const AssumedRankSpec &y) { Walk(y); }}, |
| 469 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 470 | } |
| 471 | void Post(const AssumedShapeSpec &) { Put(':'); } // R819 |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 472 | void Unparse(const DeferredShapeSpecList &x) { // R820 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 473 | for (auto j = x.v; j > 0; --j) { |
| 474 | Put(':'); |
| 475 | if (j > 1) { |
| 476 | Put(','); |
| 477 | } |
| 478 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 479 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 480 | void Unparse(const AssumedImpliedSpec &x) { // R821 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 481 | Walk(x.v, ":"); |
| 482 | Put('*'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 483 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 484 | void Unparse(const AssumedSizeSpec &x) { // R822 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 485 | Walk(std::get<std::list<ExplicitShapeSpec>>(x.t), ",", ","); |
| 486 | Walk(std::get<AssumedImpliedSpec>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 487 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 488 | void Unparse(const ImpliedShapeSpec &x) { // R823 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 489 | Walk(x.v, ","); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 490 | } |
| 491 | void Post(const AssumedRankSpec &) { Put(".."); } // R825 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 492 | void Post(const Asynchronous &) { Word("ASYNCHRONOUS"); } |
| 493 | void Post(const External &) { Word("EXTERNAL"); } |
| 494 | void Post(const Intrinsic &) { Word("INTRINSIC"); } |
| 495 | void Post(const Optional &) { Word("OPTIONAL"); } |
| 496 | void Post(const Parameter &) { Word("PARAMETER"); } |
| 497 | void Post(const Protected &) { Word("PROTECTED"); } |
| 498 | void Post(const Save &) { Word("SAVE"); } |
| 499 | void Post(const Target &) { Word("TARGET"); } |
| 500 | void Post(const Value &) { Word("VALUE"); } |
| 501 | void Post(const Volatile &) { Word("VOLATILE"); } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 502 | void Unparse(const IntentSpec &x) { // R826 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 503 | Word("INTENT("), Walk(x.v), Put(")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 504 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 505 | void Unparse(const AccessStmt &x) { // R827 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 506 | Walk(std::get<AccessSpec>(x.t)); |
| 507 | Walk(" :: ", std::get<std::list<AccessId>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 508 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 509 | void Unparse(const AllocatableStmt &x) { // R829 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 510 | Word("ALLOCATABLE :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 511 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 512 | void Unparse(const ObjectDecl &x) { // R830 & R860 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 513 | Walk(std::get<ObjectName>(x.t)); |
| 514 | Walk("(", std::get<std::optional<ArraySpec>>(x.t), ")"); |
| 515 | Walk("[", std::get<std::optional<CoarraySpec>>(x.t), "]"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 516 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 517 | void Unparse(const AsynchronousStmt &x) { // R831 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 518 | Word("ASYNCHRONOUS :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 519 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 520 | void Unparse(const BindStmt &x) { // R832 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 521 | Walk(x.t, " :: "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 522 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 523 | void Unparse(const BindEntity &x) { // R833 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 524 | bool isCommon{std::get<BindEntity::Kind>(x.t) == BindEntity::Kind::Common}; |
| 525 | const char *slash{isCommon ? "/" : ""}; |
| 526 | Put(slash), Walk(std::get<Name>(x.t)), Put(slash); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 527 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 528 | void Unparse(const CodimensionStmt &x) { // R834 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 529 | Word("CODIMENSION :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 530 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 531 | void Unparse(const CodimensionDecl &x) { // R835 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 532 | Walk(std::get<Name>(x.t)); |
| 533 | Put('['), Walk(std::get<CoarraySpec>(x.t)), Put(']'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 534 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 535 | void Unparse(const ContiguousStmt &x) { // R836 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 536 | Word("CONTIGUOUS :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 537 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 538 | void Unparse(const DataStmt &x) { // R837 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 539 | Word("DATA "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 540 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 541 | void Unparse(const DataStmtSet &x) { // R838 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 542 | Walk(std::get<std::list<DataStmtObject>>(x.t), ", "); |
| 543 | Put('/'), Walk(std::get<std::list<DataStmtValue>>(x.t), ", "), Put('/'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 544 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 545 | void Unparse(const DataImpliedDo &x) { // R840, R842 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 546 | Put('('), Walk(std::get<std::list<DataIDoObject>>(x.t), ", "), Put(','); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 547 | Walk(std::get<std::optional<IntegerTypeSpec>>(x.t), "::"); |
| 548 | Walk(std::get<LoopBounds<ScalarIntConstantExpr>>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 549 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 550 | void Unparse(const DataStmtValue &x) { // R843 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 551 | Walk(std::get<std::optional<DataStmtRepeat>>(x.t), "*"); |
| 552 | Walk(std::get<DataStmtConstant>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 553 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 554 | void Unparse(const DimensionStmt &x) { // R848 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 555 | Word("DIMENSION :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 556 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 557 | void Unparse(const DimensionStmt::Declaration &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 558 | Walk(std::get<Name>(x.t)); |
| 559 | Put('('), Walk(std::get<ArraySpec>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 560 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 561 | void Unparse(const IntentStmt &x) { // R849 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 562 | Walk(x.t, " :: "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 563 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 564 | void Unparse(const OptionalStmt &x) { // R850 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 565 | Word("OPTIONAL :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 566 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 567 | void Unparse(const ParameterStmt &x) { // R851 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 568 | Word("PARAMETER("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 569 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 570 | void Unparse(const NamedConstantDef &x) { // R852 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 571 | Walk(x.t, "="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 572 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 573 | void Unparse(const PointerStmt &x) { // R853 |
peter klausler | 26b5f57 | 2018-04-09 20:40:20 | [diff] [blame] | 574 | Word("POINTER :: "), Walk(x.v, ", "); |
| 575 | } |
| 576 | void Unparse(const PointerDecl &x) { // R854 |
| 577 | Walk(std::get<Name>(x.t)); |
| 578 | Walk("(", std::get<std::optional<DeferredShapeSpecList>>(x.t), ")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 579 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 580 | void Unparse(const ProtectedStmt &x) { // R855 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 581 | Word("PROTECTED :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 582 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 583 | void Unparse(const SaveStmt &x) { // R856 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 584 | Word("SAVE"), Walk(" :: ", x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 585 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 586 | void Unparse(const SavedEntity &x) { // R857, R858 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 587 | bool isCommon{ |
| 588 | std::get<SavedEntity::Kind>(x.t) == SavedEntity::Kind::Common}; |
| 589 | const char *slash{isCommon ? "/" : ""}; |
| 590 | Put(slash), Walk(std::get<Name>(x.t)), Put(slash); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 591 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 592 | void Unparse(const TargetStmt &x) { // R859 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 593 | Word("TARGET :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 594 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 595 | void Unparse(const ValueStmt &x) { // R861 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 596 | Word("VALUE :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 597 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 598 | void Unparse(const VolatileStmt &x) { // R862 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 599 | Word("VOLATILE :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 600 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 601 | void Unparse(const ImplicitStmt &x) { // R863 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 602 | Word("IMPLICIT "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 603 | std::visit( |
| 604 | visitors{[&](const std::list<ImplicitSpec> &y) { Walk(y, ", "); }, |
| 605 | [&](const std::list<ImplicitStmt::ImplicitNoneNameSpec> &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 606 | Word("NONE"), Walk(" (", y, ", ", ")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 607 | }}, |
| 608 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 609 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 610 | void Unparse(const ImplicitSpec &x) { // R864 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 611 | Walk(std::get<DeclarationTypeSpec>(x.t)); |
| 612 | Put('('), Walk(std::get<std::list<LetterSpec>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 613 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 614 | void Unparse(const LetterSpec &x) { // R865 |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 615 | Put(*std::get<const char *>(x.t)); |
| 616 | auto second = std::get<std::optional<const char *>>(x.t); |
| 617 | if (second.has_value()) { |
| 618 | Put('-'), Put(**second); |
| 619 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 620 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 621 | void Unparse(const ImportStmt &x) { // R867 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 622 | Word("IMPORT"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 623 | switch (x.kind) { |
peter klausler | 2e5300c | 2018-03-15 23:22:38 | [diff] [blame] | 624 | case ImportStmt::Kind::Default: Walk(" :: ", x.names, ", "); break; |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 625 | case ImportStmt::Kind::Only: |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 626 | Put(", "), Word("ONLY: "); |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 627 | Walk(x.names, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 628 | break; |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 629 | case ImportStmt::Kind::None: Word(", NONE"); break; |
| 630 | case ImportStmt::Kind::All: Word(", ALL"); break; |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 631 | default: CRASH_NO_CASE; |
| 632 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 633 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 634 | void Unparse(const NamelistStmt &x) { // R868 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 635 | Word("NAMELIST"), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 636 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 637 | void Unparse(const NamelistStmt::Group &x) { |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 638 | Put('/'), Walk(std::get<Name>(x.t)), Put('/'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 639 | Walk(std::get<std::list<Name>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 640 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 641 | void Unparse(const EquivalenceStmt &x) { // R870, R871 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 642 | Word("EQUIVALENCE"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 643 | const char *separator{" "}; |
| 644 | for (const std::list<EquivalenceObject> &y : x.v) { |
| 645 | Put(separator), Put('('), Walk(y), Put(')'); |
| 646 | separator = ", "; |
| 647 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 648 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 649 | void Unparse(const CommonStmt &x) { // R873 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 650 | Word("COMMON "); |
peter klausler | 66c98ee | 2018-04-24 22:46:16 | [diff] [blame] | 651 | Walk("/", std::get<std::optional<Name>>(x.t), "/"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 652 | Walk(std::get<std::list<CommonBlockObject>>(x.t), ", "); |
| 653 | Walk(", ", std::get<std::list<CommonStmt::Block>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 654 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 655 | void Unparse(const CommonBlockObject &x) { // R874 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 656 | Walk(std::get<Name>(x.t)); |
| 657 | Walk("(", std::get<std::optional<ArraySpec>>(x.t), ")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 658 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 659 | void Unparse(const CommonStmt::Block &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 660 | Walk("/", std::get<std::optional<Name>>(x.t), "/"); |
| 661 | Walk(std::get<std::list<CommonBlockObject>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 662 | } |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 663 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 664 | void Unparse(const Substring &x) { // R908, R909 |
peter klausler | 2884b2e | 2018-04-13 21:21:13 | [diff] [blame] | 665 | Walk(std::get<DataRef>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 666 | Put('('), Walk(std::get<SubstringRange>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 667 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 668 | void Unparse(const CharLiteralConstantSubstring &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 669 | Walk(std::get<CharLiteralConstant>(x.t)); |
| 670 | Put('('), Walk(std::get<SubstringRange>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 671 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 672 | void Unparse(const SubstringRange &x) { // R910 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 673 | Walk(x.t, ":"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 674 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 675 | void Unparse(const PartRef &x) { // R912 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 676 | Walk(x.name); |
| 677 | Walk("(", x.subscripts, ",", ")"); |
| 678 | Walk(x.imageSelector); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 679 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 680 | void Unparse(const StructureComponent &x) { // R913 |
peter klausler | 4e354d8 | 2018-03-30 22:23:37 | [diff] [blame] | 681 | Walk(x.base); |
| 682 | if (structureComponents_.find(x.component.source) != |
| 683 | structureComponents_.end()) { |
| 684 | Put('.'); |
| 685 | } else { |
| 686 | Put('%'); |
| 687 | } |
| 688 | Walk(x.component); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 689 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 690 | void Unparse(const ArrayElement &x) { // R917 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 691 | Walk(x.base); |
| 692 | Put('('), Walk(x.subscripts, ","), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 693 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 694 | void Unparse(const SubscriptTriplet &x) { // R921 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 695 | Walk(std::get<0>(x.t)), Put(':'), Walk(std::get<1>(x.t)); |
| 696 | Walk(":", std::get<2>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 697 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 698 | void Unparse(const ImageSelector &x) { // R924 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 699 | Put('['), Walk(std::get<std::list<Cosubscript>>(x.t), ","); |
| 700 | Walk(",", std::get<std::list<ImageSelectorSpec>>(x.t), ","), Put(']'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 701 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 702 | void Before(const ImageSelectorSpec::Stat &) { // R926 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 703 | Word("STAT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 704 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 705 | void Before(const ImageSelectorSpec::Team &) { Word("TEAM="); } |
| 706 | void Before(const ImageSelectorSpec::Team_Number &) { Word("TEAM_NUMBER="); } |
| 707 | void Unparse(const AllocateStmt &x) { // R927 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 708 | Word("ALLOCATE("); |
| 709 | Walk(std::get<std::optional<TypeSpec>>(x.t), "::"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 710 | Walk(std::get<std::list<Allocation>>(x.t), ", "); |
| 711 | Walk(", ", std::get<std::list<AllocOpt>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 712 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 713 | void Before(const AllocOpt &x) { // R928, R931 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 714 | std::visit(visitors{[&](const AllocOpt::Mold &) { Word("MOLD="); }, |
| 715 | [&](const AllocOpt::Source &) { Word("SOURCE="); }, |
peter klausler | ed5a6c9 | 2018-03-15 00:07:15 | [diff] [blame] | 716 | [](const StatOrErrmsg &) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 717 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 718 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 719 | void Unparse(const Allocation &x) { // R932 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 720 | Walk(std::get<AllocateObject>(x.t)); |
| 721 | Walk("(", std::get<std::list<AllocateShapeSpec>>(x.t), ",", ")"); |
| 722 | Walk("[", std::get<std::optional<AllocateCoarraySpec>>(x.t), "]"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 723 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 724 | void Unparse(const AllocateShapeSpec &x) { // R934 & R938 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 725 | Walk(std::get<std::optional<BoundExpr>>(x.t), ":"); |
| 726 | Walk(std::get<BoundExpr>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 727 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 728 | void Unparse(const AllocateCoarraySpec &x) { // R937 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 729 | Walk(std::get<std::list<AllocateCoshapeSpec>>(x.t), ",", ","); |
| 730 | Walk(std::get<std::optional<BoundExpr>>(x.t), ":"), Put('*'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 731 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 732 | void Unparse(const NullifyStmt &x) { // R939 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 733 | Word("NULLIFY("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 734 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 735 | void Unparse(const DeallocateStmt &x) { // R941 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 736 | Word("DEALLOCATE("); |
| 737 | Walk(std::get<std::list<AllocateObject>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 738 | Walk(", ", std::get<std::list<StatOrErrmsg>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 739 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 740 | void Before(const StatOrErrmsg &x) { // R942 & R1165 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 741 | std::visit(visitors{[&](const StatVariable &) { Word("STAT="); }, |
| 742 | [&](const MsgVariable &) { Word("ERRMSG="); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 743 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 744 | } |
| 745 | |
| 746 | // R1001 - R1022 |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 747 | void Unparse(const Expr::Parentheses &x) { Put('('), Walk(x.v), Put(')'); } |
| 748 | void Before(const Expr::UnaryPlus &x) { Put("+"); } |
| 749 | void Before(const Expr::Negate &x) { Put("-"); } |
| 750 | void Before(const Expr::NOT &x) { Word(".NOT."); } |
| 751 | void Unparse(const Expr::PercentLoc &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 752 | Word("%LOC("), Walk(x.v), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 753 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 754 | void Unparse(const Expr::Power &x) { Walk(x.t, "**"); } |
| 755 | void Unparse(const Expr::Multiply &x) { Walk(x.t, "*"); } |
| 756 | void Unparse(const Expr::Divide &x) { Walk(x.t, "/"); } |
| 757 | void Unparse(const Expr::Add &x) { Walk(x.t, "+"); } |
| 758 | void Unparse(const Expr::Subtract &x) { Walk(x.t, "-"); } |
| 759 | void Unparse(const Expr::Concat &x) { Walk(x.t, "//"); } |
| 760 | void Unparse(const Expr::LT &x) { Walk(x.t, "<"); } |
| 761 | void Unparse(const Expr::LE &x) { Walk(x.t, "<="); } |
| 762 | void Unparse(const Expr::EQ &x) { Walk(x.t, "=="); } |
| 763 | void Unparse(const Expr::NE &x) { Walk(x.t, "/="); } |
| 764 | void Unparse(const Expr::GE &x) { Walk(x.t, ">="); } |
| 765 | void Unparse(const Expr::GT &x) { Walk(x.t, ">"); } |
| 766 | void Unparse(const Expr::AND &x) { Walk(x.t, ".AND."); } |
| 767 | void Unparse(const Expr::OR &x) { Walk(x.t, ".OR."); } |
| 768 | void Unparse(const Expr::EQV &x) { Walk(x.t, ".EQV."); } |
| 769 | void Unparse(const Expr::NEQV &x) { Walk(x.t, ".NEQV."); } |
| 770 | void Unparse(const Expr::XOR &x) { Walk(x.t, ".XOR."); } |
| 771 | void Unparse(const Expr::ComplexConstructor &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 772 | Put('('), Walk(x.t, ","), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 773 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 774 | void Unparse(const Expr::DefinedBinary &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 775 | Walk(std::get<1>(x.t)); // left |
| 776 | Walk(std::get<DefinedOpName>(x.t)); |
| 777 | Walk(std::get<2>(x.t)); // right |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 778 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 779 | void Unparse(const DefinedOpName &x) { // R1003, R1023, R1414, & R1415 |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 780 | Put('.'), Walk(x.v), Put('.'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 781 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 782 | void Unparse(const AssignmentStmt &x) { // R1032 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 783 | Walk(x.t, " = "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 784 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 785 | void Unparse(const PointerAssignmentStmt &x) { // R1033, R1034, R1038 |
peter klausler | 2884b2e | 2018-04-13 21:21:13 | [diff] [blame] | 786 | Walk(std::get<DataRef>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 787 | std::visit( |
| 788 | visitors{[&](const std::list<BoundsRemapping> &y) { |
| 789 | Put('('), Walk(y), Put(')'); |
| 790 | }, |
| 791 | [&](const std::list<BoundsSpec> &y) { Walk("(", y, ", ", ")"); }}, |
| 792 | std::get<PointerAssignmentStmt::Bounds>(x.t).u); |
| 793 | Put(" => "), Walk(std::get<Expr>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 794 | } |
| 795 | void Post(const BoundsSpec &) { // R1035 |
| 796 | Put(':'); |
| 797 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 798 | void Unparse(const BoundsRemapping &x) { // R1036 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 799 | Walk(x.t, ":"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 800 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 801 | void Unparse(const WhereStmt &x) { // R1041, R1045, R1046 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 802 | Word("WHERE ("), Walk(x.t, ") "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 803 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 804 | void Unparse(const WhereConstructStmt &x) { // R1043 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 805 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 806 | Word("WHERE ("), Walk(std::get<LogicalExpr>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 807 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 808 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 809 | void Unparse(const MaskedElsewhereStmt &x) { // R1047 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 810 | Outdent(); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 811 | Word("ELSEWHERE ("), Walk(std::get<LogicalExpr>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 812 | Walk(" ", std::get<std::optional<Name>>(x.t)); |
| 813 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 814 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 815 | void Unparse(const ElsewhereStmt &x) { // R1048 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 816 | Outdent(), Word("ELSEWHERE"), Walk(" ", x.v), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 817 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 818 | void Unparse(const EndWhereStmt &x) { // R1049 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 819 | Outdent(), Word("END WHERE"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 820 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 821 | void Unparse(const ForallConstructStmt &x) { // R1051 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 822 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 823 | Word("FORALL"), Walk(std::get<Indirection<ConcurrentHeader>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 824 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 825 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 826 | void Unparse(const EndForallStmt &x) { // R1054 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 827 | Outdent(), Word("END FORALL"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 828 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 829 | void Before(const ForallStmt &) { // R1055 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 830 | Word("FORALL"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 831 | } |
| 832 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 833 | void Unparse(const AssociateStmt &x) { // R1103 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 834 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 835 | Word("ASSOCIATE ("); |
| 836 | Walk(std::get<std::list<Association>>(x.t), ", "), Put(')'), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 837 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 838 | void Unparse(const Association &x) { // R1104 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 839 | Walk(x.t, " => "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 840 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 841 | void Unparse(const EndAssociateStmt &x) { // R1106 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 842 | Outdent(), Word("END ASSOCIATE"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 843 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 844 | void Unparse(const BlockStmt &x) { // R1108 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 845 | Walk(x.v, ": "), Word("BLOCK"), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 846 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 847 | void Unparse(const EndBlockStmt &x) { // R1110 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 848 | Outdent(), Word("END BLOCK"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 849 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 850 | void Unparse(const ChangeTeamStmt &x) { // R1112 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 851 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 852 | Word("CHANGE TEAM ("), Walk(std::get<TeamVariable>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 853 | Walk(", ", std::get<std::list<CoarrayAssociation>>(x.t), ", "); |
| 854 | Walk(", ", std::get<std::list<StatOrErrmsg>>(x.t), ", "), Put(')'); |
| 855 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 856 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 857 | void Unparse(const CoarrayAssociation &x) { // R1113 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 858 | Walk(x.t, " => "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 859 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 860 | void Unparse(const EndChangeTeamStmt &x) { // R1114 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 861 | Outdent(), Word("END TEAM ("); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 862 | Walk(std::get<std::list<StatOrErrmsg>>(x.t), ", "); |
| 863 | Put(')'), Walk(" ", std::get<std::optional<Name>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 864 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 865 | void Unparse(const CriticalStmt &x) { // R1117 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 866 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 867 | Word("CRITICAL ("), Walk(std::get<std::list<StatOrErrmsg>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 868 | Put(')'), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 869 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 870 | void Unparse(const EndCriticalStmt &x) { // R1118 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 871 | Outdent(), Word("END CRITICAL"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 872 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 873 | void Unparse(const DoConstruct &x) { // R1119, R1120 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 874 | Walk(std::get<Statement<NonLabelDoStmt>>(x.t)); |
| 875 | Indent(), Walk(std::get<Block>(x.t), ""), Outdent(); |
| 876 | Walk(std::get<Statement<EndDoStmt>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 877 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 878 | void Unparse(const LabelDoStmt &x) { // R1121 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 879 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 880 | Word("DO "), Walk(std::get<Label>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 881 | Walk(" ", std::get<std::optional<LoopControl>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 882 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 883 | void Unparse(const NonLabelDoStmt &x) { // R1122 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 884 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 885 | Word("DO "), Walk(std::get<std::optional<LoopControl>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 886 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 887 | void Unparse(const LoopControl &x) { // R1123 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 888 | std::visit(visitors{[&](const ScalarLogicalExpr &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 889 | Word("WHILE ("), Walk(y), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 890 | }, |
| 891 | [&](const auto &y) { Walk(y); }}, |
| 892 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 893 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 894 | void Unparse(const ConcurrentHeader &x) { // R1125 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 895 | Put('('), Walk(std::get<std::optional<IntegerTypeSpec>>(x.t), "::"); |
| 896 | Walk(std::get<std::list<ConcurrentControl>>(x.t), ", "); |
| 897 | Walk(", ", std::get<std::optional<ScalarLogicalExpr>>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 898 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 899 | void Unparse(const ConcurrentControl &x) { // R1126 - R1128 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 900 | Walk(std::get<Name>(x.t)), Put('='), Walk(std::get<1>(x.t)); |
| 901 | Put(':'), Walk(std::get<2>(x.t)); |
| 902 | Walk(":", std::get<std::optional<ScalarIntExpr>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 903 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 904 | void Before(const LoopControl::Concurrent &x) { // R1129 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 905 | Word("CONCURRENT"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 906 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 907 | void Unparse(const LocalitySpec::Local &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 908 | Word("LOCAL("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 909 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 910 | void Unparse(const LocalitySpec::LocalInit &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 911 | Word("LOCAL INIT("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 912 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 913 | void Unparse(const LocalitySpec::Shared &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 914 | Word("SHARED("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 915 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 916 | void Post(const LocalitySpec::DefaultNone &x) { Word("DEFAULT(NONE)"); } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 917 | void Unparse(const EndDoStmt &x) { // R1132 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 918 | Word("END DO"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 919 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 920 | void Unparse(const CycleStmt &x) { // R1133 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 921 | Word("CYCLE"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 922 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 923 | void Unparse(const IfThenStmt &x) { // R1135 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 924 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 925 | Word("IF ("), Walk(std::get<ScalarLogicalExpr>(x.t)); |
| 926 | Put(") "), Word("THEN"), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 927 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 928 | void Unparse(const ElseIfStmt &x) { // R1136 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 929 | Outdent(), Word("ELSE IF ("); |
| 930 | Walk(std::get<ScalarLogicalExpr>(x.t)), Put(") "), Word("THEN"); |
| 931 | Walk(" ", std::get<std::optional<Name>>(x.t)), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 932 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 933 | void Unparse(const ElseStmt &x) { // R1137 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 934 | Outdent(), Word("ELSE"), Walk(" ", x.v), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 935 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 936 | void Unparse(const EndIfStmt &x) { // R1138 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 937 | Outdent(), Word("END IF"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 938 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 939 | void Unparse(const IfStmt &x) { // R1139 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 940 | Word("IF ("), Walk(x.t, ") "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 941 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 942 | void Unparse(const SelectCaseStmt &x) { // R1141, R1144 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 943 | Walk(std::get<std::optional<Name>>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 944 | Word("SELECT CASE ("); |
| 945 | Walk(std::get<Scalar<Expr>>(x.t)), Put(')'), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 946 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 947 | void Unparse(const CaseStmt &x) { // R1142 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 948 | Outdent(), Word("CASE "), Walk(std::get<CaseSelector>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 949 | Walk(" ", std::get<std::optional<Name>>(x.t)), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 950 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 951 | void Unparse(const EndSelectStmt &x) { // R1143 & R1151 & R1155 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 952 | Outdent(), Word("END SELECT"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 953 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 954 | void Unparse(const CaseSelector &x) { // R1145 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 955 | std::visit(visitors{[&](const std::list<CaseValueRange> &y) { |
| 956 | Put('('), Walk(y), Put(')'); |
| 957 | }, |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 958 | [&](const Default &) { Word("DEFAULT"); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 959 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 960 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 961 | void Unparse(const CaseValueRange::Range &x) { // R1146 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 962 | Walk(x.lower), Put(':'), Walk(x.upper); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 963 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 964 | void Unparse(const SelectRankStmt &x) { // R1149 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 965 | Walk(std::get<0>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 966 | Word("SELECT RANK ("), Walk(std::get<1>(x.t), " => "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 967 | Walk(std::get<Selector>(x.t)), Put(')'), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 968 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 969 | void Unparse(const SelectRankCaseStmt &x) { // R1150 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 970 | Outdent(), Word("RANK "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 971 | std::visit(visitors{[&](const ScalarIntConstantExpr &y) { |
| 972 | Put('('), Walk(y), Put(')'); |
| 973 | }, |
| 974 | [&](const Star &) { Put("(*)"); }, |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 975 | [&](const Default &) { Word("DEFAULT"); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 976 | std::get<SelectRankCaseStmt::Rank>(x.t).u); |
| 977 | Walk(" ", std::get<std::optional<Name>>(x.t)), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 978 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 979 | void Unparse(const SelectTypeStmt &x) { // R1153 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 980 | Walk(std::get<0>(x.t), ": "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 981 | Word("SELECT TYPE ("), Walk(std::get<1>(x.t), " => "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 982 | Walk(std::get<Selector>(x.t)), Put(')'), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 983 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 984 | void Unparse(const TypeGuardStmt &x) { // R1154 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 985 | Outdent(), Walk(std::get<TypeGuardStmt::Guard>(x.t)); |
| 986 | Walk(" ", std::get<std::optional<Name>>(x.t)), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 987 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 988 | void Unparse(const TypeGuardStmt::Guard &x) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 989 | std::visit(visitors{[&](const TypeSpec &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 990 | Word("TYPE IS ("), Walk(y), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 991 | }, |
| 992 | [&](const DerivedTypeSpec &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 993 | Word("CLASS IS ("), Walk(y), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 994 | }, |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 995 | [&](const Default &) { Word("CLASS DEFAULT"); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 996 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 997 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 998 | void Unparse(const ExitStmt &x) { // R1156 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 999 | Word("EXIT"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1000 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1001 | void Before(const GotoStmt &x) { // R1157 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1002 | Word("GO TO "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1003 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1004 | void Unparse(const ComputedGotoStmt &x) { // R1158 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1005 | Word("GO TO ("), Walk(x.t, "), "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1006 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1007 | void Unparse(const ContinueStmt &x) { // R1159 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1008 | Word("CONTINUE"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1009 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1010 | void Unparse(const StopStmt &x) { // R1160, R1161 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1011 | if (std::get<StopStmt::Kind>(x.t) == StopStmt::Kind::ErrorStop) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1012 | Word("ERROR "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1013 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1014 | Word("STOP"), Walk(" ", std::get<std::optional<StopCode>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1015 | Walk(", QUIET=", std::get<std::optional<ScalarLogicalExpr>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1016 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1017 | void Unparse(const FailImageStmt &x) { // R1163 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1018 | Word("FAIL IMAGE"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1019 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1020 | void Unparse(const SyncAllStmt &x) { // R1164 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1021 | Word("SYNC ALL ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1022 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1023 | void Unparse(const SyncImagesStmt &x) { // R1166 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1024 | Word("SYNC IMAGES ("); |
| 1025 | Walk(std::get<SyncImagesStmt::ImageSet>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1026 | Walk(", ", std::get<std::list<StatOrErrmsg>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1027 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1028 | void Unparse(const SyncMemoryStmt &x) { // R1168 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1029 | Word("SYNC MEMORY ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1030 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1031 | void Unparse(const SyncTeamStmt &x) { // R1169 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1032 | Word("SYNC TEAM ("), Walk(std::get<TeamVariable>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1033 | Walk(", ", std::get<std::list<StatOrErrmsg>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1034 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1035 | void Unparse(const EventPostStmt &x) { // R1170 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1036 | Word("EVENT POST ("), Walk(std::get<EventVariable>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1037 | Walk(", ", std::get<std::list<StatOrErrmsg>>(x.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1038 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1039 | void Before(const EventWaitStmt::EventWaitSpec &x) { // R1173, R1174 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 1040 | std::visit(visitors{[&](const ScalarIntExpr &x) { Word("UNTIL_COUNT="); }, |
peter klausler | ed5a6c9 | 2018-03-15 00:07:15 | [diff] [blame] | 1041 | [](const StatOrErrmsg &) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1042 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1043 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1044 | void Unparse(const EventWaitStmt &x) { // R1170 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1045 | Word("EVENT WAIT ("), Walk(std::get<EventVariable>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1046 | Walk(", ", std::get<std::list<EventWaitStmt::EventWaitSpec>>(x.t), ", "); |
| 1047 | Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1048 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1049 | void Unparse(const FormTeamStmt &x) { // R1175 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1050 | Word("FORM TEAM ("), Walk(std::get<ScalarIntExpr>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1051 | Put(','), Walk(std::get<TeamVariable>(x.t)); |
| 1052 | Walk(", ", std::get<std::list<FormTeamStmt::FormTeamSpec>>(x.t), ", "); |
| 1053 | Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1054 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1055 | void Before(const FormTeamStmt::FormTeamSpec &x) { // R1176, R1177 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 1056 | std::visit(visitors{[&](const ScalarIntExpr &x) { Word("NEW_INDEX="); }, |
peter klausler | ed5a6c9 | 2018-03-15 00:07:15 | [diff] [blame] | 1057 | [](const StatOrErrmsg &) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1058 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1059 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1060 | void Unparse(const LockStmt &x) { // R1178 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1061 | Word("LOCK ("), Walk(std::get<LockVariable>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1062 | Walk(", ", std::get<std::list<LockStmt::LockStat>>(x.t), ", "); |
| 1063 | Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1064 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1065 | void Before(const LockStmt::LockStat &x) { // R1179 |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 1066 | std::visit( |
| 1067 | visitors{[&](const ScalarLogicalVariable &) { Word("ACQUIRED_LOCK="); }, |
peter klausler | ed5a6c9 | 2018-03-15 00:07:15 | [diff] [blame] | 1068 | [](const StatOrErrmsg &y) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1069 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1070 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1071 | void Unparse(const UnlockStmt &x) { // R1180 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1072 | Word("UNLOCK ("), Walk(std::get<LockVariable>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1073 | Walk(", ", std::get<std::list<StatOrErrmsg>>(x.t), ", "); |
| 1074 | Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1075 | } |
| 1076 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1077 | void Unparse(const OpenStmt &x) { // R1204 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1078 | Word("OPEN ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1079 | } |
| 1080 | bool Pre(const ConnectSpec &x) { // R1205 |
| 1081 | return std::visit(visitors{[&](const FileUnitNumber &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1082 | Word("UNIT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1083 | return true; |
| 1084 | }, |
| 1085 | [&](const FileNameExpr &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1086 | Word("FILE="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1087 | return true; |
| 1088 | }, |
| 1089 | [&](const ConnectSpec::CharExpr &y) { |
| 1090 | Walk(y.t, "="); |
| 1091 | return false; |
| 1092 | }, |
| 1093 | [&](const MsgVariable &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1094 | Word("IOMSG="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1095 | return true; |
| 1096 | }, |
| 1097 | [&](const StatVariable &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1098 | Word("IOSTAT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1099 | return true; |
| 1100 | }, |
| 1101 | [&](const ConnectSpec::Recl &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1102 | Word("RECL="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1103 | return true; |
| 1104 | }, |
| 1105 | [&](const ConnectSpec::Newunit &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1106 | Word("NEWUNIT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1107 | return true; |
| 1108 | }, |
| 1109 | [&](const ErrLabel &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1110 | Word("ERR="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1111 | return true; |
| 1112 | }, |
| 1113 | [&](const StatusExpr &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1114 | Word("STATUS="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1115 | return true; |
| 1116 | }}, |
| 1117 | x.u); |
| 1118 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1119 | void Unparse(const CloseStmt &x) { // R1208 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1120 | Word("CLOSE ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1121 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1122 | void Before(const CloseStmt::CloseSpec &x) { // R1209 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1123 | std::visit(visitors{[&](const FileUnitNumber &) { Word("UNIT="); }, |
| 1124 | [&](const StatVariable &) { Word("IOSTAT="); }, |
| 1125 | [&](const MsgVariable &) { Word("IOMSG="); }, |
| 1126 | [&](const ErrLabel &) { Word("ERR="); }, |
| 1127 | [&](const StatusExpr &) { Word("STATUS="); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1128 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1129 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1130 | void Unparse(const ReadStmt &x) { // R1210 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1131 | Word("READ "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1132 | if (x.iounit) { |
| 1133 | Put('('), Walk(x.iounit); |
| 1134 | if (x.format) { |
| 1135 | Put(", "), Walk(x.format); |
| 1136 | } |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 1137 | Walk(", ", x.controls, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1138 | Put(')'); |
| 1139 | } else if (x.format) { |
| 1140 | Walk(x.format); |
| 1141 | if (!x.items.empty()) { |
| 1142 | Put(", "); |
| 1143 | } |
| 1144 | } else { |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 1145 | Put('('), Walk(x.controls, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1146 | } |
| 1147 | Walk(" ", x.items, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1148 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1149 | void Unparse(const WriteStmt &x) { // R1211 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1150 | Word("WRITE ("); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1151 | if (x.iounit) { |
| 1152 | Walk(x.iounit); |
| 1153 | if (x.format) { |
| 1154 | Put(", "), Walk(x.format); |
| 1155 | } |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 1156 | Walk(", ", x.controls, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1157 | } else { |
peter klausler | dcd0942 | 2018-03-15 23:03:28 | [diff] [blame] | 1158 | Walk(x.controls, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1159 | } |
| 1160 | Put(')'), Walk(" ", x.items, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1161 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1162 | void Unparse(const PrintStmt &x) { // R1212 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1163 | Word("PRINT "), Walk(std::get<Format>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1164 | Walk(", ", std::get<std::list<OutputItem>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1165 | } |
| 1166 | bool Pre(const IoControlSpec &x) { // R1213 |
| 1167 | return std::visit(visitors{[&](const IoUnit &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1168 | Word("UNIT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1169 | return true; |
| 1170 | }, |
| 1171 | [&](const Format &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1172 | Word("FMT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1173 | return true; |
| 1174 | }, |
| 1175 | [&](const Name &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1176 | Word("NML="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1177 | return true; |
| 1178 | }, |
| 1179 | [&](const IoControlSpec::CharExpr &y) { |
| 1180 | Walk(y.t, "="); |
| 1181 | return false; |
| 1182 | }, |
| 1183 | [&](const IoControlSpec::Asynchronous &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1184 | Word("ASYNCHRONOUS="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1185 | return true; |
| 1186 | }, |
| 1187 | [&](const EndLabel &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1188 | Word("END="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1189 | return true; |
| 1190 | }, |
| 1191 | [&](const EorLabel &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1192 | Word("EOR="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1193 | return true; |
| 1194 | }, |
| 1195 | [&](const ErrLabel &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1196 | Word("ERR="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1197 | return true; |
| 1198 | }, |
| 1199 | [&](const IdVariable &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1200 | Word("ID="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1201 | return true; |
| 1202 | }, |
| 1203 | [&](const MsgVariable &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1204 | Word("IOMSG="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1205 | return true; |
| 1206 | }, |
| 1207 | [&](const StatVariable &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1208 | Word("IOSTAT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1209 | return true; |
| 1210 | }, |
| 1211 | [&](const IoControlSpec::Pos &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1212 | Word("POS="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1213 | return true; |
| 1214 | }, |
| 1215 | [&](const IoControlSpec::Rec &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1216 | Word("REC="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1217 | return true; |
| 1218 | }, |
| 1219 | [&](const IoControlSpec::Size &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1220 | Word("SIZE="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1221 | return true; |
| 1222 | }}, |
| 1223 | x.u); |
| 1224 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1225 | void Unparse(const InputImpliedDo &x) { // R1218 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1226 | Put('('), Walk(std::get<std::list<InputItem>>(x.t), ", "), Put(", "); |
| 1227 | Walk(std::get<IoImpliedDoControl>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1228 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1229 | void Unparse(const OutputImpliedDo &x) { // R1219 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1230 | Put('('), Walk(std::get<std::list<OutputItem>>(x.t), ", "), Put(", "); |
| 1231 | Walk(std::get<IoImpliedDoControl>(x.t)), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1232 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1233 | void Unparse(const WaitStmt &x) { // R1222 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1234 | Word("WAIT ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1235 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1236 | void Before(const WaitSpec &x) { // R1223 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1237 | std::visit(visitors{[&](const FileUnitNumber &) { Word("UNIT="); }, |
| 1238 | [&](const EndLabel &) { Word("END="); }, |
| 1239 | [&](const EorLabel &) { Word("EOR="); }, |
| 1240 | [&](const ErrLabel &) { Word("ERR="); }, |
| 1241 | [&](const IdExpr &) { Word("ID="); }, |
| 1242 | [&](const MsgVariable &) { Word("IOMSG="); }, |
| 1243 | [&](const StatVariable &) { Word("IOSTAT="); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1244 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1245 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1246 | void Unparse(const BackspaceStmt &x) { // R1224 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1247 | Word("BACKSPACE ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1248 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1249 | void Unparse(const EndfileStmt &x) { // R1225 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1250 | Word("ENDFILE ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1251 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1252 | void Unparse(const RewindStmt &x) { // R1226 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1253 | Word("REWIND ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1254 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1255 | void Before(const PositionOrFlushSpec &x) { // R1227 & R1229 |
peter klausler | ad4adc2 | 2018-03-16 00:09:27 | [diff] [blame] | 1256 | std::visit(visitors{[&](const FileUnitNumber &) { Word("UNIT="); }, |
| 1257 | [&](const MsgVariable &) { Word("IOMSG="); }, |
| 1258 | [&](const StatVariable &) { Word("IOSTAT="); }, |
| 1259 | [&](const ErrLabel &) { Word("ERR="); }}, |
| 1260 | x.u); |
peter klausler | ad4adc2 | 2018-03-16 00:09:27 | [diff] [blame] | 1261 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1262 | void Unparse(const FlushStmt &x) { // R1228 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1263 | Word("FLUSH ("), Walk(x.v, ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1264 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1265 | void Unparse(const InquireStmt &x) { // R1230 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1266 | Word("INQUIRE ("); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1267 | std::visit( |
| 1268 | visitors{[&](const InquireStmt::Iolength &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1269 | Word("IOLENGTH="), Walk(y.t, ") "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1270 | }, |
| 1271 | [&](const std::list<InquireSpec> &y) { Walk(y, ", "), Put(')'); }}, |
| 1272 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1273 | } |
| 1274 | bool Pre(const InquireSpec &x) { // R1231 |
| 1275 | return std::visit(visitors{[&](const FileUnitNumber &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1276 | Word("UNIT="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1277 | return true; |
| 1278 | }, |
| 1279 | [&](const FileNameExpr &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1280 | Word("FILE="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1281 | return true; |
| 1282 | }, |
| 1283 | [&](const InquireSpec::CharVar &y) { |
| 1284 | Walk(y.t, "="); |
| 1285 | return false; |
| 1286 | }, |
| 1287 | [&](const InquireSpec::IntVar &y) { |
| 1288 | Walk(y.t, "="); |
| 1289 | return false; |
| 1290 | }, |
| 1291 | [&](const InquireSpec::LogVar &y) { |
| 1292 | Walk(y.t, "="); |
| 1293 | return false; |
| 1294 | }, |
| 1295 | [&](const IdExpr &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1296 | Word("ID="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1297 | return true; |
| 1298 | }, |
| 1299 | [&](const ErrLabel &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1300 | Word("ERR="); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1301 | return true; |
| 1302 | }}, |
| 1303 | x.u); |
| 1304 | } |
| 1305 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1306 | void Before(const FormatStmt &) { // R1301 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1307 | Word("FORMAT"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1308 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1309 | void Unparse(const format::FormatSpecification &x) { // R1302, R1303, R1305 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1310 | Put('('), Walk("", x.items, ",", x.unlimitedItems.empty() ? "" : ","); |
| 1311 | Walk("*(", x.unlimitedItems, ",", ")"), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1312 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1313 | void Unparse(const format::FormatItem &x) { // R1304, R1306, R1321 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1314 | if (x.repeatCount.has_value()) { |
| 1315 | Walk(*x.repeatCount); |
| 1316 | } |
| 1317 | std::visit(visitors{[&](const std::string &y) { PutQuoted(y); }, |
| 1318 | [&](const std::list<format::FormatItem> &y) { |
| 1319 | Walk("(", y, ",", ")"); |
| 1320 | }, |
| 1321 | [&](const auto &y) { Walk(y); }}, |
| 1322 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1323 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1324 | void Unparse( |
| 1325 | const format::IntrinsicTypeDataEditDesc &x) { // R1307(1/2) - R1311 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1326 | switch (x.kind) { |
| 1327 | #define FMT(x) \ |
| 1328 | case format::IntrinsicTypeDataEditDesc::Kind::x: Put(#x); break |
| 1329 | FMT(I); |
| 1330 | FMT(B); |
| 1331 | FMT(O); |
| 1332 | FMT(Z); |
| 1333 | FMT(F); |
| 1334 | FMT(E); |
| 1335 | FMT(EN); |
| 1336 | FMT(ES); |
| 1337 | FMT(EX); |
| 1338 | FMT(G); |
| 1339 | FMT(L); |
| 1340 | FMT(A); |
| 1341 | FMT(D); |
| 1342 | #undef FMT |
| 1343 | default: CRASH_NO_CASE; |
| 1344 | } |
| 1345 | Walk(x.width), Walk(".", x.digits), Walk("E", x.exponentWidth); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1346 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1347 | void Unparse(const format::DerivedTypeDataEditDesc &x) { // R1307(2/2), R1312 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1348 | Word("DT"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1349 | if (!x.type.empty()) { |
| 1350 | Put('"'), Put(x.type), Put('"'); |
| 1351 | } |
| 1352 | Walk("(", x.parameters, ",", ")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1353 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1354 | void Unparse(const format::ControlEditDesc &x) { // R1313, R1315-R1320 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1355 | switch (x.kind) { |
| 1356 | case format::ControlEditDesc::Kind::T: |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1357 | Word("T"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1358 | Walk(x.count); |
| 1359 | break; |
| 1360 | case format::ControlEditDesc::Kind::TL: |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1361 | Word("TL"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1362 | Walk(x.count); |
| 1363 | break; |
| 1364 | case format::ControlEditDesc::Kind::TR: |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1365 | Word("TR"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1366 | Walk(x.count); |
| 1367 | break; |
| 1368 | case format::ControlEditDesc::Kind::X: |
| 1369 | if (x.count != 1) { |
| 1370 | Walk(x.count); |
| 1371 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1372 | Word("X"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1373 | break; |
| 1374 | case format::ControlEditDesc::Kind::Slash: |
| 1375 | if (x.count != 1) { |
| 1376 | Walk(x.count); |
| 1377 | } |
| 1378 | Put('/'); |
| 1379 | break; |
| 1380 | case format::ControlEditDesc::Kind::Colon: Put(':'); break; |
| 1381 | case format::ControlEditDesc::Kind::P: |
| 1382 | Walk(x.count); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1383 | Word("P"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1384 | break; |
| 1385 | #define FMT(x) \ |
| 1386 | case format::ControlEditDesc::Kind::x: Put(#x); break |
| 1387 | FMT(SS); |
| 1388 | FMT(SP); |
| 1389 | FMT(S); |
| 1390 | FMT(BN); |
| 1391 | FMT(BZ); |
| 1392 | FMT(RU); |
| 1393 | FMT(RD); |
| 1394 | FMT(RZ); |
| 1395 | FMT(RN); |
| 1396 | FMT(RC); |
| 1397 | FMT(RP); |
| 1398 | FMT(DC); |
| 1399 | FMT(DP); |
| 1400 | #undef FMT |
| 1401 | default: CRASH_NO_CASE; |
| 1402 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1403 | } |
| 1404 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1405 | void Before(const MainProgram &x) { // R1401 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1406 | if (!std::get<std::optional<Statement<ProgramStmt>>>(x.t)) { |
| 1407 | Indent(); |
| 1408 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1409 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1410 | void Before(const ProgramStmt &x) { // R1402 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1411 | Word("PROGRAM "), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1412 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1413 | void Unparse(const EndProgramStmt &x) { // R1403 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1414 | EndSubprogram("PROGRAM", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1415 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1416 | void Before(const ModuleStmt &) { // R1405 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1417 | Word("MODULE "), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1418 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1419 | void Unparse(const EndModuleStmt &x) { // R1406 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1420 | EndSubprogram("MODULE", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1421 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1422 | void Unparse(const UseStmt &x) { // R1409 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1423 | Word("USE"), Walk(", ", x.nature), Put(" :: "), Walk(x.moduleName); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1424 | std::visit( |
| 1425 | visitors{[&](const std::list<Rename> &y) { Walk(", ", y, ", "); }, |
| 1426 | [&](const std::list<Only> &y) { Walk(", ONLY: ", y, ", "); }}, |
| 1427 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1428 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1429 | void Unparse(const Rename &x) { // R1411 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1430 | std::visit(visitors{[&](const Rename::Names &y) { Walk(y.t, " => "); }, |
| 1431 | [&](const Rename::Operators &y) { |
peter klausler | 8e7c008 | 2018-04-09 21:52:15 | [diff] [blame] | 1432 | Word("OPERATOR("), Walk(y.t, ") => OPERATOR("), Put(")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1433 | }}, |
| 1434 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1435 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1436 | void Before(const SubmoduleStmt &x) { // R1417 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1437 | Word("SUBMODULE "), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1438 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1439 | void Unparse(const ParentIdentifier &x) { // R1418 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1440 | Walk(std::get<Name>(x.t)), Walk(":", std::get<std::optional<Name>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1441 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1442 | void Unparse(const EndSubmoduleStmt &x) { // R1419 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1443 | EndSubprogram("SUBMODULE", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1444 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1445 | void Unparse(const BlockDataStmt &x) { // R1421 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1446 | Word("BLOCK DATA"), Walk(" ", x.v), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1447 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1448 | void Unparse(const EndBlockDataStmt &x) { // R1422 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1449 | EndSubprogram("BLOCK DATA", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1450 | } |
| 1451 | |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1452 | void Unparse(const InterfaceStmt &x) { // R1503 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1453 | std::visit(visitors{[&](const std::optional<GenericSpec> &y) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1454 | Word("INTERFACE"), Walk(" ", y); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1455 | }, |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1456 | [&](const Abstract &) { Word("ABSTRACT INTERFACE"); }}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1457 | x.u); |
| 1458 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1459 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1460 | void Unparse(const EndInterfaceStmt &x) { // R1504 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1461 | Outdent(), Word("END INTERFACE"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1462 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1463 | void Unparse(const ProcedureStmt &x) { // R1506 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1464 | if (std::get<ProcedureStmt::Kind>(x.t) == |
| 1465 | ProcedureStmt::Kind::ModuleProcedure) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1466 | Word("MODULE "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1467 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1468 | Word("PROCEDURE :: "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1469 | Walk(std::get<std::list<Name>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1470 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1471 | void Before(const GenericSpec &x) { // R1508, R1509 |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 1472 | std::visit( |
| 1473 | visitors{[&](const DefinedOperator &x) { Word("OPERATOR("); }, |
| 1474 | [&](const GenericSpec::Assignment &) { Word("ASSIGNMENT(=)"); }, |
| 1475 | [&](const GenericSpec::ReadFormatted &) { |
| 1476 | Word("READ(FORMATTED)"); |
| 1477 | }, |
| 1478 | [&](const GenericSpec::ReadUnformatted &) { |
| 1479 | Word("READ(UNFORMATTED)"); |
| 1480 | }, |
| 1481 | [&](const GenericSpec::WriteFormatted &) { |
| 1482 | Word("WRITE(FORMATTED)"); |
| 1483 | }, |
| 1484 | [&](const GenericSpec::WriteUnformatted &) { |
| 1485 | Word("WRITE(UNFORMATTED)"); |
| 1486 | }, |
| 1487 | [](const auto &) {}}, |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1488 | x.u); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1489 | } |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 1490 | void Post(const GenericSpec &x) { |
| 1491 | std::visit(visitors{[&](const DefinedOperator &x) { Put(')'); }, |
| 1492 | [](const auto &) {}}, |
| 1493 | x.u); |
| 1494 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1495 | void Unparse(const GenericStmt &x) { // R1510 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1496 | Word("GENERIC"), Walk(", ", std::get<std::optional<AccessSpec>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1497 | Put(" :: "), Walk(std::get<GenericSpec>(x.t)), Put(" => "); |
| 1498 | Walk(std::get<std::list<Name>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1499 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1500 | void Unparse(const ExternalStmt &x) { // R1511 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1501 | Word("EXTERNAL :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1502 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1503 | void Unparse(const ProcedureDeclarationStmt &x) { // R1512 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1504 | Word("PROCEDURE ("), Walk(std::get<std::optional<ProcInterface>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1505 | Put(')'), Walk(", ", std::get<std::list<ProcAttrSpec>>(x.t), ", "); |
| 1506 | Put(" :: "), Walk(std::get<std::list<ProcDecl>>(x.t), ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1507 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1508 | void Unparse(const ProcDecl &x) { // R1515 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1509 | Walk(std::get<Name>(x.t)); |
| 1510 | Walk(" => ", std::get<std::optional<ProcPointerInit>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1511 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1512 | void Unparse(const IntrinsicStmt &x) { // R1519 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1513 | Word("INTRINSIC :: "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1514 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1515 | void Unparse(const FunctionReference &x) { // R1520 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1516 | Walk(std::get<ProcedureDesignator>(x.v.t)); |
| 1517 | Put('('), Walk(std::get<std::list<ActualArgSpec>>(x.v.t), ", "), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1518 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1519 | void Unparse(const CallStmt &x) { // R1521 |
peter klausler | ad4adc2 | 2018-03-16 00:09:27 | [diff] [blame] | 1520 | const auto &pd = std::get<ProcedureDesignator>(x.v.t); |
| 1521 | const auto &args = std::get<std::list<ActualArgSpec>>(x.v.t); |
| 1522 | Word("CALL "), Walk(pd); |
| 1523 | if (args.empty()) { |
| 1524 | if (std::holds_alternative<ProcComponentRef>(pd.u)) { |
| 1525 | Put("()"); // pgf90 crashes on CALL to tbp without parentheses |
| 1526 | } |
| 1527 | } else { |
| 1528 | Walk("(", args, ", ", ")"); |
| 1529 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1530 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1531 | void Unparse(const ActualArgSpec &x) { // R1523 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1532 | Walk(std::get<std::optional<Keyword>>(x.t), "="); |
| 1533 | Walk(std::get<ActualArg>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1534 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1535 | void Unparse(const ActualArg::PercentRef &x) { // R1524 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1536 | Word("%REF("), Walk(x.v), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1537 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1538 | void Unparse(const ActualArg::PercentVal &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1539 | Word("%VAL("), Walk(x.v), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1540 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1541 | void Before(const AltReturnSpec &) { // R1525 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1542 | Put('*'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1543 | } |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 1544 | void Post(const PrefixSpec::Elemental) { Word("ELEMENTAL"); } // R1527 |
| 1545 | void Post(const PrefixSpec::Impure) { Word("IMPURE"); } |
| 1546 | void Post(const PrefixSpec::Module) { Word("MODULE"); } |
| 1547 | void Post(const PrefixSpec::Non_Recursive) { Word("NON_RECURSIVE"); } |
| 1548 | void Post(const PrefixSpec::Pure) { Word("PURE"); } |
| 1549 | void Post(const PrefixSpec::Recursive) { Word("RECURSIVE"); } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1550 | void Unparse(const FunctionStmt &x) { // R1530 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1551 | Walk("", std::get<std::list<PrefixSpec>>(x.t), " ", " "); |
peter klausler | 62d9cdd | 2018-03-15 00:02:21 | [diff] [blame] | 1552 | Word("FUNCTION "), Walk(std::get<Name>(x.t)), Put("("); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1553 | Walk(std::get<std::list<Name>>(x.t), ", "), Put(')'); |
| 1554 | Walk(" ", std::get<std::optional<Suffix>>(x.t)), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1555 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1556 | void Unparse(const Suffix &x) { // R1532 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1557 | if (x.resultName) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1558 | Word("RESULT("), Walk(x.resultName), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1559 | Walk(" ", x.binding); |
| 1560 | } else { |
| 1561 | Walk(x.binding); |
| 1562 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1563 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1564 | void Unparse(const EndFunctionStmt &x) { // R1533 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1565 | EndSubprogram("FUNCTION", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1566 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1567 | void Unparse(const SubroutineStmt &x) { // R1535 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1568 | Walk("", std::get<std::list<PrefixSpec>>(x.t), " ", " "); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1569 | Word("SUBROUTINE "), Walk(std::get<Name>(x.t)); |
peter klausler | d71f3cf | 2018-03-14 23:31:41 | [diff] [blame] | 1570 | const auto &args = std::get<std::list<DummyArg>>(x.t); |
| 1571 | const auto &bind = std::get<std::optional<LanguageBindingSpec>>(x.t); |
| 1572 | if (args.empty()) { |
| 1573 | Walk(" () ", bind); |
| 1574 | } else { |
| 1575 | Walk(" (", args, ", ", ")"); |
| 1576 | Walk(" ", bind); |
| 1577 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1578 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1579 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1580 | void Unparse(const EndSubroutineStmt &x) { // R1537 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1581 | EndSubprogram("SUBROUTINE", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1582 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1583 | void Before(const MpSubprogramStmt &) { // R1539 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1584 | Word("MODULE PROCEDURE "), Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1585 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1586 | void Unparse(const EndMpSubprogramStmt &x) { // R1540 |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1587 | EndSubprogram("PROCEDURE", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1588 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1589 | void Unparse(const EntryStmt &x) { // R1541 |
peter klausler | bdd93dd | 2018-04-09 20:45:30 | [diff] [blame] | 1590 | Word("ENTRY "), Walk(std::get<Name>(x.t)), Put("("); |
| 1591 | Walk(std::get<std::list<DummyArg>>(x.t), ", "), Put(")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1592 | Walk(" ", std::get<std::optional<Suffix>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1593 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1594 | void Unparse(const ReturnStmt &x) { // R1542 |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1595 | Word("RETURN"), Walk(" ", x.v); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1596 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1597 | void Unparse(const ContainsStmt &x) { // R1543 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1598 | Outdent(); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1599 | Word("CONTAINS"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1600 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1601 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1602 | void Unparse(const StmtFunctionStmt &x) { // R1544 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1603 | Walk(std::get<Name>(x.t)), Put('('); |
| 1604 | Walk(std::get<std::list<Name>>(x.t), ", "), Put(") = "); |
| 1605 | Walk(std::get<Scalar<Expr>>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1606 | } |
| 1607 | |
peter klausler | 75b2933 | 2018-03-23 22:14:52 | [diff] [blame] | 1608 | // Directives, extensions, and deprecated constructs |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1609 | void Unparse(const CompilerDirective &x) { |
peter klausler | 75b2933 | 2018-03-23 22:14:52 | [diff] [blame] | 1610 | std::visit( |
| 1611 | visitors{[&](const std::list<CompilerDirective::IgnoreTKR> &tkr) { |
| 1612 | Word("!DIR$ IGNORE_TKR"); |
| 1613 | Walk(" ", tkr, ", "); |
| 1614 | }, |
| 1615 | [&](const CompilerDirective::IVDEP &) { Word("!DIR$ IVDEP\n"); }}, |
| 1616 | x.u); |
| 1617 | Put('\n'); |
peter klausler | 75b2933 | 2018-03-23 22:14:52 | [diff] [blame] | 1618 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1619 | void Unparse(const CompilerDirective::IgnoreTKR &x) { |
peter klausler | 75b2933 | 2018-03-23 22:14:52 | [diff] [blame] | 1620 | const auto &list = std::get<std::list<const char *>>(x.t); |
| 1621 | if (!list.empty()) { |
| 1622 | Put("("); |
| 1623 | for (const char *tkr : list) { |
| 1624 | Put(*tkr); |
| 1625 | } |
| 1626 | Put(") "); |
| 1627 | } |
| 1628 | Walk(std::get<Name>(x.t)); |
peter klausler | 75b2933 | 2018-03-23 22:14:52 | [diff] [blame] | 1629 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1630 | void Unparse(const BasedPointerStmt &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1631 | Word("POINTER ("), Walk(std::get<0>(x.t)), Put(", "); |
| 1632 | Walk(std::get<1>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1633 | Walk("(", std::get<std::optional<ArraySpec>>(x.t), ")"), Put(')'); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1634 | } |
peter klausler | 4e354d8 | 2018-03-30 22:23:37 | [diff] [blame] | 1635 | void Post(const StructureField &x) { |
| 1636 | if (const auto *def = std::get_if<Statement<DataComponentDefStmt>>(&x.u)) { |
| 1637 | for (const auto &decl : |
| 1638 | std::get<std::list<ComponentDecl>>(def->statement.t)) { |
| 1639 | structureComponents_.insert(std::get<Name>(decl.t).source); |
| 1640 | } |
| 1641 | } |
| 1642 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1643 | void Unparse(const StructureStmt &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1644 | Word("STRUCTURE "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1645 | if (std::get<bool>(x.t)) { // slashes around name |
| 1646 | Put('/'), Walk(std::get<Name>(x.t)), Put('/'); |
| 1647 | Walk(" ", std::get<std::list<EntityDecl>>(x.t), ", "); |
| 1648 | } else { |
| 1649 | CHECK(std::get<std::list<EntityDecl>>(x.t).empty()); |
| 1650 | Walk(std::get<Name>(x.t)); |
| 1651 | } |
| 1652 | Indent(); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1653 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1654 | void Post(const Union::UnionStmt &) { Word("UNION"), Indent(); } |
| 1655 | void Post(const Union::EndUnionStmt &) { Outdent(), Word("END UNION"); } |
| 1656 | void Post(const Map::MapStmt &) { Word("MAP"), Indent(); } |
| 1657 | void Post(const Map::EndMapStmt &) { Outdent(), Word("END MAP"); } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1658 | void Post(const StructureDef::EndStructureStmt &) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1659 | Outdent(), Word("END STRUCTURE"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1660 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1661 | void Unparse(const OldParameterStmt &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1662 | Word("PARAMETER "), Walk(x.v, ", "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1663 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1664 | void Unparse(const ArithmeticIfStmt &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1665 | Word("IF ("), Walk(std::get<Expr>(x.t)), Put(") "); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1666 | Walk(std::get<1>(x.t)), Put(", "); |
| 1667 | Walk(std::get<2>(x.t)), Put(", "); |
| 1668 | Walk(std::get<3>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1669 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1670 | void Unparse(const AssignStmt &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1671 | Word("ASSIGN "), Walk(std::get<Label>(x.t)); |
| 1672 | Word(" TO "), Walk(std::get<Name>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1673 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1674 | void Unparse(const AssignedGotoStmt &x) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1675 | Word("GO TO "), Walk(std::get<Name>(x.t)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1676 | Walk(", (", std::get<std::list<Label>>(x.t), ", ", ")"); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1677 | } |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1678 | void Unparse(const PauseStmt &x) { Word("PAUSE"), Walk(" ", x.v); } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1679 | |
Tim Keith | 9f75566 | 2018-03-23 21:31:14 | [diff] [blame] | 1680 | #define WALK_NESTED_ENUM(CLASS, ENUM) \ |
peter klausler | 8ea4a0a | 2018-04-06 20:13:20 | [diff] [blame] | 1681 | void Unparse(const CLASS::ENUM &x) { Word(CLASS::EnumToString(x)); } |
Tim Keith | 9f75566 | 2018-03-23 21:31:14 | [diff] [blame] | 1682 | WALK_NESTED_ENUM(AccessSpec, Kind) // R807 |
| 1683 | WALK_NESTED_ENUM(TypeParamDefStmt, KindOrLen) // R734 |
| 1684 | WALK_NESTED_ENUM(IntentSpec, Intent) // R826 |
| 1685 | WALK_NESTED_ENUM(ImplicitStmt, ImplicitNoneNameSpec) // R866 |
| 1686 | WALK_NESTED_ENUM(ConnectSpec::CharExpr, Kind) // R1205 |
| 1687 | WALK_NESTED_ENUM(IoControlSpec::CharExpr, Kind) |
| 1688 | WALK_NESTED_ENUM(InquireSpec::CharVar, Kind) |
| 1689 | WALK_NESTED_ENUM(InquireSpec::IntVar, Kind) |
| 1690 | WALK_NESTED_ENUM(InquireSpec::LogVar, Kind) |
| 1691 | WALK_NESTED_ENUM(ProcedureStmt, Kind) // R1506 |
| 1692 | WALK_NESTED_ENUM(UseStmt, ModuleNature) // R1410 |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1693 | #undef WALK_NESTED_ENUM |
| 1694 | |
| 1695 | void Done() const { CHECK(indent_ == 0); } |
| 1696 | |
| 1697 | private: |
| 1698 | void Put(char); |
| 1699 | void Put(const char *); |
| 1700 | void Put(const std::string &); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1701 | void PutKeywordLetter(char); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1702 | void PutQuoted(const std::string &); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1703 | void Word(const char *); |
Tim Keith | 9f75566 | 2018-03-23 21:31:14 | [diff] [blame] | 1704 | void Word(const std::string &); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1705 | void Indent() { indent_ += indentationAmount_; } |
| 1706 | void Outdent() { |
| 1707 | CHECK(indent_ >= indentationAmount_); |
| 1708 | indent_ -= indentationAmount_; |
| 1709 | } |
| 1710 | |
| 1711 | // Call back to the traversal framework. |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 1712 | template<typename T> void Walk(const T &x) { |
| 1713 | Fortran::parser::Walk(x, *this); |
| 1714 | } |
| 1715 | |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1716 | // Traverse a std::optional<> value. Emit a prefix and/or a suffix string |
| 1717 | // only when it contains a value. |
| 1718 | template<typename A> |
| 1719 | void Walk( |
| 1720 | const char *prefix, const std::optional<A> &x, const char *suffix = "") { |
| 1721 | if (x.has_value()) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1722 | Word(prefix), Walk(*x), Word(suffix); |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 1723 | } |
| 1724 | } |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1725 | template<typename A> |
| 1726 | void Walk(const std::optional<A> &x, const char *suffix = "") { |
| 1727 | return Walk("", x, suffix); |
| 1728 | } |
| 1729 | |
| 1730 | // Traverse a std::list<>. Separate the elements with an optional string. |
| 1731 | // Emit a prefix and/or a suffix string only when the list is not empty. |
| 1732 | template<typename A> |
| 1733 | void Walk(const char *prefix, const std::list<A> &list, |
| 1734 | const char *comma = ", ", const char *suffix = "") { |
| 1735 | if (!list.empty()) { |
| 1736 | const char *str{prefix}; |
| 1737 | for (const auto &x : list) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1738 | Word(str), Walk(x); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1739 | str = comma; |
| 1740 | } |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1741 | Word(suffix); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1742 | } |
| 1743 | } |
| 1744 | template<typename A> |
| 1745 | void Walk(const std::list<A> &list, const char *comma = ", ", |
| 1746 | const char *suffix = "") { |
| 1747 | return Walk("", list, comma, suffix); |
| 1748 | } |
| 1749 | |
| 1750 | // Traverse a std::tuple<>, with an optional separator. |
peter klausler | 424ec7b | 2018-03-20 17:59:07 | [diff] [blame] | 1751 | template<std::size_t J = 0, typename T> |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1752 | void WalkTupleElements(const T &tuple, const char *separator) { |
| 1753 | if constexpr (J < std::tuple_size_v<T>) { |
| 1754 | if (J > 0) { |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1755 | Word(separator); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1756 | } |
| 1757 | Walk(std::get<J>(tuple)); |
| 1758 | WalkTupleElements<J + 1>(tuple, separator); |
| 1759 | } |
| 1760 | } |
| 1761 | template<typename... A> |
| 1762 | void Walk(const std::tuple<A...> &tuple, const char *separator = "") { |
| 1763 | WalkTupleElements(tuple, separator); |
| 1764 | } |
| 1765 | |
peter klausler | 41d9cfd | 2018-04-03 17:29:04 | [diff] [blame] | 1766 | void EndSubprogram(const char *kind, const std::optional<Name> &name) { |
| 1767 | Outdent(), Word("END "), Word(kind), Walk(" ", name); |
| 1768 | structureComponents_.clear(); |
| 1769 | } |
peter klausler | 4e354d8 | 2018-03-30 22:23:37 | [diff] [blame] | 1770 | |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1771 | std::ostream &out_; |
| 1772 | int indent_{0}; |
| 1773 | const int indentationAmount_{1}; |
| 1774 | int column_{1}; |
| 1775 | const int maxColumns_{80}; |
peter klausler | 4e354d8 | 2018-03-30 22:23:37 | [diff] [blame] | 1776 | std::set<CharBlock> structureComponents_; |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1777 | Encoding encoding_{Encoding::UTF8}; |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1778 | bool capitalizeKeywords_{true}; |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 1779 | }; |
| 1780 | |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1781 | void UnparseVisitor::Put(char ch) { |
| 1782 | if (column_ <= 1) { |
| 1783 | if (ch == '\n') { |
| 1784 | return; |
| 1785 | } |
| 1786 | for (int j{0}; j < indent_; ++j) { |
| 1787 | out_ << ' '; |
| 1788 | } |
| 1789 | column_ = indent_ + 2; |
| 1790 | } else if (ch == '\n') { |
| 1791 | column_ = 1; |
| 1792 | } else if (++column_ >= maxColumns_) { |
| 1793 | out_ << "&\n"; |
| 1794 | for (int j{0}; j < indent_; ++j) { |
| 1795 | out_ << ' '; |
| 1796 | } |
| 1797 | out_ << '&'; |
| 1798 | column_ = indent_ + 3; |
| 1799 | } |
| 1800 | out_ << ch; |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 1801 | } |
| 1802 | |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1803 | void UnparseVisitor::Put(const char *str) { |
| 1804 | for (; *str != '\0'; ++str) { |
| 1805 | Put(*str); |
| 1806 | } |
| 1807 | } |
| 1808 | |
| 1809 | void UnparseVisitor::Put(const std::string &str) { |
| 1810 | for (char ch : str) { |
| 1811 | Put(ch); |
| 1812 | } |
| 1813 | } |
| 1814 | |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1815 | void UnparseVisitor::PutKeywordLetter(char ch) { |
| 1816 | if (capitalizeKeywords_) { |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1817 | Put(ToUpperCaseLetter(ch)); |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1818 | } else { |
| 1819 | Put(ToLowerCaseLetter(ch)); |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1820 | } |
| 1821 | } |
| 1822 | |
| 1823 | void UnparseVisitor::PutQuoted(const std::string &str) { |
| 1824 | Put('"'); |
| 1825 | const auto emit = [&](char ch) { Put(ch); }; |
| 1826 | for (char ch : str) { |
| 1827 | EmitQuotedChar(ch, emit, emit); |
| 1828 | } |
| 1829 | Put('"'); |
| 1830 | } |
| 1831 | |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1832 | void UnparseVisitor::Word(const char *str) { |
| 1833 | for (; *str != '\0'; ++str) { |
| 1834 | PutKeywordLetter(*str); |
| 1835 | } |
| 1836 | } |
| 1837 | |
peter klausler | 75b2933 | 2018-03-23 22:14:52 | [diff] [blame] | 1838 | void UnparseVisitor::Word(const std::string &str) { Word(str.c_str()); } |
Tim Keith | 9f75566 | 2018-03-23 21:31:14 | [diff] [blame] | 1839 | |
peter klausler | b7cf512 | 2018-03-14 22:31:16 | [diff] [blame] | 1840 | void Unparse(std::ostream &out, const Program &program, Encoding encoding, |
| 1841 | bool capitalizeKeywords) { |
| 1842 | UnparseVisitor visitor{out, 1, encoding, capitalizeKeywords}; |
peter klausler | 79d044e | 2018-03-01 00:56:10 | [diff] [blame] | 1843 | Walk(program, visitor); |
| 1844 | visitor.Done(); |
| 1845 | } |
Tim Keith | 2af29bc | 2018-02-26 22:28:32 | [diff] [blame] | 1846 | } // namespace parser |
| 1847 | } // namespace Fortran |