implement test/Regression/TableGen/DagIntSubst.ll


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25836 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/utils/TableGen/FileParser.y b/utils/TableGen/FileParser.y
index 162f621..28bb7b3 100644
--- a/utils/TableGen/FileParser.y
+++ b/utils/TableGen/FileParser.y
@@ -68,7 +68,7 @@
 }
 
 static void setValue(const std::string &ValName, 
-		     std::vector<unsigned> *BitList, Init *V) {
+                     std::vector<unsigned> *BitList, Init *V) {
   if (!V) return;
 
   RecordVal *RV = CurRec->getValue(ValName);
diff --git a/utils/TableGen/Record.cpp b/utils/TableGen/Record.cpp
index 2a70c27..5101481 100644
--- a/utils/TableGen/Record.cpp
+++ b/utils/TableGen/Record.cpp
@@ -554,6 +554,17 @@
   return this;
 }
 
+Init *DagInit::resolveReferences(Record &R, const RecordVal *RV) {
+  std::vector<Init*> NewArgs;
+  for (unsigned i = 0, e = Args.size(); i != e; ++i)
+    NewArgs.push_back(Args[i]->resolveReferences(R, RV));
+  
+  if (Args != NewArgs)
+    return new DagInit(NodeTypeDef, NewArgs, ArgNames);
+    
+  return this;
+}
+
 
 void DagInit::print(std::ostream &OS) const {
   OS << "(" << NodeTypeDef->getName();
diff --git a/utils/TableGen/Record.h b/utils/TableGen/Record.h
index 9f30004..a4175e5 100644
--- a/utils/TableGen/Record.h
+++ b/utils/TableGen/Record.h
@@ -826,7 +826,11 @@
       ArgNames.push_back(args[i].second);
     }
   }
-
+  DagInit(Record *D, const std::vector<Init*> &args, 
+          const std::vector<std::string> &argNames)
+  : NodeTypeDef(D), Args(args), ArgNames(argNames) {
+  }
+  
   virtual Init *convertInitializerTo(RecTy *Ty) {
     return Ty->convertValue(this);
   }
@@ -847,6 +851,8 @@
     assert(Num < Args.size() && "Arg number out of range!");
     Args[Num] = I;
   }
+  
+  virtual Init *resolveReferences(Record &R, const RecordVal *RV);
 
   virtual void print(std::ostream &OS) const;
 };