|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
public interface MetaObjectProtocol
An interface that defines the API usable by clients of Groovy's Meta Object Protocol (MOP). These methods are implemented by the reference implementation of the @link groovy.lang.MetaClass interface.
MetaClassImpl
Method Summary | |
---|---|
Object |
getAttribute(Object object,
String attribute)
Retrieves an attribute of an instance of the class returned by the getTheClass() method. |
MetaMethod |
getMetaMethod(String name,
Object[] args)
Retrieves an instance MetaMethod for the given name and argument values, using the types of the argument values to establish the chosen MetaMethod |
MetaProperty |
getMetaProperty(String name)
Returns a MetaProperty for the given name or null if it doesn't exist |
List<MetaMethod> |
getMethods()
Obtain a list of all the meta methods available on this meta class |
List<MetaProperty> |
getProperties()
Obtain a list of all meta properties available on this meta class |
Object |
getProperty(Object object,
String property)
Retrieves a property of an instance of the class returned by the getTheClass() method. |
MetaMethod |
getStaticMetaMethod(String name,
Object[] args)
Retreives a static MetaMethod for the given name and argument values, using the types of the arguments to establish the chosen MetaMethod |
Class |
getTheClass()
Retrieves that Java Class that the attached Meta behaviours apply to |
MetaProperty |
hasProperty(Object obj,
String name)
Returns 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 |
Object |
invokeConstructor(Object[] arguments)
Invokes a constructor for the given arguments. |
Object |
invokeMethod(Object object,
String methodName,
Object arguments)
Invokes a method on the given object, with the given name and single argument. |
Object |
invokeMethod(Object object,
String methodName,
Object[] arguments)
Invokes a method on the given Object with the given name and arguments. |
Object |
invokeStaticMethod(Object object,
String methodName,
Object[] arguments)
Invokes a static method on the given Object with the given name and arguments. |
List<MetaMethod> |
respondsTo(Object obj,
String name)
Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name regardless of arguments. |
List<MetaMethod> |
respondsTo(Object obj,
String name,
Object[] argTypes)
Returns an object satisfying Groovy truth if the implementing MetaClass responds to a method with the given name and arguments types. |
void |
setAttribute(Object object,
String attribute,
Object newValue)
Sets an attribute of an instance of the class returned by the getTheClass() method. |
void |
setProperty(Object object,
String property,
Object newValue)
Sets a property of an instance of the class returned by the getTheClass() method. |
Method Detail |
---|
List<MetaProperty> getProperties()
MetaProperty
List<MetaMethod> getMethods()
MetaMethod
List<MetaMethod> respondsTo(Object obj, String name, Object[] argTypes)
Returns 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
obj
- The object to inspectname
- The name of the method of interestargTypes
- The argument types to match against
List<MetaMethod> respondsTo(Object obj, String name)
Returns 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
obj
- The object to inspectname
- The name of the method of interest
MetaProperty hasProperty(Object obj, String name)
Returns 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
obj
- The object to inspectname
- The name of the property
MetaProperty getMetaProperty(String name)
name
- The name of the MetaProperty
MetaMethod getStaticMetaMethod(String name, Object[] args)
name
- The name of the MetaMethodargs
- The argument types
MetaMethod getMetaMethod(String name, Object[] args)
name
- The name of the MetaMethodargs
- The argument types
Class getTheClass()
Object invokeConstructor(Object[] arguments)
arguments
- The arguments to the constructor
Object invokeMethod(Object object, String methodName, Object[] arguments)
Invokes 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.
object
- The instance which the method is invoked onmethodName
- The name of the methodarguments
- The arguments to the method
MissingMethodException
Object invokeMethod(Object object, String methodName, Object arguments)
Invokes a method on the given object, with the given name and single argument.
object
- The Object to invoke the method onmethodName
- The name of the methodarguments
- The argument to the method
invokeMethod(Object, String, Object[])
Object invokeStaticMethod(Object object, String methodName, Object[] arguments)
Invokes 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
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
MissingMethodException
Object getProperty(Object object, String property)
Retrieves 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.
object
- An instance of the class returned by the getTheClass() methodproperty
- The name of the property to retrieve the value for
MetaClassImpl
void setProperty(Object object, String property, Object newValue)
Sets 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.
object
- An instance of the class returned by the getTheClass() methodproperty
- The name of the property to setnewValue
- The new value of the propertyMetaClassImpl
Object getAttribute(Object object, String attribute)
Retrieves 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.
object
- An instance of the class returned by the getTheClass() methodattribute
- The name of the attribute to retrieve the value for
MetaClassImpl
void setAttribute(Object object, String attribute, Object newValue)
Sets 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.
object
- An instance of the class returned by the getTheClass() methodattribute
- The name of the attribute to setnewValue
- The new value of the attributeMetaClassImpl
|
Copyright © 2003-2009 The Codehaus. All rights reserved. | ||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |