Skip to content

Commit

Permalink
Fix a bug where a Staged interface for a required property generates …
Browse files Browse the repository at this point in the history
…a setter with the wrong type parameter.
  • Loading branch information
skinny85 committed Jan 20, 2024
1 parent 6917908 commit f18b7f8
Show file tree
Hide file tree
Showing 4 changed files with 60 additions and 0 deletions.
1 change: 1 addition & 0 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ repositories {
if (JavaVersion.current() <= JavaVersion.VERSION_11) {
sourceCompatibility = JavaVersion.VERSION_1_6
targetCompatibility = JavaVersion.VERSION_1_6
sourceSets.test.java.exclude '**/Optional*.java'
} else {
sourceCompatibility = JavaVersion.VERSION_17
targetCompatibility = JavaVersion.VERSION_17
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,26 @@ protected final TypeName attributeType(VariableElement attribute) {
TypeVariableName typeVariableName = (TypeVariableName) ret;
return this.mangleTypeParameter(typeVariableName);
}
// if this is an entire parameterized type, we need to mangle it
if (ret instanceof ParameterizedTypeName) {
ParameterizedTypeName parameterizedTypeName = (ParameterizedTypeName) ret;
return ParameterizedTypeName.get(parameterizedTypeName.rawType,
this.mangleTypeNameParameters(parameterizedTypeName.typeArguments).toArray(new TypeName[]{}));
}
return ret;
}

private List<TypeName> mangleTypeNameParameters(List<TypeName> typeArguments) {
List<TypeName> ret = new ArrayList<>(typeArguments.size());
for (TypeName typeName : typeArguments) {
if (typeName instanceof TypeVariableName) {
// if this is a type variable, we need to mangle it
TypeVariableName typeVariableName = (TypeVariableName) typeName;
ret.add(this.mangleTypeParameter(typeVariableName));
} else {
ret.add(typeName);
}
}
return ret;
}

Expand Down
22 changes: 22 additions & 0 deletions src/test/java/org/jilt/test/OptionalsValueTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package org.jilt.test;

import org.jilt.test.data.optionals.OptionalsValue;
import org.jilt.test.data.optionals.OptionalsValueBuilder;
import org.junit.Test;

import java.util.Optional;

import static org.assertj.core.api.Assertions.assertThat;

public class OptionalsValueTest {
@Test
public void optional_property_is_always_optional() {
OptionalsValue<String, Integer> value = OptionalsValueBuilder.<String, Integer>optionalsValue()
.optional(Optional.of("abc"))
.t2(33)
.build();

assertThat(value.optional).contains("abc");
assertThat(value.t2).isEqualTo(33);
}
}
17 changes: 17 additions & 0 deletions src/test/java/org/jilt/test/data/optionals/OptionalsValue.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package org.jilt.test.data.optionals;

import org.jilt.Builder;
import org.jilt.BuilderStyle;

import java.util.Optional;

@Builder(style = BuilderStyle.STAGED)
public final class OptionalsValue<T1, T2> {
public final Optional<T1> optional;
public final T2 t2;

public OptionalsValue(Optional<T1> optional, T2 t2) {
this.optional = optional;
this.t2 = t2;
}
}

0 comments on commit f18b7f8

Please sign in to comment.