Writing a Maven Tile
A Maven Tile is made up of a pom.xml and a tile.xml.
The pom.xml is a basic Maven project using the packaging type of tile, and the inclusion of the tiles-maven-plugin, along with release plugin configuration (often coming itself from a tile).
The POM would be minimal, only declaring the name, groupId, artifactId, version, description, and packaging (tile) attributes and generally only a declaration of the Maven Tiles plugin.
The tiles plugin will only have a configuration element defined when using other tiles (generally, you use at least one - a release tile).
pom.xml
<project>
<groupId>io.repaint.maven</groupId>
<artifactId>license-tile</artifactId>
<version>1.1-SNAPSHOT</version>
<packaging>tile</packaging>
<description>Contains consistent license information.</description>
<modelVersion>4.0.0</modelVersion>
<build>
<plugins>
<plugin>
<groupId>io.repaint.maven</groupId>
<artifactId>tiles-maven-plugin</artifactId>
<version>2.37</version>
<extensions>true</extensions>
<configuration>
<filtering>false</filtering>
<tiles>
<tile>io.repaint.tiles:github-release-tile:[1.1, 2)</tile>
</tiles>
</configuration>
</plugin>
</plugins>
</build>
</project>
With the packaging tile, the plugin will look for the attached `tile.xml“, do some basic validation on it and attach it as an artifact.
When the <filtering> configuration item is specified as true - then standard Maven resource filtering for @project.version@ style references is applied to the tile.xml file prior to install/deploy.
tile.xml
<?xml version="1.0" encoding="UTF-8"?>
<project>
<modelVersion>4.0.0</modelVersion>
<licenses>
<license>
<name>The Apache Software License, Version 2.0</name>
<url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
<distribution>repo</distribution>
</license>
</licenses>
</project>
Using Snapshots of Tiles
-SNAPSHOT versions of tiles work when installed into your local ~/.m2/repository, however - if you wish to use a published SNAPSHOT - you will need to declare a <repository> in your pom.xml that support SNAPSHOTs.
Review the introduction to repositories section on the Apache Maven website.
If you don’t wish to include <repository> definitions in your project source, declaring them in an activated <profile> in your ~/.m2/settings.xml file is a viable alternative.
📌 NOTE
This introduces an element of inconsistentcy/non-reproducability to your build and should be done with care.
Transcluding Tiles
A tile can define the tiles plugin if it wishes to cascade tile inclusion, or it can use the extended tile.xml syntax:
tile.xml
<?xml version="1.0" encoding="UTF-8"?>
<project>
<modelVersion>4.0.0</modelVersion>
<licenses>
<license>
<name>The Apache Software License, Version 2.0</name>
<url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
<distribution>repo</distribution>
</license>
</licenses>
<tiles>
<tile>io.repaint.tiles:ratpack-tile:[1,2)</tile>
</tiles>
</project>
Although this will appear to not validate when editing in an IDE, the tile plugin will strip off the tiles section when processing and use it directly.