/*! * 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. */ import { DefaultErrorStrategy } from "./DefaultErrorStrategy"; import { Parser } from "./Parser"; import { RecognitionException } from "./RecognitionException"; import { Token } from "./Token"; /** * This implementation of {@link ANTLRErrorStrategy} responds to syntax errors * by immediately canceling the parse operation with a * {@link ParseCancellationException}. The implementation ensures that the * {@link ParserRuleContext#exception} field is set for all parse tree nodes * that were not completed prior to encountering the error. * * This error strategy is useful in the following scenarios. * * * **Two-stage parsing:** This error strategy allows the first * stage of two-stage parsing to immediately terminate if an error is * encountered, and immediately fall back to the second stage. In addition to * avoiding wasted work by attempting to recover from errors here, the empty * implementation of {@link BailErrorStrategy#sync} improves the performance of * the first stage. * * **Silent validation:** When syntax errors are not being * reported or logged, and the parse result is simply ignored if errors occur, * the {@link BailErrorStrategy} avoids wasting work on recovering from errors * when the result will be ignored either way. * * ``` * myparser.errorHandler = new BailErrorStrategy(); * ``` * * @see Parser.errorHandler */ export declare class BailErrorStrategy extends DefaultErrorStrategy { /** Instead of recovering from exception `e`, re-throw it wrapped * in a {@link ParseCancellationException} so it is not caught by the * rule function catches. Use {@link Exception#getCause()} to get the * original {@link RecognitionException}. */ recover(recognizer: Parser, e: RecognitionException): void; /** Make sure we don't attempt to recover inline; if the parser * successfully recovers, it won't throw an exception. */ recoverInline(recognizer: Parser): Token; /** Make sure we don't attempt to recover from problems in subrules. */ sync(recognizer: Parser): void; }