-
Notifications
You must be signed in to change notification settings - Fork 11
Maven Build Plugin
Ben Fagin edited this page Aug 18, 2013
·
9 revisions
Starting with version 0.4, a maven build plugin is available. This allows you to define your descriptor in a separate module, and have the code generation occur on the fly with each build.
There are several components:
- The build plugin, which reads descriptors, generates sources, and compiles them. The plugin can also write out the runtime files so that consumers of your jar do not have to include the runtime jar either as a dependency or transitive dependency.
- The runtime, either included as a dependency ('flapi-runtime') or embedded in your API jar.
- The 'build-project' POM, which can be made the parent project of your descriptor module. This reduces the amount of configuration you will have to do to a few lines. It includes source and javadoc jar creation, but places them at the end of the build process to allow the generated sources to be included.
Using the parent pom, you only need to do the following in your own project:
- Create a new module or project for your builder API.
- Add Flapi as a 'test' scoped dependency.
- Add any other dependencies you need.
- Create any support classes you need in src/main.
- Create your
DescriptorMaker
implementation in src/test. - Set the flapi.descriptor.class property in your pom to this class.
- Run
mvn clean install
to create the jars for your API/
An example of this setup is included in the project. See the build-test-producer and build-test-consumer modules.
The artifact information for the parent pom is as follows:
<parent>
<groupId>unquietcode.tools.flapi</groupId>
<artifactId>build-project</artifactId>
<version>0.4</version>
</parent>
If you are unable to make use of the preconfigured parent project, you can just include the plugin directly in your build.
<plugin>
<groupId>unquietcode.tools.flapi</groupId>
<artifactId>flapi-build-plugin</artifactId>
<version>0.4</version>
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
<configuration>
<descriptorClass>...</descriptorClass>
<sourcesDirectory>...</sourcesDirectory>
<includeRuntime>...</includeRuntime>
</configuration>
</execution>
</executions>
</plugin>
You may have to add one or both of the following to your build:
<repositories>
<repository>
<id>uqc</id>
<name>UnquietCode Repository</name>
<url>http://www.unquietcode.com/maven/releases</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>uqc</id>
<name>UnquietCode Repository</name>
<url>http://www.unquietcode.com/maven/releases</url>
</pluginRepository>
</pluginRepositories>