blob: f620927a8dd6b8a90b85e58adad7fc946a146d87 [file] [log] [blame]
Chris Lattnere91c1342008-02-06 00:23:21 +00001//===--- ParseAST.cpp - Provide the clang::ParseAST method ----------------===//
Reid Spencer5f016e22007-07-11 17:01:13 +00002//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner0bc735f2007-12-29 19:59:25 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Reid Spencer5f016e22007-07-11 17:01:13 +00007//
8//===----------------------------------------------------------------------===//
9//
Chris Lattnere91c1342008-02-06 00:23:21 +000010// This file implements the clang::ParseAST method.
Reid Spencer5f016e22007-07-11 17:01:13 +000011//
12//===----------------------------------------------------------------------===//
13
Chris Lattnere91c1342008-02-06 00:23:21 +000014#include "clang/Sema/ParseAST.h"
Chris Lattner498603d2009-04-19 05:30:08 +000015#include "Sema.h"
Douglas Gregor81b747b2009-09-17 21:32:03 +000016#include "clang/Sema/CodeCompleteConsumer.h"
Douglas Gregore7785042009-04-20 15:53:59 +000017#include "clang/Sema/SemaConsumer.h"
Douglas Gregor668c1a42009-04-21 22:25:48 +000018#include "clang/Sema/ExternalSemaSource.h"
Chris Lattner556beb72007-09-15 22:56:56 +000019#include "clang/AST/ASTConsumer.h"
Douglas Gregorfdd01722009-04-14 00:24:19 +000020#include "clang/AST/ExternalASTSource.h"
Daniel Dunbare91593e2008-08-11 04:54:23 +000021#include "clang/AST/Stmt.h"
Reid Spencer5f016e22007-07-11 17:01:13 +000022#include "clang/Parse/Parser.h"
Torok Edwinf42e4a62009-08-24 13:25:12 +000023#include <cstdio>
24
Reid Spencer5f016e22007-07-11 17:01:13 +000025using namespace clang;
26
Daniel Dunbarb69eca52010-04-08 02:59:56 +000027static void DumpRecordLayouts(ASTContext &C) {
28 for (ASTContext::type_iterator I = C.types_begin(), E = C.types_end();
29 I != E; ++I) {
30 const RecordType *RT = dyn_cast<RecordType>(*I);
31 if (!RT)
32 continue;
33
34 const CXXRecordDecl *RD = dyn_cast<CXXRecordDecl>(RT->getDecl());
35 if (!RD || RD->isImplicit() || RD->isDependentType() ||
36 RD->isInvalidDecl() || !RD->getDefinition())
37 continue;
38
39 // FIXME: Do we really need to hard code this?
40 if (RD->getQualifiedNameAsString() == "__va_list_tag")
41 continue;
42
43 C.DumpRecordLayout(RD, llvm::errs());
44 }
45}
46
Reid Spencer5f016e22007-07-11 17:01:13 +000047//===----------------------------------------------------------------------===//
48// Public interface to the file
49//===----------------------------------------------------------------------===//
50
Chris Lattner556beb72007-09-15 22:56:56 +000051/// ParseAST - Parse the entire file specified, notifying the ASTConsumer as
Chris Lattner3599dbe2009-03-28 04:13:34 +000052/// the file is parsed. This inserts the parsed decls into the translation unit
53/// held by Ctx.
Daniel Dunbard3db4012008-10-16 16:54:18 +000054///
Ted Kremenek46157b52009-01-28 04:29:29 +000055void clang::ParseAST(Preprocessor &PP, ASTConsumer *Consumer,
Douglas Gregorf807fe02009-04-14 16:27:31 +000056 ASTContext &Ctx, bool PrintStats,
Douglas Gregor81b747b2009-09-17 21:32:03 +000057 bool CompleteTranslationUnit,
Daniel Dunbar3a2838d2009-11-13 08:58:20 +000058 CodeCompleteConsumer *CompletionConsumer) {
Chris Lattner556beb72007-09-15 22:56:56 +000059 // Collect global stats on Decls/Stmts (until we have a module streamer).
60 if (PrintStats) {
61 Decl::CollectingStats(true);
62 Stmt::CollectingStats(true);
63 }
Ted Kremenek46157b52009-01-28 04:29:29 +000064
Daniel Dunbar3a2838d2009-11-13 08:58:20 +000065 Sema S(PP, Ctx, *Consumer, CompleteTranslationUnit, CompletionConsumer);
Eli Friedman80f33462008-05-27 04:23:47 +000066 Parser P(PP, S);
Douglas Gregordbf8ee62010-03-17 15:44:30 +000067 if (PP.EnterMainSourceFile())
68 return;
Mike Stump1eb44332009-09-09 15:08:12 +000069
Chris Lattnera0e328f2008-02-06 00:15:02 +000070 // Initialize the parser.
71 P.Initialize();
Mike Stump1eb44332009-09-09 15:08:12 +000072
Chris Lattner3599dbe2009-03-28 04:13:34 +000073 Consumer->Initialize(Ctx);
Mike Stump1eb44332009-09-09 15:08:12 +000074
Douglas Gregore7785042009-04-20 15:53:59 +000075 if (SemaConsumer *SC = dyn_cast<SemaConsumer>(Consumer))
76 SC->InitializeSema(S);
77
Douglas Gregor668c1a42009-04-21 22:25:48 +000078 if (ExternalASTSource *External = Ctx.getExternalSource()) {
Mike Stump1eb44332009-09-09 15:08:12 +000079 if (ExternalSemaSource *ExternalSema =
Douglas Gregor668c1a42009-04-21 22:25:48 +000080 dyn_cast<ExternalSemaSource>(External))
81 ExternalSema->InitializeSema(S);
82
83 External->StartTranslationUnit(Consumer);
84 }
Douglas Gregorfdd01722009-04-14 00:24:19 +000085
Chris Lattner682bf922009-03-29 16:50:03 +000086 Parser::DeclGroupPtrTy ADecl;
Mike Stump1eb44332009-09-09 15:08:12 +000087
Chris Lattnera0e328f2008-02-06 00:15:02 +000088 while (!P.ParseTopLevelDecl(ADecl)) { // Not end of file.
89 // If we got a null return and something *was* parsed, ignore it. This
90 // is due to a top-level semicolon, an action override, or a parse error
91 // skipping something.
Chris Lattner682bf922009-03-29 16:50:03 +000092 if (ADecl)
93 Consumer->HandleTopLevelDecl(ADecl.getAsVal<DeclGroupRef>());
Chris Lattnera0e328f2008-02-06 00:15:02 +000094 };
Fariborz Jahanian63e963c2009-11-16 18:57:01 +000095 // Check for any pending objective-c implementation decl.
Fariborz Jahanian1ac71042009-11-17 17:15:16 +000096 while ((ADecl = P.RetrievePendingObjCImpDecl()))
Fariborz Jahanian63e963c2009-11-16 18:57:01 +000097 Consumer->HandleTopLevelDecl(ADecl.getAsVal<DeclGroupRef>());
Mike Stump1eb44332009-09-09 15:08:12 +000098
Daniel Dunbarec2a4ed2009-12-01 21:57:20 +000099 // Process any TopLevelDecls generated by #pragma weak.
Ryan Flynn7b1fdbd2009-07-31 02:52:19 +0000100 for (llvm::SmallVector<Decl*,2>::iterator
101 I = S.WeakTopLevelDecls().begin(),
102 E = S.WeakTopLevelDecls().end(); I != E; ++I)
103 Consumer->HandleTopLevelDecl(DeclGroupRef(*I));
104
Daniel Dunbarb69eca52010-04-08 02:59:56 +0000105 // Dump record layouts, if requested.
106 if (PP.getLangOptions().DumpRecordLayouts)
107 DumpRecordLayouts(Ctx);
108
Chris Lattner3599dbe2009-03-28 04:13:34 +0000109 Consumer->HandleTranslationUnit(Ctx);
Fariborz Jahanian26e4cd32007-10-26 19:46:17 +0000110
Daniel Dunbarec2a4ed2009-12-01 21:57:20 +0000111 if (ExternalSemaSource *ESS =
112 dyn_cast_or_null<ExternalSemaSource>(Ctx.getExternalSource()))
113 ESS->ForgetSema();
114
115 if (SemaConsumer *SC = dyn_cast<SemaConsumer>(Consumer))
116 SC->ForgetSema();
117
Chris Lattner556beb72007-09-15 22:56:56 +0000118 if (PrintStats) {
119 fprintf(stderr, "\nSTATISTICS:\n");
Chris Lattnera0e328f2008-02-06 00:15:02 +0000120 P.getActions().PrintStats();
Chris Lattner3599dbe2009-03-28 04:13:34 +0000121 Ctx.PrintStats();
Chris Lattner556beb72007-09-15 22:56:56 +0000122 Decl::PrintStats();
123 Stmt::PrintStats();
Chris Lattner31e6c7d2007-11-03 06:24:16 +0000124 Consumer->PrintStats();
Chris Lattner556beb72007-09-15 22:56:56 +0000125 }
126}