Class OwnedMetaClass
- java.lang.Object
- 
- groovy.lang.DelegatingMetaClass
- 
- org.codehaus.groovy.runtime.metaclass.OwnedMetaClass
 
 
- 
- All Implemented Interfaces:
- GroovyObject,- MetaClass,- MetaObjectProtocol,- MutableMetaClass
 - Direct Known Subclasses:
- MixedInMetaClass
 
 public abstract class OwnedMetaClass extends DelegatingMetaClass 
- 
- 
Field Summary- 
Fields inherited from class groovy.lang.DelegatingMetaClassdelegate
 
- 
 - 
Constructor SummaryConstructors Constructor Description OwnedMetaClass(MetaClass delegate)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description booleanequals(java.lang.Object obj)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.Object object, java.lang.String attribute)Retrieves an attribute of an instance of the class returned by the getTheClass() method.ClassNodegetClassNode()Obtains a reference to the original AST for the MetaClass if it is available at runtimeMetaMethodgetMetaMethod(java.lang.String name, java.lang.Class[] argTypes)MetaMethodgetMetaMethod(java.lang.String name, java.lang.Object[] args)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 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 a list of MetaMethods held by the class.protected abstract java.lang.ObjectgetOwner()protected abstract MetaClassgetOwnerMetaClass(java.lang.Object owner)java.util.List<MetaProperty>getProperties()Retrieves a list of MetaProperty instances that the MetaClass hasjava.lang.ObjectgetProperty(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, 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.Class[] argTypes)MetaMethodgetStaticMetaMethod(java.lang.String name, java.lang.Object[] args)Retrieves a static MetaMethod for the given name and argument values, using the types of the arguments to establish the chosen MetaMethodjava.lang.ClassgetTheClass()Retrieves that Java Class that the attached Meta behaviours apply tointhashCode()MetaPropertyhasProperty(java.lang.Object obj, java.lang.String name)Returns true of the implementing MetaClass has a property of the given namejava.lang.ObjectinvokeConstructor(java.lang.Object[] arguments)Invokes a constructor for the given arguments.java.lang.ObjectinvokeMethod(java.lang.Class sender, java.lang.Object receiver, java.lang.String methodName, java.lang.Object[] arguments, 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)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[] arguments)Invokes a method on the given Object with the given name and arguments.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.booleanisGroovyObject()java.util.List<MetaMethod>respondsTo(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.List<MetaMethod>respondsTo(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.intselectConstructorAndTransformArguments(int numberOfConstructors, java.lang.Object[] arguments)Internal method to support Groovy runtime.voidsetAttribute(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, java.lang.Object messageValue, boolean useSuper, boolean fromInsideClass)Sets the value of an attribute (field).voidsetAttribute(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.voidsetProperty(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, java.lang.Object messageValue, boolean useSuper, boolean fromInsideClass)Sets 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 of an instance of the class returned by the getTheClass() method.java.lang.StringtoString()- 
Methods inherited from class groovy.lang.DelegatingMetaClassaddMetaBeanProperty, addMetaMethod, addNewInstanceMethod, addNewStaticMethod, getAdaptee, getMetaClass, getProperty, initialize, invokeMethod, isModified, pickMethod, setAdaptee, setMetaClass, setProperty
 
- 
 
- 
- 
- 
Constructor Detail- 
OwnedMetaClasspublic OwnedMetaClass(MetaClass delegate) 
 
- 
 - 
Method Detail- 
getAttributepublic 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 interface- MetaObjectProtocol
- Overrides:
- getAttributein class- DelegatingMetaClass
- Parameters:
- object- An instance of the class returned by the getTheClass() method
- attribute- The name of the attribute to retrieve the value for
- Returns:
- The attribute value
- See Also:
- MetaClassImpl
 
 - 
getOwnerprotected abstract java.lang.Object getOwner() 
 - 
getClassNodepublic 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 interface- MetaClass
- Overrides:
- getClassNodein class- DelegatingMetaClass
- Returns:
- The original AST or null if it cannot be returned
 
 - 
getMetaMethodspublic java.util.List<MetaMethod> getMetaMethods() Description copied from interface:MetaClassRetrieves a list of MetaMethods held by this class. This list includes MetaMethods added by groovy.lang.ExpandoMetaClass.- Specified by:
- getMetaMethodsin interface- MetaClass
- Overrides:
- getMetaMethodsin class- DelegatingMetaClass
- Returns:
- A list of MetaMethods
 
 - 
getMethodspublic java.util.List<MetaMethod> getMethods() Description copied from interface:MetaClassRetrieves a 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
- Overrides:
- getMethodsin class- DelegatingMetaClass
- Returns:
- A list of MetaMethods
- See Also:
- MetaMethod
 
 - 
respondsTopublic java.util.List<MetaMethod> 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
- Overrides:
- respondsToin class- DelegatingMetaClass
- 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
 
 - 
respondsTopublic java.util.List<MetaMethod> 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
- Overrides:
- respondsToin class- DelegatingMetaClass
- 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
 
 - 
hasPropertypublic 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 interface- MetaObjectProtocol
- Overrides:
- hasPropertyin class- DelegatingMetaClass
- Parameters:
- obj- The object to inspect
- name- The name of the property
- Returns:
- The MetaProperty or null if it doesn't exist
 
 - 
getPropertiespublic java.util.List<MetaProperty> getProperties() Description copied from interface:MetaClassRetrieves a list of MetaProperty instances that the MetaClass has- Specified by:
- getPropertiesin interface- MetaClass
- Specified by:
- getPropertiesin interface- MetaObjectProtocol
- Overrides:
- getPropertiesin class- DelegatingMetaClass
- Returns:
- A list of MetaProperty instances
- See Also:
- MetaProperty
 
 - 
getPropertypublic 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 interface- MetaObjectProtocol
- Overrides:
- getPropertyin class- DelegatingMetaClass
- Parameters:
- object- An instance of the class returned by the getTheClass() method
- property- The name of the property to retrieve the value for
- Returns:
- The properties value
- See Also:
- MetaClassImpl
 
 - 
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
- Overrides:
- invokeConstructorin class- DelegatingMetaClass
- Parameters:
- arguments- The arguments to the constructor
- Returns:
- An instance of the java.lang.Class that this MetaObjectProtocol object applies to
 
 - 
invokeMethodpublic 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 interface- MetaObjectProtocol
- Overrides:
- invokeMethodin class- DelegatingMetaClass
- Parameters:
- object- The Object to invoke the method on
- methodName- The name of the method
- arguments- 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[])
 
 - 
invokeMethodpublic 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 arguments. The MetaClass will attempt to pick the best method for the given name and arguments. If a method cannot be invoked a MissingMethodException will be thrown.- Specified by:
- invokeMethodin interface- MetaObjectProtocol
- Overrides:
- invokeMethodin class- DelegatingMetaClass
- Parameters:
- object- The instance which the method is invoked on
- 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
 
 - 
getOwnerMetaClassprotected abstract MetaClass getOwnerMetaClass(java.lang.Object owner) 
 - 
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
- Overrides:
- invokeStaticMethodin class- DelegatingMetaClass
- 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
 
 - 
setAttributepublic 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 interface- MetaObjectProtocol
- Overrides:
- setAttributein class- DelegatingMetaClass
- Parameters:
- object- An instance of the class returned by the getTheClass() method
- attribute- The name of the attribute to set
- newValue- The new value of the attribute
- See Also:
- MetaClassImpl
 
 - 
setPropertypublic 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 interface- MetaObjectProtocol
- Overrides:
- setPropertyin class- DelegatingMetaClass
- Parameters:
- object- An instance of the class returned by the getTheClass() method
- property- The name of the property to set
- newValue- The new value of the property
- See Also:
- MetaClassImpl
 
 - 
equalspublic boolean equals(java.lang.Object obj) - Overrides:
- equalsin class- DelegatingMetaClass
 
 - 
hashCodepublic int hashCode() - Overrides:
- hashCodein class- DelegatingMetaClass
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- DelegatingMetaClass
 
 - 
getAttributepublic 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 interface- MetaClass
- Overrides:
- getAttributein class- DelegatingMetaClass
- Parameters:
- sender- The class of the object that requested the attribute
- receiver- The instance
- messageName- The name of the attribute
- useSuper- Whether to look-up on the super class or not
- Returns:
- The attribute value
 
 - 
getPropertypublic java.lang.Object getProperty(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, 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
- Overrides:
- getPropertyin class- DelegatingMetaClass
- Parameters:
- sender- The java.lang.Class instance that requested the property
- receiver- The Object which the property is being retrieved from
- messageName- The name of the property
- useSuper- Whether the call is to a super class property
- fromInsideClass- ??
- Returns:
- The properties value
 
 - 
getMetaPropertypublic 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 interface- MetaObjectProtocol
- Overrides:
- getMetaPropertyin class- DelegatingMetaClass
- Parameters:
- name- The name of the MetaProperty
- Returns:
- A MetaProperty or null
 
 - 
getStaticMetaMethodpublic MetaMethod getStaticMetaMethod(java.lang.String name, java.lang.Object[] args) 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 interface- MetaObjectProtocol
- Overrides:
- getStaticMetaMethodin class- DelegatingMetaClass
- Parameters:
- name- The name of the MetaMethod
- args- The argument types
- Returns:
- A MetaMethod or null if it doesn't exist
 
 - 
getStaticMetaMethodpublic MetaMethod getStaticMetaMethod(java.lang.String name, java.lang.Class[] argTypes) - Overrides:
- getStaticMetaMethodin class- DelegatingMetaClass
 
 - 
getMetaMethodpublic MetaMethod getMetaMethod(java.lang.String name, java.lang.Object[] args) 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 interface- MetaObjectProtocol
- Overrides:
- getMetaMethodin class- DelegatingMetaClass
- Parameters:
- name- The name of the MetaMethod
- args- 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
 
 - 
getMetaMethodpublic MetaMethod getMetaMethod(java.lang.String name, java.lang.Class[] argTypes) 
 - 
getTheClasspublic java.lang.Class getTheClass() Description copied from interface:MetaObjectProtocolRetrieves that Java Class that the attached Meta behaviours apply to- Specified by:
- getTheClassin interface- MetaObjectProtocol
- Overrides:
- getTheClassin class- DelegatingMetaClass
- Returns:
- The java.lang.Class instance
 
 - 
invokeMethodpublic java.lang.Object invokeMethod(java.lang.Class sender, java.lang.Object receiver, java.lang.String methodName, java.lang.Object[] arguments, boolean isCallToSuper, boolean fromInsideClass)Description copied from interface:MetaClassInvokes 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
- Overrides:
- invokeMethodin class- DelegatingMetaClass
- Parameters:
- sender- The java.lang.Class instance that invoked the method
- receiver- The object which the method was invoked on
- methodName- The name of the method
- arguments- 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
 
 - 
invokeMissingMethodpublic 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 interface- MetaClass
- Overrides:
- invokeMissingMethodin class- DelegatingMetaClass
- Parameters:
- instance- The instance to invoke methodMissing on
- methodName- The name of the method
- arguments- The arguments to the method
- Returns:
- The results of methodMissing or throws MissingMethodException
- See Also:
- MissingMethodException
 
 - 
invokeMissingPropertypublic 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 interface- MetaClass
- Overrides:
- invokeMissingPropertyin class- DelegatingMetaClass
- Parameters:
- instance- The instance of the class
- propertyName- The name of the property
- optionalValue- The value of the property which could be null in the case of a getter
- isGetter- Whether the missing property event was the result of a getter or a setter
- Returns:
- The result of the propertyMissing method or throws MissingPropertyException
 
 - 
isGroovyObjectpublic boolean isGroovyObject() - Overrides:
- isGroovyObjectin class- DelegatingMetaClass
 
 - 
setAttributepublic void setAttribute(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, java.lang.Object messageValue, boolean useSuper, boolean fromInsideClass)Description copied from interface:MetaClassSets 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- MetaClass
- Overrides:
- setAttributein class- DelegatingMetaClass
- Parameters:
- sender- The class of the object that requested the attribute
- receiver- The instance
- messageName- The name of the attribute
- messageValue- The value of the attribute
- useSuper- Whether to look-up on the super class or not
- fromInsideClass- Whether the call happened from the inside or the outside of a class
 
 - 
setPropertypublic void setProperty(java.lang.Class sender, java.lang.Object receiver, java.lang.String messageName, java.lang.Object messageValue, boolean useSuper, boolean fromInsideClass)Description copied from interface:MetaClassSets 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 - Specified by:
- setPropertyin interface- MetaClass
- Overrides:
- setPropertyin class- DelegatingMetaClass
- Parameters:
- sender- The java.lang.Class instance that is mutating the property
- receiver- The Object which the property is being set on
- messageName- The name of the property
- messageValue- 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
 
 - 
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
- Overrides:
- selectConstructorAndTransformArgumentsin class- DelegatingMetaClass
- Parameters:
- numberOfConstructors- The number of constructors
- arguments- The arguments
- Returns:
- selected index
 
 
- 
 
-