com.oracle.truffle.sl.nodes.expression.SLLessThanNodeGen Maven / Gradle / Ivy
// CheckStyle: start generated
package com.oracle.truffle.sl.nodes.expression;
import com.oracle.truffle.api.CompilerDirectives;
import com.oracle.truffle.api.CompilerDirectives.CompilationFinal;
import com.oracle.truffle.api.dsl.GeneratedBy;
import com.oracle.truffle.api.frame.VirtualFrame;
import com.oracle.truffle.api.nodes.NodeCost;
import com.oracle.truffle.api.nodes.UnexpectedResultException;
import com.oracle.truffle.sl.nodes.SLExpressionNode;
import com.oracle.truffle.sl.nodes.SLTypesGen;
import java.math.BigInteger;
import java.util.concurrent.locks.Lock;
@GeneratedBy(SLLessThanNode.class)
public final class SLLessThanNodeGen extends SLLessThanNode {
@Child private SLExpressionNode leftNode_;
@Child private SLExpressionNode rightNode_;
@CompilationFinal private int state_ = 1;
private SLLessThanNodeGen(SLExpressionNode leftNode, SLExpressionNode rightNode) {
this.leftNode_ = leftNode;
this.rightNode_ = rightNode;
}
@Override
public Object executeGeneric(VirtualFrame frameValue) {
int state = state_;
if ((state & 0b1101) == 0 /* only-active lessThan(long, long) */) {
return executeGeneric_long_long0(frameValue, state);
} else {
return executeGeneric_generic1(frameValue, state);
}
}
private Object executeGeneric_long_long0(VirtualFrame frameValue, int state) {
long leftNodeValue_;
try {
leftNodeValue_ = leftNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
Object rightNodeValue = rightNode_.executeGeneric(frameValue);
return executeAndSpecialize(ex.getResult(), rightNodeValue);
}
long rightNodeValue_;
try {
rightNodeValue_ = rightNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
return executeAndSpecialize(leftNodeValue_, ex.getResult());
}
assert (state & 0b10) != 0 /* is-active lessThan(long, long) */;
return lessThan(leftNodeValue_, rightNodeValue_);
}
private Object executeGeneric_generic1(VirtualFrame frameValue, int state) {
Object leftNodeValue_ = leftNode_.executeGeneric(frameValue);
Object rightNodeValue_ = rightNode_.executeGeneric(frameValue);
if ((state & 0b10) != 0 /* is-active lessThan(long, long) */ && leftNodeValue_ instanceof Long) {
long leftNodeValue__ = (long) leftNodeValue_;
if (rightNodeValue_ instanceof Long) {
long rightNodeValue__ = (long) rightNodeValue_;
return lessThan(leftNodeValue__, rightNodeValue__);
}
}
if ((state & 0b100) != 0 /* is-active lessThan(BigInteger, BigInteger) */ && SLTypesGen.isImplicitBigInteger((state & 0b110000) >>> 4 /* extract-implicit-active 0:BigInteger */, leftNodeValue_)) {
BigInteger leftNodeValue__ = SLTypesGen.asImplicitBigInteger((state & 0b110000) >>> 4 /* extract-implicit-active 0:BigInteger */, leftNodeValue_);
if (SLTypesGen.isImplicitBigInteger((state & 0b11000000) >>> 6 /* extract-implicit-active 1:BigInteger */, rightNodeValue_)) {
BigInteger rightNodeValue__ = SLTypesGen.asImplicitBigInteger((state & 0b11000000) >>> 6 /* extract-implicit-active 1:BigInteger */, rightNodeValue_);
return lessThan(leftNodeValue__, rightNodeValue__);
}
}
if ((state & 0b1000) != 0 /* is-active typeError(Object, Object) */) {
if (fallbackGuard_(leftNodeValue_, rightNodeValue_)) {
return typeError(leftNodeValue_, rightNodeValue_);
}
}
CompilerDirectives.transferToInterpreterAndInvalidate();
return executeAndSpecialize(leftNodeValue_, rightNodeValue_);
}
@Override
public boolean executeBoolean(VirtualFrame frameValue) throws UnexpectedResultException {
int state = state_;
if ((state & 0b1000) != 0 /* is-active typeError(Object, Object) */) {
return SLTypesGen.expectBoolean(executeGeneric(frameValue));
}
if ((state & 0b1101) == 0 /* only-active lessThan(long, long) */) {
return executeBoolean_long_long2(frameValue, state);
} else {
return executeBoolean_generic3(frameValue, state);
}
}
private boolean executeBoolean_long_long2(VirtualFrame frameValue, int state) throws UnexpectedResultException {
long leftNodeValue_;
try {
leftNodeValue_ = leftNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
Object rightNodeValue = rightNode_.executeGeneric(frameValue);
return SLTypesGen.expectBoolean(executeAndSpecialize(ex.getResult(), rightNodeValue));
}
long rightNodeValue_;
try {
rightNodeValue_ = rightNode_.executeLong(frameValue);
} catch (UnexpectedResultException ex) {
return SLTypesGen.expectBoolean(executeAndSpecialize(leftNodeValue_, ex.getResult()));
}
assert (state & 0b10) != 0 /* is-active lessThan(long, long) */;
return lessThan(leftNodeValue_, rightNodeValue_);
}
private boolean executeBoolean_generic3(VirtualFrame frameValue, int state) throws UnexpectedResultException {
Object leftNodeValue_ = leftNode_.executeGeneric(frameValue);
Object rightNodeValue_ = rightNode_.executeGeneric(frameValue);
if ((state & 0b10) != 0 /* is-active lessThan(long, long) */ && leftNodeValue_ instanceof Long) {
long leftNodeValue__ = (long) leftNodeValue_;
if (rightNodeValue_ instanceof Long) {
long rightNodeValue__ = (long) rightNodeValue_;
return lessThan(leftNodeValue__, rightNodeValue__);
}
}
if ((state & 0b100) != 0 /* is-active lessThan(BigInteger, BigInteger) */ && SLTypesGen.isImplicitBigInteger((state & 0b110000) >>> 4 /* extract-implicit-active 0:BigInteger */, leftNodeValue_)) {
BigInteger leftNodeValue__ = SLTypesGen.asImplicitBigInteger((state & 0b110000) >>> 4 /* extract-implicit-active 0:BigInteger */, leftNodeValue_);
if (SLTypesGen.isImplicitBigInteger((state & 0b11000000) >>> 6 /* extract-implicit-active 1:BigInteger */, rightNodeValue_)) {
BigInteger rightNodeValue__ = SLTypesGen.asImplicitBigInteger((state & 0b11000000) >>> 6 /* extract-implicit-active 1:BigInteger */, rightNodeValue_);
return lessThan(leftNodeValue__, rightNodeValue__);
}
}
CompilerDirectives.transferToInterpreterAndInvalidate();
return SLTypesGen.expectBoolean(executeAndSpecialize(leftNodeValue_, rightNodeValue_));
}
@Override
public void executeVoid(VirtualFrame frameValue) {
int state = state_;
try {
if ((state & 0b1001) == 0 /* only-active lessThan(long, long) && lessThan(BigInteger, BigInteger) */) {
executeBoolean(frameValue);
return;
}
executeGeneric(frameValue);
return;
} catch (UnexpectedResultException ex) {
return;
}
}
private Object executeAndSpecialize(Object leftNodeValue, Object rightNodeValue) {
Lock lock = getLock();
boolean hasLock = true;
lock.lock();
try {
int state = state_ & 0xfffffffe/* mask-active uninitialized*/;
if (leftNodeValue instanceof Long) {
long leftNodeValue_ = (long) leftNodeValue;
if (rightNodeValue instanceof Long) {
long rightNodeValue_ = (long) rightNodeValue;
this.state_ = state = state | 0b10 /* add-active lessThan(long, long) */;
lock.unlock();
hasLock = false;
return lessThan(leftNodeValue_, rightNodeValue_);
}
}
{
int bigIntegerCast0;
if ((bigIntegerCast0 = SLTypesGen.specializeImplicitBigInteger(leftNodeValue)) != 0) {
BigInteger leftNodeValue_ = SLTypesGen.asImplicitBigInteger(bigIntegerCast0, leftNodeValue);
int bigIntegerCast1;
if ((bigIntegerCast1 = SLTypesGen.specializeImplicitBigInteger(rightNodeValue)) != 0) {
BigInteger rightNodeValue_ = SLTypesGen.asImplicitBigInteger(bigIntegerCast1, rightNodeValue);
state = (state | (bigIntegerCast0 << 4) /* set-implicit-active 0:BigInteger */);
state = (state | (bigIntegerCast1 << 6) /* set-implicit-active 1:BigInteger */);
this.state_ = state = state | 0b100 /* add-active lessThan(BigInteger, BigInteger) */;
lock.unlock();
hasLock = false;
return lessThan(leftNodeValue_, rightNodeValue_);
}
}
}
this.state_ = state = state | 0b1000 /* add-active typeError(Object, Object) */;
lock.unlock();
hasLock = false;
return typeError(leftNodeValue, rightNodeValue);
} finally {
if (hasLock) {
lock.unlock();
}
}
}
@Override
public NodeCost getCost() {
int state = state_ & 0xfffffffe/* mask-active uninitialized*/;
if (state == 0b0) {
return NodeCost.UNINITIALIZED;
} else if (((state & 0b1110) & ((state & 0b1110) - 1)) == 0 /* is-single-active */) {
return NodeCost.MONOMORPHIC;
}
return NodeCost.POLYMORPHIC;
}
private static boolean fallbackGuard_(Object leftNodeValue, Object rightNodeValue) {
if (SLTypesGen.isImplicitBigInteger(0b11, leftNodeValue) && SLTypesGen.isImplicitBigInteger(0b11, rightNodeValue)) {
return false;
}
return true;
}
public static SLLessThanNode create(SLExpressionNode leftNode, SLExpressionNode rightNode) {
return new SLLessThanNodeGen(leftNode, rightNode);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy