diff --git a/utils/TableGen/Record.cpp b/utils/TableGen/Record.cpp index aabe0254ecf..8c47888dbed 100644 --- a/utils/TableGen/Record.cpp +++ b/utils/TableGen/Record.cpp @@ -1619,12 +1619,24 @@ std::string DagInit::getAsString() const { // Other implementations //===----------------------------------------------------------------------===// -RecordVal::RecordVal(const std::string &N, RecTy *T, unsigned P) +RecordVal::RecordVal(Init *N, RecTy *T, unsigned P) : Name(N), Ty(T), Prefix(P) { Value = Ty->convertValue(UnsetInit::get()); assert(Value && "Cannot create unset value for current type!"); } +RecordVal::RecordVal(const std::string &N, RecTy *T, unsigned P) + : Name(StringInit::get(N)), Ty(T), Prefix(P) { + Value = Ty->convertValue(UnsetInit::get()); + assert(Value && "Cannot create unset value for current type!"); +} + +const std::string &RecordVal::getName() const { + StringInit *NameString = dynamic_cast(Name); + assert(NameString && "RecordVal name is not a string!"); + return NameString->getValue(); +} + void RecordVal::dump() const { errs() << *this; } void RecordVal::print(raw_ostream &OS, bool PrintSem) const { diff --git a/utils/TableGen/Record.h b/utils/TableGen/Record.h index 8e975306378..84313e66d58 100644 --- a/utils/TableGen/Record.h +++ b/utils/TableGen/Record.h @@ -1337,14 +1337,15 @@ public: //===----------------------------------------------------------------------===// class RecordVal { - std::string Name; + Init *Name; RecTy *Ty; unsigned Prefix; Init *Value; public: + RecordVal(Init *N, RecTy *T, unsigned P); RecordVal(const std::string &N, RecTy *T, unsigned P); - const std::string &getName() const { return Name; } + const std::string &getName() const; unsigned getPrefix() const { return Prefix; } RecTy *getType() const { return Ty; }