case class NonVirtualMethodCall[+V <: Var[V]](pc: Int, declaringClass: ObjectType, isInterface: Boolean, name: String, descriptor: MethodDescriptor, receiver: Expr[V], params: Seq[Expr[V]]) extends InstanceMethodCall[V] with Product with Serializable
Call of an instance method for which no virtual method call resolution has to happen. I.e., it is either a super-call, a private instance method call or a constructor call.
- Source
- Stmt.scala
- Alphabetic
- By Inheritance
- NonVirtualMethodCall
- Serializable
- Product
- Equals
- InstanceMethodCall
- MethodCall
- Call
- Stmt
- ASTNode
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Instance Constructors
- new NonVirtualMethodCall(pc: Int, declaringClass: ObjectType, isInterface: Boolean, name: String, descriptor: MethodDescriptor, receiver: Expr[V], params: Seq[Expr[V]])
Value Members
- final def !=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def ##: Int
- Definition Classes
- AnyRef → Any
- final def ==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def allParams: Seq[Expr[V]]
The parameters of the call (including the implicit
this
reference if necessary.)The parameters of the call (including the implicit
this
reference if necessary.)- Definition Classes
- InstanceMethodCall → Call
- def asArrayStore: ArrayStore[V]
- Definition Classes
- Stmt
- def asAssignment: Assignment[V]
- Definition Classes
- Stmt
- def asAssignmentLike: AssignmentLikeStmt[V]
- Definition Classes
- Stmt
- def asCaughtException: CaughtException[V]
- Definition Classes
- Stmt
- def asCheckcast: Checkcast[V]
- Definition Classes
- Stmt
- def asExprStmt: ExprStmt[V]
- Definition Classes
- Stmt
- def asFieldWriteAccessStmt: FieldWriteAccessStmt[V]
- Definition Classes
- Stmt
- def asGoto: Goto
- Definition Classes
- Stmt
- def asIf: If[V]
- Definition Classes
- Stmt
- final def asInstanceMethodCall: NonVirtualMethodCall.this.type
- Definition Classes
- InstanceMethodCall → Stmt
- final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- def asInvokedynamicMethodCall: InvokedynamicMethodCall[V]
- Definition Classes
- Stmt
- def asJSR: JSR
- Definition Classes
- Stmt
- final def asMethodCall: NonVirtualMethodCall.this.type
- Definition Classes
- MethodCall → Stmt
- def asMonitorEnter: MonitorEnter[V]
- Definition Classes
- Stmt
- def asMonitorExit: MonitorExit[V]
- Definition Classes
- Stmt
- final def asNonVirtualMethodCall: NonVirtualMethodCall.this.type
- Definition Classes
- NonVirtualMethodCall → Stmt
- def asNop: Nop
- Definition Classes
- Stmt
- def asPutField: PutField[V]
- Definition Classes
- Stmt
- def asPutStatic: PutStatic[V]
- Definition Classes
- Stmt
- def asRet: Ret
- Definition Classes
- Stmt
- def asReturn: Return
- Definition Classes
- Stmt
- def asReturnValue: ReturnValue[V]
- Definition Classes
- Stmt
- def asStaticMethodCall: StaticMethodCall[V]
- Definition Classes
- Stmt
- def asSwitch: Switch[V]
- Definition Classes
- Stmt
- def asSynchronizationStmt: SynchronizationStmt[V]
- Definition Classes
- Stmt
- def asThrow: Throw[V]
- Definition Classes
- Stmt
- def asVirtualMethodCall: VirtualMethodCall[V]
- Definition Classes
- Stmt
- final def astID: Int
Each type of node is assigned a different
id
to make it easily possible to do a switch over all nodes.Each type of node is assigned a different
id
to make it easily possible to do a switch over all nodes.- Definition Classes
- NonVirtualMethodCall → ASTNode
- def clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @native() @IntrinsicCandidate()
- val declaringClass: ObjectType
The declaring class; can be an array type for all methods defined by
java.lang.Object
.The declaring class; can be an array type for all methods defined by
java.lang.Object
.- Definition Classes
- NonVirtualMethodCall → Call
- val descriptor: MethodDescriptor
- Definition Classes
- NonVirtualMethodCall → Call
- final def eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- final def forallSubExpressions[W >: V <: Var[W]](p: (Expr[W]) => Boolean): Boolean
- Definition Classes
- InstanceMethodCall → Stmt
- final def getClass(): Class[_ <: AnyRef]
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @IntrinsicCandidate()
- def isArrayStore: Boolean
- Definition Classes
- Stmt
- def isAssignment: Boolean
- Definition Classes
- Stmt
- def isCaughtException: Boolean
- Definition Classes
- Stmt
- def isCheckcast: Boolean
- Definition Classes
- Stmt
- def isExprStmt: Boolean
- Definition Classes
- Stmt
- def isIf: Boolean
- Definition Classes
- Stmt
- final def isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- val isInterface: Boolean
true
iff the declaring class is an interface.true
iff the declaring class is an interface.- Definition Classes
- NonVirtualMethodCall → Call
- final def isMethodCall: Boolean
- Definition Classes
- MethodCall → Stmt
- def isMonitorEnter: Boolean
- Definition Classes
- Stmt
- def isMonitorExit: Boolean
- Definition Classes
- Stmt
- final def isNonVirtualMethodCall: Boolean
- Definition Classes
- NonVirtualMethodCall → Stmt
- def isNop: Boolean
- Definition Classes
- Stmt
- def isPutField: Boolean
- Definition Classes
- Stmt
- def isPutStatic: Boolean
- Definition Classes
- Stmt
- def isReturnValue: Boolean
- Definition Classes
- Stmt
- final def isSideEffectFree: Boolean
true
if the statement/expression is GUARANTEED to have no externally observable effect if it is not executed.true
if the statement/expression is GUARANTEED to have no externally observable effect if it is not executed. Sideeffect free instructions can be removed if the result of the evaluation of the expression/statement is not used. For those instructions, which may result in an exception, it has to be guaranteed that the exception is NEVER thrown. For example, a div instruction is sideeffect free if it is (statically) known that the divisor is always not equal to zero; otherwise, even if the result value is not used, the expression is not (potentially) side effect free. An array load is only side effect free if the array reference is non-null and if the index is valid.- returns
true
if the expression is GUARENTEED to have no side effect other than wasting some CPU cycles if it is not executed.
- Definition Classes
- MethodCall → ASTNode
- Note
Deeply nested expressions are not supported; i.e. an expression's sub-expressions have to be Var or Const expressions. Generally, a statements expressions have to to simple expressions too - except of the Assignment statement; in the latter case the right-expression can have references to simple expressions. Hence, in case of Assignment statements the side-effect freenes is determined by the referenced expression; in all other cases the side-effect freeness is determined directly by the statement/expression.
- def isStaticMethodCall: Boolean
- Definition Classes
- Stmt
- def isThrow: Boolean
- Definition Classes
- Stmt
- def isVirtualMethodCall: Boolean
- Definition Classes
- Stmt
- val name: String
- Definition Classes
- NonVirtualMethodCall → Call
- final def ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- final def notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @IntrinsicCandidate()
- final def notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @IntrinsicCandidate()
- val params: Seq[Expr[V]]
The parameters of the call (excluding the implicit
this
reference.)The parameters of the call (excluding the implicit
this
reference.)- Definition Classes
- NonVirtualMethodCall → Call
- val pc: Int
The program counter of the original underyling bytecode instruction.
The program counter of the original underyling bytecode instruction.
This
pc
is independent of the (implicit)index
of the statement in the generated statements array! This pc is, e.g., useful for getting line number information.- Definition Classes
- NonVirtualMethodCall → Stmt
- def productElementNames: Iterator[String]
- Definition Classes
- Product
- val receiver: Expr[V]
- Definition Classes
- NonVirtualMethodCall → InstanceMethodCall
- final def receiverOption: Some[Expr[V]]
The receiver of the call if it is an instance call, None if it is a static call.
The receiver of the call if it is an instance call, None if it is a static call.
- Definition Classes
- InstanceMethodCall → Call
- def resolveCallTarget(callerClassType: ObjectType)(implicit p: ProjectLike): Result[Method]
Identifies the potential call target if it can be found.
Identifies the potential call target if it can be found.
- See also
[ProjectLike#specialCall] for further details.
- def resolveCallTargets(callingContext: ObjectType)(implicit p: ProjectLike, ev: <:<[V, DUVar[ValueInformation]]): Set[Method]
Convenience method which abstracts over all kinds of calls; not all information is always required.
Convenience method which abstracts over all kinds of calls; not all information is always required.
- Definition Classes
- NonVirtualMethodCall → Call
- final def synchronized[T0](arg0: => T0): T0
- Definition Classes
- AnyRef
- final def toCanonicalForm(implicit ev: <:<[V, DUVar[ValueInformation]]): Stmt[DUVar[ValueInformation]]
See org.opalj.value.ValueInformation.toCanonicalForm for detail.
See org.opalj.value.ValueInformation.toCanonicalForm for detail.
- Definition Classes
- NonVirtualMethodCall → Stmt → ASTNode
- def toString(): String
- Definition Classes
- NonVirtualMethodCall → AnyRef → Any
- final def wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
Deprecated Value Members
- def finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable]) @Deprecated
- Deprecated