aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaCodeComplete.cpp
blob: adb0469cf0bbb712886f845b8fc9415134748989 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
//===---------------- SemaCodeComplete.cpp - Code Completion ----*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
//  This file defines the code-completion semantic actions.
//
//===----------------------------------------------------------------------===//
#include "Sema.h"
#include "clang/Sema/CodeCompleteConsumer.h"

using namespace clang;

/// \brief Set the code-completion consumer for semantic analysis.
void Sema::setCodeCompleteConsumer(CodeCompleteConsumer *CCC) {
  assert(((CodeCompleter != 0) != (CCC != 0)) && 
         "Already set or cleared a code-completion consumer?");
  CodeCompleter = CCC;
}

void Sema::CodeCompleteMemberReferenceExpr(Scope *S, ExprTy *BaseE,
                                           SourceLocation OpLoc,
                                           bool IsArrow) {
  if (!BaseE || !CodeCompleter)
    return;
  
  Expr *Base = static_cast<Expr *>(BaseE);
  QualType BaseType = Base->getType();
   
  CodeCompleter->CodeCompleteMemberReferenceExpr(S, BaseType, IsArrow);
}

void Sema::CodeCompleteTag(Scope *S, unsigned TagSpec) {
  if (!CodeCompleter)
    return;
  
  TagDecl::TagKind TK;
  switch ((DeclSpec::TST)TagSpec) {
  case DeclSpec::TST_enum:
    TK = TagDecl::TK_enum;
    break;
    
  case DeclSpec::TST_union:
    TK = TagDecl::TK_union;
    break;
    
  case DeclSpec::TST_struct:
    TK = TagDecl::TK_struct;
    break;

  case DeclSpec::TST_class:
    TK = TagDecl::TK_class;
    break;
    
  default:
    assert(false && "Unknown type specifier kind in CodeCompleteTag");
    return;
  }
  CodeCompleter->CodeCompleteTag(S, TK);
}

void Sema::CodeCompleteQualifiedId(Scope *S, const CXXScopeSpec &SS,
                                   bool EnteringContext) {
  if (!SS.getScopeRep() || !CodeCompleter)
    return;
  
  CodeCompleter->CodeCompleteQualifiedId(S, 
                                      (NestedNameSpecifier *)SS.getScopeRep(),
                                         EnteringContext);
}

void Sema::CodeCompleteUsing(Scope *S) {
  if (!CodeCompleter)
    return;
  
  CodeCompleter->CodeCompleteUsing(S);
}

void Sema::CodeCompleteUsingDirective(Scope *S) {
  if (!CodeCompleter)
    return;
  
  CodeCompleter->CodeCompleteUsingDirective(S);
}

void Sema::CodeCompleteNamespaceDecl(Scope *S)  {
  if (!CodeCompleter)
    return;
  
  CodeCompleter->CodeCompleteNamespaceDecl(S);
}

void Sema::CodeCompleteNamespaceAliasDecl(Scope *S)  {
  if (!CodeCompleter)
    return;
  
  CodeCompleter->CodeCompleteNamespaceAliasDecl(S);
}

void Sema::CodeCompleteOperatorName(Scope *S) {
  if (!CodeCompleter)
    return;
  
  CodeCompleter->CodeCompleteOperatorName(S);
}