diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-10-18 16:29:03 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-10-18 16:29:03 +0000 |
commit | 4205feffcd80b14852d395d1883a67f2b3db6e22 (patch) | |
tree | 2b067027be78a2795dc31e0fc0e92c9edbeab821 /clang/lib | |
parent | e4454e0de2dd86f932d9f503b9dfce893a105a92 (diff) | |
download | bcm5719-llvm-4205feffcd80b14852d395d1883a67f2b3db6e22.tar.gz bcm5719-llvm-4205feffcd80b14852d395d1883a67f2b3db6e22.zip |
Add code completions for C++0x expressions
llvm-svn: 142357
Diffstat (limited to 'clang/lib')
-rw-r--r-- | clang/lib/Sema/SemaCodeComplete.cpp | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaCodeComplete.cpp b/clang/lib/Sema/SemaCodeComplete.cpp index 5589245d1a7..6e2094d77a2 100644 --- a/clang/lib/Sema/SemaCodeComplete.cpp +++ b/clang/lib/Sema/SemaCodeComplete.cpp @@ -1811,8 +1811,35 @@ static void AddOrdinaryNameResults(Sema::ParserCompletionContext CCC, Builder.AddPlaceholderChunk("expression"); Results.AddResult(Result(Builder.TakeString())); } - + // FIXME: Rethrow? + + if (SemaRef.getLangOptions().CPlusPlus0x) { + // nullptr + Builder.AddTypedTextChunk("nullptr"); + Results.AddResult(Result(Builder.TakeString())); + + // alignof + Builder.AddTypedTextChunk("alignof"); + Builder.AddChunk(CodeCompletionString::CK_LeftParen); + Builder.AddPlaceholderChunk("type"); + Builder.AddChunk(CodeCompletionString::CK_RightParen); + Results.AddResult(Result(Builder.TakeString())); + + // noexcept + Builder.AddTypedTextChunk("noexcept"); + Builder.AddChunk(CodeCompletionString::CK_LeftParen); + Builder.AddPlaceholderChunk("expression"); + Builder.AddChunk(CodeCompletionString::CK_RightParen); + Results.AddResult(Result(Builder.TakeString())); + + // sizeof... expression + Builder.AddTypedTextChunk("sizeof..."); + Builder.AddChunk(CodeCompletionString::CK_LeftParen); + Builder.AddPlaceholderChunk("parameter-pack"); + Builder.AddChunk(CodeCompletionString::CK_RightParen); + Results.AddResult(Result(Builder.TakeString())); + } } if (SemaRef.getLangOptions().ObjC1) { |