Class PlusExpression
java.lang.Object
org.jboss.byteman.rule.RuleElement
org.jboss.byteman.rule.expression.Expression
org.jboss.byteman.rule.expression.OperExpression
org.jboss.byteman.rule.expression.BinaryOperExpression
org.jboss.byteman.rule.expression.PlusExpression
A plus operator expression which handles the case where we do not know the type of the first
operand. this expression must be replaced by an expression with a known type during type
checking
-
Field Summary
-
Constructor Summary
ConstructorsConstructorDescriptionPlusExpression
(Rule rule, ParseNode token, Expression left, Expression right) -
Method Summary
Modifier and TypeMethodDescriptionvoid
compile
(org.objectweb.asm.MethodVisitor mv, CompileContext compileContext) interpret
(HelperAdapter helper) evaluate the expression by interpreting the expression treeensure that all type references in the expression and its component expressions can be resolved, that the type of the expression is well-defined and that it is compatible with the type expected in the context in which it occurs.Methods inherited from class org.jboss.byteman.rule.expression.BinaryOperExpression
bind, getOperand
Methods inherited from class org.jboss.byteman.rule.expression.OperExpression
convertOper, writeTo
Methods inherited from class org.jboss.byteman.rule.expression.Expression
getPos, getType
Methods inherited from class org.jboss.byteman.rule.RuleElement
getBindings, getTypeGroup, rebox, toString
-
Constructor Details
-
PlusExpression
-
-
Method Details
-
typeCheck
Description copied from class:Expression
ensure that all type references in the expression and its component expressions can be resolved, that the type of the expression is well-defined and that it is compatible with the type expected in the context in which it occurs.- Specified by:
typeCheck
in classExpression
- Parameters:
expected
- the type expected for the expression in the contxet in which it occurs. this may be void but should not be undefined at the point where type checking is performed.- Returns:
- the type of the expression
- Throws:
TypeException
- if a type check failure occurs
-
interpret
Description copied from class:Expression
evaluate the expression by interpreting the expression tree- Specified by:
interpret
in classExpression
- Parameters:
helper
- an execution context associated with the rule which contains a map of current bindings for rule variables and another map of their declared types both of which are indexed by variable name. This includes entries for the helper (name "-1"), the recipient if the trigger method is not static (name "0") and the trigger method arguments (names "1", ...)- Returns:
- the result of evaluation as an Object
- Throws:
ExecuteException
- if an error occurs during execution
-
compile
public void compile(org.objectweb.asm.MethodVisitor mv, CompileContext compileContext) throws CompileException - Specified by:
compile
in classRuleElement
- Throws:
CompileException
-