add antlr
This commit is contained in:
70
lib/antlr4/include/atn/DecisionEventInfo.h
Normal file
70
lib/antlr4/include/atn/DecisionEventInfo.h
Normal file
@@ -0,0 +1,70 @@
|
||||
/* 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 "antlr4-common.h"
|
||||
|
||||
namespace antlr4 {
|
||||
namespace atn {
|
||||
|
||||
/// <summary>
|
||||
/// This is the base class for gathering detailed information about prediction
|
||||
/// events which occur during parsing.
|
||||
///
|
||||
/// Note that we could record the parser call stack at the time this event
|
||||
/// occurred but in the presence of left recursive rules, the stack is kind of
|
||||
/// meaningless. It's better to look at the individual configurations for their
|
||||
/// individual stacks. Of course that is a <seealso cref="PredictionContext"/> object
|
||||
/// not a parse tree node and so it does not have information about the extent
|
||||
/// (start...stop) of the various subtrees. Examining the stack tops of all
|
||||
/// configurations provide the return states for the rule invocations.
|
||||
/// From there you can get the enclosing rule.
|
||||
///
|
||||
/// @since 4.3
|
||||
/// </summary>
|
||||
class ANTLR4CPP_PUBLIC DecisionEventInfo {
|
||||
public:
|
||||
/// <summary>
|
||||
/// The invoked decision number which this event is related to.
|
||||
/// </summary>
|
||||
/// <seealso cref= ATN#decisionToState </seealso>
|
||||
const size_t decision;
|
||||
|
||||
/// <summary>
|
||||
/// The configuration set containing additional information relevant to the
|
||||
/// prediction state when the current event occurred, or {@code null} if no
|
||||
/// additional information is relevant or available.
|
||||
/// </summary>
|
||||
const ATNConfigSet *configs;
|
||||
|
||||
/// <summary>
|
||||
/// The input token stream which is being parsed.
|
||||
/// </summary>
|
||||
const TokenStream *input;
|
||||
|
||||
/// <summary>
|
||||
/// The token index in the input stream at which the current prediction was
|
||||
/// originally invoked.
|
||||
/// </summary>
|
||||
const size_t startIndex;
|
||||
|
||||
/// <summary>
|
||||
/// The token index in the input stream at which the current event occurred.
|
||||
/// </summary>
|
||||
const size_t stopIndex;
|
||||
|
||||
/// <summary>
|
||||
/// {@code true} if the current event occurred during LL prediction;
|
||||
/// otherwise, {@code false} if the input occurred during SLL prediction.
|
||||
/// </summary>
|
||||
const bool fullCtx;
|
||||
|
||||
DecisionEventInfo(size_t decision, ATNConfigSet *configs, TokenStream *input, size_t startIndex,
|
||||
size_t stopIndex, bool fullCtx);
|
||||
};
|
||||
|
||||
} // namespace atn
|
||||
} // namespace antlr4
|
Reference in New Issue
Block a user