У меня есть следующая пользовательская сборка:
<assembly>
<id>full</id>
<formats>
<format>jar</format>
</formats>
<includeBaseDirectory>false</includeBaseDirectory>
<fileSets>
<fileSet>
<directory>${project.build.outputDirectory}</directory>
<outputDirectory>/</outputDirectory>
</fileSet>
</fileSets>
</assembly>
и следующий раздел конфигурации:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<descriptors>
<descriptor>src/main/assembly/assembly.xml</descriptor>
</descriptors>
<archive>
<manifest>
<mainClass>com.example.MyExample</mainClass>
<addClasspath>true</addClasspath>
<classpathPrefix>./lib/</classpathPrefix>
</manifest>
</archive>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
в соответствии с документацией на плагине сборки Maven, это должно добавить элемент классов в файл манифеста, однако он не работает. Если я пользуюсь устаревшей целью ассамблеи вместо одиночных, она работает.
Я куда-то заметил, что кто-то упомянул, что секция архива доступна только с форматом JAR, но это то, что я использую.
Когда они устарели сборку: сборку, они определяли новый способ сделать это правильно? Мне действительно не нравится использовать устаревшие функциональные возможности, но если они сломают то, как все работало и не задокументируйте его, я действительно не знаю, как избежать этого.
У кого-нибудь есть какие-то примеры того, как это сделать правильно?