• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===--- ExternalSemaSource.h - External Sema Interface ---------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 //  This file defines the ExternalSemaSource interface.
11 //
12 //===----------------------------------------------------------------------===//
13 #ifndef LLVM_CLANG_SEMA_EXTERNALSEMASOURCE_H
14 #define LLVM_CLANG_SEMA_EXTERNALSEMASOURCE_H
15 
16 #include "clang/AST/ExternalASTSource.h"
17 #include "clang/AST/Type.h"
18 #include "clang/Sema/TypoCorrection.h"
19 #include "clang/Sema/Weak.h"
20 #include "llvm/ADT/MapVector.h"
21 #include <utility>
22 
23 namespace llvm {
24 template <class T, unsigned n> class SmallSetVector;
25 }
26 
27 namespace clang {
28 
29 class CXXConstructorDecl;
30 class CXXDeleteExpr;
31 class CXXRecordDecl;
32 class DeclaratorDecl;
33 class LookupResult;
34 struct ObjCMethodList;
35 class Scope;
36 class Sema;
37 class TypedefNameDecl;
38 class ValueDecl;
39 class VarDecl;
40 struct LateParsedTemplate;
41 
42 /// \brief A simple structure that captures a vtable use for the purposes of
43 /// the \c ExternalSemaSource.
44 struct ExternalVTableUse {
45   CXXRecordDecl *Record;
46   SourceLocation Location;
47   bool DefinitionRequired;
48 };
49 
50 /// \brief An abstract interface that should be implemented by
51 /// external AST sources that also provide information for semantic
52 /// analysis.
53 class ExternalSemaSource : public ExternalASTSource {
54 public:
ExternalSemaSource()55   ExternalSemaSource() {
56     ExternalASTSource::SemaSource = true;
57   }
58 
59   ~ExternalSemaSource() override;
60 
61   /// \brief Initialize the semantic source with the Sema instance
62   /// being used to perform semantic analysis on the abstract syntax
63   /// tree.
InitializeSema(Sema & S)64   virtual void InitializeSema(Sema &S) {}
65 
66   /// \brief Inform the semantic consumer that Sema is no longer available.
ForgetSema()67   virtual void ForgetSema() {}
68 
69   /// \brief Load the contents of the global method pool for a given
70   /// selector.
71   virtual void ReadMethodPool(Selector Sel);
72 
73   /// \brief Load the set of namespaces that are known to the external source,
74   /// which will be used during typo correction.
75   virtual void ReadKnownNamespaces(
76                            SmallVectorImpl<NamespaceDecl *> &Namespaces);
77 
78   /// \brief Load the set of used but not defined functions or variables with
79   /// internal linkage, or used but not defined internal functions.
80   virtual void ReadUndefinedButUsed(
81                          llvm::DenseMap<NamedDecl*, SourceLocation> &Undefined);
82 
83   virtual void ReadMismatchingDeleteExpressions(llvm::MapVector<
84       FieldDecl *, llvm::SmallVector<std::pair<SourceLocation, bool>, 4>> &);
85 
86   /// \brief Do last resort, unqualified lookup on a LookupResult that
87   /// Sema cannot find.
88   ///
89   /// \param R a LookupResult that is being recovered.
90   ///
91   /// \param S the Scope of the identifier occurrence.
92   ///
93   /// \return true to tell Sema to recover using the LookupResult.
LookupUnqualified(LookupResult & R,Scope * S)94   virtual bool LookupUnqualified(LookupResult &R, Scope *S) { return false; }
95 
96   /// \brief Read the set of tentative definitions known to the external Sema
97   /// source.
98   ///
99   /// The external source should append its own tentative definitions to the
100   /// given vector of tentative definitions. Note that this routine may be
101   /// invoked multiple times; the external source should take care not to
102   /// introduce the same declarations repeatedly.
ReadTentativeDefinitions(SmallVectorImpl<VarDecl * > & TentativeDefs)103   virtual void ReadTentativeDefinitions(
104                                   SmallVectorImpl<VarDecl *> &TentativeDefs) {}
105 
106   /// \brief Read the set of unused file-scope declarations known to the
107   /// external Sema source.
108   ///
109   /// The external source should append its own unused, filed-scope to the
110   /// given vector of declarations. Note that this routine may be
111   /// invoked multiple times; the external source should take care not to
112   /// introduce the same declarations repeatedly.
ReadUnusedFileScopedDecls(SmallVectorImpl<const DeclaratorDecl * > & Decls)113   virtual void ReadUnusedFileScopedDecls(
114                  SmallVectorImpl<const DeclaratorDecl *> &Decls) {}
115 
116   /// \brief Read the set of delegating constructors known to the
117   /// external Sema source.
118   ///
119   /// The external source should append its own delegating constructors to the
120   /// given vector of declarations. Note that this routine may be
121   /// invoked multiple times; the external source should take care not to
122   /// introduce the same declarations repeatedly.
ReadDelegatingConstructors(SmallVectorImpl<CXXConstructorDecl * > & Decls)123   virtual void ReadDelegatingConstructors(
124                  SmallVectorImpl<CXXConstructorDecl *> &Decls) {}
125 
126   /// \brief Read the set of ext_vector type declarations known to the
127   /// external Sema source.
128   ///
129   /// The external source should append its own ext_vector type declarations to
130   /// the given vector of declarations. Note that this routine may be
131   /// invoked multiple times; the external source should take care not to
132   /// introduce the same declarations repeatedly.
ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl * > & Decls)133   virtual void ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl *> &Decls) {}
134 
135   /// \brief Read the set of potentially unused typedefs known to the source.
136   ///
137   /// The external source should append its own potentially unused local
138   /// typedefs to the given vector of declarations. Note that this routine may
139   /// be invoked multiple times; the external source should take care not to
140   /// introduce the same declarations repeatedly.
ReadUnusedLocalTypedefNameCandidates(llvm::SmallSetVector<const TypedefNameDecl *,4> & Decls)141   virtual void ReadUnusedLocalTypedefNameCandidates(
142       llvm::SmallSetVector<const TypedefNameDecl *, 4> &Decls) {}
143 
144   /// \brief Read the set of referenced selectors known to the
145   /// external Sema source.
146   ///
147   /// The external source should append its own referenced selectors to the
148   /// given vector of selectors. Note that this routine
149   /// may be invoked multiple times; the external source should take care not
150   /// to introduce the same selectors repeatedly.
ReadReferencedSelectors(SmallVectorImpl<std::pair<Selector,SourceLocation>> & Sels)151   virtual void ReadReferencedSelectors(
152                  SmallVectorImpl<std::pair<Selector, SourceLocation> > &Sels) {}
153 
154   /// \brief Read the set of weak, undeclared identifiers known to the
155   /// external Sema source.
156   ///
157   /// The external source should append its own weak, undeclared identifiers to
158   /// the given vector. Note that this routine may be invoked multiple times;
159   /// the external source should take care not to introduce the same identifiers
160   /// repeatedly.
ReadWeakUndeclaredIdentifiers(SmallVectorImpl<std::pair<IdentifierInfo *,WeakInfo>> & WI)161   virtual void ReadWeakUndeclaredIdentifiers(
162                  SmallVectorImpl<std::pair<IdentifierInfo *, WeakInfo> > &WI) {}
163 
164   /// \brief Read the set of used vtables known to the external Sema source.
165   ///
166   /// The external source should append its own used vtables to the given
167   /// vector. Note that this routine may be invoked multiple times; the external
168   /// source should take care not to introduce the same vtables repeatedly.
ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> & VTables)169   virtual void ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> &VTables) {}
170 
171   /// \brief Read the set of pending instantiations known to the external
172   /// Sema source.
173   ///
174   /// The external source should append its own pending instantiations to the
175   /// given vector. Note that this routine may be invoked multiple times; the
176   /// external source should take care not to introduce the same instantiations
177   /// repeatedly.
ReadPendingInstantiations(SmallVectorImpl<std::pair<ValueDecl *,SourceLocation>> & Pending)178   virtual void ReadPendingInstantiations(
179                  SmallVectorImpl<std::pair<ValueDecl *,
180                                            SourceLocation> > &Pending) {}
181 
182   /// \brief Read the set of late parsed template functions for this source.
183   ///
184   /// The external source should insert its own late parsed template functions
185   /// into the map. Note that this routine may be invoked multiple times; the
186   /// external source should take care not to introduce the same map entries
187   /// repeatedly.
ReadLateParsedTemplates(llvm::MapVector<const FunctionDecl *,LateParsedTemplate * > & LPTMap)188   virtual void ReadLateParsedTemplates(
189       llvm::MapVector<const FunctionDecl *, LateParsedTemplate *> &LPTMap) {}
190 
191   /// \copydoc Sema::CorrectTypo
192   /// \note LookupKind must correspond to a valid Sema::LookupNameKind
193   ///
194   /// ExternalSemaSource::CorrectTypo is always given the first chance to
195   /// correct a typo (really, to offer suggestions to repair a failed lookup).
196   /// It will even be called when SpellChecking is turned off or after a
197   /// fatal error has already been detected.
CorrectTypo(const DeclarationNameInfo & Typo,int LookupKind,Scope * S,CXXScopeSpec * SS,CorrectionCandidateCallback & CCC,DeclContext * MemberContext,bool EnteringContext,const ObjCObjectPointerType * OPT)198   virtual TypoCorrection CorrectTypo(const DeclarationNameInfo &Typo,
199                                      int LookupKind, Scope *S, CXXScopeSpec *SS,
200                                      CorrectionCandidateCallback &CCC,
201                                      DeclContext *MemberContext,
202                                      bool EnteringContext,
203                                      const ObjCObjectPointerType *OPT) {
204     return TypoCorrection();
205   }
206 
207   /// \brief Produces a diagnostic note if the external source contains a
208   /// complete definition for \p T.
209   ///
210   /// \param Loc the location at which a complete type was required but not
211   /// provided
212   ///
213   /// \param T the \c QualType that should have been complete at \p Loc
214   ///
215   /// \return true if a diagnostic was produced, false otherwise.
MaybeDiagnoseMissingCompleteType(SourceLocation Loc,QualType T)216   virtual bool MaybeDiagnoseMissingCompleteType(SourceLocation Loc,
217                                                 QualType T) {
218     return false;
219   }
220 
221   // isa/cast/dyn_cast support
classof(const ExternalASTSource * Source)222   static bool classof(const ExternalASTSource *Source) {
223     return Source->SemaSource;
224   }
225 };
226 
227 } // end namespace clang
228 
229 #endif
230