summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--llvm/docs/TableGen/LangIntro.rst6
-rw-r--r--llvm/lib/TableGen/TGParser.cpp20
-rw-r--r--llvm/test/TableGen/dag-functional.td4
3 files changed, 14 insertions, 16 deletions
diff --git a/llvm/docs/TableGen/LangIntro.rst b/llvm/docs/TableGen/LangIntro.rst
index a4b198b8958..1f9b44586d9 100644
--- a/llvm/docs/TableGen/LangIntro.rst
+++ b/llvm/docs/TableGen/LangIntro.rst
@@ -178,10 +178,10 @@ supported include:
Due to limitations of the type system, 'children' must be a list of items
of a common type. In practice, this means that they should either have the
same type or be records with a common superclass. Mixing dag and non-dag
- items is not possible.
+ items is not possible. However, '?' can be used.
- Example: !dag(op, [a1, a2], ["name1", "name2"]) results in
- (op a1:$name1, a2:$name2).
+ Example: !dag(op, [a1, a2, ?], ["name1", "name2", "name3"]) results in
+ (op a1:$name1, a2:$name2, ?:$name3).
``!listconcat(a, b, ...)``
A list value that is the result of concatenating the 'a' and 'b' lists.
diff --git a/llvm/lib/TableGen/TGParser.cpp b/llvm/lib/TableGen/TGParser.cpp
index 629320975a6..0dd4da416d9 100644
--- a/llvm/lib/TableGen/TGParser.cpp
+++ b/llvm/lib/TableGen/TGParser.cpp
@@ -1676,18 +1676,16 @@ Init *TGParser::ParseSimpleValue(Record *CurRec, RecTy *ItemType,
RecTy *EltTy = nullptr;
for (Init *V : Vals) {
TypedInit *TArg = dyn_cast<TypedInit>(V);
- if (!TArg) {
- TokError("Untyped list element");
- return nullptr;
- }
- if (EltTy) {
- EltTy = resolveTypes(EltTy, TArg->getType());
- if (!EltTy) {
- TokError("Incompatible types in list elements");
- return nullptr;
+ if (TArg) {
+ if (EltTy) {
+ EltTy = resolveTypes(EltTy, TArg->getType());
+ if (!EltTy) {
+ TokError("Incompatible types in list elements");
+ return nullptr;
+ }
+ } else {
+ EltTy = TArg->getType();
}
- } else {
- EltTy = TArg->getType();
}
}
diff --git a/llvm/test/TableGen/dag-functional.td b/llvm/test/TableGen/dag-functional.td
index 8a5fa8b4b02..b9be2bf6b09 100644
--- a/llvm/test/TableGen/dag-functional.td
+++ b/llvm/test/TableGen/dag-functional.td
@@ -8,7 +8,7 @@
// CHECK: }
// CHECK: def A1 {
-// CHECK: dag ret = (ops 1:$a, 2:$b);
+// CHECK: dag ret = (ops ?:$a, 1:$b, 2);
// CHECK: }
// CHECK: def A2 {
@@ -70,7 +70,7 @@ class B<list<Node> nodes> {
}
def A0 : Aint<[], []>;
-def A1 : Aint<[1, 2], ["a", "b"]>;
+def A1 : Aint<[?, 1, 2], ["a", "b", ?]>;
def A2 : Adag<[(ops $name), (ops 1), (ops "foo")], ["a", "b", "c"]>;
OpenPOWER on IntegriCloud