diff options
Diffstat (limited to 'llvm/test/TableGen/directive2.td')
-rw-r--r-- | llvm/test/TableGen/directive2.td | 281 |
1 files changed, 137 insertions, 144 deletions
diff --git a/llvm/test/TableGen/directive2.td b/llvm/test/TableGen/directive2.td index 1e02cbd01dad..154d1e86ffb1 100644 --- a/llvm/test/TableGen/directive2.td +++ b/llvm/test/TableGen/directive2.td @@ -1,6 +1,5 @@ // RUN: llvm-tblgen -gen-directive-decl -I %p/../../include %s | FileCheck -match-full-lines %s // RUN: llvm-tblgen -gen-directive-impl -I %p/../../include %s | FileCheck -match-full-lines %s -check-prefix=IMPL -// RUN: llvm-tblgen -gen-directive-gen -I %p/../../include %s | FileCheck -match-full-lines %s -check-prefix=GEN include "llvm/Frontend/Directive/DirectiveBase.td" @@ -79,14 +78,143 @@ def TDL_DirA : Directive<"dira"> { // CHECK-NEXT: } // namespace llvm // CHECK-NEXT: #endif // LLVM_Tdl_INC -// IMPL: #include "tdl.h.inc" +// IMPL: #ifdef GEN_FLANG_DIRECTIVE_CLAUSE_SETS +// IMPL-NEXT: #undef GEN_FLANG_DIRECTIVE_CLAUSE_SETS // IMPL-EMPTY: -// IMPL-NEXT: #include "llvm/ADT/StringRef.h" -// IMPL-NEXT: #include "llvm/ADT/StringSwitch.h" -// IMPL-NEXT: #include "llvm/Support/ErrorHandling.h" +// IMPL-NEXT: namespace llvm { +// IMPL-NEXT: namespace tdl { // IMPL-EMPTY: -// IMPL-NEXT: using namespace llvm; -// IMPL-NEXT: using namespace tdl; +// IMPL-NEXT: // Sets for dira +// IMPL-EMPTY: +// IMPL-NEXT: static allowedClauses_TDLD_dira { +// IMPL-NEXT: llvm::tdl::Clause::TDLC_clausea, +// IMPL-NEXT: llvm::tdl::Clause::TDLC_clauseb, +// IMPL-NEXT: }; +// IMPL-EMPTY: +// IMPL-NEXT: static allowedOnceClauses_TDLD_dira { +// IMPL-NEXT: }; +// IMPL-EMPTY: +// IMPL-NEXT: static allowedExclusiveClauses_TDLD_dira { +// IMPL-NEXT: }; +// IMPL-EMPTY: +// IMPL-NEXT: static requiredClauses_TDLD_dira { +// IMPL-NEXT: }; +// IMPL-NEXT: } // namespace tdl +// IMPL-NEXT: } // namespace llvm +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_FLANG_DIRECTIVE_CLAUSE_SETS +// IMPL-EMPTY: +// IMPL-NEXT: #ifdef GEN_FLANG_DIRECTIVE_CLAUSE_MAP +// IMPL-NEXT: #undef GEN_FLANG_DIRECTIVE_CLAUSE_MAP +// IMPL-EMPTY: +// IMPL-NEXT: { +// IMPL-NEXT: {llvm::tdl::Directive::TDLD_dira, +// IMPL-NEXT: { +// IMPL-NEXT: llvm::tdl::allowedClauses_TDLD_dira, +// IMPL-NEXT: llvm::tdl::allowedOnceClauses_TDLD_dira, +// IMPL-NEXT: llvm::tdl::allowedExclusiveClauses_TDLD_dira, +// IMPL-NEXT: llvm::tdl::requiredClauses_TDLD_dira, +// IMPL-NEXT: } +// IMPL-NEXT: }, +// IMPL-NEXT: } +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_FLANG_DIRECTIVE_CLAUSE_MAP +// IMPL-EMPTY: +// IMPL-NEXT: #ifdef GEN_FLANG_CLAUSE_PARSER_CLASSES +// IMPL-NEXT: #undef GEN_FLANG_CLAUSE_PARSER_CLASSES +// IMPL-EMPTY: +// IMPL-NEXT: EMPTY_CLASS(Clausea); +// IMPL-NEXT: WRAPPER_CLASS(Clauseb, std::list<IntExpr>); +// IMPL-NEXT: WRAPPER_CLASS(Clausec, std::optional<Name>); +// IMPL-NEXT: EMPTY_CLASS(Claused); +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_FLANG_CLAUSE_PARSER_CLASSES +// IMPL-EMPTY: +// IMPL-NEXT: #ifdef GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST +// IMPL-NEXT: #undef GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST +// IMPL-EMPTY: +// IMPL-NEXT: Clausea +// IMPL-NEXT: , Clauseb +// IMPL-NEXT: , Clausec +// IMPL-NEXT: , Claused +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST +// IMPL-EMPTY: +// IMPL-NEXT: #ifdef GEN_FLANG_DUMP_PARSE_TREE_CLAUSES +// IMPL-NEXT: #undef GEN_FLANG_DUMP_PARSE_TREE_CLAUSES +// IMPL-EMPTY: +// IMPL-NEXT: NODE(TdlClause, Clausea) +// IMPL-NEXT: NODE(TdlClause, Clauseb) +// IMPL-NEXT: NODE(TdlClause, Clausec) +// IMPL-NEXT: NODE(TdlClause, Claused) +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_FLANG_DUMP_PARSE_TREE_CLAUSES +// IMPL-EMPTY: +// IMPL-NEXT: #ifdef GEN_FLANG_CLAUSE_UNPARSE +// IMPL-NEXT: #undef GEN_FLANG_CLAUSE_UNPARSE +// IMPL-EMPTY: +// IMPL-NEXT: void Before(const TdlClause::Clausea &) { Word("CLAUSEA"); } +// IMPL-NEXT: void Unparse(const TdlClause::Clauseb &x) { +// IMPL-NEXT: Word("CLAUSEB"); +// IMPL-NEXT: Put("("); +// IMPL-NEXT: Walk(x.v, ","); +// IMPL-NEXT: Put(")"); +// IMPL-NEXT: } +// IMPL-NEXT: void Unparse(const TdlClause::Clausec &x) { +// IMPL-NEXT: Word("CLAUSEC"); +// IMPL-NEXT: Put("("); +// IMPL-NEXT: if (x.v.has_value()) +// IMPL-NEXT: Walk(x.v); +// IMPL-NEXT: else +// IMPL-NEXT: Put("*"); +// IMPL-NEXT: Put(")"); +// IMPL-NEXT: } +// IMPL-NEXT: void Before(const TdlClause::Claused &) { Word("CLAUSED"); } +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_FLANG_CLAUSE_UNPARSE + +// IMPL: #ifdef GEN_CLANG_CLAUSE_CLASS +// IMPL-NEXT: #undef GEN_CLANG_CLAUSE_CLASS +// IMPL-EMPTY: +// IMPL-NEXT: #ifndef CLAUSE +// IMPL-NEXT: #define CLAUSE(Enum, Str, Implicit) +// IMPL-NEXT: #endif +// IMPL-NEXT: #ifndef CLAUSE_CLASS +// IMPL-NEXT: #define CLAUSE_CLASS(Enum, Str, Class) +// IMPL-NEXT: #endif +// IMPL-NEXT: #ifndef CLAUSE_NO_CLASS +// IMPL-NEXT: #define CLAUSE_NO_CLASS(Enum, Str) +// IMPL-NEXT: #endif +// IMPL-EMPTY: +// IMPL-NEXT: #define __CLAUSE(Name, Class) \ +// IMPL-NEXT: CLAUSE(TDLC_##Name, #Name, /* Implicit */ false) \ +// IMPL-NEXT: CLAUSE_CLASS(TDLC_##Name, #Name, Class) +// IMPL-NEXT: #define __CLAUSE_NO_CLASS(Name) \ +// IMPL-NEXT: CLAUSE(TDLC_##Name, #Name, /* Implicit */ false) \ +// IMPL-NEXT: CLAUSE_NO_CLASS(TDLC_##Name, #Name) +// IMPL-NEXT: #define __IMPLICIT_CLAUSE_CLASS(Name, Str, Class) \ +// IMPL-NEXT: CLAUSE(TDLC_##Name, Str, /* Implicit */ true) \ +// IMPL-NEXT: CLAUSE_CLASS(TDLC_##Name, Str, Class) +// IMPL-NEXT: #define __IMPLICIT_CLAUSE_NO_CLASS(Name, Str) \ +// IMPL-NEXT: CLAUSE(TDLC_##Name, Str, /* Implicit */ true) \ +// IMPL-NEXT: CLAUSE_NO_CLASS(TDLC_##Name, Str) +// IMPL-EMPTY: +// IMPL-NEXT: __IMPLICIT_CLAUSE_NO_CLASS(clausea, "clausea") +// IMPL-NEXT: __CLAUSE_NO_CLASS(clauseb) +// IMPL-NEXT: __CLAUSE(clausec, ClauseC) +// IMPL-NEXT: __IMPLICIT_CLAUSE_CLASS(claused, "claused", ClauseD) +// IMPL-EMPTY: +// IMPL-NEXT: #undef __IMPLICIT_CLAUSE_NO_CLASS +// IMPL-NEXT: #undef __IMPLICIT_CLAUSE_CLASS +// IMPL-NEXT: #undef __CLAUSE +// IMPL-NEXT: #undef CLAUSE_NO_CLASS +// IMPL-NEXT: #undef CLAUSE_CLASS +// IMPL-NEXT: #undef CLAUSE +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_CLANG_CLAUSE_CLASS + +// IMPL: #ifdef GEN_DIRECTIVES_IMPL +// IMPL-NEXT: #undef GEN_DIRECTIVES_IMPL // IMPL-EMPTY: // IMPL-NEXT: Directive llvm::tdl::getTdlDirectiveKind(llvm::StringRef Str) { // IMPL-NEXT: return llvm::StringSwitch<Directive>(Str) @@ -142,140 +270,5 @@ def TDL_DirA : Directive<"dira"> { // IMPL-NEXT: } // IMPL-NEXT: llvm_unreachable("Invalid Tdl Directive kind"); // IMPL-NEXT: } - - -// GEN: #ifdef GEN_FLANG_DIRECTIVE_CLAUSE_SETS -// GEN-NEXT: #undef GEN_FLANG_DIRECTIVE_CLAUSE_SETS -// GEN-EMPTY: -// GEN-NEXT: namespace llvm { -// GEN-NEXT: namespace tdl { -// GEN-EMPTY: -// GEN-NEXT: // Sets for dira -// GEN-EMPTY: -// GEN-NEXT: static allowedClauses_TDLD_dira { -// GEN-NEXT: llvm::tdl::Clause::TDLC_clausea, -// GEN-NEXT: llvm::tdl::Clause::TDLC_clauseb, -// GEN-NEXT: }; -// GEN-EMPTY: -// GEN-NEXT: static allowedOnceClauses_TDLD_dira { -// GEN-NEXT: }; -// GEN-EMPTY: -// GEN-NEXT: static allowedExclusiveClauses_TDLD_dira { -// GEN-NEXT: }; -// GEN-EMPTY: -// GEN-NEXT: static requiredClauses_TDLD_dira { -// GEN-NEXT: }; -// GEN-NEXT: } // namespace tdl -// GEN-NEXT: } // namespace llvm -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_FLANG_DIRECTIVE_CLAUSE_SETS -// GEN-EMPTY: -// GEN-NEXT: #ifdef GEN_FLANG_DIRECTIVE_CLAUSE_MAP -// GEN-NEXT: #undef GEN_FLANG_DIRECTIVE_CLAUSE_MAP -// GEN-EMPTY: -// GEN-NEXT: { -// GEN-NEXT: {llvm::tdl::Directive::TDLD_dira, -// GEN-NEXT: { -// GEN-NEXT: llvm::tdl::allowedClauses_TDLD_dira, -// GEN-NEXT: llvm::tdl::allowedOnceClauses_TDLD_dira, -// GEN-NEXT: llvm::tdl::allowedExclusiveClauses_TDLD_dira, -// GEN-NEXT: llvm::tdl::requiredClauses_TDLD_dira, -// GEN-NEXT: } -// GEN-NEXT: }, -// GEN-NEXT: } -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_FLANG_DIRECTIVE_CLAUSE_MAP -// GEN-EMPTY: -// GEN-NEXT: #ifdef GEN_FLANG_CLAUSE_PARSER_CLASSES -// GEN-NEXT: #undef GEN_FLANG_CLAUSE_PARSER_CLASSES -// GEN-EMPTY: -// GEN-NEXT: EMPTY_CLASS(Clausea); -// GEN-NEXT: WRAPPER_CLASS(Clauseb, std::list<IntExpr>); -// GEN-NEXT: WRAPPER_CLASS(Clausec, std::optional<Name>); -// GEN-NEXT: EMPTY_CLASS(Claused); -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_FLANG_CLAUSE_PARSER_CLASSES -// GEN-EMPTY: -// GEN-NEXT: #ifdef GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST -// GEN-NEXT: #undef GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST -// GEN-EMPTY: -// GEN-NEXT: Clausea -// GEN-NEXT: , Clauseb -// GEN-NEXT: , Clausec -// GEN-NEXT: , Claused -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST -// GEN-EMPTY: -// GEN-NEXT: #ifdef GEN_FLANG_DUMP_PARSE_TREE_CLAUSES -// GEN-NEXT: #undef GEN_FLANG_DUMP_PARSE_TREE_CLAUSES -// GEN-EMPTY: -// GEN-NEXT: NODE(TdlClause, Clausea) -// GEN-NEXT: NODE(TdlClause, Clauseb) -// GEN-NEXT: NODE(TdlClause, Clausec) -// GEN-NEXT: NODE(TdlClause, Claused) -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_FLANG_DUMP_PARSE_TREE_CLAUSES -// GEN-EMPTY: -// GEN-NEXT: #ifdef GEN_FLANG_CLAUSE_UNPARSE -// GEN-NEXT: #undef GEN_FLANG_CLAUSE_UNPARSE -// GEN-EMPTY: -// GEN-NEXT: void Before(const TdlClause::Clausea &) { Word("CLAUSEA"); } -// GEN-NEXT: void Unparse(const TdlClause::Clauseb &x) { -// GEN-NEXT: Word("CLAUSEB"); -// GEN-NEXT: Put("("); -// GEN-NEXT: Walk(x.v, ","); -// GEN-NEXT: Put(")"); -// GEN-NEXT: } -// GEN-NEXT: void Unparse(const TdlClause::Clausec &x) { -// GEN-NEXT: Word("CLAUSEC"); -// GEN-NEXT: Put("("); -// GEN-NEXT: if (x.v.has_value()) -// GEN-NEXT: Walk(x.v); -// GEN-NEXT: else -// GEN-NEXT: Put("*"); -// GEN-NEXT: Put(")"); -// GEN-NEXT: } -// GEN-NEXT: void Before(const TdlClause::Claused &) { Word("CLAUSED"); } -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_FLANG_CLAUSE_UNPARSE - -// GEN: #ifdef GEN_CLANG_CLAUSE_CLASS -// GEN-NEXT: #undef GEN_CLANG_CLAUSE_CLASS -// GEN-EMPTY: -// GEN-NEXT: #ifndef CLAUSE -// GEN-NEXT: #define CLAUSE(Enum, Str, Implicit) -// GEN-NEXT: #endif -// GEN-NEXT: #ifndef CLAUSE_CLASS -// GEN-NEXT: #define CLAUSE_CLASS(Enum, Str, Class) -// GEN-NEXT: #endif -// GEN-NEXT: #ifndef CLAUSE_NO_CLASS -// GEN-NEXT: #define CLAUSE_NO_CLASS(Enum, Str) -// GEN-NEXT: #endif -// GEN-EMPTY: -// GEN-NEXT: #define __CLAUSE(Name, Class) \ -// GEN-NEXT: CLAUSE(TDLC_##Name, #Name, /* Implicit */ false) \ -// GEN-NEXT: CLAUSE_CLASS(TDLC_##Name, #Name, Class) -// GEN-NEXT: #define __CLAUSE_NO_CLASS(Name) \ -// GEN-NEXT: CLAUSE(TDLC_##Name, #Name, /* Implicit */ false) \ -// GEN-NEXT: CLAUSE_NO_CLASS(TDLC_##Name, #Name) -// GEN-NEXT: #define __IMPLICIT_CLAUSE_CLASS(Name, Str, Class) \ -// GEN-NEXT: CLAUSE(TDLC_##Name, Str, /* Implicit */ true) \ -// GEN-NEXT: CLAUSE_CLASS(TDLC_##Name, Str, Class) -// GEN-NEXT: #define __IMPLICIT_CLAUSE_NO_CLASS(Name, Str) \ -// GEN-NEXT: CLAUSE(TDLC_##Name, Str, /* Implicit */ true) \ -// GEN-NEXT: CLAUSE_NO_CLASS(TDLC_##Name, Str) -// GEN-EMPTY: -// GEN-NEXT: __IMPLICIT_CLAUSE_NO_CLASS(clausea, "clausea") -// GEN-NEXT: __CLAUSE_NO_CLASS(clauseb) -// GEN-NEXT: __CLAUSE(clausec, ClauseC) -// GEN-NEXT: __IMPLICIT_CLAUSE_CLASS(claused, "claused", ClauseD) -// GEN-EMPTY: -// GEN-NEXT: #undef __IMPLICIT_CLAUSE_NO_CLASS -// GEN-NEXT: #undef __IMPLICIT_CLAUSE_CLASS -// GEN-NEXT: #undef __CLAUSE -// GEN-NEXT: #undef CLAUSE_NO_CLASS -// GEN-NEXT: #undef CLAUSE_CLASS -// GEN-NEXT: #undef CLAUSE -// GEN-EMPTY: -// GEN-NEXT: #endif // GEN_CLANG_CLAUSE_CLASS - +// IMPL-EMPTY: +// IMPL-NEXT: #endif // GEN_DIRECTIVES_IMPL |