UNPKG

antlr4ts

Version:

ANTLR 4 runtime for JavaScript written in Typescript

160 lines 7.75 kB
"use strict"; /*! * Copyright 2016 The ANTLR Project. All rights reserved. * Licensed under the BSD-3-Clause license. See LICENSE file in the project root for license information. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.PredictionMode = void 0; // ConvertTo-TS run at 2016-10-04T11:26:36.2673893-07:00 const Array2DHashMap_1 = require("../misc/Array2DHashMap"); const MurmurHash_1 = require("../misc/MurmurHash"); const Decorators_1 = require("../Decorators"); const RuleStopState_1 = require("./RuleStopState"); /** * This enumeration defines the prediction modes available in ANTLR 4 along with * utility methods for analyzing configuration sets for conflicts and/or * ambiguities. */ var PredictionMode; (function (PredictionMode) { /** * The SLL(*) prediction mode. This prediction mode ignores the current * parser context when making predictions. This is the fastest prediction * mode, and provides correct results for many grammars. This prediction * mode is more powerful than the prediction mode provided by ANTLR 3, but * may result in syntax errors for grammar and input combinations which are * not SLL. * * When using this prediction mode, the parser will either return a correct * parse tree (i.e. the same parse tree that would be returned with the * {@link #LL} prediction mode), or it will report a syntax error. If a * syntax error is encountered when using the {@link #SLL} prediction mode, * it may be due to either an actual syntax error in the input or indicate * that the particular combination of grammar and input requires the more * powerful {@link #LL} prediction abilities to complete successfully. * * This prediction mode does not provide any guarantees for prediction * behavior for syntactically-incorrect inputs. */ PredictionMode[PredictionMode["SLL"] = 0] = "SLL"; /** * The LL(*) prediction mode. This prediction mode allows the current parser * context to be used for resolving SLL conflicts that occur during * prediction. This is the fastest prediction mode that guarantees correct * parse results for all combinations of grammars with syntactically correct * inputs. * * When using this prediction mode, the parser will make correct decisions * for all syntactically-correct grammar and input combinations. However, in * cases where the grammar is truly ambiguous this prediction mode might not * report a precise answer for *exactly which* alternatives are * ambiguous. * * This prediction mode does not provide any guarantees for prediction * behavior for syntactically-incorrect inputs. */ PredictionMode[PredictionMode["LL"] = 1] = "LL"; /** * The LL(*) prediction mode with exact ambiguity detection. In addition to * the correctness guarantees provided by the {@link #LL} prediction mode, * this prediction mode instructs the prediction algorithm to determine the * complete and exact set of ambiguous alternatives for every ambiguous * decision encountered while parsing. * * This prediction mode may be used for diagnosing ambiguities during * grammar development. Due to the performance overhead of calculating sets * of ambiguous alternatives, this prediction mode should be avoided when * the exact results are not necessary. * * This prediction mode does not provide any guarantees for prediction * behavior for syntactically-incorrect inputs. */ PredictionMode[PredictionMode["LL_EXACT_AMBIG_DETECTION"] = 2] = "LL_EXACT_AMBIG_DETECTION"; })(PredictionMode = exports.PredictionMode || (exports.PredictionMode = {})); (function (PredictionMode) { /** A Map that uses just the state and the stack context as the key. */ // NOTE: Base type used to be FlexibleHashMap<ATNConfig, BitSet> class AltAndContextMap extends Array2DHashMap_1.Array2DHashMap { constructor() { super(AltAndContextConfigEqualityComparator.INSTANCE); } } class AltAndContextConfigEqualityComparator { AltAndContextConfigEqualityComparator() { // intentionally empty } /** * The hash code is only a function of the {@link ATNState#stateNumber} * and {@link ATNConfig#context}. */ hashCode(o) { let hashCode = MurmurHash_1.MurmurHash.initialize(7); hashCode = MurmurHash_1.MurmurHash.update(hashCode, o.state.stateNumber); hashCode = MurmurHash_1.MurmurHash.update(hashCode, o.context); hashCode = MurmurHash_1.MurmurHash.finish(hashCode, 2); return hashCode; } equals(a, b) { if (a === b) { return true; } if (a == null || b == null) { return false; } return a.state.stateNumber === b.state.stateNumber && a.context.equals(b.context); } } AltAndContextConfigEqualityComparator.INSTANCE = new AltAndContextConfigEqualityComparator(); __decorate([ Decorators_1.Override ], AltAndContextConfigEqualityComparator.prototype, "hashCode", null); __decorate([ Decorators_1.Override ], AltAndContextConfigEqualityComparator.prototype, "equals", null); /** * Checks if any configuration in `configs` is in a * {@link RuleStopState}. Configurations meeting this condition have reached * the end of the decision rule (local context) or end of start rule (full * context). * * @param configs the configuration set to test * @returns `true` if any configuration in `configs` is in a * {@link RuleStopState}, otherwise `false` */ function hasConfigInRuleStopState(configs) { for (let c of configs) { if (c.state instanceof RuleStopState_1.RuleStopState) { return true; } } return false; } PredictionMode.hasConfigInRuleStopState = hasConfigInRuleStopState; /** * Checks if all configurations in `configs` are in a * {@link RuleStopState}. Configurations meeting this condition have reached * the end of the decision rule (local context) or end of start rule (full * context). * * @param configs the configuration set to test * @returns `true` if all configurations in `configs` are in a * {@link RuleStopState}, otherwise `false` */ function allConfigsInRuleStopStates(/*@NotNull*/ configs) { for (let config of configs) { if (!(config.state instanceof RuleStopState_1.RuleStopState)) { return false; } } return true; } PredictionMode.allConfigsInRuleStopStates = allConfigsInRuleStopStates; })(PredictionMode = exports.PredictionMode || (exports.PredictionMode = {})); //# sourceMappingURL=PredictionMode.js.map