MultiplexConsumer.cpp 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. //===- MultiplexConsumer.cpp - AST Consumer for PCH Generation --*- 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 MultiplexConsumer class. It also declares and defines
  11. // MultiplexASTDeserializationListener and MultiplexASTMutationListener, which
  12. // are implementation details of MultiplexConsumer.
  13. //
  14. //===----------------------------------------------------------------------===//
  15. #include "clang/Frontend/MultiplexConsumer.h"
  16. #include "clang/AST/ASTMutationListener.h"
  17. #include "clang/AST/DeclGroup.h"
  18. #include "clang/Serialization/ASTDeserializationListener.h"
  19. using namespace clang;
  20. namespace clang {
  21. // This ASTDeserializationListener forwards its notifications to a set of
  22. // child listeners.
  23. class MultiplexASTDeserializationListener
  24. : public ASTDeserializationListener {
  25. public:
  26. // Does NOT take ownership of the elements in L.
  27. MultiplexASTDeserializationListener(
  28. const std::vector<ASTDeserializationListener*>& L);
  29. virtual void ReaderInitialized(ASTReader *Reader);
  30. virtual void IdentifierRead(serialization::IdentID ID,
  31. IdentifierInfo *II);
  32. virtual void TypeRead(serialization::TypeIdx Idx, QualType T);
  33. virtual void DeclRead(serialization::DeclID ID, const Decl *D);
  34. virtual void SelectorRead(serialization::SelectorID iD, Selector Sel);
  35. virtual void MacroDefinitionRead(serialization::MacroID,
  36. MacroDefinition *MD);
  37. private:
  38. std::vector<ASTDeserializationListener*> Listeners;
  39. };
  40. MultiplexASTDeserializationListener::MultiplexASTDeserializationListener(
  41. const std::vector<ASTDeserializationListener*>& L)
  42. : Listeners(L) {
  43. }
  44. void MultiplexASTDeserializationListener::ReaderInitialized(
  45. ASTReader *Reader) {
  46. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  47. Listeners[i]->ReaderInitialized(Reader);
  48. }
  49. void MultiplexASTDeserializationListener::IdentifierRead(
  50. serialization::IdentID ID, IdentifierInfo *II) {
  51. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  52. Listeners[i]->IdentifierRead(ID, II);
  53. }
  54. void MultiplexASTDeserializationListener::TypeRead(
  55. serialization::TypeIdx Idx, QualType T) {
  56. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  57. Listeners[i]->TypeRead(Idx, T);
  58. }
  59. void MultiplexASTDeserializationListener::DeclRead(
  60. serialization::DeclID ID, const Decl *D) {
  61. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  62. Listeners[i]->DeclRead(ID, D);
  63. }
  64. void MultiplexASTDeserializationListener::SelectorRead(
  65. serialization::SelectorID ID, Selector Sel) {
  66. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  67. Listeners[i]->SelectorRead(ID, Sel);
  68. }
  69. void MultiplexASTDeserializationListener::MacroDefinitionRead(
  70. serialization::MacroID ID, MacroDefinition *MD) {
  71. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  72. Listeners[i]->MacroDefinitionRead(ID, MD);
  73. }
  74. // This ASTMutationListener forwards its notifications to a set of
  75. // child listeners.
  76. class MultiplexASTMutationListener : public ASTMutationListener {
  77. public:
  78. // Does NOT take ownership of the elements in L.
  79. MultiplexASTMutationListener(const std::vector<ASTMutationListener*>& L);
  80. virtual void CompletedTagDefinition(const TagDecl *D);
  81. virtual void AddedVisibleDecl(const DeclContext *DC, const Decl *D);
  82. virtual void AddedCXXImplicitMember(const CXXRecordDecl *RD, const Decl *D);
  83. virtual void AddedCXXTemplateSpecialization(const ClassTemplateDecl *TD,
  84. const ClassTemplateSpecializationDecl *D);
  85. virtual void AddedCXXTemplateSpecialization(const FunctionTemplateDecl *TD,
  86. const FunctionDecl *D);
  87. virtual void CompletedImplicitDefinition(const FunctionDecl *D);
  88. private:
  89. std::vector<ASTMutationListener*> Listeners;
  90. };
  91. MultiplexASTMutationListener::MultiplexASTMutationListener(
  92. const std::vector<ASTMutationListener*>& L)
  93. : Listeners(L) {
  94. }
  95. void MultiplexASTMutationListener::CompletedTagDefinition(const TagDecl *D) {
  96. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  97. Listeners[i]->CompletedTagDefinition(D);
  98. }
  99. void MultiplexASTMutationListener::AddedVisibleDecl(
  100. const DeclContext *DC, const Decl *D) {
  101. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  102. Listeners[i]->AddedVisibleDecl(DC, D);
  103. }
  104. void MultiplexASTMutationListener::AddedCXXImplicitMember(
  105. const CXXRecordDecl *RD, const Decl *D) {
  106. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  107. Listeners[i]->AddedCXXImplicitMember(RD, D);
  108. }
  109. void MultiplexASTMutationListener::AddedCXXTemplateSpecialization(
  110. const ClassTemplateDecl *TD, const ClassTemplateSpecializationDecl *D) {
  111. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  112. Listeners[i]->AddedCXXTemplateSpecialization(TD, D);
  113. }
  114. void MultiplexASTMutationListener::AddedCXXTemplateSpecialization(
  115. const FunctionTemplateDecl *TD, const FunctionDecl *D) {
  116. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  117. Listeners[i]->AddedCXXTemplateSpecialization(TD, D);
  118. }
  119. void MultiplexASTMutationListener::CompletedImplicitDefinition(
  120. const FunctionDecl *D) {
  121. for (size_t i = 0, e = Listeners.size(); i != e; ++i)
  122. Listeners[i]->CompletedImplicitDefinition(D);
  123. }
  124. } // end namespace clang
  125. MultiplexConsumer::MultiplexConsumer(const std::vector<ASTConsumer*>& C)
  126. : Consumers(C), MutationListener(0), DeserializationListener(0) {
  127. // Collect the mutation listeners and deserialization listeners of all
  128. // children, and create a multiplex listener each if so.
  129. std::vector<ASTMutationListener*> mutationListeners;
  130. std::vector<ASTDeserializationListener*> serializationListeners;
  131. for (size_t i = 0, e = Consumers.size(); i != e; ++i) {
  132. ASTMutationListener* mutationListener =
  133. Consumers[i]->GetASTMutationListener();
  134. if (mutationListener)
  135. mutationListeners.push_back(mutationListener);
  136. ASTDeserializationListener* serializationListener =
  137. Consumers[i]->GetASTDeserializationListener();
  138. if (serializationListener)
  139. serializationListeners.push_back(serializationListener);
  140. }
  141. if (mutationListeners.size()) {
  142. MutationListener.reset(new MultiplexASTMutationListener(mutationListeners));
  143. }
  144. if (serializationListeners.size()) {
  145. DeserializationListener.reset(
  146. new MultiplexASTDeserializationListener(serializationListeners));
  147. }
  148. }
  149. MultiplexConsumer::~MultiplexConsumer() {
  150. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  151. delete Consumers[i];
  152. }
  153. void MultiplexConsumer::Initialize(ASTContext &Context) {
  154. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  155. Consumers[i]->Initialize(Context);
  156. }
  157. void MultiplexConsumer::HandleTopLevelDecl(DeclGroupRef D) {
  158. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  159. Consumers[i]->HandleTopLevelDecl(D);
  160. }
  161. void MultiplexConsumer::HandleInterestingDecl(DeclGroupRef D) {
  162. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  163. Consumers[i]->HandleInterestingDecl(D);
  164. }
  165. void MultiplexConsumer::HandleTranslationUnit(ASTContext &Ctx) {
  166. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  167. Consumers[i]->HandleTranslationUnit(Ctx);
  168. }
  169. void MultiplexConsumer::HandleTagDeclDefinition(TagDecl *D) {
  170. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  171. Consumers[i]->HandleTagDeclDefinition(D);
  172. }
  173. void MultiplexConsumer::CompleteTentativeDefinition(VarDecl *D) {
  174. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  175. Consumers[i]->CompleteTentativeDefinition(D);
  176. }
  177. void MultiplexConsumer::HandleVTable(
  178. CXXRecordDecl *RD, bool DefinitionRequired) {
  179. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  180. Consumers[i]->HandleVTable(RD, DefinitionRequired);
  181. }
  182. ASTMutationListener *MultiplexConsumer::GetASTMutationListener() {
  183. return MutationListener.get();
  184. }
  185. ASTDeserializationListener *MultiplexConsumer::GetASTDeserializationListener() {
  186. return DeserializationListener.get();
  187. }
  188. void MultiplexConsumer::PrintStats() {
  189. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  190. Consumers[i]->PrintStats();
  191. }
  192. void MultiplexConsumer::InitializeSema(Sema &S) {
  193. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  194. if (SemaConsumer *SC = dyn_cast<SemaConsumer>(Consumers[i]))
  195. SC->InitializeSema(S);
  196. }
  197. void MultiplexConsumer::ForgetSema() {
  198. for (size_t i = 0, e = Consumers.size(); i != e; ++i)
  199. if (SemaConsumer *SC = dyn_cast<SemaConsumer>(Consumers[i]))
  200. SC->ForgetSema();
  201. }