Skip to content

Commit

Permalink
Merge pull request #40203 from stuartwdouglas/eager-classes
Browse files Browse the repository at this point in the history
Deprecate 'eager transformers'
  • Loading branch information
Sanne authored Apr 23, 2024
2 parents a3d1568 + 469fd3a commit af955bd
Show file tree
Hide file tree
Showing 9 changed files with 25 additions and 33 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,6 @@

public final class BytecodeTransformerBuildItem extends MultiBuildItem {

/**
* If this is true it means the class should be loaded eagerly by a thread pool in dev mode
* on multithreaded systems.
* <p>
* Transformation is expensive, so doing it this way can speed up boot time.
*/
final boolean eager;
final String classToTransform;
final BiFunction<String, ClassVisitor, ClassVisitor> visitorFunction;

Expand Down Expand Up @@ -75,7 +68,6 @@ public BytecodeTransformerBuildItem(boolean eager, String classToTransform,
BiFunction<String, ClassVisitor, ClassVisitor> visitorFunction, Set<String> requireConstPoolEntry,
boolean cacheable) {
Objects.requireNonNull(visitorFunction, "visitorFunction");
this.eager = eager;
this.classToTransform = classToTransform;
this.visitorFunction = visitorFunction;
this.requireConstPoolEntry = requireConstPoolEntry;
Expand All @@ -87,7 +79,6 @@ public BytecodeTransformerBuildItem(boolean eager, String classToTransform,
}

public BytecodeTransformerBuildItem(Builder builder) {
this.eager = builder.eager;
this.classToTransform = builder.classToTransform;
this.visitorFunction = builder.visitorFunction;
this.requireConstPoolEntry = builder.requireConstPoolEntry;
Expand All @@ -113,8 +104,9 @@ public Set<String> getRequireConstPoolEntry() {
return requireConstPoolEntry;
}

@Deprecated
public boolean isEager() {
return eager;
return false;
}

public boolean isCacheable() {
Expand Down Expand Up @@ -161,7 +153,6 @@ public static class Builder {
private String classToTransform;
private BiFunction<String, ClassVisitor, ClassVisitor> visitorFunction;
private Set<String> requireConstPoolEntry = null;
private boolean eager = false;
private boolean cacheable = false;
private int classReaderOptions = 0;
private int priority = 0;
Expand Down Expand Up @@ -191,8 +182,8 @@ public Builder setRequireConstPoolEntry(Set<String> requireConstPoolEntry) {
return this;
}

@Deprecated
public Builder setEager(boolean eager) {
this.eager = eager;
return this;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,13 +46,18 @@ public static class TransformedClass {
*/
private final byte[] data;
private final String fileName;
private final boolean eager;

@Deprecated
public TransformedClass(String className, byte[] data, String fileName, boolean eager) {
this.className = className;
this.data = data;
this.fileName = fileName;
this.eager = eager;
}

public TransformedClass(String className, byte[] data, String fileName) {
this.className = className;
this.data = data;
this.fileName = fileName;
}

public byte[] getData() {
Expand All @@ -67,8 +72,9 @@ public String getClassName() {
return className;
}

@Deprecated
public boolean isEager() {
return eager;
return false;
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,6 @@ TransformedClassesBuildItem handleClassTransformation(List<BytecodeTransformerBu
bytecodeTransformerBuildItems.size());
Set<String> noConstScanning = new HashSet<>();
Map<String, Set<String>> constScanning = new HashMap<>();
Set<String> eager = new HashSet<>();
Set<String> nonCacheable = new HashSet<>();
Map<String, Integer> classReaderOptions = new HashMap<>();
for (BytecodeTransformerBuildItem i : bytecodeTransformerBuildItems) {
Expand All @@ -106,9 +105,6 @@ TransformedClassesBuildItem handleClassTransformation(List<BytecodeTransformerBu
constScanning.computeIfAbsent(i.getClassToTransform(), (s) -> new HashSet<>())
.addAll(i.getRequireConstPoolEntry());
}
if (i.isEager()) {
eager.add(i.getClassToTransform());
}
if (!i.isCacheable()) {
nonCacheable.add(i.getClassToTransform());
}
Expand Down Expand Up @@ -164,7 +160,7 @@ public byte[] apply(String className, byte[] originalBytes) {
classReaderOptions.getOrDefault(className, 0));
TransformedClassesBuildItem.TransformedClass transformedClass = new TransformedClassesBuildItem.TransformedClass(
className, data,
classFileName, eager.contains(className));
classFileName);
return transformedClass.getData();
} else {
return originalBytes;
Expand Down Expand Up @@ -241,7 +237,7 @@ public TransformedClassesBuildItem.TransformedClass call() throws Exception {
classReaderOptions.getOrDefault(className, 0));
TransformedClassesBuildItem.TransformedClass transformedClass = new TransformedClassesBuildItem.TransformedClass(
className, data,
classFileName, eager.contains(className));
classFileName);
if (cacheable && launchModeBuildItem.getLaunchMode() == LaunchMode.DEVELOPMENT
&& classData != null) {
transformedClassesCache.put(className, transformedClass);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@
import java.nio.file.Files;
import java.nio.file.StandardOpenOption;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
Expand Down Expand Up @@ -60,8 +59,7 @@ public StartupActionImpl(CuratedApplication curatedApplication, BuildResult buil
this.devServicesProperties = extractDevServicesProperties(buildResult);
this.runtimeApplicationShutdownBuildItems = buildResult.consumeMulti(RuntimeApplicationShutdownBuildItem.class);

Set<String> eagerClasses = new HashSet<>();
Map<String, byte[]> transformedClasses = extractTransformers(buildResult, eagerClasses);
Map<String, byte[]> transformedClasses = extractTransformedClasses(buildResult);
QuarkusClassLoader baseClassLoader = curatedApplication.getBaseRuntimeClassLoader();
QuarkusClassLoader runtimeClassLoader;

Expand Down Expand Up @@ -347,16 +345,13 @@ private static Map<String, String> extractDevServicesProperties(BuildResult buil
return new HashMap<>(result.getConfig());
}

private static Map<String, byte[]> extractTransformers(BuildResult buildResult, Set<String> eagerClasses) {
private static Map<String, byte[]> extractTransformedClasses(BuildResult buildResult) {
Map<String, byte[]> ret = new HashMap<>();
TransformedClassesBuildItem transformers = buildResult.consume(TransformedClassesBuildItem.class);
for (Set<TransformedClassesBuildItem.TransformedClass> i : transformers.getTransformedClassesByJar().values()) {
for (TransformedClassesBuildItem.TransformedClass clazz : i) {
if (clazz.getData() != null) {
ret.put(clazz.getFileName(), clazz.getData());
if (clazz.isEager()) {
eagerClasses.add(clazz.getClassName());
}
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1217,7 +1217,11 @@ private void enhanceEntities(final JpaModelBuildItem jpaModel,
BuildProducer<GeneratedClassBuildItem> additionalClasses) {
HibernateEntityEnhancer hibernateEntityEnhancer = new HibernateEntityEnhancer();
for (String i : jpaModel.getManagedClassNames()) {
transformers.produce(new BytecodeTransformerBuildItem(true, i, hibernateEntityEnhancer, true));

transformers.produce(new BytecodeTransformerBuildItem.Builder()
.setClassToTransform(i)
.setVisitorFunction(hibernateEntityEnhancer)
.setCacheable(true).build());
}
Set<String> additionalClassNames = new HashSet<>();
for (AdditionalJpaModelBuildItem additionalJpaModel : additionalJpaModelBuildItems) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ void build(
for (PanacheEntityClassBuildItem entityClass : entityClasses) {
String entityClassName = entityClass.get().name().toString();
modelClasses.add(entityClassName);
transformers.produce(new BytecodeTransformerBuildItem(true, entityClassName, entityOperationsEnhancer));
transformers.produce(new BytecodeTransformerBuildItem(entityClassName, entityOperationsEnhancer));
}

panacheEntities.addAll(modelClasses);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ void build(CombinedIndexBuildItem index,
ReactiveJavaJpaTypeBundle.BUNDLE);
for (PanacheEntityClassBuildItem entityClass : entityClasses) {
String entityClassName = entityClass.get().name().toString();
transformers.produce(new BytecodeTransformerBuildItem(true, entityClassName, entityOperationsEnhancer));
transformers.produce(new BytecodeTransformerBuildItem(entityClassName, entityOperationsEnhancer));
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ void replaceFieldAccesses(CombinedIndexBuildItem index,
PanacheJpaEntityAccessorsEnhancer entityAccessorsEnhancer = new PanacheJpaEntityAccessorsEnhancer(index.getIndex(),
modelInfo);
for (String entityClassName : entitiesWithExternallyAccessibleFields) {
transformers.produce(new BytecodeTransformerBuildItem(true, entityClassName, entityAccessorsEnhancer));
transformers.produce(new BytecodeTransformerBuildItem(entityClassName, entityAccessorsEnhancer));
}

// Replace field access in application code with calls to accessors
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -755,7 +755,7 @@ private static void generateDefaultConstructors(BuildProducer<BytecodeTransforme

final String name = classInfo.name().toString();
transformers
.produce(new BytecodeTransformerBuildItem(true, name, new BiFunction<String, ClassVisitor, ClassVisitor>() {
.produce(new BytecodeTransformerBuildItem(name, new BiFunction<String, ClassVisitor, ClassVisitor>() {
@Override
public ClassVisitor apply(String className, ClassVisitor classVisitor) {
ClassVisitor cv = new ClassVisitor(Gizmo.ASM_API_VERSION, classVisitor) {
Expand Down

0 comments on commit af955bd

Please sign in to comment.