aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/TableGen/directive2.td')
-rw-r--r--llvm/test/TableGen/directive2.td281
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