summaryrefslogtreecommitdiff
path: root/deps/v8/third_party/antlr4/runtime/Cpp/runtime/src/tree/ParseTreeVisitor.h
blob: c331537b38e7f494527b374be9ee613fa467b5c0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/* 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.
 */

#pragma once

#include "support/Any.h"

namespace antlr4 {
namespace tree {

/// <summary>
/// This interface defines the basic notion of a parse tree visitor. Generated
/// visitors implement this interface and the {@code XVisitor} interface for
/// grammar {@code X}.
/// </summary>
/// @param <T> The return type of the visit operation. Use <seealso
/// cref="Void"/> for operations with no return type. </param>
// ml: no template parameter here, to avoid the need for virtual template
// functions. Instead we have our Any class.
class ANTLR4CPP_PUBLIC ParseTreeVisitor {
 public:
  virtual ~ParseTreeVisitor();

  /// <summary>
  /// Visit a parse tree, and return a user-defined result of the operation.
  /// </summary>
  /// <param name="tree"> The <seealso cref="ParseTree"/> to visit. </param>
  /// <returns> The result of visiting the parse tree. </returns>
  virtual antlrcpp::Any visit(ParseTree* tree) = 0;

  /// <summary>
  /// Visit the children of a node, and return a user-defined result of the
  /// operation.
  /// </summary>
  /// <param name="node"> The <seealso cref="ParseTree"/> whose children should
  /// be visited. </param> <returns> The result of visiting the children of the
  /// node. </returns>
  virtual antlrcpp::Any visitChildren(ParseTree* node) = 0;

  /// <summary>
  /// Visit a terminal node, and return a user-defined result of the operation.
  /// </summary>
  /// <param name="node"> The <seealso cref="TerminalNode"/> to visit. </param>
  /// <returns> The result of visiting the node. </returns>
  virtual antlrcpp::Any visitTerminal(TerminalNode* node) = 0;

  /// <summary>
  /// Visit an error node, and return a user-defined result of the operation.
  /// </summary>
  /// <param name="node"> The <seealso cref="ErrorNode"/> to visit. </param>
  /// <returns> The result of visiting the node. </returns>
  virtual antlrcpp::Any visitErrorNode(ErrorNode* node) = 0;
};

}  // namespace tree
}  // namespace antlr4