Я использую ANTLR для разбора логических выражений в пишущем Java-инструменте, и у меня возникают проблемы, потому что передача неверных строк ввода в сгенерированный лексер и анализатор ANTLR не вызывает никаких исключений.Вместо того, чтобы генерировать RecognitionException, как я и ожидал, сгенерированные файлы просто выводят сообщение об ошибке на консоль и возвращают, как если бы не было ошибок, что приводит к аварийному завершению моей программы, когда она сталкивается с пустыми данными позже.
Я использовал ANTLRWorks версии 1.4.3 для генерации файлов, и, похоже, должна быть какая-то опция, чтобы он действительно выдавал ошибки, а не печатал на консоль, но я ничего не нашел.Кто-нибудь знает, как заставить ANTLR фактически выдавать сообщения об ошибках?Я увидел, что эта же проблема в C # была решена с помощью более старой версии ANTLR, это то, что мне нужно сделать?
РЕДАКТИРОВАТЬ: После того, как Барт указал мне в направлении того, что я искал, я нашелэта страница
https://theantlrguy.atlassian.net/wiki/display/ANTLR3/Migrating+from+ANTLR+2+to+ANTLR+3
, чей раздел "Обработка ошибок" содержал код, который делал то, что я хочу, более точно.Чтобы изменить способ, которым ANTLR перехватывает исключения, вы можете сказать это в файле грамматики:
@rulecatch {
catch (RecognitionException e) {
throw e;
}
}
Это вынуждает ANTLR генерировать исключение вместо его обработки и восстановления.В этом разделе также есть кое-что о переопределении функций несоответствия и восстановления, чтобы убедиться, что выбрасываются все возможные исключения.