Class MetaClassImpl
- java.lang.Object
-
- groovy.lang.MetaClassImpl
-
- All Implemented Interfaces:
MetaClass,MetaObjectProtocol,MutableMetaClass
- Direct Known Subclasses:
ClosureMetaClass,ExpandoMetaClass,ProxyMetaClass
public class MetaClassImpl extends java.lang.Object implements MetaClass, MutableMetaClass
Allows methods to be dynamically added to existing classes at runtime- Version:
- $Revision$
- Author:
- James Strachan, Guillaume Laforge, Jochen Theodorou, Graeme Rocher, Alex Tkachman, Roshan Dawrani
- See Also:
MetaClass
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classMetaClassImpl.Index
-
Field Summary
Fields Modifier and Type Field Description protected MetaMethodgetPropertyMethodprotected static java.lang.StringINVOKE_METHOD_METHODprotected MetaMethodinvokeMethodMethodprotected booleanisGroovyObjectprotected booleanisMapprotected MetaMethodIndexmetaMethodIndexprotected static java.lang.StringMETHOD_MISSINGprotected static java.lang.StringPROPERTY_MISSINGprotected MetaClassRegistryregistryprotected MetaMethodsetPropertyMethodprotected static java.lang.StringSTATIC_METHOD_MISSINGprotected static java.lang.StringSTATIC_PROPERTY_MISSINGprotected CachedClasstheCachedClassprotected java.lang.ClasstheClass
-
Constructor Summary
Constructors Constructor Description MetaClassImpl(MetaClassRegistry registry, java.lang.Class theClass)MetaClassImpl(MetaClassRegistry registry, java.lang.Class theClass, MetaMethod[] add)MetaClassImpl(java.lang.Class theClass)MetaClassImpl(java.lang.Class theClass, MetaMethod[] add)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddMetaBeanProperty(MetaBeanProperty mp)Adds a new MetaBeanProperty to this MetaClassvoidaddMetaMethod(MetaMethod method)adds a MetaMethod to this class.protected voidaddMetaMethodToIndex(MetaMethod method, MetaMethodIndex.Header header)voidaddNewInstanceMethod(java.lang.reflect.Method method)adds a new instance method to this MetaClass.voidaddNewStaticMethod(java.lang.reflect.Method method)adds a new static method to this MetaClass.protected voidapplyPropertyDescriptors(java.beans.PropertyDescriptor[] propertyDescriptors)protected voidcheckIfGroovyObjectMethod(MetaMethod metaMethod)Checks if the metaMethod is a method from the GroovyObject interface such as setProperty, getProperty and invokeMethodprotected voidcheckInitalised()checks if the initialisation of the class id complete.protected java.lang.ObjectchooseMethod(java.lang.String methodName, java.lang.Object methodOrList, java.lang.Class[] arguments)Chooses the correct method to use from a list of methods which match by name.protected voidclearInvocationCaches()remove all method call cache entries.CallSitecreateConstructorSite(CallSite site, java.lang.Object[] args)CallSitecreatePogoCallCurrentSite(CallSite site, java.lang.Class sender, java.lang.Object[] args)CallSitecreatePogoCallSite(CallSite site, java.lang.Object[] args)CallSitecreatePojoCallSite(CallSite site, java.lang.Object receiver, java.lang.Object[] args)CallSitecreateStaticSite(CallSite site, java.lang.Object[] args)protected voiddropMethodCache(java.lang.String name)protected voiddropStaticMethodCache(java.lang.String name)protected static MetaMethodfindMethodInClassHierarchy(java.lang.Class instanceKlazz, java.lang.String methodName, java.lang.Class[] arguments, MetaClass metaClass)protected MetaMethodfindMixinMethod(java.lang.String methodName, java.lang.Class[] arguments)protected static MetaMethodfindOwnMethod(java.lang.Class instanceKlazz, java.lang.String methodName, java.lang.Class[] arguments, MetaClass metaClass, MetaMethod method)protected MetaBeanPropertyfindPropertyInClassHierarchy(java.lang.String propertyName, CachedClass theClass)MetaMethod[]getAdditionalMetaMethods()java.lang.ObjectgetAttribute(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, boolean useSuper)Retrieves the value of an attribute (field).java.lang.ObjectgetAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, boolean useSuper, boolean fromInsideClass)Looks up the given attribute (field) on the given objectjava.lang.ObjectgetAttribute(java.lang.Object object, java.lang.String attribute)Retrieves an attribute of an instance of the class returned by the getTheClass() method.ClassInfogetClassInfo()ClassNodegetClassNode()Obtains a reference to the original AST for the MetaClass if it is available at runtimeMetaPropertygetEffectiveGetMetaProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, boolean useSuper)MetaMethodgetMetaMethod(java.lang.String name, java.lang.Object[] argTypes)Retrieves an instance MetaMethod for the given name and argument values, using the types of the argument values to establish the chosen MetaMethodjava.util.List<MetaMethod>getMetaMethods()Retrieves a list of MetaMethods held by this classMetaPropertygetMetaProperty(java.lang.String name)Returns a MetaProperty for the given name or null if it doesn't existjava.util.List<MetaMethod>getMethods()Retrieves a list of MetaMethods held by the classMetaMethodgetMethodWithCaching(java.lang.Class sender, java.lang.String methodName, java.lang.Object[] arguments, boolean isCallToSuper)MetaMethodgetMethodWithoutCaching(java.lang.Class sender, java.lang.String methodName, java.lang.Class[] arguments, boolean isCallToSuper)java.util.List<MetaProperty>getProperties()Get all the properties defined for this typejava.lang.ObjectgetProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, boolean useSuper, boolean fromInsideClass)Retrieves a property on the given receiver for the specified arguments.java.lang.ObjectgetProperty(java.lang.Object object, java.lang.String property)Retrieves a property of an instance of the class returned by the getTheClass() method.MetaMethodgetStaticMetaMethod(java.lang.String name, java.lang.Object[] argTypes)Retrieves a static MetaMethod for the given name and argument values, using the types of the arguments to establish the chosen MetaMethodprotected java.lang.ObjectgetSubclassMetaMethods(java.lang.String methodName)protected java.util.LinkedList<CachedClass>getSuperClasses()CachedClassgetTheCachedClass()java.lang.ClassgetTheClass()Retrieves that Java Class that the attached Meta behaviours apply tointgetVersion()MetaPropertyhasProperty(java.lang.Object obj, java.lang.String name)Returns true of the implementing MetaClass has a property of the given namevoidincVersion()voidinitialize()complete the initialisation process.java.lang.ObjectinvokeConstructor(java.lang.Object[] arguments)Invokes a constructor for the given arguments.java.lang.ObjectinvokeConstructorAt(java.lang.Class at, java.lang.Object[] arguments)Deprecated.use invokeConstructor insteadjava.lang.ObjectinvokeMethod(java.lang.Class sender, java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments, boolean isCallToSuper, boolean fromInsideClass)Invokes the given method on the object.java.lang.ObjectinvokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object arguments)Invokes a method on the given object, with the given name and single argument.java.lang.ObjectinvokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments)Invokes the given method on the object.java.lang.ObjectinvokeMissingMethod(java.lang.Object instance, java.lang.String methodName, java.lang.Object[] arguments)Attempts to invoke the methodMissing method otherwise throws a MissingMethodExceptionjava.lang.ObjectinvokeMissingProperty(java.lang.Object instance, java.lang.String propertyName, java.lang.Object optionalValue, boolean isGetter)Invokes the propertyMissing method otherwise throws a MissingPropertyExceptionjava.lang.ObjectinvokeStaticMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object[] arguments)Invokes a static method on the given Object with the given name and arguments.protected java.lang.ObjectinvokeStaticMissingProperty(java.lang.Object instance, java.lang.String propertyName, java.lang.Object optionalValue, boolean isGetter)Hook to deal with the case of MissingProperty for static properties.booleanisGroovyObject()protected booleanisInitialized()booleanisModified()Return whether the MetaClass has been modified or notprotected voidonGetPropertyFoundInHierarchy(MetaMethod method)protected voidonInvokeMethodFoundInHierarchy(MetaMethod method)protected voidonMixinMethodFound(MetaMethod method)protected voidonSetPropertyFoundInHierarchy(MetaMethod method)protected voidonSuperMethodFoundInHierarchy(MetaMethod method)protected voidonSuperPropertyFoundInHierarchy(MetaBeanProperty property)MetaMethodpickMethod(java.lang.String methodName, java.lang.Class[] arguments)Selects a method by name and argument classes.java.util.ListrespondsTo(java.lang.Object obj, java.lang.String name)Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name regardless of arguments.java.util.ListrespondsTo(java.lang.Object obj, java.lang.String name, java.lang.Object[] argTypes)Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name and arguments types.java.lang.reflect.ConstructorretrieveConstructor(java.lang.Class[] arguments)protected MetaMethodretrieveMethod(java.lang.String methodName, java.lang.Class[] arguments)Deprecated.use pickMethod insteadMetaMethodretrieveStaticMethod(java.lang.String methodName, java.lang.Object[] arguments)intselectConstructorAndTransformArguments(int numberOfConstructors, java.lang.Object[] arguments)Internal method to support Groovy runtime.voidsetAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, java.lang.Object newValue, boolean useSuper, boolean fromInsideClass)Sets the given attribute (field) on the given objectvoidsetAttribute(java.lang.Object object, java.lang.String attribute, java.lang.Object newValue)Sets an attribute of an instance of the class returned by the getTheClass() method.voidsetProperties(java.lang.Object bean, java.util.Map map)Sets a number of bean properties from the given Map where the keys are the String names of properties and the values are the values of the properties to setvoidsetProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, java.lang.Object newValue, boolean useSuper, boolean fromInsideClass)Sets the property value on an objectvoidsetProperty(java.lang.Object object, java.lang.String property, java.lang.Object newValue)Sets a property of an instance of the class returned by the getTheClass() method.java.lang.StringtoString()
-
-
-
Field Detail
-
STATIC_METHOD_MISSING
protected static final java.lang.String STATIC_METHOD_MISSING
- See Also:
- Constant Field Values
-
STATIC_PROPERTY_MISSING
protected static final java.lang.String STATIC_PROPERTY_MISSING
- See Also:
- Constant Field Values
-
METHOD_MISSING
protected static final java.lang.String METHOD_MISSING
- See Also:
- Constant Field Values
-
PROPERTY_MISSING
protected static final java.lang.String PROPERTY_MISSING
- See Also:
- Constant Field Values
-
INVOKE_METHOD_METHOD
protected static final java.lang.String INVOKE_METHOD_METHOD
- See Also:
- Constant Field Values
-
theClass
protected final java.lang.Class theClass
-
theCachedClass
protected final CachedClass theCachedClass
-
getPropertyMethod
protected MetaMethod getPropertyMethod
-
invokeMethodMethod
protected MetaMethod invokeMethodMethod
-
setPropertyMethod
protected MetaMethod setPropertyMethod
-
registry
protected MetaClassRegistry registry
-
isGroovyObject
protected final boolean isGroovyObject
-
isMap
protected final boolean isMap
-
metaMethodIndex
protected final MetaMethodIndex metaMethodIndex
-
-
Constructor Detail
-
MetaClassImpl
public MetaClassImpl(java.lang.Class theClass, MetaMethod[] add)
-
MetaClassImpl
public MetaClassImpl(java.lang.Class theClass)
-
MetaClassImpl
public MetaClassImpl(MetaClassRegistry registry, java.lang.Class theClass, MetaMethod[] add)
-
MetaClassImpl
public MetaClassImpl(MetaClassRegistry registry, java.lang.Class theClass)
-
-
Method Detail
-
getTheCachedClass
public final CachedClass getTheCachedClass()
-
respondsTo
public java.util.List respondsTo(java.lang.Object obj, java.lang.String name, java.lang.Object[] argTypes)Description copied from interface:MetaObjectProtocolReturns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name and arguments types.
Note that this method's return value is based on realised methods and does not take into account objects or classes that implement invokeMethod or methodMissing
This method is "safe" in that it will always return a value and never throw an exception
- Specified by:
respondsToin interfaceMetaObjectProtocol- Parameters:
obj- The object to inspectname- The name of the method of interestargTypes- The argument types to match against- Returns:
- A List of MetaMethods matching the argument types which will be empty if no matching methods exist
- See Also:
MetaObjectProtocol.respondsTo(Object, String, Object[])
-
respondsTo
public java.util.List respondsTo(java.lang.Object obj, java.lang.String name)Description copied from interface:MetaObjectProtocolReturns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name regardless of arguments. In other words this method will return for foo() and foo(String).
Note that this method's return value is based on realised methods and does not take into account objects or classes that implement invokeMethod or methodMissing
This method is "safe" in that it will always return a value and never throw an exception
- Specified by:
respondsToin interfaceMetaObjectProtocol- Parameters:
obj- The object to inspectname- The name of the method of interest- Returns:
- A List of MetaMethods which will be empty if no methods with the given name exist
- See Also:
MetaObjectProtocol.respondsTo(Object, String)
-
hasProperty
public MetaProperty hasProperty(java.lang.Object obj, java.lang.String name)
Description copied from interface:MetaObjectProtocolReturns true of the implementing MetaClass has a property of the given name
Note that this method will only return true for realised properties and does not take into account implementation of getProperty or propertyMissing
- Specified by:
hasPropertyin interfaceMetaObjectProtocol- Parameters:
obj- The object to inspectname- The name of the property- Returns:
- The MetaProperty or null if it doesn't exist
- See Also:
MetaObjectProtocol.hasProperty(Object,String)
-
getMetaProperty
public MetaProperty getMetaProperty(java.lang.String name)
Description copied from interface:MetaObjectProtocolReturns a MetaProperty for the given name or null if it doesn't exist- Specified by:
getMetaPropertyin interfaceMetaObjectProtocol- Parameters:
name- The name of the MetaProperty- Returns:
- A MetaProperty or null
- See Also:
MetaObjectProtocol.getMetaProperty(String)
-
getStaticMetaMethod
public MetaMethod getStaticMetaMethod(java.lang.String name, java.lang.Object[] argTypes)
Description copied from interface:MetaObjectProtocolRetrieves a static MetaMethod for the given name and argument values, using the types of the arguments to establish the chosen MetaMethod- Specified by:
getStaticMetaMethodin interfaceMetaObjectProtocol- Parameters:
name- The name of the MetaMethodargTypes- The argument types- Returns:
- A MetaMethod or null if it doesn't exist
- See Also:
MetaObjectProtocol.getStaticMetaMethod(String, Object[])
-
getMetaMethod
public MetaMethod getMetaMethod(java.lang.String name, java.lang.Object[] argTypes)
Description copied from interface:MetaObjectProtocolRetrieves an instance MetaMethod for the given name and argument values, using the types of the argument values to establish the chosen MetaMethod- Specified by:
getMetaMethodin interfaceMetaObjectProtocol- Parameters:
name- The name of the MetaMethodargTypes- Array containing - 1) the argument values (using which their types are then inferred), or 2) the corresponding argument types- Returns:
- A MetaMethod or null if it doesn't exist
- See Also:
MetaObjectProtocol.getMetaMethod(String, Object[])
-
getTheClass
public java.lang.Class getTheClass()
Description copied from interface:MetaObjectProtocolRetrieves that Java Class that the attached Meta behaviours apply to- Specified by:
getTheClassin interfaceMetaObjectProtocol- Returns:
- The java.lang.Class instance
-
isGroovyObject
public boolean isGroovyObject()
-
getSuperClasses
protected java.util.LinkedList<CachedClass> getSuperClasses()
-
isModified
public boolean isModified()
Description copied from interface:MutableMetaClassReturn whether the MetaClass has been modified or not- Specified by:
isModifiedin interfaceMutableMetaClass- Returns:
- True if it has
-
addNewInstanceMethod
public void addNewInstanceMethod(java.lang.reflect.Method method)
Description copied from interface:MutableMetaClassadds a new instance method to this MetaClass. Instance methods are able to overwrite the original methods of the class. Calling this method should not be done after initialise was called.- Specified by:
addNewInstanceMethodin interfaceMutableMetaClass- Parameters:
method- the method to be added
-
addNewStaticMethod
public void addNewStaticMethod(java.lang.reflect.Method method)
Description copied from interface:MutableMetaClassadds a new static method to this MetaClass. This is only possible as long as initialise was not called.- Specified by:
addNewStaticMethodin interfaceMutableMetaClass- Parameters:
method- the method to be added
-
invokeMethod
public java.lang.Object invokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object arguments)Description copied from interface:MetaObjectProtocolInvokes a method on the given object, with the given name and single argument.
- Specified by:
invokeMethodin interfaceMetaObjectProtocol- Parameters:
object- The Object to invoke the method onmethodName- The name of the methodarguments- The argument to the method- Returns:
- The return value of the method which is null if the return type is void
- See Also:
MetaObjectProtocol.invokeMethod(Object, String, Object[])
-
invokeMissingMethod
public java.lang.Object invokeMissingMethod(java.lang.Object instance, java.lang.String methodName, java.lang.Object[] arguments)Description copied from interface:MetaClassAttempts to invoke the methodMissing method otherwise throws a MissingMethodException
- Specified by:
invokeMissingMethodin interfaceMetaClass- Parameters:
instance- The instance to invoke methodMissing onmethodName- The name of the methodarguments- The arguments to the method- Returns:
- The results of methodMissing or throws MissingMethodException
- See Also:
MissingMethodException
-
invokeMissingProperty
public java.lang.Object invokeMissingProperty(java.lang.Object instance, java.lang.String propertyName, java.lang.Object optionalValue, boolean isGetter)Description copied from interface:MetaClassInvokes the propertyMissing method otherwise throws a MissingPropertyException- Specified by:
invokeMissingPropertyin interfaceMetaClass- Parameters:
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 setter- Returns:
- The result of the propertyMissing method or throws MissingPropertyException
-
onSuperPropertyFoundInHierarchy
protected void onSuperPropertyFoundInHierarchy(MetaBeanProperty property)
-
onMixinMethodFound
protected void onMixinMethodFound(MetaMethod method)
-
onSuperMethodFoundInHierarchy
protected void onSuperMethodFoundInHierarchy(MetaMethod method)
-
onInvokeMethodFoundInHierarchy
protected void onInvokeMethodFoundInHierarchy(MetaMethod method)
-
onSetPropertyFoundInHierarchy
protected void onSetPropertyFoundInHierarchy(MetaMethod method)
-
onGetPropertyFoundInHierarchy
protected void onGetPropertyFoundInHierarchy(MetaMethod method)
-
invokeStaticMissingProperty
protected java.lang.Object invokeStaticMissingProperty(java.lang.Object instance, java.lang.String propertyName, java.lang.Object optionalValue, boolean isGetter)Hook to deal with the case of MissingProperty for static properties. The method will look attempt to look up "propertyMissing" handlers and invoke them otherwise thrown a MissingPropertyException- Parameters:
instance- The instancepropertyName- The name of the propertyoptionalValue- The value in the case of a setterisGetter- True if its a getter- Returns:
- The value in the case of a getter or a MissingPropertyException
-
invokeMethod
public java.lang.Object invokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments)Invokes the given method on the object. TODO: should this be deprecated? If so, we have to propogate to many places.- Specified by:
invokeMethodin interfaceMetaObjectProtocol- Parameters:
object- The instance which the method is invoked onmethodName- The name of the methodoriginalArguments- The arguments to the method- Returns:
- The return value of the method which is null if the return type is void
- See Also:
MissingMethodException
-
invokeMethod
public java.lang.Object invokeMethod(java.lang.Class sender, java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments, boolean isCallToSuper, boolean fromInsideClass)Invokes the given method on the object.- Specified by:
invokeMethodin interfaceMetaClass- Parameters:
sender- The java.lang.Class instance that invoked the methodobject- The object which the method was invoked onmethodName- The name of the methodoriginalArguments- 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 class- Returns:
- The return value of the method
-
getMethodWithCaching
public MetaMethod getMethodWithCaching(java.lang.Class sender, java.lang.String methodName, java.lang.Object[] arguments, boolean isCallToSuper)
-
retrieveConstructor
public java.lang.reflect.Constructor retrieveConstructor(java.lang.Class[] arguments)
-
retrieveStaticMethod
public MetaMethod retrieveStaticMethod(java.lang.String methodName, java.lang.Object[] arguments)
-
getMethodWithoutCaching
public MetaMethod getMethodWithoutCaching(java.lang.Class sender, java.lang.String methodName, java.lang.Class[] arguments, boolean isCallToSuper)
-
invokeStaticMethod
public java.lang.Object invokeStaticMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object[] arguments)Description copied from interface:MetaObjectProtocolInvokes a static method on the given Object with the given name and arguments.
The Object can either be an instance of the class that this MetaObjectProtocol instance applies to or the java.lang.Class instance itself. If a method cannot be invoked a MissingMethodException is will be thrown
- Specified by:
invokeStaticMethodin interfaceMetaObjectProtocol- Parameters:
object- An instance of the class returned by the getTheClass() method or the class itselfmethodName- The name of the methodarguments- The arguments to the method- Returns:
- The return value of the method which is null if the return type is void
- See Also:
MissingMethodException
-
invokeConstructorAt
public java.lang.Object invokeConstructorAt(java.lang.Class at, java.lang.Object[] arguments)Deprecated.use invokeConstructor insteadWarning, this method will be removed
-
invokeConstructor
public java.lang.Object invokeConstructor(java.lang.Object[] arguments)
Description copied from interface:MetaObjectProtocolInvokes a constructor for the given arguments. The MetaClass will attempt to pick the best argument which matches the types of the objects passed within the arguments array- Specified by:
invokeConstructorin interfaceMetaObjectProtocol- Parameters:
arguments- The arguments to the constructor- Returns:
- An instance of the java.lang.Class that this MetaObjectProtocol object applies to
-
selectConstructorAndTransformArguments
public int selectConstructorAndTransformArguments(int numberOfConstructors, java.lang.Object[] arguments)Description copied from interface:MetaClassInternal method to support Groovy runtime. Not for client usage.- Specified by:
selectConstructorAndTransformArgumentsin interfaceMetaClass- Parameters:
numberOfConstructors- The number of constructorsarguments- The arguments- Returns:
- selected index
-
checkInitalised
protected void checkInitalised()
checks if the initialisation of the class id complete. This method should be called as a form of assert, it is no way to test if there is still initialisation work to be done. Such logic must be implemented in a different way.- Throws:
java.lang.IllegalStateException- if the initialisation is incomplete yet
-
setProperties
public void setProperties(java.lang.Object bean, java.util.Map map)Sets a number of bean properties from the given Map where the keys are the String names of properties and the values are the values of the properties to set
-
getProperty
public java.lang.Object getProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, boolean useSuper, boolean fromInsideClass)Description copied from interface:MetaClassRetrieves 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
- Specified by:
getPropertyin interfaceMetaClass- Parameters:
sender- The java.lang.Class instance that requested the propertyobject- The Object which the property is being retrieved fromname- The name of the propertyuseSuper- Whether the call is to a super class propertyfromInsideClass- ??- Returns:
- the given property's value on the object
-
getEffectiveGetMetaProperty
public MetaProperty getEffectiveGetMetaProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, boolean useSuper)
-
getProperties
public java.util.List<MetaProperty> getProperties()
Get all the properties defined for this type- Specified by:
getPropertiesin interfaceMetaClass- Specified by:
getPropertiesin interfaceMetaObjectProtocol- Returns:
- a list of MetaProperty objects
- See Also:
MetaProperty
-
applyPropertyDescriptors
protected void applyPropertyDescriptors(java.beans.PropertyDescriptor[] propertyDescriptors)
-
addMetaBeanProperty
public void addMetaBeanProperty(MetaBeanProperty mp)
Adds a new MetaBeanProperty to this MetaClass- Specified by:
addMetaBeanPropertyin interfaceMutableMetaClass- Parameters:
mp- The MetaBeanProperty
-
setProperty
public void setProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, java.lang.Object newValue, boolean useSuper, boolean fromInsideClass)Sets the property value on an object- Specified by:
setPropertyin interfaceMetaClass- Parameters:
sender- The java.lang.Class instance that is mutating the propertyobject- The Object which the property is being set onname- The name of the propertynewValue- The new value of the property to setuseSuper- Whether the call is to a super class propertyfromInsideClass- ??
-
getAttribute
public java.lang.Object getAttribute(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, boolean useSuper)Description copied from interface:MetaClassRetrieves the value of an attribute (field). This method is to support the Groovy runtime and not for general client API usage.- Specified by:
getAttributein interfaceMetaClass- Parameters:
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 not- Returns:
- The attribute value
-
getAttribute
public java.lang.Object getAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, boolean useSuper, boolean fromInsideClass)Looks up the given attribute (field) on the given object
-
setAttribute
public void setAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, java.lang.Object newValue, boolean useSuper, boolean fromInsideClass)Sets the given attribute (field) on the given object- Specified by:
setAttributein interfaceMetaClass- Parameters:
sender- The class of the object that requested the attributeobject- The instanceattribute- The name of the attributenewValue- 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 class
-
getClassNode
public ClassNode getClassNode()
Description copied from interface:MetaClassObtains a reference to the original AST for the MetaClass if it is available at runtime- Specified by:
getClassNodein interfaceMetaClass- Returns:
- The original AST or null if it cannot be returned
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
addMetaMethod
public void addMetaMethod(MetaMethod method)
adds a MetaMethod to this class. WARNING: this method will not do the neccessary steps for multimethod logic and using this method doesn't mean, that a method added here is replacing another method from a parent class completely. These steps are usually done by initialize, which means if you need these steps, you have to add the method before running initialize the first time.- Specified by:
addMetaMethodin interfaceMutableMetaClass- Parameters:
method- the MetaMethod- See Also:
initialize()
-
addMetaMethodToIndex
protected void addMetaMethodToIndex(MetaMethod method, MetaMethodIndex.Header header)
-
checkIfGroovyObjectMethod
protected final void checkIfGroovyObjectMethod(MetaMethod metaMethod)
Checks if the metaMethod is a method from the GroovyObject interface such as setProperty, getProperty and invokeMethod- Parameters:
metaMethod- The metaMethod instance- See Also:
GroovyObject
-
isInitialized
protected boolean isInitialized()
-
chooseMethod
protected java.lang.Object chooseMethod(java.lang.String methodName, java.lang.Object methodOrList, java.lang.Class[] arguments)Chooses the correct method to use from a list of methods which match by name.- Parameters:
methodOrList- the possible methods to choose fromarguments-
-
initialize
public void initialize()
Description copied from interface:MetaClasscomplete the initialisation process. After this method is called no methods should be added to the meta class. Invocation of methods or access to fields/properties is forbidden unless this method is called. This method should contain any initialisation code, taking a longer time to complete. An example is the creation of the Reflector. It is suggested to synchronize this method.- Specified by:
initializein interfaceMetaClass
-
getMethods
public java.util.List<MetaMethod> getMethods()
Description copied from interface:MetaClassRetrieves a list of MetaMethods held by the class- Specified by:
getMethodsin interfaceMetaClass- Specified by:
getMethodsin interfaceMetaObjectProtocol- Returns:
- A list of MetaMethods
- See Also:
MetaMethod
-
getMetaMethods
public java.util.List<MetaMethod> getMetaMethods()
Description copied from interface:MetaClassRetrieves a list of MetaMethods held by this class- Specified by:
getMetaMethodsin interfaceMetaClass- Returns:
- A list of MetaMethods
-
dropStaticMethodCache
protected void dropStaticMethodCache(java.lang.String name)
-
dropMethodCache
protected void dropMethodCache(java.lang.String name)
-
createPojoCallSite
public CallSite createPojoCallSite(CallSite site, java.lang.Object receiver, java.lang.Object[] args)
-
createPogoCallCurrentSite
public CallSite createPogoCallCurrentSite(CallSite site, java.lang.Class sender, java.lang.Object[] args)
-
createConstructorSite
public CallSite createConstructorSite(CallSite site, java.lang.Object[] args)
-
getClassInfo
public ClassInfo getClassInfo()
-
getVersion
public int getVersion()
-
incVersion
public void incVersion()
-
getAdditionalMetaMethods
public MetaMethod[] getAdditionalMetaMethods()
-
findPropertyInClassHierarchy
protected MetaBeanProperty findPropertyInClassHierarchy(java.lang.String propertyName, CachedClass theClass)
-
findMixinMethod
protected MetaMethod findMixinMethod(java.lang.String methodName, java.lang.Class[] arguments)
-
findMethodInClassHierarchy
protected static MetaMethod findMethodInClassHierarchy(java.lang.Class instanceKlazz, java.lang.String methodName, java.lang.Class[] arguments, MetaClass metaClass)
-
findOwnMethod
protected static MetaMethod findOwnMethod(java.lang.Class instanceKlazz, java.lang.String methodName, java.lang.Class[] arguments, MetaClass metaClass, MetaMethod method)
-
getSubclassMetaMethods
protected java.lang.Object getSubclassMetaMethods(java.lang.String methodName)
-
getProperty
public java.lang.Object getProperty(java.lang.Object object, java.lang.String property)Description copied from interface:MetaObjectProtocolRetrieves a property of an instance of the class returned by the getTheClass() method.
What this means is largely down to the MetaClass implementation, however the default case would result in an attempt to invoke a JavaBean getter, or if no such getter exists a public field of the instance.
- Specified by:
getPropertyin interfaceMetaObjectProtocol- Parameters:
object- An instance of the class returned by the getTheClass() methodproperty- The name of the property to retrieve the value for- Returns:
- The properties value
- See Also:
MetaClassImpl
-
setProperty
public void setProperty(java.lang.Object object, java.lang.String property, java.lang.Object newValue)Description copied from interface:MetaObjectProtocolSets a property of an instance of the class returned by the getTheClass() method.
What this means is largely down to the MetaClass implementation, however the default case would result in an attempt to invoke a JavaBean setter, or if no such setter exists to set a public field of the instance.
- Specified by:
setPropertyin interfaceMetaObjectProtocol- Parameters:
object- An instance of the class returned by the getTheClass() methodproperty- The name of the property to setnewValue- The new value of the property- See Also:
MetaClassImpl
-
getAttribute
public java.lang.Object getAttribute(java.lang.Object object, java.lang.String attribute)Description copied from interface:MetaObjectProtocolRetrieves an attribute of an instance of the class returned by the getTheClass() method.
What this means is largely down to the MetaClass implementation, however the default case would result in attempt to read a field of the instance.
- Specified by:
getAttributein interfaceMetaObjectProtocol- Parameters:
object- An instance of the class returned by the getTheClass() methodattribute- The name of the attribute to retrieve the value for- Returns:
- The attribute value
- See Also:
MetaClassImpl
-
setAttribute
public void setAttribute(java.lang.Object object, java.lang.String attribute, java.lang.Object newValue)Description copied from interface:MetaObjectProtocolSets an attribute of an instance of the class returned by the getTheClass() method.
What this means is largely down to the MetaClass implementation, however the default case would result in an attempt to set a field of the instance.
- Specified by:
setAttributein interfaceMetaObjectProtocol- Parameters:
object- An instance of the class returned by the getTheClass() methodattribute- The name of the attribute to setnewValue- The new value of the attribute- See Also:
MetaClassImpl
-
pickMethod
public MetaMethod pickMethod(java.lang.String methodName, java.lang.Class[] arguments)
Description copied from interface:MetaClassSelects a method by name and argument classes. This method does not search for an exact match, it searches for a compatible method. For this the method selection mechanism is used as provided by the implementation of this MetaClass. pickMethod may or may not be used during the method selection process when invoking a method. There is no warranty for that.- Specified by:
pickMethodin interfaceMetaClass- Parameters:
methodName- the name of the method to pickarguments- the method arguments- Returns:
- a matching MetaMethod or null
-
retrieveMethod
protected MetaMethod retrieveMethod(java.lang.String methodName, java.lang.Class[] arguments)
Deprecated.use pickMethod instead
-
clearInvocationCaches
protected void clearInvocationCaches()
remove all method call cache entries. This should be done if a method is added during runtime, but not by using a category.
-
-