blob: 77721bdf629e92864640a32e6fbaf88ffeb23b1c [file] [log] [blame]
Chris Lattner698f9252009-04-27 05:27:42 +00001//===--- PCHReaderDecl.cpp - Decl Deserialization ---------------*- 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 implements the PCHReader::ReadDeclRecord method, which is the
11// entrypoint for loading a decl.
12//
13//===----------------------------------------------------------------------===//
14
15#include "clang/Frontend/PCHReader.h"
16#include "clang/AST/ASTConsumer.h"
17#include "clang/AST/ASTContext.h"
18#include "clang/AST/DeclVisitor.h"
19#include "clang/AST/DeclGroup.h"
20#include "clang/AST/Expr.h"
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +000021#include "clang/AST/TypeLoc.h"
Chris Lattner698f9252009-04-27 05:27:42 +000022using namespace clang;
23
Chris Lattner698f9252009-04-27 05:27:42 +000024
25//===----------------------------------------------------------------------===//
26// Declaration deserialization
27//===----------------------------------------------------------------------===//
28
29namespace {
30 class PCHDeclReader : public DeclVisitor<PCHDeclReader, void> {
31 PCHReader &Reader;
32 const PCHReader::RecordData &Record;
33 unsigned &Idx;
34
35 public:
36 PCHDeclReader(PCHReader &Reader, const PCHReader::RecordData &Record,
37 unsigned &Idx)
38 : Reader(Reader), Record(Record), Idx(Idx) { }
39
40 void VisitDecl(Decl *D);
41 void VisitTranslationUnitDecl(TranslationUnitDecl *TU);
42 void VisitNamedDecl(NamedDecl *ND);
43 void VisitTypeDecl(TypeDecl *TD);
44 void VisitTypedefDecl(TypedefDecl *TD);
45 void VisitTagDecl(TagDecl *TD);
46 void VisitEnumDecl(EnumDecl *ED);
47 void VisitRecordDecl(RecordDecl *RD);
48 void VisitValueDecl(ValueDecl *VD);
49 void VisitEnumConstantDecl(EnumConstantDecl *ECD);
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +000050 void VisitDeclaratorDecl(DeclaratorDecl *DD);
Chris Lattner698f9252009-04-27 05:27:42 +000051 void VisitFunctionDecl(FunctionDecl *FD);
52 void VisitFieldDecl(FieldDecl *FD);
53 void VisitVarDecl(VarDecl *VD);
54 void VisitImplicitParamDecl(ImplicitParamDecl *PD);
55 void VisitParmVarDecl(ParmVarDecl *PD);
56 void VisitOriginalParmVarDecl(OriginalParmVarDecl *PD);
57 void VisitFileScopeAsmDecl(FileScopeAsmDecl *AD);
58 void VisitBlockDecl(BlockDecl *BD);
59 std::pair<uint64_t, uint64_t> VisitDeclContext(DeclContext *DC);
60 void VisitObjCMethodDecl(ObjCMethodDecl *D);
61 void VisitObjCContainerDecl(ObjCContainerDecl *D);
62 void VisitObjCInterfaceDecl(ObjCInterfaceDecl *D);
63 void VisitObjCIvarDecl(ObjCIvarDecl *D);
64 void VisitObjCProtocolDecl(ObjCProtocolDecl *D);
65 void VisitObjCAtDefsFieldDecl(ObjCAtDefsFieldDecl *D);
66 void VisitObjCClassDecl(ObjCClassDecl *D);
67 void VisitObjCForwardProtocolDecl(ObjCForwardProtocolDecl *D);
68 void VisitObjCCategoryDecl(ObjCCategoryDecl *D);
69 void VisitObjCImplDecl(ObjCImplDecl *D);
70 void VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D);
71 void VisitObjCImplementationDecl(ObjCImplementationDecl *D);
72 void VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *D);
73 void VisitObjCPropertyDecl(ObjCPropertyDecl *D);
74 void VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D);
75 };
76}
77
78void PCHDeclReader::VisitDecl(Decl *D) {
79 D->setDeclContext(cast_or_null<DeclContext>(Reader.GetDecl(Record[Idx++])));
80 D->setLexicalDeclContext(
81 cast_or_null<DeclContext>(Reader.GetDecl(Record[Idx++])));
82 D->setLocation(SourceLocation::getFromRawEncoding(Record[Idx++]));
83 D->setInvalidDecl(Record[Idx++]);
84 if (Record[Idx++])
Argyrios Kyrtzidis40b598e2009-06-30 02:34:44 +000085 D->addAttr(Reader.ReadAttributes());
Chris Lattner698f9252009-04-27 05:27:42 +000086 D->setImplicit(Record[Idx++]);
Douglas Gregore0762c92009-06-19 23:52:42 +000087 D->setUsed(Record[Idx++]);
Chris Lattner698f9252009-04-27 05:27:42 +000088 D->setAccess((AccessSpecifier)Record[Idx++]);
89}
90
91void PCHDeclReader::VisitTranslationUnitDecl(TranslationUnitDecl *TU) {
92 VisitDecl(TU);
93}
94
95void PCHDeclReader::VisitNamedDecl(NamedDecl *ND) {
96 VisitDecl(ND);
Mike Stump1eb44332009-09-09 15:08:12 +000097 ND->setDeclName(Reader.ReadDeclarationName(Record, Idx));
Chris Lattner698f9252009-04-27 05:27:42 +000098}
99
100void PCHDeclReader::VisitTypeDecl(TypeDecl *TD) {
101 VisitNamedDecl(TD);
102 TD->setTypeForDecl(Reader.GetType(Record[Idx++]).getTypePtr());
103}
104
105void PCHDeclReader::VisitTypedefDecl(TypedefDecl *TD) {
106 // Note that we cannot use VisitTypeDecl here, because we need to
107 // set the underlying type of the typedef *before* we try to read
108 // the type associated with the TypedefDecl.
109 VisitNamedDecl(TD);
110 TD->setUnderlyingType(Reader.GetType(Record[Idx + 1]));
111 TD->setTypeForDecl(Reader.GetType(Record[Idx]).getTypePtr());
112 Idx += 2;
113}
114
115void PCHDeclReader::VisitTagDecl(TagDecl *TD) {
116 VisitTypeDecl(TD);
Douglas Gregor8e9e9ef2009-07-29 23:36:44 +0000117 TD->setPreviousDeclaration(
118 cast_or_null<TagDecl>(Reader.GetDecl(Record[Idx++])));
Chris Lattner698f9252009-04-27 05:27:42 +0000119 TD->setTagKind((TagDecl::TagKind)Record[Idx++]);
120 TD->setDefinition(Record[Idx++]);
121 TD->setTypedefForAnonDecl(
122 cast_or_null<TypedefDecl>(Reader.GetDecl(Record[Idx++])));
Argyrios Kyrtzidisad93a742009-07-14 03:18:02 +0000123 TD->setRBraceLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
Douglas Gregor741dd9a2009-07-21 14:46:17 +0000124 TD->setTagKeywordLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
Chris Lattner698f9252009-04-27 05:27:42 +0000125}
126
127void PCHDeclReader::VisitEnumDecl(EnumDecl *ED) {
128 VisitTagDecl(ED);
129 ED->setIntegerType(Reader.GetType(Record[Idx++]));
Douglas Gregor8dbc3c62009-05-27 17:20:35 +0000130 // FIXME: C++ InstantiatedFrom
Chris Lattner698f9252009-04-27 05:27:42 +0000131}
132
133void PCHDeclReader::VisitRecordDecl(RecordDecl *RD) {
134 VisitTagDecl(RD);
135 RD->setHasFlexibleArrayMember(Record[Idx++]);
136 RD->setAnonymousStructOrUnion(Record[Idx++]);
Fariborz Jahanian643b7df2009-07-08 16:37:44 +0000137 RD->setHasObjectMember(Record[Idx++]);
Chris Lattner698f9252009-04-27 05:27:42 +0000138}
139
140void PCHDeclReader::VisitValueDecl(ValueDecl *VD) {
141 VisitNamedDecl(VD);
142 VD->setType(Reader.GetType(Record[Idx++]));
143}
144
145void PCHDeclReader::VisitEnumConstantDecl(EnumConstantDecl *ECD) {
146 VisitValueDecl(ECD);
147 if (Record[Idx++])
Chris Lattnerda930612009-04-27 05:58:23 +0000148 ECD->setInitExpr(Reader.ReadDeclExpr());
Chris Lattner698f9252009-04-27 05:27:42 +0000149 ECD->setInitVal(Reader.ReadAPSInt(Record, Idx));
150}
151
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +0000152namespace {
153
154class TypeLocReader : public TypeLocVisitor<TypeLocReader> {
155 PCHReader &Reader;
156 const PCHReader::RecordData &Record;
157 unsigned &Idx;
158
159public:
160 TypeLocReader(PCHReader &Reader, const PCHReader::RecordData &Record,
161 unsigned &Idx)
162 : Reader(Reader), Record(Record), Idx(Idx) { }
163
164#define ABSTRACT_TYPELOC(CLASS)
165#define TYPELOC(CLASS, PARENT, TYPE) \
Mike Stump1eb44332009-09-09 15:08:12 +0000166 void Visit##CLASS(CLASS TyLoc);
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +0000167#include "clang/AST/TypeLocNodes.def"
Mike Stump1eb44332009-09-09 15:08:12 +0000168
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +0000169 void VisitTypeLoc(TypeLoc TyLoc) {
170 assert(0 && "A type loc wrapper was not handled!");
171 }
172};
173
174}
175
176void TypeLocReader::VisitDefaultTypeSpecLoc(DefaultTypeSpecLoc TyLoc) {
177 TyLoc.setStartLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
178}
179void TypeLocReader::VisitTypedefLoc(TypedefLoc TyLoc) {
180 TyLoc.setNameLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
181}
182void TypeLocReader::VisitPointerLoc(PointerLoc TyLoc) {
183 TyLoc.setStarLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
184}
185void TypeLocReader::VisitBlockPointerLoc(BlockPointerLoc TyLoc) {
186 TyLoc.setCaretLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
187}
188void TypeLocReader::VisitMemberPointerLoc(MemberPointerLoc TyLoc) {
189 TyLoc.setStarLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
190}
191void TypeLocReader::VisitReferenceLoc(ReferenceLoc TyLoc) {
192 TyLoc.setAmpLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
193}
194void TypeLocReader::VisitFunctionLoc(FunctionLoc TyLoc) {
195 TyLoc.setLParenLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
196 TyLoc.setRParenLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
197 for (unsigned i = 0, e = TyLoc.getNumArgs(); i != e; ++i)
198 TyLoc.setArg(i, cast<ParmVarDecl>(Reader.GetDecl(Record[Idx++])));
199}
200void TypeLocReader::VisitArrayLoc(ArrayLoc TyLoc) {
201 TyLoc.setLBracketLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
202 TyLoc.setRBracketLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
203 if (Record[Idx++])
204 TyLoc.setSizeExpr(Reader.ReadDeclExpr());
205}
206
207void PCHDeclReader::VisitDeclaratorDecl(DeclaratorDecl *DD) {
208 VisitValueDecl(DD);
209 QualType InfoTy = Reader.GetType(Record[Idx++]);
210 if (InfoTy.isNull())
211 return;
212
213 DeclaratorInfo *DInfo = Reader.getContext()->CreateDeclaratorInfo(InfoTy);
214 TypeLocReader TLR(Reader, Record, Idx);
215 for (TypeLoc TL = DInfo->getTypeLoc(); !TL.isNull(); TL = TL.getNextTypeLoc())
216 TLR.Visit(TL);
217 DD->setDeclaratorInfo(DInfo);
218}
219
Chris Lattner698f9252009-04-27 05:27:42 +0000220void PCHDeclReader::VisitFunctionDecl(FunctionDecl *FD) {
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +0000221 VisitDeclaratorDecl(FD);
Chris Lattner698f9252009-04-27 05:27:42 +0000222 if (Record[Idx++])
Chris Lattnerda930612009-04-27 05:58:23 +0000223 FD->setLazyBody(Reader.getDeclsCursor().GetCurrentBitNo());
Chris Lattner698f9252009-04-27 05:27:42 +0000224 FD->setPreviousDeclaration(
225 cast_or_null<FunctionDecl>(Reader.GetDecl(Record[Idx++])));
226 FD->setStorageClass((FunctionDecl::StorageClass)Record[Idx++]);
227 FD->setInline(Record[Idx++]);
Anders Carlsson77b7f1d2009-05-14 22:15:41 +0000228 FD->setVirtualAsWritten(Record[Idx++]);
Chris Lattner698f9252009-04-27 05:27:42 +0000229 FD->setPure(Record[Idx++]);
Anders Carlssona75e8532009-05-14 21:46:00 +0000230 FD->setHasInheritedPrototype(Record[Idx++]);
231 FD->setHasWrittenPrototype(Record[Idx++]);
Chris Lattner698f9252009-04-27 05:27:42 +0000232 FD->setDeleted(Record[Idx++]);
Daniel Dunbar7f8b57a2009-09-22 05:38:14 +0000233 FD->setTrivial(Record[Idx++]);
234 FD->setCopyAssignment(Record[Idx++]);
235 FD->setHasImplicitReturnZero(Record[Idx++]);
Argyrios Kyrtzidis8cff90e2009-06-20 08:09:34 +0000236 FD->setLocEnd(SourceLocation::getFromRawEncoding(Record[Idx++]));
Douglas Gregor1eee0e72009-05-14 21:06:31 +0000237 // FIXME: C++ TemplateOrInstantiation
Chris Lattner698f9252009-04-27 05:27:42 +0000238 unsigned NumParams = Record[Idx++];
239 llvm::SmallVector<ParmVarDecl *, 16> Params;
240 Params.reserve(NumParams);
241 for (unsigned I = 0; I != NumParams; ++I)
242 Params.push_back(cast<ParmVarDecl>(Reader.GetDecl(Record[Idx++])));
Jay Foadbeaaccd2009-05-21 09:52:38 +0000243 FD->setParams(*Reader.getContext(), Params.data(), NumParams);
Chris Lattner698f9252009-04-27 05:27:42 +0000244}
245
246void PCHDeclReader::VisitObjCMethodDecl(ObjCMethodDecl *MD) {
247 VisitNamedDecl(MD);
248 if (Record[Idx++]) {
249 // In practice, this won't be executed (since method definitions
250 // don't occur in header files).
Chris Lattnerda930612009-04-27 05:58:23 +0000251 MD->setBody(Reader.ReadDeclStmt());
Chris Lattner698f9252009-04-27 05:27:42 +0000252 MD->setSelfDecl(cast<ImplicitParamDecl>(Reader.GetDecl(Record[Idx++])));
253 MD->setCmdDecl(cast<ImplicitParamDecl>(Reader.GetDecl(Record[Idx++])));
254 }
255 MD->setInstanceMethod(Record[Idx++]);
256 MD->setVariadic(Record[Idx++]);
257 MD->setSynthesized(Record[Idx++]);
258 MD->setDeclImplementation((ObjCMethodDecl::ImplementationControl)Record[Idx++]);
259 MD->setObjCDeclQualifier((Decl::ObjCDeclQualifier)Record[Idx++]);
260 MD->setResultType(Reader.GetType(Record[Idx++]));
261 MD->setEndLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
262 unsigned NumParams = Record[Idx++];
263 llvm::SmallVector<ParmVarDecl *, 16> Params;
264 Params.reserve(NumParams);
265 for (unsigned I = 0; I != NumParams; ++I)
266 Params.push_back(cast<ParmVarDecl>(Reader.GetDecl(Record[Idx++])));
Jay Foadbeaaccd2009-05-21 09:52:38 +0000267 MD->setMethodParams(*Reader.getContext(), Params.data(), NumParams);
Chris Lattner698f9252009-04-27 05:27:42 +0000268}
269
270void PCHDeclReader::VisitObjCContainerDecl(ObjCContainerDecl *CD) {
271 VisitNamedDecl(CD);
272 CD->setAtEndLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
273}
274
275void PCHDeclReader::VisitObjCInterfaceDecl(ObjCInterfaceDecl *ID) {
276 VisitObjCContainerDecl(ID);
277 ID->setTypeForDecl(Reader.GetType(Record[Idx++]).getTypePtr());
278 ID->setSuperClass(cast_or_null<ObjCInterfaceDecl>
279 (Reader.GetDecl(Record[Idx++])));
280 unsigned NumProtocols = Record[Idx++];
281 llvm::SmallVector<ObjCProtocolDecl *, 16> Protocols;
282 Protocols.reserve(NumProtocols);
283 for (unsigned I = 0; I != NumProtocols; ++I)
284 Protocols.push_back(cast<ObjCProtocolDecl>(Reader.GetDecl(Record[Idx++])));
Jay Foadbeaaccd2009-05-21 09:52:38 +0000285 ID->setProtocolList(Protocols.data(), NumProtocols, *Reader.getContext());
Chris Lattner698f9252009-04-27 05:27:42 +0000286 unsigned NumIvars = Record[Idx++];
287 llvm::SmallVector<ObjCIvarDecl *, 16> IVars;
288 IVars.reserve(NumIvars);
289 for (unsigned I = 0; I != NumIvars; ++I)
290 IVars.push_back(cast<ObjCIvarDecl>(Reader.GetDecl(Record[Idx++])));
Jay Foadbeaaccd2009-05-21 09:52:38 +0000291 ID->setIVarList(IVars.data(), NumIvars, *Reader.getContext());
Chris Lattner698f9252009-04-27 05:27:42 +0000292 ID->setCategoryList(
293 cast_or_null<ObjCCategoryDecl>(Reader.GetDecl(Record[Idx++])));
294 ID->setForwardDecl(Record[Idx++]);
295 ID->setImplicitInterfaceDecl(Record[Idx++]);
296 ID->setClassLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
297 ID->setSuperClassLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
Argyrios Kyrtzidisc999f1f2009-07-18 00:33:23 +0000298 ID->setLocEnd(SourceLocation::getFromRawEncoding(Record[Idx++]));
Chris Lattner698f9252009-04-27 05:27:42 +0000299}
300
301void PCHDeclReader::VisitObjCIvarDecl(ObjCIvarDecl *IVD) {
302 VisitFieldDecl(IVD);
303 IVD->setAccessControl((ObjCIvarDecl::AccessControl)Record[Idx++]);
304}
305
306void PCHDeclReader::VisitObjCProtocolDecl(ObjCProtocolDecl *PD) {
307 VisitObjCContainerDecl(PD);
308 PD->setForwardDecl(Record[Idx++]);
309 PD->setLocEnd(SourceLocation::getFromRawEncoding(Record[Idx++]));
310 unsigned NumProtoRefs = Record[Idx++];
311 llvm::SmallVector<ObjCProtocolDecl *, 16> ProtoRefs;
312 ProtoRefs.reserve(NumProtoRefs);
313 for (unsigned I = 0; I != NumProtoRefs; ++I)
314 ProtoRefs.push_back(cast<ObjCProtocolDecl>(Reader.GetDecl(Record[Idx++])));
Jay Foadbeaaccd2009-05-21 09:52:38 +0000315 PD->setProtocolList(ProtoRefs.data(), NumProtoRefs, *Reader.getContext());
Chris Lattner698f9252009-04-27 05:27:42 +0000316}
317
318void PCHDeclReader::VisitObjCAtDefsFieldDecl(ObjCAtDefsFieldDecl *FD) {
319 VisitFieldDecl(FD);
320}
321
322void PCHDeclReader::VisitObjCClassDecl(ObjCClassDecl *CD) {
323 VisitDecl(CD);
324 unsigned NumClassRefs = Record[Idx++];
325 llvm::SmallVector<ObjCInterfaceDecl *, 16> ClassRefs;
326 ClassRefs.reserve(NumClassRefs);
327 for (unsigned I = 0; I != NumClassRefs; ++I)
328 ClassRefs.push_back(cast<ObjCInterfaceDecl>(Reader.GetDecl(Record[Idx++])));
Douglas Gregor75fdb232009-05-22 22:45:36 +0000329 CD->setClassList(*Reader.getContext(), ClassRefs.data(), NumClassRefs);
Chris Lattner698f9252009-04-27 05:27:42 +0000330}
331
332void PCHDeclReader::VisitObjCForwardProtocolDecl(ObjCForwardProtocolDecl *FPD) {
333 VisitDecl(FPD);
334 unsigned NumProtoRefs = Record[Idx++];
335 llvm::SmallVector<ObjCProtocolDecl *, 16> ProtoRefs;
336 ProtoRefs.reserve(NumProtoRefs);
337 for (unsigned I = 0; I != NumProtoRefs; ++I)
338 ProtoRefs.push_back(cast<ObjCProtocolDecl>(Reader.GetDecl(Record[Idx++])));
Douglas Gregor75fdb232009-05-22 22:45:36 +0000339 FPD->setProtocolList(ProtoRefs.data(), NumProtoRefs, *Reader.getContext());
Chris Lattner698f9252009-04-27 05:27:42 +0000340}
341
342void PCHDeclReader::VisitObjCCategoryDecl(ObjCCategoryDecl *CD) {
343 VisitObjCContainerDecl(CD);
344 CD->setClassInterface(cast<ObjCInterfaceDecl>(Reader.GetDecl(Record[Idx++])));
345 unsigned NumProtoRefs = Record[Idx++];
346 llvm::SmallVector<ObjCProtocolDecl *, 16> ProtoRefs;
347 ProtoRefs.reserve(NumProtoRefs);
348 for (unsigned I = 0; I != NumProtoRefs; ++I)
349 ProtoRefs.push_back(cast<ObjCProtocolDecl>(Reader.GetDecl(Record[Idx++])));
Ted Kremenek66ef1112009-05-22 22:34:23 +0000350 CD->setProtocolList(ProtoRefs.data(), NumProtoRefs, *Reader.getContext());
Chris Lattner698f9252009-04-27 05:27:42 +0000351 CD->setNextClassCategory(cast_or_null<ObjCCategoryDecl>(Reader.GetDecl(Record[Idx++])));
352 CD->setLocEnd(SourceLocation::getFromRawEncoding(Record[Idx++]));
353}
354
355void PCHDeclReader::VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *CAD) {
356 VisitNamedDecl(CAD);
357 CAD->setClassInterface(cast<ObjCInterfaceDecl>(Reader.GetDecl(Record[Idx++])));
358}
359
360void PCHDeclReader::VisitObjCPropertyDecl(ObjCPropertyDecl *D) {
361 VisitNamedDecl(D);
362 D->setType(Reader.GetType(Record[Idx++]));
363 // FIXME: stable encoding
364 D->setPropertyAttributes(
365 (ObjCPropertyDecl::PropertyAttributeKind)Record[Idx++]);
366 // FIXME: stable encoding
367 D->setPropertyImplementation(
368 (ObjCPropertyDecl::PropertyControl)Record[Idx++]);
369 D->setGetterName(Reader.ReadDeclarationName(Record, Idx).getObjCSelector());
370 D->setSetterName(Reader.ReadDeclarationName(Record, Idx).getObjCSelector());
371 D->setGetterMethodDecl(
372 cast_or_null<ObjCMethodDecl>(Reader.GetDecl(Record[Idx++])));
373 D->setSetterMethodDecl(
374 cast_or_null<ObjCMethodDecl>(Reader.GetDecl(Record[Idx++])));
375 D->setPropertyIvarDecl(
376 cast_or_null<ObjCIvarDecl>(Reader.GetDecl(Record[Idx++])));
377}
378
379void PCHDeclReader::VisitObjCImplDecl(ObjCImplDecl *D) {
Argyrios Kyrtzidisaecae622009-07-27 19:04:32 +0000380 VisitObjCContainerDecl(D);
Chris Lattner698f9252009-04-27 05:27:42 +0000381 D->setClassInterface(
382 cast_or_null<ObjCInterfaceDecl>(Reader.GetDecl(Record[Idx++])));
Chris Lattner698f9252009-04-27 05:27:42 +0000383}
384
385void PCHDeclReader::VisitObjCCategoryImplDecl(ObjCCategoryImplDecl *D) {
386 VisitObjCImplDecl(D);
387 D->setIdentifier(Reader.GetIdentifierInfo(Record, Idx));
388}
389
390void PCHDeclReader::VisitObjCImplementationDecl(ObjCImplementationDecl *D) {
391 VisitObjCImplDecl(D);
392 D->setSuperClass(
393 cast_or_null<ObjCInterfaceDecl>(Reader.GetDecl(Record[Idx++])));
394}
395
396
397void PCHDeclReader::VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D) {
398 VisitDecl(D);
399 D->setAtLoc(SourceLocation::getFromRawEncoding(Record[Idx++]));
400 D->setPropertyDecl(
401 cast_or_null<ObjCPropertyDecl>(Reader.GetDecl(Record[Idx++])));
402 D->setPropertyIvarDecl(
403 cast_or_null<ObjCIvarDecl>(Reader.GetDecl(Record[Idx++])));
404}
405
406void PCHDeclReader::VisitFieldDecl(FieldDecl *FD) {
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +0000407 VisitDeclaratorDecl(FD);
Chris Lattner698f9252009-04-27 05:27:42 +0000408 FD->setMutable(Record[Idx++]);
409 if (Record[Idx++])
Chris Lattnerda930612009-04-27 05:58:23 +0000410 FD->setBitWidth(Reader.ReadDeclExpr());
Chris Lattner698f9252009-04-27 05:27:42 +0000411}
412
413void PCHDeclReader::VisitVarDecl(VarDecl *VD) {
Argyrios Kyrtzidisd4a7e542009-08-19 01:28:35 +0000414 VisitDeclaratorDecl(VD);
Chris Lattner698f9252009-04-27 05:27:42 +0000415 VD->setStorageClass((VarDecl::StorageClass)Record[Idx++]);
416 VD->setThreadSpecified(Record[Idx++]);
417 VD->setCXXDirectInitializer(Record[Idx++]);
418 VD->setDeclaredInCondition(Record[Idx++]);
419 VD->setPreviousDeclaration(
420 cast_or_null<VarDecl>(Reader.GetDecl(Record[Idx++])));
Chris Lattner698f9252009-04-27 05:27:42 +0000421 if (Record[Idx++])
Douglas Gregor78d15832009-05-26 18:54:04 +0000422 VD->setInit(*Reader.getContext(), Reader.ReadDeclExpr());
Chris Lattner698f9252009-04-27 05:27:42 +0000423}
424
425void PCHDeclReader::VisitImplicitParamDecl(ImplicitParamDecl *PD) {
426 VisitVarDecl(PD);
427}
428
429void PCHDeclReader::VisitParmVarDecl(ParmVarDecl *PD) {
430 VisitVarDecl(PD);
431 PD->setObjCDeclQualifier((Decl::ObjCDeclQualifier)Record[Idx++]);
Chris Lattner698f9252009-04-27 05:27:42 +0000432}
433
434void PCHDeclReader::VisitOriginalParmVarDecl(OriginalParmVarDecl *PD) {
435 VisitParmVarDecl(PD);
436 PD->setOriginalType(Reader.GetType(Record[Idx++]));
437}
438
439void PCHDeclReader::VisitFileScopeAsmDecl(FileScopeAsmDecl *AD) {
440 VisitDecl(AD);
Chris Lattnerda930612009-04-27 05:58:23 +0000441 AD->setAsmString(cast<StringLiteral>(Reader.ReadDeclExpr()));
Chris Lattner698f9252009-04-27 05:27:42 +0000442}
443
444void PCHDeclReader::VisitBlockDecl(BlockDecl *BD) {
445 VisitDecl(BD);
Chris Lattnerda930612009-04-27 05:58:23 +0000446 BD->setBody(cast_or_null<CompoundStmt>(Reader.ReadDeclStmt()));
Chris Lattner698f9252009-04-27 05:27:42 +0000447 unsigned NumParams = Record[Idx++];
448 llvm::SmallVector<ParmVarDecl *, 16> Params;
449 Params.reserve(NumParams);
450 for (unsigned I = 0; I != NumParams; ++I)
451 Params.push_back(cast<ParmVarDecl>(Reader.GetDecl(Record[Idx++])));
Mike Stump1eb44332009-09-09 15:08:12 +0000452 BD->setParams(*Reader.getContext(), Params.data(), NumParams);
Chris Lattner698f9252009-04-27 05:27:42 +0000453}
454
Mike Stump1eb44332009-09-09 15:08:12 +0000455std::pair<uint64_t, uint64_t>
Chris Lattner698f9252009-04-27 05:27:42 +0000456PCHDeclReader::VisitDeclContext(DeclContext *DC) {
457 uint64_t LexicalOffset = Record[Idx++];
458 uint64_t VisibleOffset = Record[Idx++];
459 return std::make_pair(LexicalOffset, VisibleOffset);
460}
461
462//===----------------------------------------------------------------------===//
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000463// Attribute Reading
Chris Lattner698f9252009-04-27 05:27:42 +0000464//===----------------------------------------------------------------------===//
465
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000466/// \brief Reads attributes from the current stream position.
467Attr *PCHReader::ReadAttributes() {
468 unsigned Code = DeclsCursor.ReadCode();
Mike Stump1eb44332009-09-09 15:08:12 +0000469 assert(Code == llvm::bitc::UNABBREV_RECORD &&
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000470 "Expected unabbreviated record"); (void)Code;
Mike Stump1eb44332009-09-09 15:08:12 +0000471
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000472 RecordData Record;
473 unsigned Idx = 0;
474 unsigned RecCode = DeclsCursor.ReadRecord(Code, Record);
Mike Stump1eb44332009-09-09 15:08:12 +0000475 assert(RecCode == pch::DECL_ATTR && "Expected attribute record");
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000476 (void)RecCode;
477
478#define SIMPLE_ATTR(Name) \
479 case Attr::Name: \
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000480 New = ::new (*Context) Name##Attr(); \
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000481 break
482
483#define STRING_ATTR(Name) \
484 case Attr::Name: \
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000485 New = ::new (*Context) Name##Attr(ReadString(Record, Idx)); \
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000486 break
487
488#define UNSIGNED_ATTR(Name) \
489 case Attr::Name: \
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000490 New = ::new (*Context) Name##Attr(Record[Idx++]); \
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000491 break
492
493 Attr *Attrs = 0;
494 while (Idx < Record.size()) {
495 Attr *New = 0;
496 Attr::Kind Kind = (Attr::Kind)Record[Idx++];
497 bool IsInherited = Record[Idx++];
498
499 switch (Kind) {
500 STRING_ATTR(Alias);
501 UNSIGNED_ATTR(Aligned);
502 SIMPLE_ATTR(AlwaysInline);
503 SIMPLE_ATTR(AnalyzerNoReturn);
504 STRING_ATTR(Annotate);
505 STRING_ATTR(AsmLabel);
Mike Stump1eb44332009-09-09 15:08:12 +0000506
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000507 case Attr::Blocks:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000508 New = ::new (*Context) BlocksAttr(
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000509 (BlocksAttr::BlocksAttrTypes)Record[Idx++]);
510 break;
Mike Stump1eb44332009-09-09 15:08:12 +0000511
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000512 case Attr::Cleanup:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000513 New = ::new (*Context) CleanupAttr(
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000514 cast<FunctionDecl>(GetDecl(Record[Idx++])));
515 break;
516
517 SIMPLE_ATTR(Const);
518 UNSIGNED_ATTR(Constructor);
519 SIMPLE_ATTR(DLLExport);
520 SIMPLE_ATTR(DLLImport);
521 SIMPLE_ATTR(Deprecated);
522 UNSIGNED_ATTR(Destructor);
523 SIMPLE_ATTR(FastCall);
Mike Stump1eb44332009-09-09 15:08:12 +0000524
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000525 case Attr::Format: {
526 std::string Type = ReadString(Record, Idx);
527 unsigned FormatIdx = Record[Idx++];
528 unsigned FirstArg = Record[Idx++];
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000529 New = ::new (*Context) FormatAttr(Type, FormatIdx, FirstArg);
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000530 break;
531 }
Mike Stump1eb44332009-09-09 15:08:12 +0000532
Fariborz Jahanian5b160922009-05-20 17:41:43 +0000533 case Attr::FormatArg: {
534 unsigned FormatIdx = Record[Idx++];
535 New = ::new (*Context) FormatArgAttr(FormatIdx);
536 break;
537 }
Mike Stump1eb44332009-09-09 15:08:12 +0000538
Fariborz Jahanian5b530052009-05-13 18:09:35 +0000539 case Attr::Sentinel: {
540 int sentinel = Record[Idx++];
541 int nullPos = Record[Idx++];
542 New = ::new (*Context) SentinelAttr(sentinel, nullPos);
543 break;
544 }
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000545
546 SIMPLE_ATTR(GNUInline);
Mike Stump1eb44332009-09-09 15:08:12 +0000547
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000548 case Attr::IBOutletKind:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000549 New = ::new (*Context) IBOutletAttr();
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000550 break;
551
Ryan Flynn76168e22009-08-09 20:07:29 +0000552 SIMPLE_ATTR(Malloc);
Mike Stump1feade82009-08-26 22:31:08 +0000553 SIMPLE_ATTR(NoDebug);
554 SIMPLE_ATTR(NoInline);
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000555 SIMPLE_ATTR(NoReturn);
556 SIMPLE_ATTR(NoThrow);
Mike Stump1eb44332009-09-09 15:08:12 +0000557
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000558 case Attr::NonNull: {
559 unsigned Size = Record[Idx++];
560 llvm::SmallVector<unsigned, 16> ArgNums;
561 ArgNums.insert(ArgNums.end(), &Record[Idx], &Record[Idx] + Size);
562 Idx += Size;
Douglas Gregor75fdb232009-05-22 22:45:36 +0000563 New = ::new (*Context) NonNullAttr(ArgNums.data(), Size);
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000564 break;
565 }
Mike Stump1eb44332009-09-09 15:08:12 +0000566
Nate Begeman6f3d8382009-06-26 06:32:41 +0000567 case Attr::ReqdWorkGroupSize: {
568 unsigned X = Record[Idx++];
569 unsigned Y = Record[Idx++];
570 unsigned Z = Record[Idx++];
571 New = ::new (*Context) ReqdWorkGroupSizeAttr(X, Y, Z);
572 break;
573 }
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000574
575 SIMPLE_ATTR(ObjCException);
576 SIMPLE_ATTR(ObjCNSObject);
Ted Kremenekb71368d2009-05-09 02:44:38 +0000577 SIMPLE_ATTR(CFReturnsRetained);
578 SIMPLE_ATTR(NSReturnsRetained);
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000579 SIMPLE_ATTR(Overloadable);
Anders Carlssona860e752009-08-08 18:23:56 +0000580 SIMPLE_ATTR(Packed);
581 UNSIGNED_ATTR(PragmaPack);
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000582 SIMPLE_ATTR(Pure);
583 UNSIGNED_ATTR(Regparm);
584 STRING_ATTR(Section);
585 SIMPLE_ATTR(StdCall);
586 SIMPLE_ATTR(TransparentUnion);
587 SIMPLE_ATTR(Unavailable);
588 SIMPLE_ATTR(Unused);
589 SIMPLE_ATTR(Used);
Mike Stump1eb44332009-09-09 15:08:12 +0000590
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000591 case Attr::Visibility:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000592 New = ::new (*Context) VisibilityAttr(
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000593 (VisibilityAttr::VisibilityTypes)Record[Idx++]);
594 break;
595
596 SIMPLE_ATTR(WarnUnusedResult);
597 SIMPLE_ATTR(Weak);
598 SIMPLE_ATTR(WeakImport);
599 }
600
601 assert(New && "Unable to decode attribute?");
602 New->setInherited(IsInherited);
603 New->setNext(Attrs);
604 Attrs = New;
605 }
606#undef UNSIGNED_ATTR
607#undef STRING_ATTR
608#undef SIMPLE_ATTR
609
610 // The list of attributes was built backwards. Reverse the list
611 // before returning it.
612 Attr *PrevAttr = 0, *NextAttr = 0;
613 while (Attrs) {
614 NextAttr = Attrs->getNext();
615 Attrs->setNext(PrevAttr);
616 PrevAttr = Attrs;
617 Attrs = NextAttr;
618 }
619
620 return PrevAttr;
621}
622
623//===----------------------------------------------------------------------===//
624// PCHReader Implementation
625//===----------------------------------------------------------------------===//
Chris Lattner698f9252009-04-27 05:27:42 +0000626
627/// \brief Note that we have loaded the declaration with the given
628/// Index.
Mike Stump1eb44332009-09-09 15:08:12 +0000629///
Chris Lattner698f9252009-04-27 05:27:42 +0000630/// This routine notes that this declaration has already been loaded,
631/// so that future GetDecl calls will return this declaration rather
632/// than trying to load a new declaration.
633inline void PCHReader::LoadedDecl(unsigned Index, Decl *D) {
634 assert(!DeclsLoaded[Index] && "Decl loaded twice?");
635 DeclsLoaded[Index] = D;
636}
637
638
639/// \brief Determine whether the consumer will be interested in seeing
640/// this declaration (via HandleTopLevelDecl).
641///
642/// This routine should return true for anything that might affect
643/// code generation, e.g., inline function definitions, Objective-C
644/// declarations with metadata, etc.
645static bool isConsumerInterestedIn(Decl *D) {
Daniel Dunbar04a0b502009-09-17 03:06:44 +0000646 if (isa<FileScopeAsmDecl>(D))
647 return true;
Chris Lattner698f9252009-04-27 05:27:42 +0000648 if (VarDecl *Var = dyn_cast<VarDecl>(D))
649 return Var->isFileVarDecl() && Var->getInit();
650 if (FunctionDecl *Func = dyn_cast<FunctionDecl>(D))
651 return Func->isThisDeclarationADefinition();
652 return isa<ObjCProtocolDecl>(D);
653}
654
655/// \brief Read the declaration at the given offset from the PCH file.
656Decl *PCHReader::ReadDeclRecord(uint64_t Offset, unsigned Index) {
657 // Keep track of where we are in the stream, then jump back there
658 // after reading this declaration.
Chris Lattnerda930612009-04-27 05:58:23 +0000659 SavedStreamPosition SavedPosition(DeclsCursor);
Chris Lattner698f9252009-04-27 05:27:42 +0000660
Douglas Gregord89275b2009-07-06 18:54:52 +0000661 // Note that we are loading a declaration record.
662 LoadingTypeOrDecl Loading(*this);
Mike Stump1eb44332009-09-09 15:08:12 +0000663
Chris Lattnerda930612009-04-27 05:58:23 +0000664 DeclsCursor.JumpToBit(Offset);
Chris Lattner698f9252009-04-27 05:27:42 +0000665 RecordData Record;
Chris Lattnerda930612009-04-27 05:58:23 +0000666 unsigned Code = DeclsCursor.ReadCode();
Chris Lattner698f9252009-04-27 05:27:42 +0000667 unsigned Idx = 0;
668 PCHDeclReader Reader(*this, Record, Idx);
669
Chris Lattnerda930612009-04-27 05:58:23 +0000670 Decl *D = 0;
671 switch ((pch::DeclCode)DeclsCursor.ReadRecord(Code, Record)) {
Chris Lattner698f9252009-04-27 05:27:42 +0000672 case pch::DECL_ATTR:
673 case pch::DECL_CONTEXT_LEXICAL:
674 case pch::DECL_CONTEXT_VISIBLE:
675 assert(false && "Record cannot be de-serialized with ReadDeclRecord");
676 break;
Chris Lattner698f9252009-04-27 05:27:42 +0000677 case pch::DECL_TRANSLATION_UNIT:
678 assert(Index == 0 && "Translation unit must be at index 0");
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000679 D = Context->getTranslationUnitDecl();
Chris Lattner698f9252009-04-27 05:27:42 +0000680 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000681 case pch::DECL_TYPEDEF:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000682 D = TypedefDecl::Create(*Context, 0, SourceLocation(), 0, QualType());
Chris Lattner698f9252009-04-27 05:27:42 +0000683 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000684 case pch::DECL_ENUM:
Douglas Gregor741dd9a2009-07-21 14:46:17 +0000685 D = EnumDecl::Create(*Context, 0, SourceLocation(), 0, SourceLocation(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000686 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000687 case pch::DECL_RECORD:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000688 D = RecordDecl::Create(*Context, TagDecl::TK_struct, 0, SourceLocation(),
Douglas Gregor741dd9a2009-07-21 14:46:17 +0000689 0, SourceLocation(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000690 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000691 case pch::DECL_ENUM_CONSTANT:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000692 D = EnumConstantDecl::Create(*Context, 0, SourceLocation(), 0, QualType(),
Chris Lattner698f9252009-04-27 05:27:42 +0000693 0, llvm::APSInt());
694 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000695 case pch::DECL_FUNCTION:
Mike Stump1eb44332009-09-09 15:08:12 +0000696 D = FunctionDecl::Create(*Context, 0, SourceLocation(), DeclarationName(),
Argyrios Kyrtzidisa1d56622009-08-19 01:27:57 +0000697 QualType(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000698 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000699 case pch::DECL_OBJC_METHOD:
Mike Stump1eb44332009-09-09 15:08:12 +0000700 D = ObjCMethodDecl::Create(*Context, SourceLocation(), SourceLocation(),
Chris Lattner698f9252009-04-27 05:27:42 +0000701 Selector(), QualType(), 0);
702 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000703 case pch::DECL_OBJC_INTERFACE:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000704 D = ObjCInterfaceDecl::Create(*Context, 0, SourceLocation(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000705 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000706 case pch::DECL_OBJC_IVAR:
Argyrios Kyrtzidisa1d56622009-08-19 01:27:57 +0000707 D = ObjCIvarDecl::Create(*Context, 0, SourceLocation(), 0, QualType(), 0,
Chris Lattner698f9252009-04-27 05:27:42 +0000708 ObjCIvarDecl::None);
709 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000710 case pch::DECL_OBJC_PROTOCOL:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000711 D = ObjCProtocolDecl::Create(*Context, 0, SourceLocation(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000712 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000713 case pch::DECL_OBJC_AT_DEFS_FIELD:
Mike Stump1eb44332009-09-09 15:08:12 +0000714 D = ObjCAtDefsFieldDecl::Create(*Context, 0, SourceLocation(), 0,
Chris Lattner698f9252009-04-27 05:27:42 +0000715 QualType(), 0);
716 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000717 case pch::DECL_OBJC_CLASS:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000718 D = ObjCClassDecl::Create(*Context, 0, SourceLocation());
Chris Lattner698f9252009-04-27 05:27:42 +0000719 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000720 case pch::DECL_OBJC_FORWARD_PROTOCOL:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000721 D = ObjCForwardProtocolDecl::Create(*Context, 0, SourceLocation());
Chris Lattner698f9252009-04-27 05:27:42 +0000722 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000723 case pch::DECL_OBJC_CATEGORY:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000724 D = ObjCCategoryDecl::Create(*Context, 0, SourceLocation(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000725 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000726 case pch::DECL_OBJC_CATEGORY_IMPL:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000727 D = ObjCCategoryImplDecl::Create(*Context, 0, SourceLocation(), 0, 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000728 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000729 case pch::DECL_OBJC_IMPLEMENTATION:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000730 D = ObjCImplementationDecl::Create(*Context, 0, SourceLocation(), 0, 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000731 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000732 case pch::DECL_OBJC_COMPATIBLE_ALIAS:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000733 D = ObjCCompatibleAliasDecl::Create(*Context, 0, SourceLocation(), 0, 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000734 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000735 case pch::DECL_OBJC_PROPERTY:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000736 D = ObjCPropertyDecl::Create(*Context, 0, SourceLocation(), 0, QualType());
Chris Lattner698f9252009-04-27 05:27:42 +0000737 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000738 case pch::DECL_OBJC_PROPERTY_IMPL:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000739 D = ObjCPropertyImplDecl::Create(*Context, 0, SourceLocation(),
Mike Stump1eb44332009-09-09 15:08:12 +0000740 SourceLocation(), 0,
Chris Lattner698f9252009-04-27 05:27:42 +0000741 ObjCPropertyImplDecl::Dynamic, 0);
742 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000743 case pch::DECL_FIELD:
Mike Stump1eb44332009-09-09 15:08:12 +0000744 D = FieldDecl::Create(*Context, 0, SourceLocation(), 0, QualType(), 0, 0,
Argyrios Kyrtzidisa5d82002009-08-21 00:31:54 +0000745 false);
Chris Lattner698f9252009-04-27 05:27:42 +0000746 break;
Chris Lattner698f9252009-04-27 05:27:42 +0000747 case pch::DECL_VAR:
Argyrios Kyrtzidisa1d56622009-08-19 01:27:57 +0000748 D = VarDecl::Create(*Context, 0, SourceLocation(), 0, QualType(), 0,
Argyrios Kyrtzidisa5d82002009-08-21 00:31:54 +0000749 VarDecl::None);
Chris Lattner698f9252009-04-27 05:27:42 +0000750 break;
751
752 case pch::DECL_IMPLICIT_PARAM:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000753 D = ImplicitParamDecl::Create(*Context, 0, SourceLocation(), 0, QualType());
Chris Lattner698f9252009-04-27 05:27:42 +0000754 break;
755
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000756 case pch::DECL_PARM_VAR:
Mike Stump1eb44332009-09-09 15:08:12 +0000757 D = ParmVarDecl::Create(*Context, 0, SourceLocation(), 0, QualType(), 0,
Chris Lattner698f9252009-04-27 05:27:42 +0000758 VarDecl::None, 0);
759 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000760 case pch::DECL_ORIGINAL_PARM_VAR:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000761 D = OriginalParmVarDecl::Create(*Context, 0, SourceLocation(), 0,
Argyrios Kyrtzidisa1d56622009-08-19 01:27:57 +0000762 QualType(),0, QualType(), VarDecl::None, 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000763 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000764 case pch::DECL_FILE_SCOPE_ASM:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000765 D = FileScopeAsmDecl::Create(*Context, 0, SourceLocation(), 0);
Chris Lattner698f9252009-04-27 05:27:42 +0000766 break;
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000767 case pch::DECL_BLOCK:
Chris Lattnerd1d64a02009-04-27 21:45:14 +0000768 D = BlockDecl::Create(*Context, 0, SourceLocation());
Chris Lattner698f9252009-04-27 05:27:42 +0000769 break;
770 }
Chris Lattner698f9252009-04-27 05:27:42 +0000771
772 assert(D && "Unknown declaration reading PCH file");
Chris Lattner4e3fcc82009-04-27 06:01:06 +0000773 LoadedDecl(Index, D);
774 Reader.Visit(D);
Chris Lattner698f9252009-04-27 05:27:42 +0000775
776 // If this declaration is also a declaration context, get the
777 // offsets for its tables of lexical and visible declarations.
778 if (DeclContext *DC = dyn_cast<DeclContext>(D)) {
779 std::pair<uint64_t, uint64_t> Offsets = Reader.VisitDeclContext(DC);
780 if (Offsets.first || Offsets.second) {
781 DC->setHasExternalLexicalStorage(Offsets.first != 0);
782 DC->setHasExternalVisibleStorage(Offsets.second != 0);
783 DeclContextOffsets[DC] = Offsets;
784 }
785 }
786 assert(Idx == Record.size());
787
788 // If we have deserialized a declaration that has a definition the
789 // AST consumer might need to know about, notify the consumer
790 // about that definition now or queue it for later.
791 if (isConsumerInterestedIn(D)) {
792 if (Consumer) {
793 DeclGroupRef DG(D);
794 Consumer->HandleTopLevelDecl(DG);
795 } else {
796 InterestingDecls.push_back(D);
797 }
798 }
799
800 return D;
801}