Package groovy.lang
Class ProxyMetaClass
java.lang.Object
groovy.lang.MetaClassImpl
groovy.lang.ProxyMetaClass
- All Implemented Interfaces:
- AdaptingMetaClass,- MetaClass,- MetaObjectProtocol,- MutableMetaClass
- Direct Known Subclasses:
- MockProxyMetaClass
As subclass of MetaClass, ProxyMetaClass manages calls from Groovy Objects to POJOs.
 It enriches MetaClass with the feature of making method invocations interceptable by
 an Interceptor. To this end, it acts as a decorator (decorator pattern) allowing
 to add or withdraw this feature at runtime.
 See groovy/lang/InterceptorTest.groovy for details.
 
WARNING: This implementation of ProxyMetaClass is NOT thread-safe and hence should only be used for as a per-instance MetaClass running in a single thread. Do not place this MetaClass in the MetaClassRegistry as it will result in unpredictable behaviour
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from class groovy.lang.MetaClassImplMetaClassImpl.Index, MetaClassImpl.MetaConstructor
- 
Field SummaryFieldsFields inherited from class groovy.lang.MetaClassImplEMPTY_ARGUMENTS, getPropertyMethod, INVOKE_METHOD_METHOD, invokeMethodMethod, isGroovyObject, isMap, metaMethodIndex, METHOD_MISSING, PROPERTY_MISSING, registry, setPropertyMethod, STATIC_METHOD_MISSING, STATIC_PROPERTY_MISSING, theCachedClass, theClass
- 
Constructor SummaryConstructorsConstructorDescriptionProxyMetaClass(MetaClassRegistry registry, Class theClass, MetaClass adaptee) 
- 
Method SummaryModifier and TypeMethodDescriptionReturns the MetaClass that this adapter adaptsstatic ProxyMetaClassgetInstance(Class theClass) convenience factory method for the most usual case.getProperty(Class aClass, Object object, String property, boolean useSuper, boolean fromInsideClass) Interceptors the call to getProperty if a PropertyAccessInterceptor is availablevoidComplete the initialisation process.invokeConstructor(Object[] arguments) Call invokeConstructor on adaptee with logic like in MetaClass unless we have an Interceptor.invokeMethod(Class sender, Object object, String methodName, Object[] arguments, boolean isCallToSuper, boolean fromInsideClass) Call invokeMethod on adaptee with logic like in MetaClass unless we have an Interceptor.invokeMethod(Object object, String methodName, Object[] arguments) Call invokeMethod on adaptee with logic like in MetaClass unless we have an Interceptor.invokeStaticMethod(Object object, String methodName, Object[] arguments) Call invokeStaticMethod on adaptee with logic like in MetaClass unless we have an Interceptor.voidsetAdaptee(MetaClass metaClass) Sets the MetaClass adapted by this MetaClassvoidsetInterceptor(Interceptor interceptor) voidsetProperty(Class aClass, Object object, String property, Object newValue, boolean useSuper, boolean fromInsideClass) Interceptors the call to a property setter if a PropertyAccessInterceptor is availableUse the ProxyMetaClass for the given Closure.use(GroovyObject object, Closure closure) Use the ProxyMetaClass for the given Closure.Methods inherited from class groovy.lang.MetaClassImpladdMetaBeanProperty, addMetaMethod, addMetaMethodToIndex, addNewInstanceMethod, addNewStaticMethod, applyPropertyDescriptors, checkIfGroovyObjectMethod, checkInitalised, chooseMethod, clearInvocationCaches, createConstructorSite, createErrorMessageForAmbiguity, createPogoCallCurrentSite, createPogoCallSite, createPojoCallSite, createStaticSite, createTransformMetaMethod, doChooseMostSpecificParams, dropMethodCache, dropStaticMethodCache, findMethodInClassHierarchy, findMixinMethod, findOwnMethod, findPropertyInClassHierarchy, getAdditionalMetaMethods, getAttribute, getAttribute, getAttribute, getClassInfo, getClassNode, getEffectiveGetMetaProperty, getMetaMethod, getMetaMethods, getMetaProperty, getMethods, getMethodWithCaching, getMethodWithoutCaching, getProperties, getProperty, getRegistry, getStaticMetaMethod, getSubclassMetaMethods, getSuperClasses, getTheCachedClass, getTheClass, getVersion, handleMatches, hasCustomInvokeMethod, hasCustomStaticInvokeMethod, hasProperty, incVersion, invokeMethod, invokeMissingMethod, invokeMissingProperty, invokeStaticMissingProperty, isGroovyObject, isInitialized, isModified, isPermissivePropertyAccess, onGetPropertyFoundInHierarchy, onInvokeMethodFoundInHierarchy, onMixinMethodFound, onSetPropertyFoundInHierarchy, onSuperMethodFoundInHierarchy, onSuperPropertyFoundInHierarchy, pickMethod, reinitialize, respondsTo, respondsTo, retrieveConstructor, retrieveConstructor, retrieveStaticMethod, selectConstructorAndTransformArguments, setAttribute, setAttribute, setInitialized, setPermissivePropertyAccess, setProperties, setProperty, toStringMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface groovy.lang.MetaClassgetAttribute, getClassNode, getMetaMethods, getMethods, getProperties, invokeMissingMethod, invokeMissingProperty, pickMethod, selectConstructorAndTransformArguments, setAttributeMethods inherited from interface groovy.lang.MetaObjectProtocolgetAttribute, getMetaMethod, getMetaProperty, getProperty, getStaticMetaMethod, getTheClass, hasProperty, invokeMethod, respondsTo, respondsTo, setAttribute, setProperty
- 
Field Details- 
adaptee
- 
interceptor
 
- 
- 
Constructor Details- 
ProxyMetaClass- Parameters:
- adaptee- the MetaClass to decorate with interceptability
 
 
- 
- 
Method Details- 
getInstanceconvenience factory method for the most usual case.
- 
initializepublic void initialize()Description copied from class:MetaClassImplComplete the initialisation process. After this method is called no methods should be added to the metaclass. 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
- Overrides:
- initializein class- MetaClassImpl
 
- 
getAdapteeDescription copied from interface:AdaptingMetaClassReturns the MetaClass that this adapter adapts- Specified by:
- getAdapteein interface- AdaptingMetaClass
- Returns:
- The MetaClass instance
 
- 
setAdapteeDescription copied from interface:AdaptingMetaClassSets the MetaClass adapted by this MetaClass- Specified by:
- setAdapteein interface- AdaptingMetaClass
- Parameters:
- metaClass- The MetaClass to adapt
 
- 
getInterceptor- Returns:
- the interceptor in use or null if no interceptor is used
 
- 
setInterceptor- Parameters:
- interceptor- may be null to reset any interception
 
- 
useUse the ProxyMetaClass for the given Closure. Cares for balanced register/unregister.- Parameters:
- closure- piece of code to be executed with registered ProxyMetaClass
 
- 
useUse the ProxyMetaClass for the given Closure. Cares for balanced setting/unsetting ProxyMetaClass.- Parameters:
- closure- piece of code to be executed with ProxyMetaClass
 
- 
invokeMethodCall invokeMethod on adaptee with logic like in MetaClass unless we have an Interceptor. With Interceptor the call is nested in its beforeInvoke and afterInvoke methods. The method call is suppressed if Interceptor.doInvoke() returns false. See Interceptor for details.- Specified by:
- invokeMethodin interface- MetaObjectProtocol
- Overrides:
- invokeMethodin class- MetaClassImpl
- Parameters:
- object- The object which the method was invoked on
- methodName- The name of the method
- arguments- The arguments to the method
- Returns:
- The return value of the method
- See Also:
 
- 
invokeMethodpublic Object invokeMethod(Class sender, Object object, String methodName, Object[] arguments, boolean isCallToSuper, boolean fromInsideClass) Call invokeMethod on adaptee with logic like in MetaClass unless we have an Interceptor. With Interceptor the call is nested in its beforeInvoke and afterInvoke methods. The method call is suppressed if Interceptor.doInvoke() returns false. See Interceptor for details.- Specified by:
- invokeMethodin interface- MetaClass
- Overrides:
- invokeMethodin class- MetaClassImpl
- 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
- 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
- See Also:
 
- 
invokeStaticMethodCall invokeStaticMethod on adaptee with logic like in MetaClass unless we have an Interceptor. With Interceptor the call is nested in its beforeInvoke and afterInvoke methods. The method call is suppressed if Interceptor.doInvoke() returns false. See Interceptor for details.- Specified by:
- invokeStaticMethodin interface- MetaObjectProtocol
- Overrides:
- invokeStaticMethodin class- MetaClassImpl
- 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:
 
- 
invokeConstructorCall invokeConstructor on adaptee with logic like in MetaClass unless we have an Interceptor. With Interceptor the call is nested in its beforeInvoke and afterInvoke methods. The method call is suppressed if Interceptor.doInvoke() returns false. See Interceptor for details.- Specified by:
- invokeConstructorin interface- MetaObjectProtocol
- Overrides:
- invokeConstructorin class- MetaClassImpl
- Parameters:
- arguments- The arguments to the constructor
- Returns:
- An instance of the java.lang.Class that this MetaObjectProtocol object applies to
 
- 
getPropertypublic Object getProperty(Class aClass, Object object, String property, boolean useSuper, boolean fromInsideClass) Interceptors the call to getProperty if a PropertyAccessInterceptor is available- Specified by:
- getPropertyin interface- MetaClass
- Overrides:
- getPropertyin class- MetaClassImpl
- Parameters:
- object- the object to invoke the getter on
- property- the property name
- aClass- The java.lang.Class instance that requested the property
- useSuper- Whether the call is to a super class property
- fromInsideClass- ??
- Returns:
- the value of the property
 
- 
setPropertypublic void setProperty(Class aClass, Object object, String property, Object newValue, boolean useSuper, boolean fromInsideClass) Interceptors the call to a property setter if a PropertyAccessInterceptor is available- Specified by:
- setPropertyin interface- MetaClass
- Overrides:
- setPropertyin class- MetaClassImpl
- Parameters:
- object- The object to invoke the setter on
- property- The property name to set
- newValue- The new value of the property
- aClass- The java.lang.Class instance that is mutating the property
- 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.
 
 
-