Package ome.services.blitz.util
Class IceMethodInvoker
- java.lang.Object
- 
- ome.services.blitz.util.IceMethodInvoker
 
- 
 public class IceMethodInvoker extends java.lang.ObjectMethod-cache primed either with anServiceInterfaceinstance or with aClasswith generic typeServiceInterface. Actual invocation happens viainvoke(Object, Ice.Current, IceMapper, Object[])No reference is held to the initial priming argument inIceMethodInvoker(ServiceInterface, OmeroContext)just the class. MAPPING RULES:- Method names exact
- Collections of the same type only (no arrays)
- Primitives use Ice primitives (long, int, bool,...)
- Primitive wrappers all use RTypes (RLong, RInt, RBool,...)
 - Currently ignoring
 NotNullannotations
 - Since:
- 3.0-Beta2
 
- 
- 
Constructor SummaryConstructors Constructor Description IceMethodInvoker(java.lang.Class<S> k, ome.system.OmeroContext context)Creates anIceMethodInvokerinstance by using reflection on theClassargument.IceMethodInvoker(ome.api.ServiceInterface srv, ome.system.OmeroContext context)Create anIceMethodInvokerinstance using theClassof the passed argument to callIceMethodInvoker(Class, OmeroContext).
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.reflect.MethodgetMethod(java.lang.String name)For testing the cached method.java.lang.Objectinvoke(java.lang.Object obj, Ice.Current current, IceMapper mapper, java.lang.Object... args)Calls the method named inCurrent.operationwith the arguments provided mapped via theIceMapperinstance.booleanisVoid(Ice.Current current)Checks for a void return type, which is needed to know what type of ice_response() method to invoke.
 
- 
- 
- 
Constructor Detail- 
IceMethodInvokerpublic IceMethodInvoker(ome.api.ServiceInterface srv, ome.system.OmeroContext context)Create anIceMethodInvokerinstance using theClassof the passed argument to callIceMethodInvoker(Class, OmeroContext).- Parameters:
- srv- A Non-null- ServiceInterfaceinstance.
- context- The active- OmeroContextinstance.
 
 - 
IceMethodInvokerpublic IceMethodInvoker(java.lang.Class<S> k, ome.system.OmeroContext context)Creates anIceMethodInvokerinstance by using reflection on theClassargument. All information is cached internally in a staticmapif the given service class argument has not already been cached.- Type Parameters:
- S- A type which subclasses- ServiceInterface
- Parameters:
- context- A non-null- ServiceInterface- Class
 
 
- 
 - 
Method Detail- 
isVoidpublic boolean isVoid(Ice.Current current) Checks for a void return type, which is needed to know what type of ice_response() method to invoke.
 - 
invokepublic java.lang.Object invoke(java.lang.Object obj, Ice.Current current, IceMapper mapper, java.lang.Object... args) throws Ice.UserExceptionCalls the method named inCurrent.operationwith the arguments provided mapped via theIceMapperinstance. The return value or any method which is thrown is equally mapped and returned. Exceptions are handled byIceMapper.handleException(Throwable, OmeroContext).- Parameters:
- obj- Instance for the call to- Method.invoke(Object, Object[]). Can be null if this is a static call.
- current- The current Ice operation. Non-null.
- mapper- A non-null mapper.
- args- The proper number of arguments for the method specified in current.
- Returns:
- Either the return value of the invocation, or the exception if one was thrown.
- Throws:
- Ice.UserException
 
 - 
getMethodpublic java.lang.reflect.Method getMethod(java.lang.String name) For testing the cached method.
 
- 
 
-