All Downloads are FREE. Search and download functionalities are using the official Maven repository.

js.antlr4.dfa.DFA.js Maven / Gradle / Ivy

//
/* Copyright (c) 2012-2016 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.
 */

var Set = require("../Utils").Set;
var DFAState = require('./DFAState').DFAState;
var StarLoopEntryState = require('../atn/ATNState').StarLoopEntryState;
var ATNConfigSet = require('./../atn/ATNConfigSet').ATNConfigSet;
var DFASerializer = require('./DFASerializer').DFASerializer;
var LexerDFASerializer = require('./DFASerializer').LexerDFASerializer;



function DFA(atnStartState, decision) {
	if (decision === undefined) {
		decision = 0;
	}
	// From which ATN state did we create this DFA?
	this.atnStartState = atnStartState;
	this.decision = decision;
	// A set of all DFA states. Use {@link Map} so we can get old state back
	// ({@link Set} only allows you to see if it's there).
	this._states = new Set();
	this.s0 = null;
	// {@code true} if this DFA is for a precedence decision; otherwise,
	// {@code false}. This is the backing field for {@link //isPrecedenceDfa},
	// {@link //setPrecedenceDfa}.
	this.precedenceDfa = false;
    if (atnStartState instanceof StarLoopEntryState)
    {
        if (atnStartState.isPrecedenceDecision) {
            this.precedenceDfa = true;
            precedenceState = new DFAState(null, new ATNConfigSet());
            precedenceState.edges = [];
            precedenceState.isAcceptState = false;
            precedenceState.requiresFullContext = false;
            this.s0 = precedenceState;
        }
    }
	return this;
}

// Get the start state for a specific precedence value.
//
// @param precedence The current precedence.
// @return The start state corresponding to the specified precedence, or
// {@code null} if no start state exists for the specified precedence.
//
// @throws IllegalStateException if this is not a precedence DFA.
// @see //isPrecedenceDfa()

DFA.prototype.getPrecedenceStartState = function(precedence) {
	if (!(this.precedenceDfa)) {
		throw ("Only precedence DFAs may contain a precedence start state.");
	}
	// s0.edges is never null for a precedence DFA
	if (precedence < 0 || precedence >= this.s0.edges.length) {
		return null;
	}
	return this.s0.edges[precedence] || null;
};

// Set the start state for a specific precedence value.
//
// @param precedence The current precedence.
// @param startState The start state corresponding to the specified
// precedence.
//
// @throws IllegalStateException if this is not a precedence DFA.
// @see //isPrecedenceDfa()
//
DFA.prototype.setPrecedenceStartState = function(precedence, startState) {
	if (!(this.precedenceDfa)) {
		throw ("Only precedence DFAs may contain a precedence start state.");
	}
	if (precedence < 0) {
		return;
	}

	// synchronization on s0 here is ok. when the DFA is turned into a
	// precedence DFA, s0 will be initialized once and not updated again
	// s0.edges is never null for a precedence DFA
	this.s0.edges[precedence] = startState;
};

//
// Sets whether this is a precedence DFA. If the specified value differs
// from the current DFA configuration, the following actions are taken;
// otherwise no changes are made to the current DFA.
//
// 
    //
  • The {@link //states} map is cleared
  • //
  • If {@code precedenceDfa} is {@code false}, the initial state // {@link //s0} is set to {@code null}; otherwise, it is initialized to a new // {@link DFAState} with an empty outgoing {@link DFAState//edges} array to // store the start states for individual precedence values.
  • //
  • The {@link //precedenceDfa} field is updated
  • //
// // @param precedenceDfa {@code true} if this is a precedence DFA; otherwise, // {@code false} DFA.prototype.setPrecedenceDfa = function(precedenceDfa) { if (this.precedenceDfa!==precedenceDfa) { this._states = new DFAStatesSet(); if (precedenceDfa) { var precedenceState = new DFAState(null, new ATNConfigSet()); precedenceState.edges = []; precedenceState.isAcceptState = false; precedenceState.requiresFullContext = false; this.s0 = precedenceState; } else { this.s0 = null; } this.precedenceDfa = precedenceDfa; } }; Object.defineProperty(DFA.prototype, "states", { get : function() { return this._states; } }); // Return a list of all states in this DFA, ordered by state number. DFA.prototype.sortedStates = function() { var list = this._states.values(); return list.sort(function(a, b) { return a.stateNumber - b.stateNumber; }); }; DFA.prototype.toString = function(literalNames, symbolicNames) { literalNames = literalNames || null; symbolicNames = symbolicNames || null; if (this.s0 === null) { return ""; } var serializer = new DFASerializer(this, literalNames, symbolicNames); return serializer.toString(); }; DFA.prototype.toLexerString = function() { if (this.s0 === null) { return ""; } var serializer = new LexerDFASerializer(this); return serializer.toString(); }; exports.DFA = DFA;




© 2015 - 2025 Weber Informatics LLC | Privacy Policy