mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
Fix a bug in !subst where TableGen would go and resubstitute text it had
just substituted. This could cause infinite looping in certain pathological cases. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@91843 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7b1eb8a409
commit
f660802f34
15
test/TableGen/subst2.td
Normal file
15
test/TableGen/subst2.td
Normal file
@ -0,0 +1,15 @@
|
||||
// RUN: tblgen %s | FileCheck %s
|
||||
// CHECK: No subst
|
||||
// CHECK: No foo
|
||||
// CHECK: RECURSE foo
|
||||
|
||||
class Recurse<string t> {
|
||||
string Text = t;
|
||||
}
|
||||
|
||||
class Text<string text> :
|
||||
Recurse<!subst("RECURSE", "RECURSE", !subst("NORECURSE", "foo", text))>;
|
||||
|
||||
def Ok1 : Text<"No subst">;
|
||||
def Ok2 : Text<"No NORECURSE">;
|
||||
def Trouble : Text<"RECURSE NORECURSE">;
|
@ -945,11 +945,13 @@ Init *TernOpInit::Fold(Record *CurRec, MultiClass *CurMultiClass) {
|
||||
std::string Val = RHSs->getValue();
|
||||
|
||||
std::string::size_type found;
|
||||
std::string::size_type idx = 0;
|
||||
do {
|
||||
found = Val.find(LHSs->getValue());
|
||||
found = Val.find(LHSs->getValue(), idx);
|
||||
if (found != std::string::npos) {
|
||||
Val.replace(found, LHSs->getValue().size(), MHSs->getValue());
|
||||
}
|
||||
idx = found + MHSs->getValue().size();
|
||||
} while (found != std::string::npos);
|
||||
|
||||
return new StringInit(Val);
|
||||
|
Loading…
Reference in New Issue
Block a user