All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.bytebuddy.instrumentation.method.bytecode.stack.assign.primitive.VoidAwareAssigner Maven / Gradle / Ivy

Go to download

Byte Buddy is a Java library for creating Java classes at run time. This artifact is a build of Byte Buddy with all ASM dependencies repackaged into its own name space.

There is a newer version: 1.15.11
Show newest version
package net.bytebuddy.instrumentation.method.bytecode.stack.assign.primitive;

import net.bytebuddy.instrumentation.method.bytecode.stack.Removal;
import net.bytebuddy.instrumentation.method.bytecode.stack.StackManipulation;
import net.bytebuddy.instrumentation.method.bytecode.stack.assign.Assigner;
import net.bytebuddy.instrumentation.method.bytecode.stack.constant.DefaultValue;
import net.bytebuddy.instrumentation.type.TypeDescription;

/**
 * This assigner is able to handle the {@code void} type. This means:
 * 
    *
  1. If a {@code void} type is assigned to the {@code void} it will consider this a trivial operation.
  2. *
  3. If a {@code void} type is assigned to a non-{@code void} type, it will pop the top value from the stack.
  4. *
  5. If a non-{@code void} type is assigned to a {@code void} type, it will load the target type's default value * only if this was configured at the assigner's construction.
  6. *
  7. If two non-{@code void} types are subject of the assignment, it will delegate the assignment to its chained * assigner.
  8. *
*/ public class VoidAwareAssigner implements Assigner { /** * An assigner that is capable of handling assignments that do not involve {@code void} types. */ private final Assigner chained; /** * Creates a new assigner that is capable of handling void types. * * @param chained A chained assigner which will be queried by this assigner to handle assignments that * do not involve a {@code void} type. */ public VoidAwareAssigner(Assigner chained) { this.chained = chained; } @Override public StackManipulation assign(TypeDescription sourceType, TypeDescription targetType, boolean dynamicallyTyped) { if (sourceType.represents(void.class) && targetType.represents(void.class)) { return StackManipulation.LegalTrivial.INSTANCE; } else if (sourceType.represents(void.class) /* && subType != void.class */) { return dynamicallyTyped ? DefaultValue.of(targetType) : StackManipulation.Illegal.INSTANCE; } else if (/* superType != void.class && */ targetType.represents(void.class)) { return Removal.pop(sourceType); } else /* superType != void.class && subType != void.class */ { return chained.assign(sourceType, targetType, dynamicallyTyped); } } @Override public boolean equals(Object other) { return this == other || !(other == null || getClass() != other.getClass()) && chained.equals(((VoidAwareAssigner) other).chained); } @Override public int hashCode() { return chained.hashCode(); } @Override public String toString() { return "VoidAwareAssigner{chained=" + chained + '}'; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy