public interface MetaClass extends MetaObjectProtocol
MetaClassImpl
,
MetaObjectProtocol
Modifier and Type | Method and Description |
---|---|
Object |
getAttribute(Class sender,
Object receiver,
String messageName,
boolean useSuper)
Retrieves the value of an attribute (field).
|
ClassNode |
getClassNode()
Obtains a reference to the original AST for the MetaClass if it is available at runtime
|
List<MetaMethod> |
getMetaMethods()
Retrieves a list of MetaMethods held by this class.
|
List<MetaMethod> |
getMethods()
Retrieves a list of MetaMethods held by the class.
|
List<MetaProperty> |
getProperties()
Retrieves a list of MetaProperty instances that the MetaClass has
|
Object |
getProperty(Class sender,
Object receiver,
String property,
boolean isCallToSuper,
boolean fromInsideClass)
Retrieves a property on the given receiver for the specified arguments.
|
void |
initialize()
Complete the initialisation process.
|
Object |
invokeMethod(Class sender,
Object receiver,
String methodName,
Object[] arguments,
boolean isCallToSuper,
boolean fromInsideClass)
Invokes a method on the given receiver for the specified arguments.
|
Object |
invokeMissingMethod(Object instance,
String methodName,
Object[] arguments)
Attempts to invoke the methodMissing method otherwise throws a MissingMethodException
|
Object |
invokeMissingProperty(Object instance,
String propertyName,
Object optionalValue,
boolean isGetter)
Invokes the propertyMissing method otherwise throws a MissingPropertyException
|
MetaMethod |
pickMethod(String methodName,
Class[] arguments)
Selects a method by name and argument classes.
|
int |
selectConstructorAndTransformArguments(int numberOfConstructors,
Object[] arguments)
Internal method to support Groovy runtime.
|
void |
setAttribute(Class sender,
Object receiver,
String messageName,
Object messageValue,
boolean useSuper,
boolean fromInsideClass)
Sets the value of an attribute (field).
|
void |
setProperty(Class sender,
Object receiver,
String property,
Object value,
boolean isCallToSuper,
boolean fromInsideClass)
Sets a property on the given receiver for the specified arguments.
|
getAttribute, getMetaMethod, getMetaProperty, getProperty, getStaticMetaMethod, getTheClass, hasProperty, invokeConstructor, invokeMethod, invokeMethod, invokeStaticMethod, respondsTo, respondsTo, setAttribute, setProperty
Object invokeMethod(Class sender, Object receiver, String methodName, Object[] arguments, boolean isCallToSuper, boolean fromInsideClass)
Invokes a method on the given receiver for the specified arguments. The sender is the class that invoked the method on the object. The MetaClass will attempt to establish the method to invoke based on the name and arguments provided.
The isCallToSuper and fromInsideClass help the Groovy runtime perform optimisations on the call to go directly to the super class if necessary
sender
- The java.lang.Class instance that invoked the methodreceiver
- The object which the method was invoked onmethodName
- The name of the methodarguments
- The arguments to the methodisCallToSuper
- Whether the method is a call to a super class methodfromInsideClass
- Whether the call was invoked from the inside or the outside of the classObject getProperty(Class sender, Object receiver, String property, boolean isCallToSuper, boolean fromInsideClass)
Retrieves a property on the given receiver for the specified arguments. The sender is the class that is requesting the property from the object. The MetaClass will attempt to establish the method to invoke based on the name and arguments provided.
The isCallToSuper and fromInsideClass help the Groovy runtime perform optimisations on the call to go directly to the super class if necessary
sender
- The java.lang.Class instance that requested the propertyreceiver
- The Object which the property is being retrieved fromproperty
- The name of the propertyisCallToSuper
- Whether the call is to a super class propertyfromInsideClass
- ??void setProperty(Class sender, Object receiver, String property, Object value, boolean isCallToSuper, boolean fromInsideClass)
Sets a property on the given receiver for the specified arguments. The sender is the class that is setting the property from the object. The MetaClass will attempt to establish the method to invoke based on the name and arguments provided.
The isCallToSuper and fromInsideClass help the Groovy runtime perform optimisations on the call to go directly to the super class if necessary
sender
- The java.lang.Class instance that is mutating the propertyreceiver
- The Object which the property is being set onproperty
- The name of the propertyvalue
- The new value of the property to setisCallToSuper
- Whether the call is to a super class propertyfromInsideClass
- Whether the call was invoked from the inside or the outside of the classObject invokeMissingMethod(Object instance, String methodName, Object[] arguments)
Attempts to invoke the methodMissing method otherwise throws a MissingMethodException
instance
- The instance to invoke methodMissing onmethodName
- The name of the methodarguments
- The arguments to the methodMissingMethodException
Object invokeMissingProperty(Object instance, String propertyName, Object optionalValue, boolean isGetter)
instance
- The instance of the classpropertyName
- The name of the propertyoptionalValue
- The value of the property which could be null in the case of a getterisGetter
- Whether the missing property event was the result of a getter or a setterObject getAttribute(Class sender, Object receiver, String messageName, boolean useSuper)
sender
- The class of the object that requested the attributereceiver
- The instancemessageName
- The name of the attributeuseSuper
- Whether to look-up on the super class or notvoid setAttribute(Class sender, Object receiver, String messageName, Object messageValue, boolean useSuper, boolean fromInsideClass)
sender
- The class of the object that requested the attributereceiver
- The instancemessageName
- The name of the attributemessageValue
- The value of the attributeuseSuper
- Whether to look-up on the super class or notfromInsideClass
- Whether the call happened from the inside or the outside of a classvoid initialize()
List<MetaProperty> getProperties()
getProperties
in interface MetaObjectProtocol
MetaProperty
List<MetaMethod> getMethods()
getMethods
in interface MetaObjectProtocol
MetaMethod
ClassNode getClassNode()
List<MetaMethod> getMetaMethods()
int selectConstructorAndTransformArguments(int numberOfConstructors, Object[] arguments)
numberOfConstructors
- The number of constructorsarguments
- The argumentsMetaMethod pickMethod(String methodName, Class[] arguments)
methodName
- the name of the method to pickarguments
- the method argumentsGroovyRuntimeException
- if there is more than one matching method