-
If you are using Maven, add the following dependencies to your project:
<dependency>
<groupId>org.jboss.forge.roaster</groupId>
<artifactId>roaster-api</artifactId>
<version>${version.roaster}</version>
</dependency>
<dependency>
<groupId>org.jboss.forge.roaster</groupId>
<artifactId>roaster-jdt</artifactId>
<version>${version.roaster}</version>
<scope>runtime</scope>
</dependency>
-
Otherwise, download and extract (or build from sources) the most recent the most recent distribution containing the Roaster distribution and command line tools
Execute roaster by running the following script (add these to your $PATH for convenience):
bin/roaster (Unix/Linux/OSX)
bin/roaster.bat (Windows)
Options described here:
$ roaster -h
Usage: roaster [OPTION]... FILES ...
The fastest way to build applications, share your software, and enjoy doing it.
-c, --config [CONFIG_FILE]
specify the path to the Eclipse code format profile (usually found at '$PROJECT/.settings/org.eclipse.jdt.core.prefs')
-r, --recursive
format files in found sub-directories recursively
FILES...
specify one or more space-separated files or directories to format
-h, --help
display this help and exit
Roaster provides a fluent API to generate java classes. Here an example:
final JavaClassSource javaClass = Roaster.create(JavaClassSource.class);
javaClass.setPackage("com.company.example").setName("Person");
javaClass.addInterface(Serializable.class);
javaClass.addField()
.setName("serialVersionUID")
.setType("long")
.setLiteralInitializer("1L")
.setPrivate()
.setStatic(true)
.setFinal(true);
javaClass.addProperty(Integer.class, "id").setMutable(false);
javaClass.addProperty(String.class, "firstName");
javaClass.addProperty("String", "lastName");
javaClass.addMethod()
.setConstructor(true)
.setPublic()
.setBody("this.id = id;")
.addParameter(Integer.class, "id");
Will produce:
package com.company.example;
import java.io.Serializable;
public class Person implements Serializable {
private static final long serialVersionUID = 1L;
private final Integer id;
private String firstName;
private String lastName;
public Integer getId() {
return id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public Person(Integer id) {
this.id = id;
}
}
Of course it is possible to mix both approaches (parser and writer) to modify Java code programmatically:
JavaClassSource javaClass =
Roaster.parse(JavaClassSource.class, "public class SomeClass {}");
javaClass.addMethod()
.setPublic()
.setStatic(true)
.setName("main")
.setReturnTypeVoid()
.setBody("System.out.println(\"Hello World\");")
.addParameter("java.lang.String[]", "args");
System.out.println(javaClass);
Here is an example on how to add JavaDoc to a class:
JavaClassSource javaClass =
Roaster.parse(JavaClassSource.class, "public class SomeClass {}");
JavaDocSource javaDoc = javaClass.getJavaDoc();
javaDoc.setFullText("Full class documentation");
// or
javaDoc.setText("Class documentation text");
javaDoc.addTagValue("@author","George Gastaldi");
System.out.println(javaClass);
Roaster formats the Java Source Code by calling the format() method:
String javaCode = "public class MyClass{ private String field;}";
String formattedCode = Roaster.format(javaCode);
System.out.println(formattedCode);
The Java Language Specification allows you to define multiple classes in the same .java file. Roaster supports parsing the entire unit by calling the parseUnit() method:
String javaCode = "public class MyClass{ private String field;} public class AnotherClass {}";
JavaUnit unit = Roaster.parseUnit(javaCode);
JavaClassSource myClass = unit.getGoverningType();
JavaClassSource anotherClass = (JavaClassSource) unit.getTopLevelTypes().get(1);
ROASTER on JBossDeveloper. You might need to log in, in order to view the issues.
Roaster uses the same forum and mailing lists as the JBoss Forge project. See the JBoss Forge Community page.
For the writer part: