diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2009-08-06 17:22:51 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-08-06 17:22:51 +0000 |
| commit | 11a8e95a1a246f7d57570c989808120c2a47824c (patch) | |
| tree | e11aac3064d4831c5a6f1b1c2981f8fd6a2855bd | |
| parent | b4764e5b7fd06cae7081279bcb48e757ae544370 (diff) | |
| download | bcm5719-llvm-11a8e95a1a246f7d57570c989808120c2a47824c.tar.gz bcm5719-llvm-11a8e95a1a246f7d57570c989808120c2a47824c.zip | |
After reporting ill-formed copy constructor(12.8.p3)
don't recurs and crash.
llvm-svn: 78323
| -rw-r--r-- | clang/lib/Sema/SemaOverload.cpp | 3 | ||||
| -rw-r--r-- | clang/test/SemaCXX/copy-constructor-error.cpp | 13 |
2 files changed, 15 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index c28e052ae64..0fb515e80d3 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/lib/Sema/SemaOverload.cpp @@ -1344,7 +1344,8 @@ bool Sema::IsUserDefinedConversion(Expr *From, QualType ToType, = ToRecordDecl->lookup(ConstructorName); Con != ConEnd; ++Con) { CXXConstructorDecl *Constructor = cast<CXXConstructorDecl>(*Con); - if (Constructor->isConvertingConstructor()) + if (!Constructor->isInvalidDecl() && + Constructor->isConvertingConstructor()) AddOverloadCandidate(Constructor, &From, 1, CandidateSet, /*SuppressUserConversions=*/true, ForceRValue); } diff --git a/clang/test/SemaCXX/copy-constructor-error.cpp b/clang/test/SemaCXX/copy-constructor-error.cpp new file mode 100644 index 00000000000..afe741faa48 --- /dev/null +++ b/clang/test/SemaCXX/copy-constructor-error.cpp @@ -0,0 +1,13 @@ +// RUN: clang-cc -fsyntax-only -verify %s + +struct S { // expected-note {{candidate function}} + S (S); // expected-error {{copy constructor must pass its first argument by reference}} \\ + // expected-note {{candidate function}} +}; + +S f(); + +void g() { + S a( f() ); // expected-error {{call to constructor of 'a' is ambiguous}} +} + |

