From: Chris Lattner Date: Wed, 6 Oct 2010 04:55:48 +0000 (+0000) Subject: Generalize tblgen's dag parsing logic to handle arbitrary expressions X-Git-Url: http://plrg.eecs.uci.edu/git/?p=oota-llvm.git;a=commitdiff_plain;h=46f55527d848bcc7cff1210137caff29bbf1b010 Generalize tblgen's dag parsing logic to handle arbitrary expressions as the operator of the dag. Specifically, this allows parsing things like (F.x 4) in addition to just (a 4). Unfortunately, this runs afoul of an idiom being used by llvmc. It is using dags like (foo [1,2,3]) to represent a list of stuff being passed into foo. With this change, this is parsed as a [1,2,3] subscript on foo instead of being the first argument to the dag. Cope with this in the short term by requiring a "-llvmc-temp-hack" argument to tblgen to get the old parsing behavior. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@115742 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Makefile.rules b/Makefile.rules index 261578f35f7..62718b73f7a 100644 --- a/Makefile.rules +++ b/Makefile.rules @@ -1779,7 +1779,7 @@ $(INCTMPFiles) : $(TBLGEN) $(TDFiles) $(ObjDir)/%.inc.tmp: %.td $(ObjDir)/.dir $(Echo) "Building LLVMC compilation graph description with tblgen" - $(Verb) $(TableGen) -gen-llvmc -o $(call SYSPATH, $@) $< + $(Verb) $(TableGen) -gen-llvmc -llvmc-temp-hack -o $(call SYSPATH, $@) $< clean-local:: -$(Verb) $(RM) -f $(INCFiles) diff --git a/test/LLVMC/MultipleOutputLanguages.td b/test/LLVMC/MultipleOutputLanguages.td index 02512c2db7c..16ce6be85c8 100644 --- a/test/LLVMC/MultipleOutputLanguages.td +++ b/test/LLVMC/MultipleOutputLanguages.td @@ -1,5 +1,5 @@ // Check that multiple output languages work. -// RUN: tblgen -I %p/../../include --gen-llvmc %s -o %t +// RUN: tblgen -I %p/../../include -llvmc-temp-hack --gen-llvmc %s -o %t // RUN: FileCheck -input-file %t %s // RUN: %compile_cxx %t // XFAIL: vg_leak diff --git a/test/LLVMC/OptionPreprocessor.td b/test/LLVMC/OptionPreprocessor.td index 8019c42634f..44670cee932 100644 --- a/test/LLVMC/OptionPreprocessor.td +++ b/test/LLVMC/OptionPreprocessor.td @@ -1,5 +1,5 @@ // Test for the OptionPreprocessor and related functionality. -// RUN: tblgen -I %p/../../include --gen-llvmc %s -o %t +// RUN: tblgen -I %p/../../include -llvmc-temp-hack --gen-llvmc %s -o %t // RUN: FileCheck -input-file %t %s // RUN: %compile_cxx %t // XFAIL: vg_leak diff --git a/test/TableGen/Dag.td b/test/TableGen/Dag.td index 8b406a59d34..d3481a550c3 100644 --- a/test/TableGen/Dag.td +++ b/test/TableGen/Dag.td @@ -33,3 +33,39 @@ def VAL2 : C2; // CHECK-NEXT: dag d = (X2 Y2) // CHECK-NEXT: dag e = (Y2 X2) + +//===----------------------------------------------------------------------===// +// Complex dag operator (F.TheOp). + +class operator; +def somedef1 : operator; +def somedef2 : operator; + +class foo { + operator TheOp = a; +} + +class bar { + dag Dag1 = (somedef1 1); + dag Dag2 = (a 2); + dag Dag3 = (F.TheOp 2); +} + +def foo1 : foo; +def foo2 : foo; + +def VAL3 : bar; + +// CHECK: def VAL3 { // bar +// CHECK-NEXT: dag Dag1 = (somedef1 1); +// CHECK-NEXT: dag Dag2 = (somedef1 2); +// CHECK-NEXT: dag Dag3 = (somedef1 2); +// CHECK-NEXT: } + + +def VAL4 : bar; +// CHECK: def VAL4 { +// CHECK-NEXT: dag Dag1 = (somedef1 1); +// CHECK-NEXT: dag Dag2 = (somedef2 2); +// CHECK-NEXT: dag Dag3 = (somedef2 2); +// CHECK-NEXT: } diff --git a/utils/TableGen/TGParser.cpp b/utils/TableGen/TGParser.cpp index b0389ddb729..188ba4d2b1b 100644 --- a/utils/TableGen/TGParser.cpp +++ b/utils/TableGen/TGParser.cpp @@ -17,8 +17,14 @@ #include #include #include "llvm/ADT/SmallVector.h" +#include "llvm/Support/CommandLine.h" using namespace llvm; +/// LLVMCHack - This is a temporary hack that changes how "(foo [1, 2, 3])" +/// parses. +/// FIXME: REMOVE THIS. +static cl::opt LLVMCHack("llvmc-temp-hack", cl::ReallyHidden); + //===----------------------------------------------------------------------===// // Support Code for the Semantic Actions. //===----------------------------------------------------------------------===// @@ -1213,11 +1219,18 @@ Init *TGParser::ParseSimpleValue(Record *CurRec, RecTy *ItemType) { return 0; } - Init *Operator = 0; - if (Lex.getCode() == tgtok::Id) - Operator = ParseIDValue(CurRec); - else - Operator = ParseOperation(CurRec); + Init *Operator; + /// LLVMC Requires an old grammar and I don't know how to update it, placate + /// it in the short term by changing the grammar specifically for llvmc. + /// FIXME: REMOVE THIS. + if (!LLVMCHack) + Operator = ParseValue(CurRec); + else { + if (Lex.getCode() == tgtok::Id) + Operator = ParseIDValue(CurRec); + else + Operator = ParseOperation(CurRec); + } if (Operator == 0) return 0; // If the operator name is present, parse it.