diff options
| author | Alexis Hunt <alercah@gmail.com> | 2011-05-03 20:43:02 +0000 |
|---|---|---|
| committer | Alexis Hunt <alercah@gmail.com> | 2011-05-03 20:43:02 +0000 |
| commit | 5583d56ddbe6e9f6e6e0303781eebd8840a86ac2 (patch) | |
| tree | febc41c4a3cee3afa2991cc50ac166d5558df5bd /clang/lib | |
| parent | eaa6ed1ad81fab3552ed43fef73cf76cb90d5d94 (diff) | |
| download | bcm5719-llvm-5583d56ddbe6e9f6e6e0303781eebd8840a86ac2.tar.gz bcm5719-llvm-5583d56ddbe6e9f6e6e0303781eebd8840a86ac2.zip | |
Move the AST modifications to after the cycle detection in
lib/Sema/SemaDeclCXX.cpp to avoid getting stuck in an infinite loop. See
the comment for more explanation.
llvm-svn: 130788
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 27632a1a57c..94177b1d127 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -2072,12 +2072,6 @@ static bool CollectFieldInitializer(BaseAndFieldInfo &Info, bool Sema::SetDelegatingInitializer(CXXConstructorDecl *Constructor, CXXCtorInitializer *Initializer) { - Constructor->setNumCtorInitializers(1); - CXXCtorInitializer **initializer = - new (Context) CXXCtorInitializer*[1]; - memcpy(initializer, &Initializer, sizeof (CXXCtorInitializer*)); - Constructor->setCtorInitializers(initializer); - // FIXME: This doesn't catch indirect loops yet CXXConstructorDecl *Target = Initializer->getTargetConstructor(); while (Target) { @@ -2089,6 +2083,18 @@ Sema::SetDelegatingInitializer(CXXConstructorDecl *Constructor, Target = Target->getTargetConstructor(); } + // We do the cycle detection first so that we know that we're not + // going to create a cycle by inserting this link. This ensures that + // the AST is cycle-free and we don't get a scenario where we have + // a B -> C -> B cycle and then add an A -> B link and get stuck in + // an infinite loop as we check for cycles with A and never get there + // because we get stuck in a cycle not including A. + Constructor->setNumCtorInitializers(1); + CXXCtorInitializer **initializer = + new (Context) CXXCtorInitializer*[1]; + memcpy(initializer, &Initializer, sizeof (CXXCtorInitializer*)); + Constructor->setCtorInitializers(initializer); + return false; } |

