Class MetaClassImpl
- All Implemented Interfaces:
- MetaClass,- MetaObjectProtocol,- MutableMetaClass
- Direct Known Subclasses:
- ClosureMetaClass,- ExpandoMetaClass,- ProxyMetaClass
public class MetaClassImpl extends java.lang.Object implements MetaClass, MutableMetaClass
- See Also:
- MetaClass
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classMetaClassImpl.Indexstatic classMetaClassImpl.MetaConstructorThis is a helper class introduced in Groovy 2.1.0, which is used only by indy.
- 
Field SummaryFields Modifier and Type Field Description static java.lang.Object[]EMPTY_ARGUMENTSprotected 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 SummaryConstructors Constructor Description MetaClassImpl(MetaClassRegistry registry, java.lang.Class theClass)Constructor with registry setting methods to nullMetaClassImpl(MetaClassRegistry registry, java.lang.Class theClass, MetaMethod[] add)Constructor with registryMetaClassImpl(java.lang.Class theClass)Constructor that sets the methods to nullMetaClassImpl(java.lang.Class theClass, MetaMethod[] add)Constructor
- 
Method SummaryModifier 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 an instance method to this metaclass.voidaddNewStaticMethod(java.lang.reflect.Method method)Adds a 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)Create a CallSiteprotected static java.lang.StringcreateErrorMessageForAmbiguity(java.lang.String theClassName, java.lang.String name, java.lang.Class[] arguments, java.util.LinkedList matches)CallSitecreatePogoCallCurrentSite(CallSite site, java.lang.Class sender, java.lang.Object[] args)Create a CallSiteCallSitecreatePogoCallSite(CallSite site, java.lang.Object[] args)Create a CallSiteCallSitecreatePojoCallSite(CallSite site, java.lang.Object receiver, java.lang.Object[] args)Create a CallSiteCallSitecreateStaticSite(CallSite site, java.lang.Object[] args)Create a CallSiteprotected MetaMethodcreateTransformMetaMethod(MetaMethod method)protected static java.lang.ObjectdoChooseMostSpecificParams(java.lang.String theClassName, java.lang.String name, java.util.List matchingMethods, java.lang.Class[] arguments, boolean checkParametersCompatible)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()Retrieves a list of additional MetaMethods held by this classjava.lang.ObjectgetAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, 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)Retrieves the value of an attribute (field).java.lang.ObjectgetAttribute(java.lang.Object object, java.lang.String attribute)Retrieves the value of an attribute (field).ClassInfogetClassInfo()Returns the ClassInfo for the contained ClassClassNodegetClassNode()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 the list of MetaMethods held by this class.MetaPropertygetMetaProperty(java.lang.String name)Returns a MetaProperty for the given name or null if it doesn't existjava.util.List<MetaMethod>getMethods()Retrieves the list of MetaMethods held by the class.MetaMethodgetMethodWithCaching(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 on the given object for the specified arguments.MetaClassRegistrygetRegistry()Returns the registry for this metaclassMetaMethodgetStaticMetaMethod(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()Returns the cached class for this metaclassjava.lang.ClassgetTheClass()Returns the class this object this is the metaclass of.intgetVersion()Returns version of the contained Classprotected static longhandleMatches(long matchesDistance, java.util.LinkedList matches, java.lang.Object method, long dist)booleanhasCustomInvokeMethod()indicates is the meta class method invocation for non-static methods is done through a custom invoker object.booleanhasCustomStaticInvokeMethod()indicates is the meta class method invocation for static methods is done through a custom invoker object.MetaPropertyhasProperty(java.lang.Object obj, java.lang.String name)Returns true of the implementing MetaClass has a property of the given namevoidincVersion()Increments version of the contained Classvoidinitialize()Complete the initialisation process.java.lang.ObjectinvokeConstructor(java.lang.Object[] arguments)Invokes a constructor for the given arguments.java.lang.ObjectinvokeMethod(java.lang.Class sender, java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments, boolean isCallToSuper, boolean fromInsideClass)Invokes a method on the given receiver for the specified arguments.java.lang.ObjectinvokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object arguments)Invoke a method on the given object with the given arguments.java.lang.ObjectinvokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments)Invokes a method on the given receiver for the specified arguments.java.lang.ObjectinvokeMissingMethod(java.lang.Object instance, java.lang.String methodName, java.lang.Object[] arguments)Invoke a missing method on the given object with the given arguments.java.lang.ObjectinvokeMissingProperty(java.lang.Object instance, java.lang.String propertyName, java.lang.Object optionalValue, boolean isGetter)Invoke a missing property on the given object with the given arguments.java.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()Return whether the class represented by this metaclass instance is an instance of the GroovyObject classprotected booleanisInitialized()booleanisModified()Returns whether this MetaClassImpl has been modified.booleanisPermissivePropertyAccess()protected 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.protected voidreinitialize()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)MetaMethodretrieveConstructor(java.lang.Object[] arguments)This is a helper method added in Groovy 2.1.0, which is used only by indy.MetaMethodretrieveStaticMethod(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 an attribute on the given receiver for the specified arguments.voidsetAttribute(java.lang.Object object, java.lang.String attribute, java.lang.Object newValue)Sets the value of an attribute (field).protected voidsetInitialized(boolean initialized)voidsetPermissivePropertyAccess(boolean permissivePropertyAccess)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)Retrieves a property on the given receiver for the specified arguments.voidsetProperty(java.lang.Object object, java.lang.String property, java.lang.Object newValue)Sets a property on the given object for the specified arguments.java.lang.StringtoString()Returns a string representation of this metaclassMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
- 
Field Details- 
EMPTY_ARGUMENTSpublic static final java.lang.Object[] EMPTY_ARGUMENTS
- 
STATIC_METHOD_MISSINGprotected static final java.lang.String STATIC_METHOD_MISSING- See Also:
- Constant Field Values
 
- 
STATIC_PROPERTY_MISSINGprotected static final java.lang.String STATIC_PROPERTY_MISSING- See Also:
- Constant Field Values
 
- 
METHOD_MISSINGprotected static final java.lang.String METHOD_MISSING- See Also:
- Constant Field Values
 
- 
PROPERTY_MISSINGprotected static final java.lang.String PROPERTY_MISSING- See Also:
- Constant Field Values
 
- 
INVOKE_METHOD_METHODprotected static final java.lang.String INVOKE_METHOD_METHOD- See Also:
- Constant Field Values
 
- 
theClassprotected final java.lang.Class theClass
- 
theCachedClass
- 
isGroovyObjectprotected final boolean isGroovyObject
- 
isMapprotected final boolean isMap
- 
metaMethodIndex
- 
getPropertyMethod
- 
invokeMethodMethod
- 
setPropertyMethod
- 
registry
 
- 
- 
Constructor Details- 
MetaClassImplConstructor- Parameters:
- theClass- The class this is the metaclass dor
- add- The methods for this class
 
- 
MetaClassImplpublic MetaClassImpl(java.lang.Class theClass)Constructor that sets the methods to null- Parameters:
- theClass- The class this is the metaclass dor
 
- 
MetaClassImplConstructor with registry- Parameters:
- registry- The metaclass registry for this MetaClass
- theClass- The class
- add- The methods
 
- 
MetaClassImplConstructor with registry setting methods to null- Parameters:
- registry- The metaclass registry for this MetaClass
- theClass- The class
 
 
- 
- 
Method Details- 
getTheCachedClassReturns the cached class for this metaclass- Returns:
- The cached class.
 
- 
getRegistryReturns the registry for this metaclass- Returns:
- The registry
 
- 
respondsTopublic 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 interface- MetaObjectProtocol
- Parameters:
- obj- The object to inspect
- name- The name of the method of interest
- argTypes- 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[])
 
- 
respondsTopublic 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 interface- MetaObjectProtocol
- Parameters:
- obj- The object to inspect
- name- 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)
 
- 
hasPropertyDescription 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 interface- MetaObjectProtocol
- Parameters:
- obj- The object to inspect
- name- The name of the property
- Returns:
- The MetaProperty or null if it doesn't exist
- See Also:
- MetaObjectProtocol.hasProperty(Object, String)
 
- 
getMetaPropertyDescription copied from interface:MetaObjectProtocolReturns a MetaProperty for the given name or null if it doesn't exist- Specified by:
- getMetaPropertyin interface- MetaObjectProtocol
- Parameters:
- name- The name of the MetaProperty
- Returns:
- A MetaProperty or null
- See Also:
- MetaObjectProtocol.getMetaProperty(String)
 
- 
getStaticMetaMethodDescription 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 interface- MetaObjectProtocol
- Parameters:
- name- The name of the MetaMethod
- argTypes- The argument types
- Returns:
- A MetaMethod or null if it doesn't exist
- See Also:
- MetaObjectProtocol.getStaticMetaMethod(String, Object[])
 
- 
getMetaMethodDescription 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 interface- MetaObjectProtocol
- Parameters:
- name- The name of the MetaMethod
- argTypes- 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[])
 
- 
getTheClasspublic java.lang.Class getTheClass()Returns the class this object this is the metaclass of.- Specified by:
- getTheClassin interface- MetaObjectProtocol
- Returns:
- The class contained by this metaclass
 
- 
isGroovyObjectpublic boolean isGroovyObject()Return whether the class represented by this metaclass instance is an instance of the GroovyObject class- Returns:
- true if this is a groovy class, false otherwise.
 
- 
getSuperClasses
- 
isModifiedpublic boolean isModified()Returns whether this MetaClassImpl has been modified. Since MetaClassImpl is not designed for modification this method always returns false- Specified by:
- isModifiedin interface- MutableMetaClass
- Returns:
- false
 
- 
addNewInstanceMethodpublic void addNewInstanceMethod(java.lang.reflect.Method method)Adds an instance method to this metaclass.- Specified by:
- addNewInstanceMethodin interface- MutableMetaClass
- Parameters:
- method- The method to be added
 
- 
addNewStaticMethodpublic void addNewStaticMethod(java.lang.reflect.Method method)Adds a static method to this metaclass.- Specified by:
- addNewStaticMethodin interface- MutableMetaClass
- Parameters:
- method- The method to be added
 
- 
invokeMethodpublic java.lang.Object invokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object arguments)Invoke a method on the given object with the given arguments.- Specified by:
- invokeMethodin interface- MetaObjectProtocol
- Parameters:
- object- The object the method should be invoked on.
- methodName- The name of the method to invoke.
- arguments- The arguments to the invoked method as null, a Tuple, an array or a single argument of any type.
- Returns:
- The result of the method invocation.
- See Also:
- MetaObjectProtocol.invokeMethod(Object, String, Object[])
 
- 
invokeMissingMethodpublic java.lang.Object invokeMissingMethod(java.lang.Object instance, java.lang.String methodName, java.lang.Object[] arguments)Invoke a missing method on the given object with the given arguments.- Specified by:
- invokeMissingMethodin interface- MetaClass
- Parameters:
- instance- The object the method should be invoked on.
- methodName- The name of the method to invoke.
- arguments- The arguments to the invoked method.
- Returns:
- The result of the method invocation.
- See Also:
- MissingMethodException
 
- 
invokeMissingPropertypublic java.lang.Object invokeMissingProperty(java.lang.Object instance, java.lang.String propertyName, java.lang.Object optionalValue, boolean isGetter)Invoke a missing property on the given object with the given arguments.- Specified by:
- invokeMissingPropertyin interface- MetaClass
- Parameters:
- instance- The object the method should be invoked on.
- propertyName- The name of the property to invoke.
- optionalValue- The (optional) new value for the property
- isGetter- Whether the method is a getter
- Returns:
- The result of the method invocation.
 
- 
onSuperPropertyFoundInHierarchy
- 
onMixinMethodFound
- 
onSuperMethodFoundInHierarchy
- 
onInvokeMethodFoundInHierarchy
- 
onSetPropertyFoundInHierarchy
- 
onGetPropertyFoundInHierarchy
- 
invokeStaticMissingPropertyprotected 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 instance
- propertyName- The name of the property
- optionalValue- The value in the case of a setter
- isGetter- True if its a getter
- Returns:
- The value in the case of a getter or a MissingPropertyException
 
- 
invokeMethodpublic java.lang.Object invokeMethod(java.lang.Object object, java.lang.String methodName, java.lang.Object[] originalArguments)Invokes a method on the given receiver for the specified arguments. The MetaClass will attempt to establish the method to invoke based on the name and arguments provided.- Specified by:
- invokeMethodin interface- MetaObjectProtocol
- Parameters:
- object- The object which the method was invoked on
- methodName- The name of the method
- originalArguments- The arguments to the method
- Returns:
- The return value of the method
- See Also:
- MetaClass.invokeMethod(Class, Object, String, Object[], boolean, boolean)
 
- 
invokeMethodpublic 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 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 - Specified by:
- invokeMethodin interface- MetaClass
- Parameters:
- sender- The java.lang.Class instance that invoked the method
- object- The object which the method was invoked on
- methodName- The name of the method
- originalArguments- The arguments to the method
- isCallToSuper- Whether the method is a call to a super class method
- fromInsideClass- Whether the call was invoked from the inside or the outside of the class
- Returns:
- The return value of the method
- See Also:
- MetaClass.invokeMethod(Class, Object, String, Object[], boolean, boolean)
 
- 
createTransformMetaMethod
- 
getMethodWithCachingpublic MetaMethod getMethodWithCaching(java.lang.Class sender, java.lang.String methodName, java.lang.Object[] arguments, boolean isCallToSuper)
- 
retrieveConstructorpublic java.lang.reflect.Constructor retrieveConstructor(java.lang.Class[] arguments)
- 
retrieveStaticMethod
- 
getMethodWithoutCachingpublic MetaMethod getMethodWithoutCaching(java.lang.Class sender, java.lang.String methodName, java.lang.Class[] arguments, boolean isCallToSuper)
- 
invokeStaticMethodpublic 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 interface- MetaObjectProtocol
- Parameters:
- object- An instance of the class returned by the getTheClass() method or the class itself
- methodName- The name of the method
- arguments- The arguments to the method
- Returns:
- The return value of the method which is null if the return type is void
- See Also:
- MissingMethodException
 
- 
invokeConstructorpublic 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 interface- MetaObjectProtocol
- Parameters:
- arguments- The arguments to the constructor
- Returns:
- An instance of the java.lang.Class that this MetaObjectProtocol object applies to
 
- 
selectConstructorAndTransformArgumentspublic 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 interface- MetaClass
- Parameters:
- numberOfConstructors- The number of constructors
- arguments- The arguments
- Returns:
- selected index
 
- 
checkInitalisedprotected 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
 
- 
retrieveConstructorThis is a helper method added in Groovy 2.1.0, which is used only by indy. This method is for internal use only.- Since:
- Groovy 2.1.0
 
- 
setPropertiespublic 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
- 
getPropertypublic 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 interface- MetaClass
- Parameters:
- sender- The java.lang.Class instance that requested the property
- object- The Object which the property is being retrieved from
- name- The name of the property
- useSuper- Whether the call is to a super class property
- fromInsideClass- ??
- Returns:
- the given property's value on the object
 
- 
getEffectiveGetMetaPropertypublic MetaProperty getEffectiveGetMetaProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, boolean useSuper)
- 
getPropertiesGet all the properties defined for this type- Specified by:
- getPropertiesin interface- MetaClass
- Specified by:
- getPropertiesin interface- MetaObjectProtocol
- Returns:
- a list of MetaProperty objects
- See Also:
- MetaProperty
 
- 
applyPropertyDescriptorsprotected void applyPropertyDescriptors(java.beans.PropertyDescriptor[] propertyDescriptors)
- 
addMetaBeanPropertyAdds a new MetaBeanProperty to this MetaClass- Specified by:
- addMetaBeanPropertyin interface- MutableMetaClass
- Parameters:
- mp- The MetaBeanProperty
 
- 
setPropertypublic void setProperty(java.lang.Class sender, java.lang.Object object, java.lang.String name, java.lang.Object newValue, boolean useSuper, 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 useSuper and fromInsideClass help the Groovy runtime perform optimisations on the call to go directly to the super class if necessary - Specified by:
- setPropertyin interface- MetaClass
- Parameters:
- sender- The java.lang.Class instance that is mutating the property
- object- The Object which the property is being set on
- name- The name of the property
- newValue- The new value of the property to set
- useSuper- Whether the call is to a super class property
- fromInsideClass- Whether the call was invoked from the inside or the outside of the class.
 
- 
getAttributepublic java.lang.Object getAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, boolean useSuper)Retrieves the value of an attribute (field). This method is to support the Groovy runtime and not for general client API usage.- Specified by:
- getAttributein interface- MetaClass
- Parameters:
- sender- The class of the object that requested the attribute
- object- The instance
- attribute- The name of the attribute
- useSuper- Whether to look-up on the super class or not
- Returns:
- The attribute value
 
- 
getAttributepublic java.lang.Object getAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, boolean useSuper, boolean fromInsideClass)Retrieves the value of an attribute (field). This method is to support the Groovy runtime and not for general client API usage.- Parameters:
- sender- The class of the object that requested the attribute
- object- The instance the attribute is to be retrieved from
- attribute- The name of the attribute
- useSuper- Whether to look-up on the super class or not
- fromInsideClass- Whether the call was invoked from the inside or the outside of the class.
- Returns:
- The attribute value
 
- 
setAttributepublic void setAttribute(java.lang.Class sender, java.lang.Object object, java.lang.String attribute, java.lang.Object newValue, boolean useSuper, boolean fromInsideClass)Sets an attribute on the given receiver for the specified arguments. The sender is the class that is setting the attribute 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:
- setAttributein interface- MetaClass
- Parameters:
- sender- The java.lang.Class instance that is mutating the property
- object- The Object which the property is being set on
- attribute- The name of the attribute,
- newValue- The new value of the attribute to set
- useSuper- Whether the call is to a super class property
- fromInsideClass- Whether the call was invoked from the inside or the outside of the class
 
- 
getClassNodeObtains a reference to the original AST for the MetaClass if it is available at runtime- Specified by:
- getClassNodein interface- MetaClass
- Returns:
- The original AST or null if it cannot be returned
 
- 
toStringpublic java.lang.String toString()Returns a string representation of this metaclass- Overrides:
- toStringin class- java.lang.Object
 
- 
addMetaMethodadds 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 interface- MutableMetaClass
- Parameters:
- method- the MetaMethod
- See Also:
- initialize()
 
- 
addMetaMethodToIndex
- 
checkIfGroovyObjectMethodChecks if the metaMethod is a method from the GroovyObject interface such as setProperty, getProperty and invokeMethod- Parameters:
- metaMethod- The metaMethod instance
- See Also:
- GroovyObject
 
- 
isInitializedprotected boolean isInitialized()
- 
setInitializedprotected void setInitialized(boolean initialized)
- 
chooseMethodprotected 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 from
- arguments- the arguments
 
- 
doChooseMostSpecificParamsprotected static java.lang.Object doChooseMostSpecificParams(java.lang.String theClassName, java.lang.String name, java.util.List matchingMethods, java.lang.Class[] arguments, boolean checkParametersCompatible)
- 
createErrorMessageForAmbiguityprotected static java.lang.String createErrorMessageForAmbiguity(java.lang.String theClassName, java.lang.String name, java.lang.Class[] arguments, java.util.LinkedList matches)
- 
handleMatchesprotected static long handleMatches(long matchesDistance, java.util.LinkedList matches, java.lang.Object method, long dist)
- 
initializepublic void initialize()Complete 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 interface- MetaClass
 
- 
reinitializeprotected void reinitialize()
- 
getMethodsRetrieves the list of MetaMethods held by the class. This list does not include MetaMethods added by groovy.lang.ExpandoMetaClass.- Specified by:
- getMethodsin interface- MetaClass
- Specified by:
- getMethodsin interface- MetaObjectProtocol
- Returns:
- A list of MetaMethods
- See Also:
- MetaMethod
 
- 
getMetaMethodsRetrieves the list of MetaMethods held by this class. This list includes MetaMethods added by groovy.lang.ExpandoMetaClass.- Specified by:
- getMetaMethodsin interface- MetaClass
- Returns:
- A list of MetaMethods
 
- 
dropStaticMethodCacheprotected void dropStaticMethodCache(java.lang.String name)
- 
dropMethodCacheprotected void dropMethodCache(java.lang.String name)
- 
createPojoCallSitepublic CallSite createPojoCallSite(CallSite site, java.lang.Object receiver, java.lang.Object[] args)Create a CallSite
- 
createStaticSiteCreate a CallSite
- 
createPogoCallSiteCreate a CallSite
- 
createPogoCallCurrentSitepublic CallSite createPogoCallCurrentSite(CallSite site, java.lang.Class sender, java.lang.Object[] args)Create a CallSite
- 
createConstructorSiteCreate a CallSite
- 
getClassInfoReturns the ClassInfo for the contained Class- Returns:
- The ClassInfo for the contained class.
 
- 
getVersionpublic int getVersion()Returns version of the contained Class- Returns:
- The version of the contained class.
 
- 
incVersionpublic void incVersion()Increments version of the contained Class
- 
getAdditionalMetaMethodsRetrieves a list of additional MetaMethods held by this class- Returns:
- A list of MetaMethods
 
- 
findPropertyInClassHierarchyprotected MetaBeanProperty findPropertyInClassHierarchy(java.lang.String propertyName, CachedClass theClass)
- 
findMixinMethod
- 
findMethodInClassHierarchyprotected static MetaMethod findMethodInClassHierarchy(java.lang.Class instanceKlazz, java.lang.String methodName, java.lang.Class[] arguments, MetaClass metaClass)
- 
findOwnMethodprotected static MetaMethod findOwnMethod(java.lang.Class instanceKlazz, java.lang.String methodName, java.lang.Class[] arguments, MetaClass metaClass, MetaMethod method)
- 
getSubclassMetaMethodsprotected java.lang.Object getSubclassMetaMethods(java.lang.String methodName)
- 
getPropertypublic java.lang.Object getProperty(java.lang.Object object, java.lang.String property)Retrieves a property on the given object for the specified arguments. - Specified by:
- getPropertyin interface- MetaObjectProtocol
- Parameters:
- object- The Object which the property is being retrieved from
- property- The name of the property
- Returns:
- The properties value
- See Also:
- MetaClassImpl
 
- 
setPropertypublic void setProperty(java.lang.Object object, java.lang.String property, java.lang.Object newValue)Sets a property on the given object for the specified arguments. - Specified by:
- setPropertyin interface- MetaObjectProtocol
- Parameters:
- object- The Object which the property is being retrieved from
- property- The name of the property
- newValue- The new value
- See Also:
- MetaClassImpl
 
- 
getAttributepublic java.lang.Object getAttribute(java.lang.Object object, java.lang.String attribute)Retrieves the value of an attribute (field). This method is to support the Groovy runtime and not for general client API usage.- Specified by:
- getAttributein interface- MetaObjectProtocol
- Parameters:
- object- The object to get the attribute from
- attribute- The name of the attribute
- Returns:
- The attribute value
- See Also:
- MetaClassImpl
 
- 
setAttributepublic void setAttribute(java.lang.Object object, java.lang.String attribute, java.lang.Object newValue)Sets the value of an attribute (field). This method is to support the Groovy runtime and not for general client API usage.- Specified by:
- setAttributein interface- MetaObjectProtocol
- Parameters:
- object- The object to get the attribute from
- attribute- The name of the attribute
- newValue- The new value of the attribute
- See Also:
- MetaClassImpl
 
- 
pickMethodSelects 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 interface- MetaClass
- Parameters:
- methodName- the name of the method to pick
- arguments- the method arguments
- Returns:
- a matching MetaMethod or null
- Throws:
- GroovyRuntimeException- if there is more than one matching method
 
- 
hasCustomInvokeMethodpublic boolean hasCustomInvokeMethod()indicates is the meta class method invocation for non-static methods is done through a custom invoker object.- Returns:
- true - if the method invocation is not done by the meta class itself
 
- 
hasCustomStaticInvokeMethodpublic boolean hasCustomStaticInvokeMethod()indicates is the meta class method invocation for static methods is done through a custom invoker object.- Returns:
- true - if the method invocation is not done by the meta class itself
 
- 
clearInvocationCachesprotected 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.
- 
isPermissivePropertyAccesspublic boolean isPermissivePropertyAccess()
- 
setPermissivePropertyAccesspublic void setPermissivePropertyAccess(boolean permissivePropertyAccess)
 
-