Skip to content

Templates rocker

Module templates_rocker

Rocker template engine adapter for Hexagon.

For usage instructions, refer to the Templates Port documentation.

For using Rocker templates in GraalVM native images, the template file (and the classes) need to be specified as resources in the configuration (I.e.: using -H:IncludeResources=.*\\.(html|class)). Adding the classes used in the templates to the reflect-config.json file is also required.

Install the Dependency

1
2
3
4
5
repositories {
    mavenCentral()
}

implementation("com.hexagontk:templates_rocker:$hexagonVersion")
1
2
3
4
5
<dependency>
  <groupId>com.hexagontk</groupId>
  <artifactId>templates_rocker</artifactId>
  <version>$hexagonVersion</version>
</dependency>

Use the Adapter

In order to use this adapter you need to set up a build plugin to compile the templates. To do so in Gradle, add the following lines to build.gradle.kts:

1
2
3
4
5
6
7
8
rocker {
  configurations {
    create("main") {
      templateDir.set(file("src/main/resources"))
      optimize.set(true)
    }
  }
}

On top of that, you must also declare the template parameters this way: @args(java.util.Map<String, Object> context) and use the data from the map.

Package com.hexagontk.templates.rocker

Classes that implement the Templates Port interface with the Rocker engine.