summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaInit.cpp
diff options
context:
space:
mode:
authorRichard Trieu <rtrieu@google.com>2011-09-01 21:44:13 +0000
committerRichard Trieu <rtrieu@google.com>2011-09-01 21:44:13 +0000
commita04ad1a1b9030ade5dd908e0684a862c5ccc93d0 (patch)
tree82785e8dc7cdd28412dd6eb971d85f93a5a3c9b6 /clang/lib/Sema/SemaInit.cpp
parenta3ba6d3b809c59b01e30486a2d8a6628597a31a9 (diff)
downloadbcm5719-llvm-a04ad1a1b9030ade5dd908e0684a862c5ccc93d0.tar.gz
bcm5719-llvm-a04ad1a1b9030ade5dd908e0684a862c5ccc93d0.zip
Extend the self-reference warning to catch when a constructor references itself upon initialization, such as using itself within its own copy constructor.
struct S {}; S s(s); llvm-svn: 138969
Diffstat (limited to 'clang/lib/Sema/SemaInit.cpp')
-rw-r--r--clang/lib/Sema/SemaInit.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp
index 06d530f007b..bcdd4801ab6 100644
--- a/clang/lib/Sema/SemaInit.cpp
+++ b/clang/lib/Sema/SemaInit.cpp
@@ -3078,6 +3078,14 @@ static void TryConstructorInitialization(Sema &S,
Expr **Args, unsigned NumArgs,
QualType DestType,
InitializationSequence &Sequence) {
+ // Check constructor arguments for self reference.
+ if (DeclaratorDecl *DD = Entity.getDecl())
+ // Parameters arguments are occassionially constructed with itself,
+ // for instance, in recursive functions. Skip them.
+ if (!isa<ParmVarDecl>(DD))
+ for (unsigned i = 0; i < NumArgs; ++i)
+ S.CheckSelfReference(DD, Args[i]);
+
// Build the candidate set directly in the initialization sequence
// structure, so that it will persist if we fail.
OverloadCandidateSet &CandidateSet = Sequence.getFailedCandidateSet();
OpenPOWER on IntegriCloud