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

com.oracle.truffle.js.nodes.access.JSProxyCallNodeGen Maven / Gradle / Ivy

The newest version!
// CheckStyle: start generated
package com.oracle.truffle.js.nodes.access;

import com.oracle.truffle.api.CompilerDirectives;
import com.oracle.truffle.api.CompilerDirectives.CompilationFinal;
import com.oracle.truffle.api.dsl.DSLSupport;
import com.oracle.truffle.api.dsl.GeneratedBy;
import com.oracle.truffle.api.dsl.NeverDefault;
import com.oracle.truffle.api.dsl.UnsupportedSpecializationException;
import com.oracle.truffle.api.dsl.InlineSupport.InlineTarget;
import com.oracle.truffle.api.dsl.InlineSupport.StateField;
import com.oracle.truffle.api.dsl.InlineSupport.UnsafeAccessedField;
import com.oracle.truffle.api.profiles.InlinedBranchProfile;
import com.oracle.truffle.api.profiles.InlinedConditionProfile;
import com.oracle.truffle.js.nodes.unary.IsCallableNode;
import com.oracle.truffle.js.nodes.unary.IsConstructorNode;
import com.oracle.truffle.js.runtime.JSContext;
import java.lang.invoke.MethodHandles;
import java.lang.invoke.VarHandle;
import java.util.Objects;

/**
 * Debug Info: 
 *   Specialization {@link JSProxyCallNode#doCall}
 *     Activation probability: 0.65000
 *     With/without class size: 17/4 bytes
 *   Specialization {@link JSProxyCallNode#doConstruct}
 *     Activation probability: 0.35000
 *     With/without class size: 11/4 bytes
 * 
*/ @GeneratedBy(JSProxyCallNode.class) @SuppressWarnings("javadoc") public final class JSProxyCallNodeGen extends JSProxyCallNode { private static final StateField STATE_0_UPDATER = StateField.create(MethodHandles.lookup(), "state_0_"); /** * Source Info:
     *   Specialization: {@link JSProxyCallNode#doCall}
     *   Parameter: {@link InlinedConditionProfile} pxTrapFunProfile
     *   Inline method: {@link InlinedConditionProfile#inline}
*/ private static final InlinedConditionProfile INLINED_PX_TRAP_FUN_PROFILE = InlinedConditionProfile.inline(InlineTarget.create(InlinedConditionProfile.class, STATE_0_UPDATER.subUpdater(2, 2))); /** * Source Info:
     *   Specialization: {@link JSProxyCallNode#doCall}
     *   Parameter: {@link InlinedBranchProfile} errorBranch
     *   Inline method: {@link InlinedBranchProfile#inline}
*/ private static final InlinedBranchProfile INLINED_ERROR_BRANCH = InlinedBranchProfile.inline(InlineTarget.create(InlinedBranchProfile.class, STATE_0_UPDATER.subUpdater(4, 1))); /** * State Info:
     *   0: SpecializationActive {@link JSProxyCallNode#doCall}
     *   1: SpecializationActive {@link JSProxyCallNode#doConstruct}
     *   2-3: InlinedCache
     *        Specialization: {@link JSProxyCallNode#doCall}
     *        Parameter: {@link InlinedConditionProfile} pxTrapFunProfile
     *        Inline method: {@link InlinedConditionProfile#inline}
     *   4: InlinedCache
     *        Specialization: {@link JSProxyCallNode#doCall}
     *        Parameter: {@link InlinedBranchProfile} errorBranch
     *        Inline method: {@link InlinedBranchProfile#inline}
     * 
*/ @CompilationFinal @UnsafeAccessedField private int state_0_; /** * Source Info:
     *   Specialization: {@link JSProxyCallNode#doCall}
     *   Parameter: {@link IsCallableNode} isCallable
*/ @Child private IsCallableNode call_isCallable_; /** * Source Info:
     *   Specialization: {@link JSProxyCallNode#doConstruct}
     *   Parameter: {@link IsConstructorNode} isConstructor
*/ @Child private IsConstructorNode construct_isConstructor_; private JSProxyCallNodeGen(JSContext context, boolean isNew, boolean isNewTarget) { super(context, isNew, isNewTarget); } @Override public Object execute(Object[] arg0Value) { int state_0 = this.state_0_; if ((state_0 & 0b11) != 0 /* is SpecializationActive[JSProxyCallNode.doCall(Object[], IsCallableNode, InlinedConditionProfile, InlinedBranchProfile)] || SpecializationActive[JSProxyCallNode.doConstruct(Object[], IsConstructorNode, InlinedConditionProfile, InlinedBranchProfile)] */) { if ((state_0 & 0b1) != 0 /* is SpecializationActive[JSProxyCallNode.doCall(Object[], IsCallableNode, InlinedConditionProfile, InlinedBranchProfile)] */) { { IsCallableNode isCallable__ = this.call_isCallable_; if (isCallable__ != null) { assert DSLSupport.assertIdempotence((!(isNew))); assert DSLSupport.assertIdempotence((!(isNewTarget))); return doCall(arg0Value, isCallable__, INLINED_PX_TRAP_FUN_PROFILE, INLINED_ERROR_BRANCH); } } } if ((state_0 & 0b10) != 0 /* is SpecializationActive[JSProxyCallNode.doConstruct(Object[], IsConstructorNode, InlinedConditionProfile, InlinedBranchProfile)] */) { { IsConstructorNode isConstructor__ = this.construct_isConstructor_; if (isConstructor__ != null) { assert DSLSupport.assertIdempotence((isNew || isNewTarget)); return doConstruct(arg0Value, isConstructor__, INLINED_PX_TRAP_FUN_PROFILE, INLINED_ERROR_BRANCH); } } } } CompilerDirectives.transferToInterpreterAndInvalidate(); return executeAndSpecialize(arg0Value); } private Object executeAndSpecialize(Object[] arg0Value) { int state_0 = this.state_0_; if ((!(isNew)) && (!(isNewTarget))) { IsCallableNode isCallable__ = this.insert((IsCallableNode.create())); Objects.requireNonNull(isCallable__, "A specialization cache returned a default value. The cache initializer must never return a default value for this cache. Use @Cached(neverDefault=false) to allow default values for this cached value or make sure the cache initializer never returns the default value."); VarHandle.storeStoreFence(); this.call_isCallable_ = isCallable__; state_0 = state_0 | 0b1 /* add SpecializationActive[JSProxyCallNode.doCall(Object[], IsCallableNode, InlinedConditionProfile, InlinedBranchProfile)] */; this.state_0_ = state_0; return doCall(arg0Value, isCallable__, INLINED_PX_TRAP_FUN_PROFILE, INLINED_ERROR_BRANCH); } if ((isNew || isNewTarget)) { IsConstructorNode isConstructor__ = this.insert((IsConstructorNode.create())); Objects.requireNonNull(isConstructor__, "A specialization cache returned a default value. The cache initializer must never return a default value for this cache. Use @Cached(neverDefault=false) to allow default values for this cached value or make sure the cache initializer never returns the default value."); VarHandle.storeStoreFence(); this.construct_isConstructor_ = isConstructor__; state_0 = state_0 | 0b10 /* add SpecializationActive[JSProxyCallNode.doConstruct(Object[], IsConstructorNode, InlinedConditionProfile, InlinedBranchProfile)] */; this.state_0_ = state_0; return doConstruct(arg0Value, isConstructor__, INLINED_PX_TRAP_FUN_PROFILE, INLINED_ERROR_BRANCH); } throw new UnsupportedSpecializationException(this, null, arg0Value); } @NeverDefault public static JSProxyCallNode create(JSContext context, boolean isNew, boolean isNewTarget) { return new JSProxyCallNodeGen(context, isNew, isNewTarget); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy