-
-
Notifications
You must be signed in to change notification settings - Fork 22
How to generate sources at runtime
Burningwave edited this page Feb 3, 2021
·
6 revisions
With UnitSourceGenerator you can generate source code and store it on the drive. Assuming this class as example:
package source.generation.test;
import java.util.Arrays;
import java.util.List;
public class GeneratedClass {
private List<String> words;
public GeneratedClass(String... words) {
this.words = Arrays.asList(words);
}
public void print() {
System.out.print(String.join(" ", words));
}
public static void main(String[] args) {
new GeneratedClass(args).print();
}
}
... The relative code to generate and store it will be:
package source.generation.test;
import java.lang.reflect.Modifier;
import java.util.Arrays;
import java.util.List;
import org.burningwave.core.classes.ClassSourceGenerator;
import org.burningwave.core.classes.FunctionSourceGenerator;
import org.burningwave.core.classes.GenericSourceGenerator;
import org.burningwave.core.classes.TypeDeclarationSourceGenerator;
import org.burningwave.core.classes.UnitSourceGenerator;
import org.burningwave.core.classes.VariableSourceGenerator;
public class SourceGenerationTester {
public static UnitSourceGenerator generate() {
return UnitSourceGenerator.create(SourceGenerationTester.class.getPackage().getName())
.addClass(
ClassSourceGenerator.create(TypeDeclarationSourceGenerator.create("GeneratedClass"))
.addField(
VariableSourceGenerator.create(
TypeDeclarationSourceGenerator.create(List.class)
.addGeneric(GenericSourceGenerator.create(String.class)),
"words"
)
)
.addConstructor(
FunctionSourceGenerator.create().addParameter(
VariableSourceGenerator.create(
TypeDeclarationSourceGenerator.create(String.class)
.setAsVarArgs(true),
"words"
)
).addBodyCodeLine("this.words = Arrays.asList(words);").useType(Arrays.class)
)
.addMethod(
FunctionSourceGenerator.create("print")
.addModifier(Modifier.PUBLIC).setReturnType(void.class)
.addBodyCodeLine(
"System.out.println(\"\\n\\t\" + String.join(\" \", words) + \"\\n\");"
)
)
.addMethod(
FunctionSourceGenerator.create("main")
.addModifier(Modifier.PUBLIC | Modifier.STATIC)
.setReturnType(void.class)
.addParameter(VariableSourceGenerator.create(String[].class, "args"))
.addBodyCodeLine("new GeneratedClass(args).print();")
)
);
}
public static void main(String[] args) {
UnitSourceGenerator unitSG = SourceGenerationTester.generate();
unitSG.storeToClassPath(System.getProperty("user.home") + "/Desktop/sources");
System.out.println("\nGenerated code:\n" + unitSG);
}
}
Once the sources have been generated you can also compile them at runtime: to do this follow this guide.
Burningwave core is a fully indipendent, advanced, free and open source Java frameworks building library that contains AN EXTREMELY POWERFUL CLASSPATH SCANNER.
To include Burningwave Core library in your projects simply use with Apache Maven:
<dependency>
<groupId>org.burningwave</groupId>
<artifactId>core</artifactId>
<version>12.65.2</version>
</dependency>
To use Burningwave Core as a Java module add the following to your module-info.java
:
requires org.burningwave.core;
ClassFactory
ClassHunter
- In depth look to and configuration guide
- USE CASE: retrieving all classes of the classpath
- USE CASE: retrieving all classes that implement one or more interfaces
- USE CASE: finding all classes that extend a base class
- USE CASE: searching for all classes that have package name that matches a regex
- USE CASE: finding all classes for module name (Java 9 and later)
- USE CASE: finding all annotated classes
- USE CASE: how to scan classes for specific annotations and collect its values
- USE CASE: searching for all classes with a constructor that takes a specific type as first parameter and with at least 2 methods that begin for a given string
- USE CASE: searching for all classes with methods whose name begins for a given string and that takes a specific type as its first parameter
- USE CASE: finding all classes that have at least 2 protected fields