ANTLR4 TokenStreamRewriter.getText() теряет пробелы в пользовательском правиле синтаксического анализатора DOCTYPEPython

Программы на Python
Ответить
Anonymous
 ANTLR4 TokenStreamRewriter.getText() теряет пробелы в пользовательском правиле синтаксического анализатора DOCTYPE

Сообщение Anonymous »

Я использую ANTLR4 для анализа XML-файлов, а затем вывожу проанализированный контент с помощью TokenStreamRewriter.getText().

Для обычных тегов XML (например, и ) выходные данные корректны: пробелы и разрывы строк сохраняются.
Однако для добавленного мной специального правила синтаксического анализатора DOCTYPE выходные данные теряет все пробелы, даже если исходный XML содержит пробелы и разрывы строк.
Ожидаемое поведение:

Я хочу, чтобы выходные данные DOCTYPE сохраняли исходное форматирование, включая пробелы и разрывы строк, например: Фактическое поведение:

Вывод, создаваемый TokenStreamRewriter.getText(), выглядит следующим образом: Все пробелы удаляются и все объединяется.
Используются правила синтаксического анализатора:

Код: Выделить всё

dtd :
DOCTYPE_OPEN Name LBRACK misc* entityDecl* RBRACK CLOSE misc* entityRef?
;

entityDecl
: ENTITY_OPEN Name STRING misc* CLOSE
;

entityRef
: '' EntityRef ''
;
Описание проблемы:

Я подозреваю, что эта проблема связана с уровнем лексера. TokenStreamRewriter.getText() просто объединяет token.text, поэтому, если лексер пропускает пробельные токены, они не отображаются в выводе.
Я хочу знать:
  • Как я могу изменить правила лексера/парсера ANTLR4, чтобы в выводе DOCTYPE сохранялись пробелы?
  • Существует ли рекомендуемый подход, гарантирующий, что TokenStreamRewriter.getText() выводит текст, который почти идентичен исходному XML?
Что я пробовал:
  • Добавление пробелов в посетителе вручную работает, но это громоздко.
  • Использование rewriter.getText(ctx.start, ctx.stop) не помогает, если пропускаются токены пробелов.
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»