aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Sema/SemaCodeComplete.cpp
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2015-03-13 07:39:30 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2015-03-13 07:39:30 +0000
commitee1d76f361ddbfdb3ed43f25f767ebde47ff70a9 (patch)
tree3db4708724ee6750f7a1297a4dca5b0077ebcc4b /clang/lib/Sema/SemaCodeComplete.cpp
parent41a185c521ad48cbaccb8c0c37eb249755e540ba (diff)
downloadllvm-ee1d76f361ddbfdb3ed43f25f767ebde47ff70a9.zip
llvm-ee1d76f361ddbfdb3ed43f25f767ebde47ff70a9.tar.gz
llvm-ee1d76f361ddbfdb3ed43f25f767ebde47ff70a9.tar.bz2
[libclang] Fix crash when code-completing inside constructor initializer for a builtin type.
rdar://20149746 llvm-svn: 232145
Diffstat (limited to 'clang/lib/Sema/SemaCodeComplete.cpp')
-rw-r--r--clang/lib/Sema/SemaCodeComplete.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaCodeComplete.cpp b/clang/lib/Sema/SemaCodeComplete.cpp
index 80238e5..eeeb851 100644
--- a/clang/lib/Sema/SemaCodeComplete.cpp
+++ b/clang/lib/Sema/SemaCodeComplete.cpp
@@ -4035,12 +4035,18 @@ void Sema::CodeCompleteConstructor(Scope *S, QualType Type, SourceLocation Loc,
if (RequireCompleteType(Loc, Type, 0))
return;
+ CXXRecordDecl *RD = Type->getAsCXXRecordDecl();
+ if (!RD) {
+ CodeCompleteExpression(S, Type);
+ return;
+ }
+
// FIXME: Provide support for member initializers.
// FIXME: Provide support for variadic template constructors.
OverloadCandidateSet CandidateSet(Loc, OverloadCandidateSet::CSK_Normal);
- for (auto C : LookupConstructors(Type->getAsCXXRecordDecl())) {
+ for (auto C : LookupConstructors(RD)) {
if (auto FD = dyn_cast<FunctionDecl>(C)) {
AddOverloadCandidate(FD, DeclAccessPair::make(FD, C->getAccess()),
Args, CandidateSet,