[llvm-commits] [llvm] r117843 - /llvm/trunk/utils/TableGen/StringMatcher.cpp
Chris Lattner
sabre at nondot.org
Sat Oct 30 12:57:17 PDT 2010
Author: lattner
Date: Sat Oct 30 14:57:17 2010
New Revision: 117843
URL: http://llvm.org/viewvc/llvm-project?rev=117843&view=rev
Log:
fix a fixme in stringmatcher, having it generate nice looking code if the
'tomatch' code contains \n's.
Modified:
llvm/trunk/utils/TableGen/StringMatcher.cpp
Modified: llvm/trunk/utils/TableGen/StringMatcher.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/TableGen/StringMatcher.cpp?rev=117843&r1=117842&r2=117843&view=diff
==============================================================================
--- llvm/trunk/utils/TableGen/StringMatcher.cpp (original)
+++ llvm/trunk/utils/TableGen/StringMatcher.cpp Sat Oct 30 14:57:17 2010
@@ -51,9 +51,18 @@
if (CharNo == Matches[0]->first.size()) {
assert(Matches.size() == 1 && "Had duplicate keys to match on");
- // FIXME: If Matches[0].first has embeded \n, this will be bad.
- OS << Indent << Matches[0]->second << "\t // \"" << Matches[0]->first
- << "\"\n";
+ // If the to-execute code has \n's in it, indent each subsequent line.
+ StringRef Code = Matches[0]->second;
+
+ std::pair<StringRef, StringRef> Split = Code.split('\n');
+ OS << Indent << Split.first << "\t // \"" << Matches[0]->first << "\"\n";
+
+ Code = Split.second;
+ while (!Code.empty()) {
+ Split = Code.split('\n');
+ OS << Indent << Split.first << "\n";
+ Code = Split.second;
+ }
return false;
}
More information about the llvm-commits
mailing list