summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-09-22 23:22:24 +0000
committerDouglas Gregor <dgregor@apple.com>2009-09-22 23:22:24 +0000
commit2b3ee156fc516ba18752b5e05b29d63b7df1ce1a (patch)
treeb8c3c6dc88528ebecc1db3988cd80db92c76235e
parent5bf52697b079b4b7c9db9a38c202788743d7264d (diff)
downloadbcm5719-llvm-2b3ee156fc516ba18752b5e05b29d63b7df1ce1a.tar.gz
bcm5719-llvm-2b3ee156fc516ba18752b5e05b29d63b7df1ce1a.zip
When code-completion finds a declaration only because it is usable as
the start of a nested-name-specifier, add the "::" after the nested-name-specifier to the code-completion string. llvm-svn: 82587
-rw-r--r--clang/include/clang/Sema/CodeCompleteConsumer.h11
-rw-r--r--clang/lib/Sema/SemaCodeComplete.cpp9
-rw-r--r--clang/test/CodeCompletion/tag.cpp4
3 files changed, 18 insertions, 6 deletions
diff --git a/clang/include/clang/Sema/CodeCompleteConsumer.h b/clang/include/clang/Sema/CodeCompleteConsumer.h
index 6a10b28be91..d18b4a732f2 100644
--- a/clang/include/clang/Sema/CodeCompleteConsumer.h
+++ b/clang/include/clang/Sema/CodeCompleteConsumer.h
@@ -173,6 +173,10 @@ public:
/// \brief Whether this result was found via lookup into a base class.
bool QualifierIsInformative : 1;
+ /// \brief Whether this declaration is the beginning of a
+ /// nested-name-specifier and, therefore, should be followed by '::'.
+ bool StartsNestedNameSpecifier : 1;
+
/// \brief If the result should have a nested-name-specifier, this is it.
/// When \c QualifierIsInformative, the nested-name-specifier is
/// informative rather than required.
@@ -183,13 +187,14 @@ public:
NestedNameSpecifier *Qualifier = 0,
bool QualifierIsInformative = false)
: Kind(RK_Declaration), Declaration(Declaration), Rank(Rank),
- Hidden(false), QualifierIsInformative(QualifierIsInformative),
- Qualifier(Qualifier) { }
+ Hidden(false), QualifierIsInformative(QualifierIsInformative),
+ StartsNestedNameSpecifier(false), Qualifier(Qualifier) { }
/// \brief Build a result that refers to a keyword or symbol.
Result(const char *Keyword, unsigned Rank)
: Kind(RK_Keyword), Keyword(Keyword), Rank(Rank), Hidden(false),
- QualifierIsInformative(0), Qualifier(0) { }
+ QualifierIsInformative(0), StartsNestedNameSpecifier(false),
+ Qualifier(0) { }
/// \brief Retrieve the declaration stored in this result.
NamedDecl *getDeclaration() const {
diff --git a/clang/lib/Sema/SemaCodeComplete.cpp b/clang/lib/Sema/SemaCodeComplete.cpp
index f57480e13e8..f0be3c68b83 100644
--- a/clang/lib/Sema/SemaCodeComplete.cpp
+++ b/clang/lib/Sema/SemaCodeComplete.cpp
@@ -313,6 +313,11 @@ void ResultBuilder::MaybeAddResult(Result R, DeclContext *CurContext) {
R.QualifierIsInformative = false;
}
+ // If the filter is for nested-name-specifiers, then this result starts a
+ // nested-name-specifier.
+ if (Filter == &ResultBuilder::IsNestedNameSpecifier)
+ R.StartsNestedNameSpecifier = true;
+
// Insert this result into the set of results and into the current shadow
// map.
SMap.insert(std::make_pair(R.Declaration->getDeclName(),
@@ -849,11 +854,13 @@ CodeCompleteConsumer::Result::CreateCodeCompletionString(Sema &S) {
return Result;
}
- if (Qualifier) {
+ if (Qualifier || StartsNestedNameSpecifier) {
CodeCompletionString *Result = new CodeCompletionString;
AddQualifierToCompletionString(Result, Qualifier, QualifierIsInformative,
S.Context);
Result->AddTextChunk(ND->getNameAsString().c_str());
+ if (StartsNestedNameSpecifier)
+ Result->AddTextChunk("::");
return Result;
}
diff --git a/clang/test/CodeCompletion/tag.cpp b/clang/test/CodeCompletion/tag.cpp
index 2642b7c7317..b00ff1fabda 100644
--- a/clang/test/CodeCompletion/tag.cpp
+++ b/clang/test/CodeCompletion/tag.cpp
@@ -21,6 +21,6 @@ namespace N {
// CHECK-CC1: A : 4
// CHECK-CC1: X : 4
// CHECK-CC1: Y : 4
- // CHECK-CC1: M : 9
- // CHECK-CC1: N : 9
+ // CHECK-CC1: M : 9 : M::
+ // CHECK-CC1: N : 9 : N::
// RUN: true
OpenPOWER on IntegriCloud