Sha256: 0d404974b0590035547f1a9ebdad5568ce9826c2840477eff6d3c0314b50b381
Contents?: true
Size: 1.35 KB
Versions: 19
Compression:
Stored size: 1.35 KB
Contents
/* Copyright (c) 2012-2017 The ANTLR Project. All rights reserved. * Use of this file is governed by the BSD 3-clause license that * can be found in the LICENSE.txt file in the project root. */ #include "tree/ErrorNode.h" #include "ParserRuleContext.h" #include "tree/ParseTreeListener.h" #include "support/CPPUtils.h" #include "support/Casts.h" #include "tree/IterativeParseTreeWalker.h" #include "tree/ParseTreeWalker.h" using namespace antlr4::tree; using namespace antlrcpp; static IterativeParseTreeWalker defaultWalker; ParseTreeWalker &ParseTreeWalker::DEFAULT = defaultWalker; void ParseTreeWalker::walk(ParseTreeListener *listener, ParseTree *t) const { if (ErrorNode::is(*t)) { listener->visitErrorNode(downCast<ErrorNode*>(t)); return; } if (TerminalNode::is(*t)) { listener->visitTerminal(downCast<TerminalNode*>(t)); return; } enterRule(listener, t); for (auto &child : t->children) { walk(listener, child); } exitRule(listener, t); } void ParseTreeWalker::enterRule(ParseTreeListener *listener, ParseTree *r) const { auto *ctx = downCast<ParserRuleContext*>(r); listener->enterEveryRule(ctx); ctx->enterRule(listener); } void ParseTreeWalker::exitRule(ParseTreeListener *listener, ParseTree *r) const { auto *ctx = downCast<ParserRuleContext*>(r); ctx->exitRule(listener); listener->exitEveryRule(ctx); }
Version data entries
19 entries across 19 versions & 3 rubygems