Go to file
Speiger 48853140d0 Added Missing Newlines 2021-01-11 13:43:50 +01:00
.settings Initial Repo Data 2021-01-11 13:02:39 +01:00
gradle/wrapper Initial Repo Data 2021-01-11 13:02:39 +01:00
src/main/java/speiger/src/builder Uploading SourceCode and Documentation 2021-01-11 13:43:07 +01:00
.classpath Initial Repo Data 2021-01-11 13:02:39 +01:00
.gitignore Updating Git ignore to not include Bin Folder 2021-01-11 13:05:34 +01:00
.project Initial Repo Data 2021-01-11 13:02:39 +01:00
LICENSE Initial commit 2021-01-11 11:51:55 +00:00
README.md Added Missing Newlines 2021-01-11 13:43:50 +01:00
build.gradle Initial Repo Data 2021-01-11 13:02:39 +01:00
gradlew Initial Repo Data 2021-01-11 13:02:39 +01:00
gradlew.bat Initial Repo Data 2021-01-11 13:02:39 +01:00
settings.gradle Inital Commit 2021-01-11 13:02:02 +01:00

README.md

Simple-Code-Generator

This Tool is a very Simple Code Generator that can read a template file and segment it based on a Set of variables that can be defined. Separate to that this tool can replace text via simple Regular Expression mapping. It has a cache that keeps track of the input (if it was changed), and only cares that the file format is Text based.

It is as bare bones as it can get but that also makes it flexible.

How to create a Template Processor

Create a class that extends TemplateProcessor. And run the process method SourceFolder: Is the folder that is traversed through and Files are given back. OutputFolder: Is the folder where the Processed files get put into. If the "relativePackages" are set to true then the source folder structure is transferred. DataFolder: Is the folder where the input cache is stored. It uses a MD5 generator to compare inputs. Right now only FileNames without extensions are stored in there. So no Duplicated FileName support for now.

Methods:

init: Is called when the Processes was started for the first time.
isFileValid: The Method that checks if a File can be used for a template.
relativePackages: If the Folder Structure from the SourceFolder should be transferred to the OutputFolder.
createProcesses: The Main Function that provides the FileName (without extension) and a consumer of how the file should be processed.
A TemplateProcess is a Collection of Variables that is used for File Segmentation and a List of UnaryOperators that allow to edit the build code.
A Simple sum up: Template Process is Tuple<Set, List> that also contains the new FileName.

package test.example;

public class ExampleClass
{
#if METHOD_ONE
	public void methodOne() {}
#else if METHOD_TWO && !SKIP
	public void methodTwo() {}
#else
	public void methodThree() {}
#endif
}

If the Variable "METHOD_ONE" is present only the code in the if is parsed into the template process.
If the Variable "METHOD_TWO" is present and the "SKIP" Variable is missing then the code in the else if block is parsed into the template process
Otherwise the else block is included.
Whenever a if is started, it has to end with a #endif, Even if the last condition is a else if or a else.
Recursion is supported and necessary