From 7543cd45dfd116f5121a23e4b95d43387a733b1f Mon Sep 17 00:00:00 2001 From: Camotoy <20743703+Camotoy@users.noreply.github.com> Date: Sat, 24 Aug 2024 18:55:23 -0400 Subject: [PATCH] Don't try to initialize ConfigSerializable if @Field is marked --- .../interfaces/processor/ConfigImplementationGenerator.java | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/extra/interface/ap/src/main/java/org/spongepowered/configurate/interfaces/processor/ConfigImplementationGenerator.java b/extra/interface/ap/src/main/java/org/spongepowered/configurate/interfaces/processor/ConfigImplementationGenerator.java index dcb60dc3..2283ac93 100644 --- a/extra/interface/ap/src/main/java/org/spongepowered/configurate/interfaces/processor/ConfigImplementationGenerator.java +++ b/extra/interface/ap/src/main/java/org/spongepowered/configurate/interfaces/processor/ConfigImplementationGenerator.java @@ -179,13 +179,14 @@ private boolean gatherElementSpec( final FieldSpec.Builder fieldSpec = FieldSpec.builder(TypeName.get(nodeType), simpleName, Modifier.PRIVATE); - if (hasAnnotation(element, Field.class)) { + final boolean isField = hasAnnotation(element, Field.class); + if (isField) { fieldSpec.addModifiers(Modifier.TRANSIENT); } // set a default value for config subsections final TypeElement nodeTypeElement = Utils.toBoxedTypeElement(nodeType, this.processor.typeUtils); - if (!element.isDefault() && hasAnnotation(nodeTypeElement, ConfigSerializable.class)) { + if (!isField && !element.isDefault() && hasAnnotation(nodeTypeElement, ConfigSerializable.class)) { ClassName configClass = ClassName.get(nodeTypeElement); if (nodeTypeElement.getKind().isInterface()) { // first find the generated class for given type