/* 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 "Token.h"
#include "support/BitSet.h"
#include "atn/PredictionContext.h"
#include "atn/ATNConfig.h"
namespace antlr4 {
namespace atn {
class ANTLR4CPP_PUBLIC LL1Analyzer {
public:
/// Special value added to the lookahead sets to indicate that we hit
/// a predicate during analysis if {@code seeThruPreds==false}.
static const size_t HIT_PRED = Token::INVALID_TYPE;
const atn::ATN &_atn;
LL1Analyzer(const atn::ATN &atn);
virtual ~LL1Analyzer();
///
/// Calculates the SLL(1) expected lookahead set for each outgoing transition
/// of an . The returned array has one element for each
/// outgoing transition in {@code s}. If the closure from transition
/// i leads to a semantic predicate before matching a symbol, the
/// element at index i of the result will be {@code null}.
///
/// the ATN state
/// the expected symbols for each outgoing transition of {@code s}.
virtual std::vector getDecisionLookahead(ATNState *s) const;
///
/// Compute set of tokens that can follow {@code s} in the ATN in the
/// specified {@code ctx}.
///
/// If {@code ctx} is {@code null} and the end of the rule containing
/// {@code s} is reached, is added to the result set.
/// If {@code ctx} is not {@code null} and the end of the outermost rule is
/// reached, is added to the result set.
///
/// the ATN state
/// the complete parser context, or {@code null} if the context
/// should be ignored
///
/// The set of tokens that can follow {@code s} in the ATN in the
/// specified {@code ctx}.
virtual misc::IntervalSet LOOK(ATNState *s, RuleContext *ctx) const;
///
/// Compute set of tokens that can follow {@code s} in the ATN in the
/// specified {@code ctx}.
///
/// If {@code ctx} is {@code null} and the end of the rule containing
/// {@code s} is reached, is added to the result set.
/// If {@code ctx} is not {@code null} and the end of the outermost rule is
/// reached, is added to the result set.
///
/// the ATN state
/// the ATN state to stop at. This can be a
/// to detect epsilon paths through a closure.
/// the complete parser context, or {@code null} if the context
/// should be ignored
///
/// The set of tokens that can follow {@code s} in the ATN in the
/// specified {@code ctx}.
virtual misc::IntervalSet LOOK(ATNState *s, ATNState *stopState, RuleContext *ctx) const;
///
/// Compute set of tokens that can follow {@code s} in the ATN in the
/// specified {@code ctx}.
///
/// If {@code ctx} is {@code null} and {@code stopState} or the end of the
/// rule containing {@code s} is reached, is added to
/// the result set. If {@code ctx} is not {@code null} and {@code addEOF} is
/// {@code true} and {@code stopState} or the end of the outermost rule is
/// reached, is added to the result set.
///
/// the ATN state.
/// the ATN state to stop at. This can be a
/// to detect epsilon paths through a closure.
/// The outer context, or {@code null} if the outer context should
/// not be used.
/// The result lookahead set.
/// A set used for preventing epsilon closures in the ATN
/// from causing a stack overflow. Outside code should pass
/// {@code new HashSet} for this argument.
/// A set used for preventing left recursion in the
/// ATN from causing a stack overflow. Outside code should pass
/// {@code new BitSet()} for this argument.
/// {@code true} to true semantic predicates as
/// implicitly {@code true} and "see through them", otherwise {@code false}
/// to treat semantic predicates as opaque and add to the
/// result if one is encountered.
/// Add to the result if the end of the
/// outermost context is reached. This parameter has no effect if {@code ctx}
/// is {@code null}.
protected:
virtual void _LOOK(ATNState *s, ATNState *stopState, Ref const& ctx, misc::IntervalSet &look,
ATNConfig::Set &lookBusy, antlrcpp::BitSet &calledRuleStack, bool seeThruPreds, bool addEOF) const;
};
} // namespace atn
} // namespace antlr4