blob: 7999da01d91e9c96d65c0ae842621ac4aa1108a0 [file] [log] [blame]
Reid Spencer5f016e22007-07-11 17:01:13 +00001//===--- PrintParserActions.cpp - Implement -parse-print-callbacks mode ---===//
2//
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//
10// This code simply runs the preprocessor on the input file and prints out the
11// result. This is the traditional behavior of the -E option.
12//
13//===----------------------------------------------------------------------===//
14
15#include "clang.h"
Reid Spencer5f016e22007-07-11 17:01:13 +000016#include "clang/Parse/Action.h"
17#include "clang/Parse/DeclSpec.h"
Ted Kremenekbdd30c22008-01-14 16:44:48 +000018#include "llvm/Support/Streams.h"
Reid Spencer5f016e22007-07-11 17:01:13 +000019using namespace clang;
20
21namespace {
22 class ParserPrintActions : public MinimalAction {
23
Steve Naroffb4292f22007-10-31 20:55:39 +000024 public:
Daniel Dunbare10b0f22008-10-31 08:56:51 +000025 ParserPrintActions(Preprocessor &PP) : MinimalAction(PP) {}
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +000026
27 // Printing Functions which also must call MinimalAction
28
Steve Naroff08d92e42007-09-15 18:49:24 +000029 /// ActOnDeclarator - This callback is invoked when a declarator is parsed
Reid Spencer5f016e22007-07-11 17:01:13 +000030 /// and 'Init' specifies the initializer if any. This is for things like:
31 /// "int X = 4" or "typedef int foo".
Steve Naroff08d92e42007-09-15 18:49:24 +000032 virtual DeclTy *ActOnDeclarator(Scope *S, Declarator &D,
Daniel Dunbar914701e2008-08-05 16:28:08 +000033 DeclTy *LastInGroup) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +000034 llvm::cout << __FUNCTION__ << " ";
Reid Spencer5f016e22007-07-11 17:01:13 +000035 if (IdentifierInfo *II = D.getIdentifier()) {
Ted Kremenekbdd30c22008-01-14 16:44:48 +000036 llvm::cout << "'" << II->getName() << "'";
Reid Spencer5f016e22007-07-11 17:01:13 +000037 } else {
Ted Kremenekbdd30c22008-01-14 16:44:48 +000038 llvm::cout << "<anon>";
Reid Spencer5f016e22007-07-11 17:01:13 +000039 }
Ted Kremenekbdd30c22008-01-14 16:44:48 +000040 llvm::cout << "\n";
Reid Spencer5f016e22007-07-11 17:01:13 +000041
42 // Pass up to EmptyActions so that the symbol table is maintained right.
Daniel Dunbar914701e2008-08-05 16:28:08 +000043 return MinimalAction::ActOnDeclarator(S, D, LastInGroup);
Reid Spencer5f016e22007-07-11 17:01:13 +000044 }
Steve Naroff640db422007-10-10 17:45:44 +000045 /// ActOnPopScope - This callback is called immediately before the specified
46 /// scope is popped and deleted.
47 virtual void ActOnPopScope(SourceLocation Loc, Scope *S) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +000048 llvm::cout << __FUNCTION__ << "\n";
49 return MinimalAction::ActOnPopScope(Loc, S);
50 }
51
52 /// ActOnTranslationUnitScope - This callback is called once, immediately
53 /// after creating the translation unit scope (in Parser::Initialize).
54 virtual void ActOnTranslationUnitScope(SourceLocation Loc, Scope *S) {
55 llvm::cout << __FUNCTION__ << "\n";
56 MinimalAction::ActOnTranslationUnitScope(Loc, S);
57 }
58
59
60 Action::DeclTy *ActOnStartClassInterface(SourceLocation AtInterfaceLoc,
61 IdentifierInfo *ClassName,
62 SourceLocation ClassLoc,
63 IdentifierInfo *SuperName,
64 SourceLocation SuperLoc,
65 DeclTy * const *ProtoRefs,
66 unsigned NumProtocols,
67 SourceLocation EndProtoLoc,
68 AttributeList *AttrList) {
69 llvm::cout << __FUNCTION__ << "\n";
70 return MinimalAction::ActOnStartClassInterface(AtInterfaceLoc,
71 ClassName, ClassLoc,
72 SuperName, SuperLoc,
73 ProtoRefs, NumProtocols,
74 EndProtoLoc, AttrList);
75 }
76
77 /// ActOnForwardClassDeclaration -
78 /// Scope will always be top level file scope.
79 Action::DeclTy *ActOnForwardClassDeclaration(SourceLocation AtClassLoc,
80 IdentifierInfo **IdentList,
81 unsigned NumElts) {
82 llvm::cout << __FUNCTION__ << "\n";
83 return MinimalAction::ActOnForwardClassDeclaration(AtClassLoc, IdentList,
84 NumElts);
85 }
86
87 // Pure Printing
88
89 /// ActOnParamDeclarator - This callback is invoked when a parameter
90 /// declarator is parsed. This callback only occurs for functions
91 /// with prototypes. S is the function prototype scope for the
92 /// parameters (C++ [basic.scope.proto]).
93 virtual DeclTy *ActOnParamDeclarator(Scope *S, Declarator &D) {
94 llvm::cout << __FUNCTION__ << " ";
95 if (IdentifierInfo *II = D.getIdentifier()) {
96 llvm::cout << "'" << II->getName() << "'";
97 } else {
98 llvm::cout << "<anon>";
99 }
100 llvm::cout << "\n";
101 return 0;
102 }
103
104 /// AddInitializerToDecl - This action is called immediately after
105 /// ParseDeclarator (when an initializer is present). The code is factored
106 /// this way to make sure we are able to handle the following:
107 /// void func() { int xx = xx; }
108 /// This allows ActOnDeclarator to register "xx" prior to parsing the
109 /// initializer. The declaration above should still result in a warning,
110 /// since the reference to "xx" is uninitialized.
Sebastian Redl798d1192008-12-13 16:23:55 +0000111 virtual void AddInitializerToDecl(DeclTy *Dcl, ExprArg Init) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000112 llvm::cout << __FUNCTION__ << "\n";
113 }
114
115 /// FinalizeDeclaratorGroup - After a sequence of declarators are parsed, this
116 /// gives the actions implementation a chance to process the group as a whole.
117 virtual DeclTy *FinalizeDeclaratorGroup(Scope *S, DeclTy *Group) {
118 llvm::cout << __FUNCTION__ << "\n";
119 return 0;
120 }
121
122 /// ActOnStartOfFunctionDef - This is called at the start of a function
123 /// definition, instead of calling ActOnDeclarator. The Declarator includes
124 /// information about formal arguments that are part of this function.
125 virtual DeclTy *ActOnStartOfFunctionDef(Scope *FnBodyScope, Declarator &D) {
126 llvm::cout << __FUNCTION__ << "\n";
127 return 0;
128 }
129
130 /// ActOnStartOfFunctionDef - This is called at the start of a function
131 /// definition, after the FunctionDecl has already been created.
132 virtual DeclTy *ActOnStartOfFunctionDef(Scope *FnBodyScope, DeclTy *D) {
133 llvm::cout << __FUNCTION__ << "\n";
134 return 0;
135 }
136
137 virtual void ObjCActOnStartOfMethodDef(Scope *FnBodyScope, DeclTy *D) {
138 llvm::cout << __FUNCTION__ << "\n";
139 }
140
141 /// ActOnFunctionDefBody - This is called when a function body has completed
142 /// parsing. Decl is the DeclTy returned by ParseStartOfFunctionDef.
Sebastian Redl798d1192008-12-13 16:23:55 +0000143 virtual DeclTy *ActOnFinishFunctionBody(DeclTy *Decl, StmtArg Body) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000144 llvm::cout << __FUNCTION__ << "\n";
145 return 0;
146 }
147
Sebastian Redl798d1192008-12-13 16:23:55 +0000148 virtual DeclTy *ActOnFileScopeAsmDecl(SourceLocation Loc, ExprArg AsmString) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000149 llvm::cout << __FUNCTION__ << "\n";
150 return 0;
151 }
152
153 /// ParsedFreeStandingDeclSpec - This method is invoked when a declspec with
154 /// no declarator (e.g. "struct foo;") is parsed.
155 virtual DeclTy *ParsedFreeStandingDeclSpec(Scope *S, DeclSpec &DS) {
156 llvm::cout << __FUNCTION__ << "\n";
157 return 0;
158 }
Douglas Gregore79837a2008-12-17 01:46:43 +0000159
160 /// ActOnLinkageSpec - Parsed a C++ linkage-specification that
161 /// contained braces. Lang/StrSize contains the language string that
162 /// was parsed at location Loc. Decls/NumDecls provides the
163 /// declarations parsed inside the linkage specification.
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000164 virtual DeclTy *ActOnLinkageSpec(SourceLocation Loc, SourceLocation LBrace,
165 SourceLocation RBrace, const char *Lang,
Douglas Gregore79837a2008-12-17 01:46:43 +0000166 unsigned StrSize,
167 DeclTy **Decls, unsigned NumDecls) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000168 llvm::cout << __FUNCTION__ << "\n";
169 return 0;
170 }
Douglas Gregore79837a2008-12-17 01:46:43 +0000171
172 /// ActOnLinkageSpec - Parsed a C++ linkage-specification without
173 /// braces. Lang/StrSize contains the language string that was
174 /// parsed at location Loc. D is the declaration parsed.
175 virtual DeclTy *ActOnLinkageSpec(SourceLocation Loc, const char *Lang,
176 unsigned StrSize, DeclTy *D) {
177 return 0;
178 }
179
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000180 //===--------------------------------------------------------------------===//
181 // Type Parsing Callbacks.
182 //===--------------------------------------------------------------------===//
183
Sebastian Redlcee63fb2008-12-02 14:43:59 +0000184 virtual TypeResult ActOnTypeName(Scope *S, Declarator &D) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000185 llvm::cout << __FUNCTION__ << "\n";
186 return 0;
187 }
188
189 virtual DeclTy *ActOnTag(Scope *S, unsigned TagType, TagKind TK,
Argyrios Kyrtzidiseb83ecd2008-11-08 16:45:02 +0000190 SourceLocation KWLoc, const CXXScopeSpec &SS,
191 IdentifierInfo *Name, SourceLocation NameLoc,
Douglas Gregorc4b4e7b2008-12-24 02:52:09 +0000192 AttributeList *Attr,
193 MultiTemplateParamsArg TemplateParameterLists) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000194 // TagType is an instance of DeclSpec::TST, indicating what kind of tag this
195 // is (struct/union/enum/class).
196 llvm::cout << __FUNCTION__ << "\n";
197 return 0;
198 }
199
200 /// Act on @defs() element found when parsing a structure. ClassName is the
201 /// name of the referenced class.
Douglas Gregor44b43212008-12-11 16:49:14 +0000202 virtual void ActOnDefs(Scope *S, DeclTy *TagD, SourceLocation DeclStart,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000203 IdentifierInfo *ClassName,
204 llvm::SmallVectorImpl<DeclTy*> &Decls) {
205 llvm::cout << __FUNCTION__ << "\n";
206 }
207
Douglas Gregor44b43212008-12-11 16:49:14 +0000208 virtual DeclTy *ActOnField(Scope *S, DeclTy *TagD,
209 SourceLocation DeclStart,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000210 Declarator &D, ExprTy *BitfieldWidth) {
211 llvm::cout << __FUNCTION__ << "\n";
212 return 0;
213 }
214
215 virtual DeclTy *ActOnIvar(Scope *S, SourceLocation DeclStart,
216 Declarator &D, ExprTy *BitfieldWidth,
217 tok::ObjCKeywordKind visibility) {
218 llvm::cout << __FUNCTION__ << "\n";
219 return 0;
220 }
221
222 virtual void ActOnFields(Scope* S, SourceLocation RecLoc, DeclTy *TagDecl,
223 DeclTy **Fields, unsigned NumFields,
Daniel Dunbar1bfe1c22008-10-03 02:03:53 +0000224 SourceLocation LBrac, SourceLocation RBrac,
225 AttributeList *AttrList) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000226 llvm::cout << __FUNCTION__ << "\n";
227 }
228
229 virtual DeclTy *ActOnEnumConstant(Scope *S, DeclTy *EnumDecl,
230 DeclTy *LastEnumConstant,
231 SourceLocation IdLoc, IdentifierInfo *Id,
232 SourceLocation EqualLoc, ExprTy *Val) {
233 llvm::cout << __FUNCTION__ << "\n";
234 return 0;
235 }
236
237 virtual void ActOnEnumBody(SourceLocation EnumLoc, DeclTy *EnumDecl,
238 DeclTy **Elements, unsigned NumElements) {
239 llvm::cout << __FUNCTION__ << "\n";
240 }
241
242 //===--------------------------------------------------------------------===//
243 // Statement Parsing Callbacks.
244 //===--------------------------------------------------------------------===//
Sebastian Redla60528c2008-12-21 12:04:03 +0000245
246 virtual OwningStmtResult ActOnNullStmt(SourceLocation SemiLoc) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000247 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redla60528c2008-12-21 12:04:03 +0000248 return StmtEmpty();
249 }
250
251 virtual OwningStmtResult ActOnCompoundStmt(SourceLocation L,
252 SourceLocation R,
253 MultiStmtArg Elts,
254 bool isStmtExpr) {
255 llvm::cout << __FUNCTION__ << "\n";
256 return StmtEmpty();
257 }
258 virtual OwningStmtResult ActOnDeclStmt(DeclTy *Decl,
259 SourceLocation StartLoc,
260 SourceLocation EndLoc) {
261 llvm::cout << __FUNCTION__ << "\n";
262 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000263 }
264
Sebastian Redla60528c2008-12-21 12:04:03 +0000265 virtual OwningStmtResult ActOnExprStmt(ExprArg Expr) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000266 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redla60528c2008-12-21 12:04:03 +0000267 return OwningStmtResult(*this, Expr.release());
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000268 }
269
270 /// ActOnCaseStmt - Note that this handles the GNU 'case 1 ... 4' extension,
271 /// which can specify an RHS value.
Sebastian Redl117054a2008-12-28 16:13:43 +0000272 virtual OwningStmtResult ActOnCaseStmt(SourceLocation CaseLoc,
273 ExprArg LHSVal,
274 SourceLocation DotDotDotLoc,
275 ExprArg RHSVal,
276 SourceLocation ColonLoc,
277 StmtArg SubStmt) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000278 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redl117054a2008-12-28 16:13:43 +0000279 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000280 }
Sebastian Redl117054a2008-12-28 16:13:43 +0000281 virtual OwningStmtResult ActOnDefaultStmt(SourceLocation DefaultLoc,
282 SourceLocation ColonLoc,
283 StmtArg SubStmt, Scope *CurScope){
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000284 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redl117054a2008-12-28 16:13:43 +0000285 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000286 }
Sebastian Redlde307472009-01-11 00:38:46 +0000287
288 virtual OwningStmtResult ActOnLabelStmt(SourceLocation IdentLoc,
289 IdentifierInfo *II,
290 SourceLocation ColonLoc,
291 StmtArg SubStmt) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000292 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redlde307472009-01-11 00:38:46 +0000293 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000294 }
Sebastian Redlde307472009-01-11 00:38:46 +0000295
296 virtual OwningStmtResult ActOnIfStmt(SourceLocation IfLoc, ExprArg CondVal,
297 StmtArg ThenVal,SourceLocation ElseLoc,
298 StmtArg ElseVal) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000299 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redlde307472009-01-11 00:38:46 +0000300 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000301 }
Sebastian Redlde307472009-01-11 00:38:46 +0000302
303 virtual OwningStmtResult ActOnStartOfSwitchStmt(ExprArg Cond) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000304 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redlde307472009-01-11 00:38:46 +0000305 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000306 }
Sebastian Redlde307472009-01-11 00:38:46 +0000307
308 virtual OwningStmtResult ActOnFinishSwitchStmt(SourceLocation SwitchLoc,
309 StmtArg Switch,
310 StmtArg Body) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000311 llvm::cout << __FUNCTION__ << "\n";
Sebastian Redlde307472009-01-11 00:38:46 +0000312 return StmtEmpty();
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000313 }
314
315 virtual StmtResult ActOnWhileStmt(SourceLocation WhileLoc, ExprTy *Cond,
316 StmtTy *Body) {
317 llvm::cout << __FUNCTION__ << "\n";
318 return 0;
319 }
320 virtual StmtResult ActOnDoStmt(SourceLocation DoLoc, StmtTy *Body,
321 SourceLocation WhileLoc, ExprTy *Cond) {
322 llvm::cout << __FUNCTION__ << "\n";
323 return 0;
324 }
325 virtual StmtResult ActOnForStmt(SourceLocation ForLoc,
326 SourceLocation LParenLoc,
327 StmtTy *First, ExprTy *Second, ExprTy *Third,
328 SourceLocation RParenLoc, StmtTy *Body) {
329 llvm::cout << __FUNCTION__ << "\n";
330 return 0;
331 }
332 virtual StmtResult ActOnObjCForCollectionStmt(SourceLocation ForColLoc,
333 SourceLocation LParenLoc,
334 StmtTy *First, ExprTy *Second,
335 SourceLocation RParenLoc, StmtTy *Body) {
336 llvm::cout << __FUNCTION__ << "\n";
337 return 0;
338 }
339 virtual StmtResult ActOnGotoStmt(SourceLocation GotoLoc,
340 SourceLocation LabelLoc,
341 IdentifierInfo *LabelII) {
342 llvm::cout << __FUNCTION__ << "\n";
343 return 0;
344 }
345 virtual StmtResult ActOnIndirectGotoStmt(SourceLocation GotoLoc,
346 SourceLocation StarLoc,
347 ExprTy *DestExp) {
348 llvm::cout << __FUNCTION__ << "\n";
349 return 0;
350 }
351 virtual StmtResult ActOnContinueStmt(SourceLocation ContinueLoc,
352 Scope *CurScope) {
353 llvm::cout << __FUNCTION__ << "\n";
354 return 0;
355 }
356 virtual StmtResult ActOnBreakStmt(SourceLocation GotoLoc, Scope *CurScope) {
357 llvm::cout << __FUNCTION__ << "\n";
358 return 0;
359 }
360 virtual StmtResult ActOnReturnStmt(SourceLocation ReturnLoc,
361 ExprTy *RetValExp) {
362 llvm::cout << __FUNCTION__ << "\n";
363 return 0;
364 }
365 virtual StmtResult ActOnAsmStmt(SourceLocation AsmLoc,
366 bool IsSimple,
367 bool IsVolatile,
368 unsigned NumOutputs,
369 unsigned NumInputs,
370 std::string *Names,
371 ExprTy **Constraints,
372 ExprTy **Exprs,
373 ExprTy *AsmString,
374 unsigned NumClobbers,
375 ExprTy **Clobbers,
376 SourceLocation RParenLoc) {
377 llvm::cout << __FUNCTION__ << "\n";
378 return 0;
379 }
380
381 // Objective-c statements
382 virtual StmtResult ActOnObjCAtCatchStmt(SourceLocation AtLoc,
383 SourceLocation RParen, StmtTy *Parm,
384 StmtTy *Body, StmtTy *CatchList) {
385 llvm::cout << __FUNCTION__ << "\n";
386 return 0;
387 }
388
389 virtual StmtResult ActOnObjCAtFinallyStmt(SourceLocation AtLoc,
390 StmtTy *Body) {
391 llvm::cout << __FUNCTION__ << "\n";
392 return 0;
393 }
394
395 virtual StmtResult ActOnObjCAtTryStmt(SourceLocation AtLoc,
396 StmtTy *Try,
397 StmtTy *Catch, StmtTy *Finally) {
398 llvm::cout << __FUNCTION__ << "\n";
399 return 0;
400 }
401
402 virtual StmtResult ActOnObjCAtThrowStmt(SourceLocation AtLoc,
403 StmtTy *Throw) {
404 llvm::cout << __FUNCTION__ << "\n";
405 return 0;
406 }
407
408 virtual StmtResult ActOnObjCAtSynchronizedStmt(SourceLocation AtLoc,
409 ExprTy *SynchExpr,
410 StmtTy *SynchBody) {
411 llvm::cout << __FUNCTION__ << "\n";
412 return 0;
413 }
Sebastian Redla0fd8652008-12-21 16:41:36 +0000414
415 // C++ Statements
416 virtual DeclTy *ActOnExceptionDeclarator(Scope *S, Declarator &D) {
417 llvm::cout << __FUNCTION__ << "\n";
418 return 0;
419 }
420
421 virtual OwningStmtResult ActOnCXXCatchBlock(SourceLocation CatchLoc,
422 DeclTy *ExceptionDecl,
423 StmtArg HandlerBlock) {
424 llvm::cout << __FUNCTION__ << "\n";
425 return StmtEmpty();
426 }
427
428 virtual OwningStmtResult ActOnCXXTryBlock(SourceLocation TryLoc,
429 StmtArg TryBlock,
430 MultiStmtArg Handlers) {
431 llvm::cout << __FUNCTION__ << "\n";
432 return StmtEmpty();
433 }
434
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000435 //===--------------------------------------------------------------------===//
436 // Expression Parsing Callbacks.
437 //===--------------------------------------------------------------------===//
438
439 // Primary Expressions.
440
441 /// ActOnIdentifierExpr - Parse an identifier in expression context.
442 /// 'HasTrailingLParen' indicates whether or not the identifier has a '('
443 /// token immediately after it.
444 virtual ExprResult ActOnIdentifierExpr(Scope *S, SourceLocation Loc,
445 IdentifierInfo &II,
Argyrios Kyrtzidiseb83ecd2008-11-08 16:45:02 +0000446 bool HasTrailingLParen,
447 const CXXScopeSpec *SS) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000448 llvm::cout << __FUNCTION__ << "\n";
449 return 0;
450 }
451
Chris Lattnerd9f69102008-08-10 01:53:14 +0000452 virtual ExprResult ActOnPredefinedExpr(SourceLocation Loc,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000453 tok::TokenKind Kind) {
454 llvm::cout << __FUNCTION__ << "\n";
455 return 0;
456 }
457
458 virtual ExprResult ActOnCharacterConstant(const Token &) {
459 llvm::cout << __FUNCTION__ << "\n";
460 return 0;
461 }
462
463 virtual ExprResult ActOnNumericConstant(const Token &) {
464 llvm::cout << __FUNCTION__ << "\n";
465 return 0;
466 }
467
468 /// ActOnStringLiteral - The specified tokens were lexed as pasted string
469 /// fragments (e.g. "foo" "bar" L"baz").
470 virtual ExprResult ActOnStringLiteral(const Token *Toks, unsigned NumToks) {
471 llvm::cout << __FUNCTION__ << "\n";
472 return 0;
473 }
474
475 virtual ExprResult ActOnParenExpr(SourceLocation L, SourceLocation R,
476 ExprTy *Val) {
477 llvm::cout << __FUNCTION__ << "\n";
478 return Val; // Default impl returns operand.
479 }
480
481 // Postfix Expressions.
Douglas Gregor74253732008-11-19 15:42:04 +0000482 virtual ExprResult ActOnPostfixUnaryOp(Scope *S, SourceLocation OpLoc,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000483 tok::TokenKind Kind, ExprTy *Input) {
484 llvm::cout << __FUNCTION__ << "\n";
485 return 0;
486 }
Douglas Gregor337c6b92008-11-19 17:17:41 +0000487 virtual ExprResult ActOnArraySubscriptExpr(Scope *S, ExprTy *Base,
488 SourceLocation LLoc, ExprTy *Idx,
489 SourceLocation RLoc) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000490 llvm::cout << __FUNCTION__ << "\n";
491 return 0;
492 }
Douglas Gregor3fc749d2008-12-23 00:26:44 +0000493 virtual ExprResult ActOnMemberReferenceExpr(Scope *S, ExprTy *Base,
494 SourceLocation OpLoc,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000495 tok::TokenKind OpKind,
496 SourceLocation MemberLoc,
497 IdentifierInfo &Member) {
498 llvm::cout << __FUNCTION__ << "\n";
499 return 0;
500 }
501
502 /// ActOnCallExpr - Handle a call to Fn with the specified array of arguments.
503 /// This provides the location of the left/right parens and a list of comma
504 /// locations. There are guaranteed to be one fewer commas than arguments,
505 /// unless there are zero arguments.
Douglas Gregor5c37de72008-12-06 00:22:45 +0000506 virtual ExprResult ActOnCallExpr(Scope *S, ExprTy *Fn,
507 SourceLocation LParenLoc,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000508 ExprTy **Args, unsigned NumArgs,
509 SourceLocation *CommaLocs,
510 SourceLocation RParenLoc) {
511 llvm::cout << __FUNCTION__ << "\n";
512 return 0;
513 }
514
515 // Unary Operators. 'Tok' is the token for the operator.
Douglas Gregor74253732008-11-19 15:42:04 +0000516 virtual ExprResult ActOnUnaryOp(Scope *S, SourceLocation OpLoc,
517 tok::TokenKind Op, ExprTy *Input) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000518 llvm::cout << __FUNCTION__ << "\n";
519 return 0;
520 }
521 virtual ExprResult
Sebastian Redl05189992008-11-11 17:56:53 +0000522 ActOnSizeOfAlignOfExpr(SourceLocation OpLoc, bool isSizeof, bool isType,
523 void *TyOrEx, const SourceRange &ArgRange) {
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000524 llvm::cout << __FUNCTION__ << "\n";
525 return 0;
526 }
527
528 virtual ExprResult ActOnCompoundLiteral(SourceLocation LParen, TypeTy *Ty,
529 SourceLocation RParen, ExprTy *Op) {
530 llvm::cout << __FUNCTION__ << "\n";
531 return 0;
532 }
533 virtual ExprResult ActOnInitList(SourceLocation LParenLoc,
534 ExprTy **InitList, unsigned NumInit,
Chris Lattner220ad7c2008-10-26 23:35:51 +0000535 InitListDesignations &Designators,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000536 SourceLocation RParenLoc) {
537 llvm::cout << __FUNCTION__ << "\n";
538 return 0;
539 }
540 virtual ExprResult ActOnCastExpr(SourceLocation LParenLoc, TypeTy *Ty,
541 SourceLocation RParenLoc, ExprTy *Op) {
542 llvm::cout << __FUNCTION__ << "\n";
543 return 0;
544 }
545
Douglas Gregoreaebc752008-11-06 23:29:22 +0000546 virtual ExprResult ActOnBinOp(Scope *S, SourceLocation TokLoc,
547 tok::TokenKind Kind,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000548 ExprTy *LHS, ExprTy *RHS) {
549 llvm::cout << __FUNCTION__ << "\n";
550 return 0;
551 }
552
553 /// ActOnConditionalOp - Parse a ?: operation. Note that 'LHS' may be null
554 /// in the case of a the GNU conditional expr extension.
555 virtual ExprResult ActOnConditionalOp(SourceLocation QuestionLoc,
556 SourceLocation ColonLoc,
557 ExprTy *Cond, ExprTy *LHS, ExprTy *RHS){
558 llvm::cout << __FUNCTION__ << "\n";
559 return 0;
560 }
561
562 //===---------------------- GNU Extension Expressions -------------------===//
563
564 virtual ExprResult ActOnAddrLabel(SourceLocation OpLoc, SourceLocation LabLoc,
565 IdentifierInfo *LabelII) { // "&&foo"
566 llvm::cout << __FUNCTION__ << "\n";
567 return 0;
568 }
569
570 virtual ExprResult ActOnStmtExpr(SourceLocation LPLoc, StmtTy *SubStmt,
571 SourceLocation RPLoc) { // "({..})"
572 llvm::cout << __FUNCTION__ << "\n";
573 return 0;
574 }
575
Douglas Gregor3fc749d2008-12-23 00:26:44 +0000576 virtual ExprResult ActOnBuiltinOffsetOf(Scope *S, SourceLocation BuiltinLoc,
Daniel Dunbarbb8f4e62008-08-01 00:41:12 +0000577 SourceLocation TypeLoc, TypeTy *Arg1,
578 OffsetOfComponent *CompPtr,
579 unsigned NumComponents,
580 SourceLocation RParenLoc) {
581 llvm::cout << __FUNCTION__ << "\n";
582 return 0;
583 }
584
585 // __builtin_types_compatible_p(type1, type2)
586 virtual ExprResult ActOnTypesCompatibleExpr(SourceLocation BuiltinLoc,
587 TypeTy *arg1, TypeTy *arg2,
588 SourceLocation RPLoc) {
589 llvm::cout << __FUNCTION__ << "\n";
590 return 0;
591 }
592 // __builtin_choose_expr(constExpr, expr1, expr2)
593 virtual ExprResult ActOnChooseExpr(SourceLocation BuiltinLoc,
594 ExprTy *cond, ExprTy *expr1, ExprTy *expr2,
595 SourceLocation RPLoc) {
596 llvm::cout << __FUNCTION__ << "\n";
597 return 0;
598 }
599 // __builtin_overload(...)
600 virtual ExprResult ActOnOverloadExpr(ExprTy **Args, unsigned NumArgs,
601 SourceLocation *CommaLocs,
602 SourceLocation BuiltinLoc,
603 SourceLocation RPLoc) {
604 llvm::cout << __FUNCTION__ << "\n";
605 return 0;
606 }
607
608
609 // __builtin_va_arg(expr, type)
610 virtual ExprResult ActOnVAArg(SourceLocation BuiltinLoc,
611 ExprTy *expr, TypeTy *type,
612 SourceLocation RPLoc) {
613 llvm::cout << __FUNCTION__ << "\n";
614 return 0;
Reid Spencer5f016e22007-07-11 17:01:13 +0000615 }
616 };
617}
618
Daniel Dunbare10b0f22008-10-31 08:56:51 +0000619MinimalAction *clang::CreatePrintParserActionsAction(Preprocessor &PP) {
620 return new ParserPrintActions(PP);
Reid Spencer5f016e22007-07-11 17:01:13 +0000621}