All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
net.zerobuilder.compiler.generate.BuilderContextB Maven / Gradle / Ivy
package net.zerobuilder.compiler.generate;
import com.squareup.javapoet.CodeBlock;
import com.squareup.javapoet.FieldSpec;
import com.squareup.javapoet.MethodSpec;
import com.squareup.javapoet.ParameterSpec;
import com.squareup.javapoet.ParameterizedTypeName;
import com.squareup.javapoet.TypeName;
import net.zerobuilder.compiler.generate.DtoBeanGoalContext.BeanGoalContext;
import net.zerobuilder.compiler.generate.DtoBeanStep.AbstractBeanStep;
import net.zerobuilder.compiler.generate.DtoBeanStep.AccessorPairStep;
import net.zerobuilder.compiler.generate.DtoBeanStep.BeanStepCases;
import net.zerobuilder.compiler.generate.DtoBeanStep.LoneGetterStep;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Optional;
import java.util.function.Function;
import static com.squareup.javapoet.MethodSpec.methodBuilder;
import static com.squareup.javapoet.WildcardTypeName.subtypeOf;
import static java.util.Collections.singletonList;
import static javax.lang.model.element.Modifier.PUBLIC;
import static net.zerobuilder.compiler.generate.DtoBeanParameter.beanParameterName;
import static net.zerobuilder.compiler.generate.DtoBeanStep.asFunction;
import static net.zerobuilder.compiler.generate.StepContext.nullCheck;
import static net.zerobuilder.compiler.generate.Utilities.ClassNames.ITERABLE;
import static net.zerobuilder.compiler.generate.Utilities.nullCheck;
import static net.zerobuilder.compiler.generate.Utilities.parameterSpec;
import static net.zerobuilder.compiler.generate.Utilities.presentInstances;
import static net.zerobuilder.compiler.generate.Utilities.statement;
final class BuilderContextB {
static final Function> fields
= goal -> singletonList(goal.goal.field);
static final Function> steps
= goal -> {
List builder = new ArrayList<>();
Function> stepToMethods = stepToMethods(goal, false);
for (AbstractBeanStep step : goal.goal.steps.subList(0, goal.goal.steps.size() - 1)) {
builder.addAll(stepToMethods.apply(step));
}
builder.addAll(stepToMethods(goal, true).apply(goal.goal.steps.get(goal.goal.steps.size() - 1)));
return builder;
};
private static Function>
stepToMethods(final BeanGoalContext goal, final boolean isLast) {
return asFunction(new BeanStepCases>() {
@Override
public List accessorPair(AccessorPairStep step) {
return regularMethods(step, goal, isLast);
}
@Override
public List loneGetter(LoneGetterStep step) {
return collectionMethods(step, goal, isLast);
}
});
}
private static List regularMethods(AccessorPairStep step, BeanGoalContext goal, boolean isLast) {
List builder = new ArrayList<>();
builder.add(regularStep(step, goal, isLast));
builder.addAll(presentInstances(regularEmptyCollection(step, goal, isLast)));
return builder;
}
private static Optional regularEmptyCollection(AccessorPairStep step, BeanGoalContext goal, boolean isLast) {
Optional maybeEmptyOption = step.emptyOption();
if (!maybeEmptyOption.isPresent()) {
return Optional.empty();
}
DtoStep.EmptyOption emptyOption = maybeEmptyOption.get();
TypeName type = step.accessorPair.type;
String name = step.accessorPair.accept(beanParameterName);
ParameterSpec emptyColl = parameterSpec(type, name);
return Optional.of(methodBuilder(emptyOption.name)
.addAnnotation(Override.class)
.returns(step.nextType)
.addStatement("$T $N = $L", emptyColl.type, emptyColl, emptyOption.initializer)
.addStatement("this.$N.$L($N)", goal.goal.field, step.setter, emptyColl)
.addCode(regularFinalBlock(goal, isLast))
.addModifiers(PUBLIC)
.build());
}
private static List collectionMethods(LoneGetterStep step, BeanGoalContext goal, boolean isLast) {
return Arrays.asList(
iterateCollection(step, goal, isLast),
loneGetterEmptyCollection(step, goal, isLast));
}
private static MethodSpec loneGetterEmptyCollection(LoneGetterStep step, BeanGoalContext goal, boolean isLast) {
return methodBuilder(step.emptyMethod)
.addAnnotation(Override.class)
.returns(step.nextType)
.addCode(regularFinalBlock(goal, isLast))
.addModifiers(PUBLIC)
.build();
}
private static CodeBlock regularFinalBlock(BeanGoalContext goal, boolean isLast) {
return isLast
? statement("return this.$N", goal.goal.field)
: statement("return this");
}
private static MethodSpec iterateCollection(LoneGetterStep step,
BeanGoalContext goal,
boolean isLast) {
String name = step.loneGetter.accept(beanParameterName);
ParameterizedTypeName iterable = ParameterizedTypeName.get(ITERABLE,
subtypeOf(step.loneGetter.iterationType()));
ParameterSpec parameter = parameterSpec(iterable, name);
ParameterSpec iterationVar = step.loneGetter.iterationVar(parameter);
return methodBuilder(name)
.addAnnotation(Override.class)
.returns(step.nextType)
.addParameter(parameter)
.addCode(nullCheck(parameter))
.beginControlFlow("for ($T $N : $N)",
iterationVar.type, iterationVar, parameter)
.addStatement("this.$N.$L().add($N)", goal.goal.field,
step.loneGetter.getter, iterationVar)
.endControlFlow()
.addCode(regularFinalBlock(goal, isLast))
.addModifiers(PUBLIC)
.build();
}
private static MethodSpec regularStep(AccessorPairStep step, BeanGoalContext goal, boolean isLast) {
ParameterSpec parameter = step.parameter();
return methodBuilder(step.accessorPair.accept(beanParameterName))
.addAnnotation(Override.class)
.addParameter(parameter)
.addModifiers(PUBLIC)
.returns(step.nextType)
.addCode(nullCheck.apply(step))
.addStatement("this.$N.$L($N)", goal.goal.field, step.setter, parameter)
.addCode(regularFinalBlock(goal, isLast)).build();
}
private BuilderContextB() {
throw new UnsupportedOperationException("no instances");
}
}