Я новичок в Maven. У меня есть проект, который включает файл определения грамматики, который читается Sable CC, который является генератором парсера. Sable CC читает файл грамматики и генерирует исходный код Java, который после компиляции создает анализатор. Парсер используется остальной частью моего проекта.
Не думаю, что мой вопрос - это вопрос Sable CC, поскольку я видел похожие файлы POM. XML, в которых используется Antlr (еще один генератор синтаксического анализатора, сравнимый с Sable CC) и раздел <plugin>
этого POM. XML выглядит почти так же, как мой раздел <plugin>
в моем файле POM. XML.
Вот структура файла моего проекта, определяющая те части, которые используются by Sable CC:
Вот мой полный файл POM. XML, который я собрал вместе на основе примеров плагинов, которые я До сих пор видел (и, в частности, тот, что для Sable CC):
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mbm</groupId>
<artifactId>properties</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>Properties</name>
<description>Define and process program arguments</description>
<dependencies>
</dependencies>
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>sablecc-maven-plugin</artifactId>
<version>2.2</version>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</pluginManagement>
</build>
</project>
Мой вопрос: как плагин Sable CC узнает, где находится входной файл и где 4 категории? сгенерированных Java исходных файлов (анализ, лексер, узел и анализатор) должны go? Я подозреваю, что мне нужно добавить больше "материала" Maven в мой файл POM, но я не знаю, что.