Class ArrayExpression
- java.lang.Object
-
- org.jboss.byteman.rule.RuleElement
-
- org.jboss.byteman.rule.expression.Expression
-
- org.jboss.byteman.rule.expression.AssignableExpression
-
- org.jboss.byteman.rule.expression.ArrayExpression
-
public class ArrayExpression extends AssignableExpression
an expression which identifies an array reference.
-
-
Field Summary
Fields Modifier and Type Field Description (package private) Expression
arrayRef
(package private) java.util.List<Expression>
idxList
-
Constructor Summary
Constructors Constructor Description ArrayExpression(Rule rule, Type type, ParseNode token, Expression arrayRef, java.util.List<Expression> idxList)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
bind()
verify that variables mentioned in this expression are actually available in the supplied bindings list and infer/validate the type of this expression or its subexpressions where possiblevoid
bindAssign()
bind as an assignable expression.void
compile(org.objectweb.asm.MethodVisitor mv, CompileContext compileContext)
void
compileAssign(org.objectweb.asm.MethodVisitor mv, CompileContext compileContext)
compile an assignment to the referenced location using the value on the top of the Java stack.java.lang.Object
interpret(HelperAdapter helper)
evaluate the expression by interpreting the expression treejava.lang.Object
interpretAssign(HelperAdapter helper, java.lang.Object value)
execute an assignment to the referenced location by interpretation of the expression, using the object passed in this callType
typeCheck(Type expected)
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.private void
typeCheckAny()
Type
typeCheckAssign(Type expected)
typecheck the expression as an lvalue of an assignment operationvoid
writeTo(java.io.StringWriter stringWriter)
-
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
-
-
-
-
Field Detail
-
arrayRef
Expression arrayRef
-
idxList
java.util.List<Expression> idxList
-
-
Constructor Detail
-
ArrayExpression
public ArrayExpression(Rule rule, Type type, ParseNode token, Expression arrayRef, java.util.List<Expression> idxList)
-
-
Method Detail
-
bind
public void bind() throws TypeException
verify that variables mentioned in this expression are actually available in the supplied bindings list and infer/validate the type of this expression or its subexpressions where possible- Specified by:
bind
in classExpression
- Throws:
TypeException
- if any variable is missing or has the wrong type
-
typeCheck
public Type typeCheck(Type expected) throws TypeException
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
-
typeCheckAssign
public Type typeCheckAssign(Type expected) throws TypeException
Description copied from class:AssignableExpression
typecheck the expression as an lvalue of an assignment operation- Specified by:
typeCheckAssign
in classAssignableExpression
- Parameters:
expected
- the expected type for the expression- Returns:
- the expression type
- Throws:
TypeException
- if a type check error occurs
-
typeCheckAny
private void typeCheckAny() throws TypeException
- Throws:
TypeException
-
interpret
public java.lang.Object interpret(HelperAdapter helper) throws ExecuteException
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
-
writeTo
public void writeTo(java.io.StringWriter stringWriter)
- Specified by:
writeTo
in classExpression
-
interpretAssign
public java.lang.Object interpretAssign(HelperAdapter helper, java.lang.Object value) throws ExecuteException
Description copied from class:AssignableExpression
execute an assignment to the referenced location by interpretation of the expression, using the object passed in this call- Specified by:
interpretAssign
in classAssignableExpression
- 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", ...)value
- the value to be assigned to this object- Returns:
- the result of evaluation as an Object
- Throws:
ExecuteException
- if an error occurs during execution
-
compileAssign
public void compileAssign(org.objectweb.asm.MethodVisitor mv, CompileContext compileContext) throws CompileException
Description copied from class:AssignableExpression
compile an assignment to the referenced location using the value on the top of the Java stack.- Specified by:
compileAssign
in classAssignableExpression
- Parameters:
mv
- the current method visitorcompileContext
- the current compile context- Throws:
CompileException
- if a compile error occurs
-
bindAssign
public void bindAssign() throws TypeException
Description copied from class:AssignableExpression
bind as an assignable expression. for variables and dollar expressions this will ensure that a binding exists and that it is marked as potentially updateable.- Specified by:
bindAssign
in classAssignableExpression
- Throws:
TypeException
- if the expression contains an invalid or unassignable reference
-
-