diff --git a/llvm/utils/TableGen/CodeGenMapTable.cpp b/llvm/utils/TableGen/CodeGenMapTable.cpp --- a/llvm/utils/TableGen/CodeGenMapTable.cpp +++ b/llvm/utils/TableGen/CodeGenMapTable.cpp @@ -443,14 +443,16 @@ if (ValueCols.size() > 1) { for (unsigned i = 0, e = ValueCols.size(); i < e; i++) { ListInit *ColumnI = ValueCols[i]; + OS << " if ("; for (unsigned j = 0, ColSize = ColumnI->size(); j < ColSize; ++j) { std::string ColName = ColFields->getElement(j)->getAsUnquotedString(); - OS << " if (in" << ColName; + OS << "in" << ColName; OS << " == "; OS << ColName << "_" << ColumnI->getElement(j)->getAsUnquotedString(); - if (j < ColumnI->size() - 1) OS << " && "; - else OS << ")\n"; + if (j < ColumnI->size() - 1) + OS << " && "; } + OS << ")\n"; OS << " return " << InstrMapDesc.getName(); OS << "Table[mid]["< 1) { for (Init *CF : ColFields->getValues()) { std::string ColName = CF->getAsUnquotedString(); - OS << ", enum " << ColName << " in" << ColName << ") {\n"; + OS << ", enum " << ColName << " in" << ColName; } - } else { OS << ") {\n"; } + } + OS << ") {\n"; // Emit map table. unsigned TableSize = emitBinSearchTable(OS);