1 /* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved.
2 * Use of this file is governed by the BSD 3-clause license that
3 * can be found in the LICENSE.txt file in the project root.
6 #include "tree/ErrorNode.h"
7 #include "ParserRuleContext.h"
8 #include "tree/ParseTreeListener.h"
9 #include "support/CPPUtils.h"
11 #include "tree/IterativeParseTreeWalker.h"
12 #include "tree/ParseTreeWalker.h"
14 using namespace antlr4::tree;
15 using namespace antlrcpp;
17 static IterativeParseTreeWalker defaultWalker;
18 ParseTreeWalker &ParseTreeWalker::DEFAULT = defaultWalker;
20 ParseTreeWalker::~ParseTreeWalker() {
23 void ParseTreeWalker::walk(ParseTreeListener *listener, ParseTree *t) const {
24 if (is<ErrorNode *>(t)) {
25 listener->visitErrorNode(dynamic_cast<ErrorNode *>(t));
27 } else if (is<TerminalNode *>(t)) {
28 listener->visitTerminal(dynamic_cast<TerminalNode *>(t));
32 enterRule(listener, t);
33 for (auto &child : t->children) {
34 walk(listener, child);
36 exitRule(listener, t);
39 void ParseTreeWalker::enterRule(ParseTreeListener *listener, ParseTree *r) const {
40 ParserRuleContext *ctx = dynamic_cast<ParserRuleContext *>(r);
41 listener->enterEveryRule(ctx);
42 ctx->enterRule(listener);
45 void ParseTreeWalker::exitRule(ParseTreeListener *listener, ParseTree *r) const {
46 ParserRuleContext *ctx = dynamic_cast<ParserRuleContext *>(r);
47 ctx->exitRule(listener);
48 listener->exitEveryRule(ctx);