summaryrefslogtreecommitdiff
path: root/deps/v8/third_party/antlr4/runtime/Cpp/runtime/src/atn/ATNSimulator.h
blob: a43ed7f691043a7af559b1cd3a2619561a4e297a (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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/* 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 "atn/ATN.h"
#include "atn/PredictionContext.h"
#include "misc/IntervalSet.h"
#include "support/CPPUtils.h"

namespace antlr4 {
namespace atn {

class ANTLR4CPP_PUBLIC ATNSimulator {
 public:
  /// Must distinguish between missing edge and edge we know leads nowhere.
  static const Ref<dfa::DFAState> ERROR_STATE;
  const ATN& atn;

  ATNSimulator(const ATN& atn, PredictionContextCache& sharedContextCache);
  virtual ~ATNSimulator();

  virtual void reset() = 0;

  /**
   * Clear the DFA cache used by the current instance. Since the DFA cache may
   * be shared by multiple ATN simulators, this method may affect the
   * performance (but not accuracy) of other parsers which are being used
   * concurrently.
   *
   * @throws UnsupportedOperationException if the current instance does not
   * support clearing the DFA.
   *
   * @since 4.3
   */
  virtual void clearDFA();
  virtual PredictionContextCache& getSharedContextCache();
  virtual Ref<PredictionContext> getCachedContext(
      Ref<PredictionContext> const& context);

  /// @deprecated Use <seealso cref="ATNDeserializer#deserialize"/> instead.
  static ATN deserialize(const std::vector<uint16_t>& data);

  /// @deprecated Use <seealso cref="ATNDeserializer#checkCondition(boolean)"/>
  /// instead.
  static void checkCondition(bool condition);

  /// @deprecated Use <seealso cref="ATNDeserializer#checkCondition(boolean,
  /// String)"/> instead.
  static void checkCondition(bool condition, const std::string& message);

  /// @deprecated Use <seealso cref="ATNDeserializer#edgeFactory"/> instead.
  static Transition* edgeFactory(const ATN& atn, int type, int src, int trg,
                                 int arg1, int arg2, int arg3,
                                 const std::vector<misc::IntervalSet>& sets);

  /// @deprecated Use <seealso cref="ATNDeserializer#stateFactory"/> instead.
  static ATNState* stateFactory(int type, int ruleIndex);

 protected:
  static antlrcpp::SingleWriteMultipleReadLock
      _stateLock;  // Lock for DFA states.
  static antlrcpp::SingleWriteMultipleReadLock
      _edgeLock;  // Lock for the sparse edge map in DFA states.

  /// <summary>
  /// The context cache maps all PredictionContext objects that are equals()
  ///  to a single cached copy. This cache is shared across all contexts
  ///  in all ATNConfigs in all DFA states.  We rebuild each ATNConfigSet
  ///  to use only cached nodes/graphs in addDFAState(). We don't want to
  ///  fill this during closure() since there are lots of contexts that
  ///  pop up but are not used ever again. It also greatly slows down closure().
  ///  <p/>
  ///  This cache makes a huge difference in memory and a little bit in speed.
  ///  For the Java grammar on java.*, it dropped the memory requirements
  ///  at the end from 25M to 16M. We don't store any of the full context
  ///  graphs in the DFA because they are limited to local context only,
  ///  but apparently there's a lot of repetition there as well. We optimize
  ///  the config contexts before storing the config set in the DFA states
  ///  by literally rebuilding them with cached subgraphs only.
  ///  <p/>
  ///  I tried a cache for use during closure operations, that was
  ///  whacked after each adaptivePredict(). It cost a little bit
  ///  more time I think and doesn't save on the overall footprint
  ///  so it's not worth the complexity.
  /// </summary>
  PredictionContextCache& _sharedContextCache;
};

}  // namespace atn
}  // namespace antlr4