UNPKG

antlr4ng

Version:

Alternative JavaScript/TypeScript runtime for ANTLR4

42 lines (41 loc) 2 kB
import { DefaultErrorStrategy } from "./DefaultErrorStrategy.js"; import { Parser } from "./Parser.js"; import { RecognitionException } from "./RecognitionException.js"; /** * 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.setErrorHandler(new BailErrorStrategy());` * * @see Parser#setErrorHandler(ANTLRErrorStrategy) */ 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): never; sync(_recognizer: Parser): void; }