Ice.ObjectPrxHelperBase Maven / Gradle / Ivy
//
// Copyright (c) ZeroC, Inc. All rights reserved.
//
package Ice;
import java.util.LinkedList;
import java.util.List;
/**
* Base class for all proxies.
**/
public class ObjectPrxHelperBase implements ObjectPrx, java.io.Serializable
{
/**
* Returns a hash code for this proxy.
*
* @return The hash code.
**/
@Override
public final int
hashCode()
{
return _reference.hashCode();
}
/**
* Returns the communicator that created this proxy.
*
* @return The communicator that created this proxy.
**/
@Override
public final Communicator
ice_getCommunicator()
{
return _reference.getCommunicator();
}
/**
* Returns the stringified form of this proxy.
*
* @return The stringified proxy.
**/
@Override
public final String
toString()
{
return _reference.toString();
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @return true
if this proxy supports the specified interface; false
, otherwise.
**/
@Override
public final boolean
ice_isA(String id)
{
return _iceI_ice_isA(id, null, false);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param context The Context
map for the invocation.
* @return true
if this proxy supports the specified interface; false
, otherwise.
**/
@Override
public final boolean
ice_isA(String id, java.util.Map context)
{
return _iceI_ice_isA(id, context, true);
}
private static final String _ice_isA_name = "ice_isA";
private boolean
_iceI_ice_isA(String id, java.util.Map context, boolean explicitCtx)
{
_checkTwowayOnly(_ice_isA_name);
return end_ice_isA(_iceI_begin_ice_isA(id, context, explicitCtx, true, null));
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id)
{
return _iceI_begin_ice_isA(id, null, false, false, null);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param context The Context
map for the invocation.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id, java.util.Map context)
{
return _iceI_begin_ice_isA(id, context, true, false, null);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id, Callback cb)
{
return _iceI_begin_ice_isA(id, null, false, false, cb);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param context The Context
map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id, java.util.Map context, Callback cb)
{
return _iceI_begin_ice_isA(id, context, true, false, cb);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id, Callback_Object_ice_isA cb)
{
return _iceI_begin_ice_isA(id, null, false, false, cb);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param context The Context
map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id, java.util.Map context, Callback_Object_ice_isA cb)
{
return _iceI_begin_ice_isA(id, context, true, false, cb);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id,
IceInternal.Functional_BoolCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_isA(id, null, false, false, responseCb, exceptionCb, null);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id,
IceInternal.Functional_BoolCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_isA(id, null, false, false, responseCb, exceptionCb, sentCb);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param context The Context
map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id,
java.util.Map context,
IceInternal.Functional_BoolCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_isA(id, context, true, false, responseCb, exceptionCb, null);
}
/**
* Tests whether this proxy supports a given interface.
*
* @param id The Slice type ID of an interface.
* @param context The Context
map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_isA(String id,
java.util.Map context,
IceInternal.Functional_BoolCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_isA(id, context, true, false, responseCb, exceptionCb, sentCb);
}
private AsyncResult
_iceI_begin_ice_isA(String id,
java.util.Map context,
boolean explicitCtx,
boolean synchronous,
IceInternal.Functional_BoolCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_isA(id, context, explicitCtx, synchronous,
new IceInternal.Functional_TwowayCallbackBool(responseCb, exceptionCb, sentCb)
{
@Override
public final void _iceCompleted(AsyncResult result)
{
ObjectPrxHelperBase._iceI_ice_isA_completed(this, result);
}
});
}
private AsyncResult
_iceI_begin_ice_isA(String id, java.util.Map context, boolean explicitCtx,
boolean synchronous, IceInternal.CallbackBase cb)
{
_checkAsyncTwowayOnly(_ice_isA_name);
IceInternal.OutgoingAsync result = getOutgoingAsync(_ice_isA_name, cb);
try
{
result.prepare(_ice_isA_name, OperationMode.Nonmutating, context, explicitCtx, synchronous);
OutputStream ostr = result.startWriteParams(Ice.FormatType.DefaultFormat);
ostr.writeString(id);
result.endWriteParams();
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
/**
* Completes the asynchronous ice_isA request.
*
* @param r The asynchronous result.
* @return true
if this proxy supports the specified interface; false
, otherwise.
**/
@Override
public final boolean
end_ice_isA(AsyncResult r)
{
IceInternal.OutgoingAsync result = IceInternal.OutgoingAsync.check(r, this, _ice_isA_name);
try
{
if(!result.waitForResponseOrUserEx())
{
try
{
result.throwUserException();
}
catch(UserException ex)
{
throw new UnknownUserException(ex.ice_id(), ex);
}
}
boolean ret;
InputStream istr = result.startReadParams();
ret = istr.readBool();
result.endReadParams();
return ret;
}
finally
{
if(result != null)
{
result.cacheMessageBuffers();
}
}
}
static public void _iceI_ice_isA_completed(TwowayCallbackBool cb, AsyncResult result)
{
boolean ret = false;
try
{
ret = result.getProxy().end_ice_isA(result);
}
catch(LocalException ex)
{
cb.exception(ex);
return;
}
catch(SystemException ex)
{
cb.exception(ex);
return;
}
cb.response(ret);
}
/**
* Tests whether the target object of this proxy can be reached.
**/
@Override
public final void
ice_ping()
{
_iceI_ice_ping(null, false);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param context The Context
map for the invocation.
**/
@Override
public final void
ice_ping(java.util.Map context)
{
_iceI_ice_ping(context, true);
}
private static final String _ice_ping_name = "ice_ping";
private void
_iceI_ice_ping(java.util.Map context, boolean explicitCtx)
{
end_ice_ping(_iceI_begin_ice_ping(context, explicitCtx, true, null));
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping()
{
return _iceI_begin_ice_ping(null, false, false, null);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param context The context map for the invocation.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(java.util.Map context)
{
return _iceI_begin_ice_ping(context, true, false, null);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(Callback cb)
{
return _iceI_begin_ice_ping(null, false, false, cb);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(java.util.Map context, Callback cb)
{
return _iceI_begin_ice_ping(context, true, false, cb);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(Callback_Object_ice_ping cb)
{
return _iceI_begin_ice_ping(null, false, false, cb);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(java.util.Map context, Callback_Object_ice_ping cb)
{
return _iceI_begin_ice_ping(context, true, false, cb);
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(IceInternal.Functional_VoidCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_ping(null, false, false,
new IceInternal.Functional_OnewayCallback(responseCb, exceptionCb, null));
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(IceInternal.Functional_VoidCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_ping(null, false, false, new IceInternal.Functional_OnewayCallback(responseCb,
exceptionCb, sentCb));
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param context The context map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(java.util.Map context,
IceInternal.Functional_VoidCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_ping(context, true, false, new IceInternal.Functional_OnewayCallback(responseCb,
exceptionCb, null));
}
/**
* Tests whether the target object of this proxy can be reached.
*
* @param context The context map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ping(java.util.Map context,
IceInternal.Functional_VoidCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_ping(context, true, false,
new IceInternal.Functional_OnewayCallback(responseCb, exceptionCb, sentCb));
}
private AsyncResult _iceI_begin_ice_ping(java.util.Map context, boolean explicitCtx,
boolean synchronous, IceInternal.CallbackBase cb)
{
IceInternal.OutgoingAsync result = getOutgoingAsync(_ice_ping_name, cb);
try
{
result.prepare(_ice_ping_name, OperationMode.Nonmutating, context, explicitCtx, synchronous);
result.writeEmptyParams();
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
/**
* Completes the asynchronous ping request.
*
* @param result The asynchronous result.
**/
@Override
public final void
end_ice_ping(AsyncResult result)
{
_end(result, _ice_ping_name);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @return The Slice type IDs of the interfaces supported by the target object, in base-to-derived
* order. The first element of the returned array is always ::Ice::Object
.
**/
@Override
public final String[]
ice_ids()
{
return _iceI_ice_ids(null, false);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param context The Context
map for the invocation.
* @return The Slice type IDs of the interfaces supported by the target object, in base-to-derived
* order. The first element of the returned array is always ::Ice::Object
.
**/
@Override
public final String[]
ice_ids(java.util.Map context)
{
return _iceI_ice_ids(context, true);
}
private static final String _ice_ids_name = "ice_ids";
private String[]
_iceI_ice_ids(java.util.Map context, boolean explicitCtx)
{
_checkTwowayOnly(_ice_id_name);
return end_ice_ids(_iceI_begin_ice_ids(context, explicitCtx, true, null));
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids()
{
return _iceI_begin_ice_ids(null, false, false, null);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(java.util.Map context)
{
return _iceI_begin_ice_ids(context, true, false, null);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(Callback cb)
{
return _iceI_begin_ice_ids(null, false, false,cb);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(java.util.Map context, Callback cb)
{
return _iceI_begin_ice_ids(context, true, false,cb);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(Callback_Object_ice_ids cb)
{
return _iceI_begin_ice_ids(null, false, false,cb);
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(java.util.Map context, Callback_Object_ice_ids cb)
{
return _iceI_begin_ice_ids(context, true, false,cb);
}
private class FunctionalCallback_Object_ice_ids extends IceInternal.Functional_TwowayCallbackArg1
{
FunctionalCallback_Object_ice_ids(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
super(responseCb, exceptionCb, sentCb);
}
@Override
public final void _iceCompleted(AsyncResult result)
{
ObjectPrxHelperBase._iceI_ice_ids_completed(this, result);
}
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_ids(null, false, false, new FunctionalCallback_Object_ice_ids(responseCb, exceptionCb,
null));
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_ids(null, false, false, new FunctionalCallback_Object_ice_ids(responseCb, exceptionCb,
sentCb));
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(java.util.Map context,
IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_ids(context, true, false, new FunctionalCallback_Object_ice_ids(responseCb, exceptionCb,
null));
}
/**
* Returns the Slice type IDs of the interfaces supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_ids(java.util.Map context,
IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_ids(context, true, false,
new FunctionalCallback_Object_ice_ids(responseCb, exceptionCb, sentCb));
}
private AsyncResult _iceI_begin_ice_ids(java.util.Map context, boolean explicitCtx,
boolean synchronous, IceInternal.CallbackBase cb)
{
_checkAsyncTwowayOnly(_ice_ids_name);
IceInternal.OutgoingAsync result = getOutgoingAsync(_ice_ids_name, cb);
try
{
result.prepare(_ice_ids_name, OperationMode.Nonmutating, context, explicitCtx, synchronous);
result.writeEmptyParams();
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
/**
* Completes the asynchronous ice_ids request.
*
* @param r The asynchronous result.
* @return The Slice type IDs of the interfaces supported by the target object, in base-to-derived
* order. The first element of the returned array is always ::Ice::Object
.
**/
@Override
public final String[]
end_ice_ids(AsyncResult r)
{
IceInternal.OutgoingAsync result = IceInternal.OutgoingAsync.check(r, this, _ice_ids_name);
try
{
if(!result.waitForResponseOrUserEx())
{
try
{
result.throwUserException();
}
catch(UserException ex)
{
throw new UnknownUserException(ex.ice_id(), ex);
}
}
String[] ret = null;
InputStream istr = result.startReadParams();
ret = StringSeqHelper.read(istr);
result.endReadParams();
return ret;
}
finally
{
if(result != null)
{
result.cacheMessageBuffers();
}
}
}
static public void _iceI_ice_ids_completed(TwowayCallbackArg1 cb, AsyncResult result)
{
String[] ret = null;
try
{
ret = result.getProxy().end_ice_ids(result);
}
catch(LocalException ex)
{
cb.exception(ex);
return;
}
catch(SystemException ex)
{
cb.exception(ex);
return;
}
cb.response(ret);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @return The Slice type ID of the most-derived interface.
**/
@Override
public final String
ice_id()
{
return _iceI_ice_id(null, false);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param context The Context
map for the invocation.
* @return The Slice type ID of the most-derived interface.
**/
@Override
public final String
ice_id(java.util.Map context)
{
return _iceI_ice_id(context, true);
}
private static final String _ice_id_name = "ice_id";
private String
_iceI_ice_id(java.util.Map context, boolean explicitCtx)
{
_checkTwowayOnly(_ice_id_name);
return end_ice_id(_iceI_begin_ice_id(context, explicitCtx, true, null));
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id()
{
return _iceI_begin_ice_id(null, false, false, null);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(java.util.Map context)
{
return _iceI_begin_ice_id(context, true, false, null);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(Callback cb)
{
return _iceI_begin_ice_id(null, false, false, cb);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(java.util.Map context, Callback cb)
{
return _iceI_begin_ice_id(context, true, false, cb);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(Callback_Object_ice_id cb)
{
return _iceI_begin_ice_id(null, false, false, cb);
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(java.util.Map context, Callback_Object_ice_id cb)
{
return _iceI_begin_ice_id(context, true, false, cb);
}
private class FunctionalCallback_Object_ice_id extends IceInternal.Functional_TwowayCallbackArg1
{
FunctionalCallback_Object_ice_id(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
super(responseCb, exceptionCb, sentCb);
}
@Override
public final void _iceCompleted(AsyncResult result)
{
ObjectPrxHelperBase._iceI_ice_id_completed(this, result);
}
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_id(null, false, false, new FunctionalCallback_Object_ice_id(responseCb, exceptionCb, null));
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_id(null, false, false, new FunctionalCallback_Object_ice_id(responseCb, exceptionCb, sentCb));
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(java.util.Map context,
IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_id(context, true, false, new FunctionalCallback_Object_ice_id(responseCb, exceptionCb, null));
}
/**
* Returns the Slice type ID of the most-derived interface supported by the target object of this proxy.
*
* @param context The context map for the invocation.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
**/
@Override
public final AsyncResult
begin_ice_id(java.util.Map context,
IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_id(context, true, false,
new FunctionalCallback_Object_ice_id(responseCb, exceptionCb, sentCb));
}
private AsyncResult _iceI_begin_ice_id(java.util.Map context, boolean explicitCtx,
boolean synchronous, IceInternal.CallbackBase cb)
{
_checkAsyncTwowayOnly(_ice_id_name);
IceInternal.OutgoingAsync result = getOutgoingAsync(_ice_id_name, cb);
try
{
result.prepare(_ice_id_name, OperationMode.Nonmutating, context, explicitCtx, synchronous);
result.writeEmptyParams();
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
/**
* Completes the asynchronous ice_id request.
*
* @param r The asynchronous result.
* @return The Slice type ID of the most-derived interface.
**/
@Override
public final String
end_ice_id(AsyncResult r)
{
IceInternal.OutgoingAsync result = IceInternal.OutgoingAsync.check(r, this, _ice_id_name);
try
{
if(!result.waitForResponseOrUserEx())
{
try
{
result.throwUserException();
}
catch(UserException ex)
{
throw new UnknownUserException(ex.ice_id(), ex);
}
}
String ret = null;
InputStream istr = result.startReadParams();
ret = istr.readString();
result.endReadParams();
return ret;
}
finally
{
if(result != null)
{
result.cacheMessageBuffers();
}
}
}
static public void _iceI_ice_id_completed(TwowayCallbackArg1 cb, AsyncResult result)
{
String ret = null;
try
{
ret = result.getProxy().end_ice_id(result);
}
catch(LocalException ex)
{
cb.exception(ex);
return;
}
catch(SystemException ex)
{
cb.exception(ex);
return;
}
cb.response(ret);
}
/**
* Invoke an operation dynamically.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* @param outParams The encoded out-paramaters and return value
* for the operation. The return value follows any out-parameters.
* @return If the operation completed successfully, the return value
* is true
. If the operation raises a user exception,
* the return value is false
; in this case, outParams
* contains the encoded user exception. If the operation raised an
* it throws it directly.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final boolean
ice_invoke(String operation, OperationMode mode, byte[] inParams, ByteSeqHolder outParams)
{
return _iceI_ice_invoke(operation, mode, inParams, outParams, null, false);
}
/**
* Invoke an operation dynamically.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* @param outParams The encoded out-paramaters and return value
* for the operation. The return value follows any out-parameters.
* @param context The context map for the invocation.
* @return If the operation was invoked synchronously (because there
* was no need to queue the request), the return value is true
;
* otherwise, if the invocation was queued, the return value is false
.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final boolean
ice_invoke(String operation, OperationMode mode, byte[] inParams, ByteSeqHolder outParams,
java.util.Map context)
{
return _iceI_ice_invoke(operation, mode, inParams, outParams, context, true);
}
private boolean
_iceI_ice_invoke(String operation, OperationMode mode, byte[] inParams, ByteSeqHolder outParams,
java.util.Map context, boolean explicitCtx)
{
return end_ice_invoke(outParams, _iceI_begin_ice_invoke(operation, mode, inParams, context, explicitCtx, true, null));
}
private static final String _ice_invoke_name = "ice_invoke";
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult
begin_ice_invoke(String operation, OperationMode mode, byte[] inParams)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, null, false, false, null);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param context The context map for the invocation.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult
begin_ice_invoke(String operation, OperationMode mode, byte[] inParams,
java.util.Map context)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, context, true, false, null);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult
begin_ice_invoke(String operation, OperationMode mode, byte[] inParams, Callback cb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, null, false, false, cb);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult
begin_ice_invoke(String operation, OperationMode mode, byte[] inParams, java.util.Map context,
Callback cb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, context, true, false, cb);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult
begin_ice_invoke(String operation, OperationMode mode, byte[] inParams, Callback_Object_ice_invoke cb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, null, false, false, cb);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param context The context map for the invocation.
* @param cb The asynchronous callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult
begin_ice_invoke(String operation, OperationMode mode, byte[] inParams, java.util.Map context,
Callback_Object_ice_invoke cb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, context, true, false, cb);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult begin_ice_invoke(String operation, OperationMode mode, byte[] inParams,
FunctionalCallback_Object_ice_invoke_Response responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, null, false, false, responseCb, exceptionCb, sentCb);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* for the operation. The return value follows any out-parameters.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult begin_ice_invoke(String operation, OperationMode mode, byte[] inParams,
FunctionalCallback_Object_ice_invoke_Response responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, null, false, false, responseCb, exceptionCb, null);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* @param context The context map for the invocation.
* for the operation. The return value follows any out-parameters.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @param sentCb The asynchronous sent callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult begin_ice_invoke(String operation, OperationMode mode, byte[] inParams,
java.util.Map context,
FunctionalCallback_Object_ice_invoke_Response responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, context, true, false, responseCb, exceptionCb, sentCb);
}
/**
* Invokes an operation dynamically and asynchronously.
*
* @param operation The name of the operation to invoke.
* @param mode The operation mode (normal or idempotent).
* @param inParams The encoded in-parameters for the operation.
* @param context The context map for the invocation.
* for the operation. The return value follows any out-parameters.
* @param responseCb The asynchronous response callback object.
* @param exceptionCb The asynchronous exception callback object.
* @return The asynchronous result object.
*
* @see Blobject
* @see OperationMode
**/
@Override
public final AsyncResult begin_ice_invoke(String operation, OperationMode mode, byte[] inParams,
java.util.Map context,
FunctionalCallback_Object_ice_invoke_Response responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_invoke(operation, mode, inParams, context, true, false, responseCb, exceptionCb, null);
}
private AsyncResult _iceI_begin_ice_invoke(String operation, OperationMode mode, byte[] inParams,
java.util.Map context,
boolean explicitCtx,
boolean synchronous,
FunctionalCallback_Object_ice_invoke_Response responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
class CB extends IceInternal.Functional_TwowayCallback implements _Callback_Object_ice_invoke
{
CB(FunctionalCallback_Object_ice_invoke_Response responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
super(responseCb != null, exceptionCb, sentCb);
_responseCb = responseCb;
}
@Override
public void response(boolean ret, byte[] outParams)
{
_responseCb.apply(ret, outParams);
}
@Override
public final void _iceCompleted(AsyncResult result)
{
ObjectPrxHelperBase._iceI_ice_invoke_completed(this, result);
}
FunctionalCallback_Object_ice_invoke_Response _responseCb;
}
return _iceI_begin_ice_invoke(operation, mode, inParams, context, explicitCtx, synchronous,
new CB(responseCb, exceptionCb, sentCb));
}
private AsyncResult
_iceI_begin_ice_invoke(String operation, OperationMode mode, byte[] inParams, java.util.Map context,
boolean explicitCtx, boolean synchronous, IceInternal.CallbackBase cb)
{
IceInternal.OutgoingAsync result = getOutgoingAsync(_ice_invoke_name, cb);
try
{
result.prepare(operation, mode, context, explicitCtx, synchronous);
result.writeParamEncaps(inParams);
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
/**
* Completes the asynchronous ice_invoke request.
*
* @param outParams The encoded out-paramaters and return value.
* @param r The asynchronous result.
* @return If the operation completed successfully, the return value
* is true
. If the operation raises a user exception,
* the return value is false
; in this case, outParams
* contains the encoded user exception. If the operation raises a run-time exception,
* it throws it directly.
**/
@Override
public final boolean
end_ice_invoke(ByteSeqHolder outParams, AsyncResult r)
{
IceInternal.OutgoingAsync result = IceInternal.OutgoingAsync.check(r, this, _ice_invoke_name);
try
{
boolean ok = result.waitForResponseOrUserEx();
if(_reference.getMode() == IceInternal.Reference.ModeTwoway)
{
if(outParams != null)
{
outParams.value = result.readParamEncaps();
}
}
return ok;
}
finally
{
if(result != null)
{
result.cacheMessageBuffers();
}
}
}
public static void _iceI_ice_invoke_completed(_Callback_Object_ice_invoke cb, AsyncResult result)
{
ByteSeqHolder outParams = new ByteSeqHolder();
boolean ret = false;
try
{
ret = result.getProxy().end_ice_invoke(outParams, result);
}
catch(LocalException ex)
{
cb.exception(ex);
return;
}
catch(SystemException ex)
{
cb.exception(ex);
return;
}
cb.response(ret, outParams.value);
}
/**
* Returns the identity embedded in this proxy.
*
* @return The identity of the target object.
**/
@Override
public final Identity
ice_getIdentity()
{
return _reference.getIdentity().clone();
}
/**
* Creates a new proxy that is identical to this proxy, except for the identity.
*
* @param newIdentity The identity for the new proxy.
* @return The proxy with the new identity.
**/
@Override
public final ObjectPrx
ice_identity(Identity newIdentity)
{
if(newIdentity.name.equals(""))
{
throw new IllegalIdentityException();
}
if(newIdentity.equals(_reference.getIdentity()))
{
return this;
}
else
{
ObjectPrxHelperBase proxy = new ObjectPrxHelperBase();
proxy._setup(_reference.changeIdentity(newIdentity));
return proxy;
}
}
/**
* Returns the per-proxy context for this proxy.
*
* @return The per-proxy context. If the proxy does not have a per-proxy (implicit) context, the return value
* is null
.
**/
@Override
public final java.util.Map
ice_getContext()
{
return new java.util.HashMap(_reference.getContext());
}
/**
* Creates a new proxy that is identical to this proxy, except for the per-proxy context.
*
* @param newContext The context for the new proxy.
* @return The proxy with the new per-proxy context.
**/
@Override
public final ObjectPrx
ice_context(java.util.Map newContext)
{
return newInstance(_reference.changeContext(newContext));
}
/**
* Returns the facet for this proxy.
*
* @return The facet for this proxy. If the proxy uses the default facet, the return value is the empty string.
**/
@Override
public final String
ice_getFacet()
{
return _reference.getFacet();
}
/**
* Creates a new proxy that is identical to this proxy, except for the facet.
*
* @param newFacet The facet for the new proxy.
* @return The proxy with the new facet.
**/
@Override
public final ObjectPrx
ice_facet(String newFacet)
{
if(newFacet == null)
{
newFacet = "";
}
if(newFacet.equals(_reference.getFacet()))
{
return this;
}
else
{
ObjectPrxHelperBase proxy = new ObjectPrxHelperBase();
proxy._setup(_reference.changeFacet(newFacet));
return proxy;
}
}
/**
* Returns the adapter ID for this proxy.
*
* @return The adapter ID. If the proxy does not have an adapter ID, the return value is the empty string.
**/
@Override
public final String
ice_getAdapterId()
{
return _reference.getAdapterId();
}
/**
* Creates a new proxy that is identical to this proxy, except for the adapter ID.
*
* @param newAdapterId The adapter ID for the new proxy.
* @return The proxy with the new adapter ID.
**/
@Override
public final ObjectPrx
ice_adapterId(String newAdapterId)
{
if(newAdapterId == null)
{
newAdapterId = "";
}
if(newAdapterId.equals(_reference.getAdapterId()))
{
return this;
}
else
{
return newInstance(_reference.changeAdapterId(newAdapterId));
}
}
/**
* Returns the endpoints used by this proxy.
*
* @return The endpoints used by this proxy.
*
* @see Endpoint
**/
@Override
public final Endpoint[]
ice_getEndpoints()
{
return _reference.getEndpoints().clone();
}
/**
* Creates a new proxy that is identical to this proxy, except for the endpoints.
*
* @param newEndpoints The endpoints for the new proxy.
* @return The proxy with the new endpoints.
**/
@Override
public final ObjectPrx
ice_endpoints(Endpoint[] newEndpoints)
{
if(java.util.Arrays.equals(newEndpoints, _reference.getEndpoints()))
{
return this;
}
else
{
IceInternal.EndpointI[] edpts = new IceInternal.EndpointI[newEndpoints.length];
edpts = java.util.Arrays.asList(newEndpoints).toArray(edpts);
return newInstance(_reference.changeEndpoints(edpts));
}
}
/**
* Returns the locator cache timeout of this proxy.
*
* @return The locator cache timeout value (in seconds).
*
* @see Locator
**/
@Override
public final int
ice_getLocatorCacheTimeout()
{
return _reference.getLocatorCacheTimeout();
}
/**
* Returns the invocation timeout of this proxy.
*
* @return The invocation timeout value (in seconds).
**/
@Override
public final int
ice_getInvocationTimeout()
{
return _reference.getInvocationTimeout();
}
/**
* Returns the connection id of this proxy.
*
* @return The connection id.
*
**/
@Override
public final String
ice_getConnectionId()
{
return _reference.getConnectionId();
}
/**
* Creates a new proxy that is identical to this proxy, except for the locator cache timeout.
*
* @param newTimeout The new locator cache timeout (in seconds).
*
* @see Locator
**/
@Override
public final ObjectPrx
ice_locatorCacheTimeout(int newTimeout)
{
if(newTimeout < -1)
{
throw new IllegalArgumentException("invalid value passed to ice_locatorCacheTimeout: " + newTimeout);
}
if(newTimeout == _reference.getLocatorCacheTimeout())
{
return this;
}
else
{
return newInstance(_reference.changeLocatorCacheTimeout(newTimeout));
}
}
/**
* Creates a new proxy that is identical to this proxy, except for the invocation timeout.
*
* @param newTimeout The new invocation timeout (in seconds).
**/
@Override
public final ObjectPrx
ice_invocationTimeout(int newTimeout)
{
if(newTimeout < 1 && newTimeout != -1 && newTimeout != -2)
{
throw new IllegalArgumentException("invalid value passed to ice_invocationTimeout: " + newTimeout);
}
if(newTimeout == _reference.getInvocationTimeout())
{
return this;
}
else
{
return newInstance(_reference.changeInvocationTimeout(newTimeout));
}
}
/**
* Returns whether this proxy caches connections.
*
* @return true
if this proxy caches connections; false
, otherwise.
**/
@Override
public final boolean
ice_isConnectionCached()
{
return _reference.getCacheConnection();
}
/**
* Creates a new proxy that is identical to this proxy, except for connection caching.
*
* @param newCache true
if the new proxy should cache connections; false
, otherwise.
* @return The new proxy with the specified caching policy.
**/
@Override
public final ObjectPrx
ice_connectionCached(boolean newCache)
{
if(newCache == _reference.getCacheConnection())
{
return this;
}
else
{
return newInstance(_reference.changeCacheConnection(newCache));
}
}
/**
* Returns how this proxy selects endpoints (randomly or ordered).
*
* @return The endpoint selection policy.
*
* @see EndpointSelectionType
**/
@Override
public final Ice.EndpointSelectionType
ice_getEndpointSelection()
{
return _reference.getEndpointSelection();
}
/**
* Creates a new proxy that is identical to this proxy, except for the endpoint selection policy.
*
* @param newType The new endpoint selection policy.
* @return The new proxy with the specified endpoint selection policy.
*
* @see EndpointSelectionType
**/
@Override
public final ObjectPrx
ice_endpointSelection(Ice.EndpointSelectionType newType)
{
if(newType == _reference.getEndpointSelection())
{
return this;
}
else
{
return newInstance(_reference.changeEndpointSelection(newType));
}
}
/**
* Returns whether this proxy uses only secure endpoints.
*
* @return true
if all endpoints for this proxy are secure; false
, otherwise.
**/
@Override
public final boolean
ice_isSecure()
{
return _reference.getSecure();
}
/**
* Creates a new proxy that is identical to this proxy, except for its endpoints.
*
* @param b If b
is true
, only endpoints that use a secure transport are
* retained for the new proxy. If b
is false, the returned proxy is identical to this proxy.
* @return The new proxy with possible different endpoints.k
**/
@Override
public final ObjectPrx
ice_secure(boolean b)
{
if(b == _reference.getSecure())
{
return this;
}
else
{
return newInstance(_reference.changeSecure(b));
}
}
/**
* Creates a new proxy that is identical to this proxy, except for the encoding used to marshal
* parameters.
*
* @param e The encoding version to use to marshal requests parameters.
* @return The new proxy with the specified encoding version.
**/
@Override
public final ObjectPrx
ice_encodingVersion(Ice.EncodingVersion e)
{
if(e.equals(_reference.getEncoding()))
{
return this;
}
else
{
return newInstance(_reference.changeEncoding(e));
}
}
/**
* Returns the encoding version used to marshal requests parameters.
*
* @return The encoding version.
**/
@Override
public final Ice.EncodingVersion
ice_getEncodingVersion()
{
return _reference.getEncoding().clone();
}
/**
* Returns whether this proxy prefers secure endpoints.
*
* @return true
if the proxy always attempts to invoke via secure endpoints before it
* attempts to use insecure endpoints; false
, otherwise;
**/
@Override
public final boolean
ice_isPreferSecure()
{
return _reference.getPreferSecure();
}
/**
* Creates a new proxy that is identical to this proxy, except for its endpoint selection policy.
*
* @param b If b
is true
, the new proxy will use secure endpoints for invocations
* and only use insecure endpoints if an invocation cannot be made via secure endpoints. If b
is
* false
, the proxy prefers insecure endpoints to secure ones.
* @return The new proxy with the new endpoint selection policy.
**/
@Override
public final ObjectPrx
ice_preferSecure(boolean b)
{
if(b == _reference.getPreferSecure())
{
return this;
}
else
{
return newInstance(_reference.changePreferSecure(b));
}
}
/**
* Returns the router for this proxy.
*
* @return The router for the proxy. If no router is configured for the proxy, the return value
* is null
.
**/
@Override
public final Ice.RouterPrx
ice_getRouter()
{
IceInternal.RouterInfo ri = _reference.getRouterInfo();
return ri != null ? ri.getRouter() : null;
}
/**
* Creates a new proxy that is identical to this proxy, except for the router.
*
* @param router The router for the new proxy.
* @return The new proxy with the specified router.
**/
@Override
public final ObjectPrx
ice_router(Ice.RouterPrx router)
{
IceInternal.Reference ref = _reference.changeRouter(router);
if(ref.equals(_reference))
{
return this;
}
else
{
return newInstance(ref);
}
}
/**
* Returns the locator for this proxy.
*
* @return The locator for this proxy. If no locator is configured, the return value is null
.
**/
@Override
public final Ice.LocatorPrx
ice_getLocator()
{
IceInternal.LocatorInfo ri = _reference.getLocatorInfo();
return ri != null ? ri.getLocator() : null;
}
/**
* Creates a new proxy that is identical to this proxy, except for the locator.
*
* @param locator The locator for the new proxy.
* @return The new proxy with the specified locator.
**/
@Override
public final ObjectPrx
ice_locator(Ice.LocatorPrx locator)
{
IceInternal.Reference ref = _reference.changeLocator(locator);
if(ref.equals(_reference))
{
return this;
}
else
{
return newInstance(ref);
}
}
/**
* Returns whether this proxy uses collocation optimization.
*
* @return true
if the proxy uses collocation optimization; false
, otherwise.
**/
@Override
public final boolean
ice_isCollocationOptimized()
{
return _reference.getCollocationOptimized();
}
/**
* Creates a new proxy that is identical to this proxy, except for collocation optimization.
*
* @param b true
if the new proxy enables collocation optimization; false
, otherwise.
* @return The new proxy the specified collocation optimization.
**/
@Override
public final ObjectPrx
ice_collocationOptimized(boolean b)
{
if(b == _reference.getCollocationOptimized())
{
return this;
}
else
{
return newInstance(_reference.changeCollocationOptimized(b));
}
}
/**
* Creates a new proxy that is identical to this proxy, but uses twoway invocations.
*
* @return A new proxy that uses twoway invocations.
**/
@Override
public final ObjectPrx
ice_twoway()
{
if(_reference.getMode() == IceInternal.Reference.ModeTwoway)
{
return this;
}
else
{
return newInstance(_reference.changeMode(IceInternal.Reference.ModeTwoway));
}
}
/**
* Returns whether this proxy uses twoway invocations.
* @return true
if this proxy uses twoway invocations; false
, otherwise.
**/
@Override
public final boolean
ice_isTwoway()
{
return _reference.getMode() == IceInternal.Reference.ModeTwoway;
}
/**
* Creates a new proxy that is identical to this proxy, but uses oneway invocations.
*
* @return A new proxy that uses oneway invocations.
**/
@Override
public final ObjectPrx
ice_oneway()
{
if(_reference.getMode() == IceInternal.Reference.ModeOneway)
{
return this;
}
else
{
return newInstance(_reference.changeMode(IceInternal.Reference.ModeOneway));
}
}
/**
* Returns whether this proxy uses oneway invocations.
* @return true
if this proxy uses oneway invocations; false
, otherwise.
**/
@Override
public final boolean
ice_isOneway()
{
return _reference.getMode() == IceInternal.Reference.ModeOneway;
}
/**
* Creates a new proxy that is identical to this proxy, but uses batch oneway invocations.
*
* @return A new proxy that uses batch oneway invocations.
**/
@Override
public final ObjectPrx
ice_batchOneway()
{
if(_reference.getMode() == IceInternal.Reference.ModeBatchOneway)
{
return this;
}
else
{
return newInstance(_reference.changeMode(IceInternal.Reference.ModeBatchOneway));
}
}
/**
* Returns whether this proxy uses batch oneway invocations.
* @return true
if this proxy uses batch oneway invocations; false
, otherwise.
**/
@Override
public final boolean
ice_isBatchOneway()
{
return _reference.getMode() == IceInternal.Reference.ModeBatchOneway;
}
/**
* Creates a new proxy that is identical to this proxy, but uses datagram invocations.
*
* @return A new proxy that uses datagram invocations.
**/
@Override
public final ObjectPrx
ice_datagram()
{
if(_reference.getMode() == IceInternal.Reference.ModeDatagram)
{
return this;
}
else
{
return newInstance(_reference.changeMode(IceInternal.Reference.ModeDatagram));
}
}
/**
* Returns whether this proxy uses datagram invocations.
* @return true
if this proxy uses datagram invocations; false
, otherwise.
**/
@Override
public final boolean
ice_isDatagram()
{
return _reference.getMode() == IceInternal.Reference.ModeDatagram;
}
/**
* Creates a new proxy that is identical to this proxy, but uses batch datagram invocations.
*
* @return A new proxy that uses batch datagram invocations.
**/
@Override
public final ObjectPrx
ice_batchDatagram()
{
if(_reference.getMode() == IceInternal.Reference.ModeBatchDatagram)
{
return this;
}
else
{
return newInstance(_reference.changeMode(IceInternal.Reference.ModeBatchDatagram));
}
}
/**
* Returns whether this proxy uses batch datagram invocations.
* @return true
if this proxy uses batch datagram invocations; false
, otherwise.
**/
@Override
public final boolean
ice_isBatchDatagram()
{
return _reference.getMode() == IceInternal.Reference.ModeBatchDatagram;
}
/**
* Creates a new proxy that is identical to this proxy, except for compression.
*
* @param co true
enables compression for the new proxy; false
disables compression.
* @return A new proxy with the specified compression setting.
**/
@Override
public final ObjectPrx
ice_compress(boolean co)
{
IceInternal.Reference ref = _reference.changeCompress(co);
if(ref.equals(_reference))
{
return this;
}
else
{
return newInstance(ref);
}
}
/**
* Obtains the compression override setting of this proxy.
*
* @return The compression override setting. If no optional value is present, no override is
* set. Otherwise, true if compression is enabled, false otherwise.
*/
@Override
public final Ice.BooleanOptional
ice_getCompress()
{
return _reference.getCompress();
}
/**
* Creates a new proxy that is identical to this proxy, except for its timeout setting.
*
* @param t The timeout for the new proxy in milliseconds.
* @return A new proxy with the specified timeout.
**/
@Override
public final ObjectPrx
ice_timeout(int t)
{
if(t < 1 && t != -1)
{
throw new IllegalArgumentException("invalid value passed to ice_timeout: " + t);
}
IceInternal.Reference ref = _reference.changeTimeout(t);
if(ref.equals(_reference))
{
return this;
}
else
{
return newInstance(ref);
}
}
/**
* Obtains the timeout override of this proxy.
*
* @return The timeout override. If no optional value is present, no override is set. Otherwise,
* returns the timeout override value.
*/
@Override
public final Ice.IntOptional
ice_getTimeout()
{
return _reference.getTimeout();
}
/**
* Creates a new proxy that is identical to this proxy, except for its connection ID.
*
* @param id The connection ID for the new proxy. An empty string removes the
* connection ID.
*
* @return A new proxy with the specified connection ID.
**/
@Override
public final ObjectPrx
ice_connectionId(String id)
{
IceInternal.Reference ref = _reference.changeConnectionId(id);
if(ref.equals(_reference))
{
return this;
}
else
{
return newInstance(ref);
}
}
/**
* Returns a proxy that is identical to this proxy, except it's a fixed proxy bound
* the given connection.
*
* @param connection The fixed proxy connection.
* @return A fixed proxy bound to the given connection.
*/
@Override
public final ObjectPrx
ice_fixed(Ice.Connection connection)
{
if(connection == null)
{
throw new IllegalArgumentException("invalid null connection passed to ice_fixed");
}
if(!(connection instanceof Ice.ConnectionI))
{
throw new IllegalArgumentException("invalid connection passed to ice_fixed");
}
IceInternal.Reference ref = _reference.changeConnection((Ice.ConnectionI)connection);
if(ref.equals(_reference))
{
return this;
}
else
{
return newInstance(ref);
}
}
/**
* Returns whether this proxy is a fixed proxy.
*
* @return true
if this is a fixed proxy, false
otherwise.
**/
@Override
public final boolean ice_isFixed()
{
return _reference instanceof IceInternal.FixedReference;
}
/**
* Returns the {@link Connection} for this proxy. If the proxy does not yet have an established connection,
* it first attempts to create a connection.
*
* @return The {@link Connection} for this proxy.
* @throws CollocationOptimizationException If the proxy uses collocation optimization and denotes a
* collocated object.
*
* @see Connection
**/
@Override
public final Connection
ice_getConnection()
{
return end_ice_getConnection(begin_ice_getConnection());
}
/**
* Asynchronously gets the connection for this proxy. The call does not block.
*
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_getConnection()
{
return _iceI_begin_ice_getConnectionInternal(null);
}
/**
* Asynchronously gets the connection for this proxy. The call does not block.
*
* @param cb The callback object to notify the application when the flush is complete.
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_getConnection(Callback cb)
{
return _iceI_begin_ice_getConnectionInternal(cb);
}
/**
* Asynchronously gets the connection for this proxy. The call does not block.
*
* @param cb The callback object to notify the application when the flush is complete.
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_getConnection(Callback_Object_ice_getConnection cb)
{
return _iceI_begin_ice_getConnectionInternal(cb);
}
private class FunctionalCallback_Object_ice_getConnection
extends IceInternal.Functional_TwowayCallbackArg1
{
FunctionalCallback_Object_ice_getConnection(
IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
super(responseCb, exceptionCb, null);
}
@Override
public final void _iceCompleted(AsyncResult result)
{
ObjectPrxHelperBase._iceI_ice_getConnection_completed(this, result);
}
}
/**
* Asynchronously gets the connection for this proxy. The call does not block.
*
* @param responseCb The callback object to notify the application when the there is a response available.
* @param exceptionCb The callback object to notify the application when the there is an exception getting
* connection.
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_getConnection(IceInternal.Functional_GenericCallback1 responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb)
{
return _iceI_begin_ice_getConnectionInternal(
new FunctionalCallback_Object_ice_getConnection(responseCb, exceptionCb));
}
private static final String _ice_getConnection_name = "ice_getConnection";
private AsyncResult
_iceI_begin_ice_getConnectionInternal(IceInternal.CallbackBase cb)
{
IceInternal.ProxyGetConnection result = new IceInternal.ProxyGetConnection(this, _ice_getConnection_name, cb);
try
{
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
@Override
public Ice.Connection
end_ice_getConnection(AsyncResult r)
{
IceInternal.ProxyGetConnection result = IceInternal.ProxyGetConnection.check(r, this, _ice_getConnection_name);
result.waitForResponseOrUserEx();
return result.getConnection();
}
static public void _iceI_ice_getConnection_completed(TwowayCallbackArg1 cb, AsyncResult result)
{
Ice.Connection ret = null;
try
{
ret = result.getProxy().end_ice_getConnection(result);
}
catch(LocalException ex)
{
cb.exception(ex);
return;
}
catch(SystemException ex)
{
cb.exception(ex);
return;
}
cb.response(ret);
}
/**
* Returns the cached {@link Connection} for this proxy. If the proxy does not yet have an established
* connection, it does not attempt to create a connection.
*
* @return The cached {@link Connection} for this proxy (null
if the proxy does not have
* an established connection).
* @throws CollocationOptimizationException If the proxy uses collocation optimization and denotes a
* collocated object.
*
* @see Connection
**/
@Override
public final Connection
ice_getCachedConnection()
{
IceInternal.RequestHandler handler = null;
synchronized(this)
{
handler = _requestHandler;
}
if(handler != null)
{
try
{
return handler.getConnection();
}
catch(LocalException ex)
{
}
}
return null;
}
/**
* Flushes any pending batched requests for this communicator. The call blocks until the flush is complete.
**/
@Override
public void
ice_flushBatchRequests()
{
end_ice_flushBatchRequests(begin_ice_flushBatchRequests());
}
/**
* Asynchronously flushes any pending batched requests for this communicator. The call does not block.
*
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_flushBatchRequests()
{
return _iceI_begin_ice_flushBatchRequestsInternal(null);
}
/**
* Asynchronously flushes any pending batched requests for this communicator. The call does not block.
*
* @param cb The callback object to notify the application when the flush is complete.
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_flushBatchRequests(Callback cb)
{
return _iceI_begin_ice_flushBatchRequestsInternal(cb);
}
/**
* Asynchronously flushes any pending batched requests for this communicator. The call does not block.
*
* @param cb The callback object to notify the application when the flush is complete.
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_flushBatchRequests(Callback_Object_ice_flushBatchRequests cb)
{
return _iceI_begin_ice_flushBatchRequestsInternal(cb);
}
/**
* Asynchronously flushes any pending batched requests for this communicator. The call does not block.
*
* @param exceptionCb The callback object to notify the application when the there is an exception flushing
* the requests.
* @param sentCb The callback object to notify the application when the flush is complete.
* @return The asynchronous result object.
**/
@Override
public AsyncResult
begin_ice_flushBatchRequests(IceInternal.Functional_VoidCallback responseCb,
IceInternal.Functional_GenericCallback1 exceptionCb,
IceInternal.Functional_BoolCallback sentCb)
{
return _iceI_begin_ice_flushBatchRequestsInternal(
new IceInternal.Functional_OnewayCallback(responseCb, exceptionCb, sentCb));
}
private static final String _ice_flushBatchRequests_name = "ice_flushBatchRequests";
private AsyncResult
_iceI_begin_ice_flushBatchRequestsInternal(IceInternal.CallbackBase cb)
{
IceInternal.ProxyFlushBatch result = new IceInternal.ProxyFlushBatch(this, _ice_flushBatchRequests_name, cb);
try
{
result.invoke();
}
catch(Exception ex)
{
result.abort(ex);
}
return result;
}
@Override
public void
end_ice_flushBatchRequests(AsyncResult r)
{
IceInternal.ProxyFlushBatch result = IceInternal.ProxyFlushBatch.check(r, this, _ice_flushBatchRequests_name);
result.waitForResponseOrUserEx();
}
/**
* Returns whether this proxy equals the passed object. Two proxies are equal if they are equal in all respects,
* that is, if their object identity, endpoints timeout settings, and so on are all equal.
*
* @param r The object to compare this proxy with.
* @return true
if this proxy is equal to r
; false
, otherwise.
**/
@Override
public final boolean
equals(java.lang.Object r)
{
if(this == r)
{
return true;
}
if(r instanceof ObjectPrxHelperBase)
{
return _reference.equals(((ObjectPrxHelperBase)r)._reference);
}
return false;
}
public void _write(OutputStream os)
{
_reference.getIdentity().ice_writeMembers(os);
_reference.streamWrite(os);
}
public final IceInternal.Reference
_getReference()
{
return _reference;
}
public final void
_copyFrom(ObjectPrx from)
{
synchronized(from)
{
ObjectPrxHelperBase h = (ObjectPrxHelperBase)from;
_reference = h._reference;
_requestHandler = h._requestHandler;
}
}
public final int
_handleException(Exception ex, IceInternal.RequestHandler handler, OperationMode mode, boolean sent,
Holder interval, int cnt)
{
_updateRequestHandler(handler, null); // Clear the request handler
//
// We only retry local exception, system exceptions aren't retried.
//
// A CloseConnectionException indicates graceful server shutdown, and is therefore
// always repeatable without violating "at-most-once". That's because by sending a
// close connection message, the server guarantees that all outstanding requests
// can safely be repeated.
//
// An ObjectNotExistException can always be retried as well without violating
// "at-most-once" (see the implementation of the checkRetryAfterException method
// of the ProxyFactory class for the reasons why it can be useful).
//
// If the request didn't get sent or if it's non-mutating or idempotent it can
// also always be retried if the retry count isn't reached.
//
if(ex instanceof LocalException && (!sent ||
mode == OperationMode.Nonmutating || mode == OperationMode.Idempotent ||
ex instanceof CloseConnectionException ||
ex instanceof ObjectNotExistException))
{
try
{
return _reference.getInstance().proxyFactory().checkRetryAfterException((LocalException)ex,
_reference,
interval,
cnt);
}
catch(CommunicatorDestroyedException exc)
{
//
// The communicator is already destroyed, so we cannot retry.
//
throw ex;
}
}
else
{
throw ex; // Retry could break at-most-once semantics, don't retry.
}
}
public final void
_checkTwowayOnly(String name)
{
//
// No mutex lock necessary, there is nothing mutable in this
// operation.
//
if(!ice_isTwoway())
{
TwowayOnlyException ex = new TwowayOnlyException();
ex.operation = name;
throw ex;
}
}
public final void
_checkAsyncTwowayOnly(String name)
{
//
// No mutex lock necessary, there is nothing mutable in this
// operation.
//
if(!ice_isTwoway())
{
throw new java.lang.IllegalArgumentException("`" + name + "' can only be called with a twoway proxy");
}
}
public final void
_end(AsyncResult r, String operation)
{
IceInternal.ProxyOutgoingAsyncBase result = IceInternal.ProxyOutgoingAsyncBase.check(r, this, operation);
try
{
boolean ok = result.waitForResponseOrUserEx();
if(_reference.getMode() == IceInternal.Reference.ModeTwoway)
{
IceInternal.OutgoingAsync outAsync = (IceInternal.OutgoingAsync)result;
if(!ok)
{
try
{
outAsync.throwUserException();
}
catch(UserException ex)
{
throw new UnknownUserException(ex.ice_id(), ex);
}
}
outAsync.readEmptyParams();
}
}
finally
{
if(result != null)
{
result.cacheMessageBuffers();
}
}
}
public final IceInternal.RequestHandler
_getRequestHandler()
{
if(_reference.getCacheConnection())
{
synchronized(this)
{
if(_requestHandler != null)
{
return _requestHandler;
}
}
}
return _reference.getRequestHandler(this);
}
synchronized public final IceInternal.BatchRequestQueue
_getBatchRequestQueue()
{
if(_batchRequestQueue == null)
{
_batchRequestQueue = _reference.getBatchRequestQueue();
}
return _batchRequestQueue;
}
public IceInternal.RequestHandler
_setRequestHandler(IceInternal.RequestHandler handler)
{
if(_reference.getCacheConnection())
{
synchronized(this)
{
if(_requestHandler == null)
{
_requestHandler = handler;
}
return _requestHandler;
}
}
return handler;
}
public void
_updateRequestHandler(IceInternal.RequestHandler previous, IceInternal.RequestHandler handler)
{
if(_reference.getCacheConnection() && previous != null)
{
synchronized(this)
{
if(_requestHandler != null && _requestHandler != handler)
{
//
// Update the request handler only if "previous" is the same
// as the current request handler. This is called after
// connection binding by the connect request handler. We only
// replace the request handler if the current handler is the
// connect request handler.
//
_requestHandler = _requestHandler.update(previous, handler);
}
}
}
}
public void
cacheMessageBuffers(InputStream is, OutputStream os)
{
synchronized(this)
{
if(_streamCache == null)
{
_streamCache = new LinkedList();
}
_streamCache.add(new StreamCacheEntry(is, os));
}
}
//
// Only for use by IceInternal.ProxyFactory
//
public final void
_setup(IceInternal.Reference ref)
{
//
// No need to synchronize, as this operation is only called
// upon initial initialization.
//
assert(_reference == null);
assert(_requestHandler == null);
_reference = ref;
}
protected static T checkedCastImpl(Ice.ObjectPrx obj, String id, Class proxyCls, Class> helperCls)
{
return checkedCastImpl(obj, null, false, null, false, id, proxyCls, helperCls);
}
protected static T checkedCastImpl(Ice.ObjectPrx obj, java.util.Map ctx, String id,
Class proxyCls, Class> helperCls)
{
return checkedCastImpl(obj, ctx, true, null, false, id, proxyCls, helperCls);
}
protected static T checkedCastImpl(Ice.ObjectPrx obj, String facet, String id, Class proxyCls,
Class> helperCls)
{
return checkedCastImpl(obj, null, false, facet, true, id, proxyCls, helperCls);
}
protected static T checkedCastImpl(Ice.ObjectPrx obj, String facet, java.util.Map ctx,
String id, Class proxyCls, Class> helperCls)
{
return checkedCastImpl(obj, ctx, true, facet, true, id, proxyCls, helperCls);
}
protected static T checkedCastImpl(Ice.ObjectPrx obj, java.util.Map ctx, boolean explicitCtx,
String facet, boolean explicitFacet, String id, Class proxyCls,
Class> helperCls)
{
T d = null;
if(obj != null)
{
if(explicitFacet)
{
obj = obj.ice_facet(facet);
}
if(proxyCls.isInstance(obj))
{
d = proxyCls.cast(obj);
}
else
{
try
{
final boolean b = explicitCtx ? obj.ice_isA(id, ctx) : obj.ice_isA(id);
if(b)
{
ObjectPrxHelperBase h = null;
try
{
h = ObjectPrxHelperBase.class.cast(helperCls.getDeclaredConstructor().newInstance());
}
catch(NoSuchMethodException ex)
{
throw new SyscallException(ex);
}
catch(java.lang.reflect.InvocationTargetException ex)
{
throw new SyscallException(ex);
}
catch(InstantiationException ex)
{
throw new SyscallException(ex);
}
catch(IllegalAccessException ex)
{
throw new SyscallException(ex);
}
h._copyFrom(obj);
d = proxyCls.cast(h);
}
}
catch(FacetNotExistException ex)
{
}
}
}
return d;
}
protected static T uncheckedCastImpl(Ice.ObjectPrx obj, Class proxyCls, Class> helperCls)
{
return uncheckedCastImpl(obj, null, false, proxyCls, helperCls);
}
protected static T uncheckedCastImpl(Ice.ObjectPrx obj, String facet, Class proxyCls, Class> helperCls)
{
return uncheckedCastImpl(obj, facet, true, proxyCls, helperCls);
}
protected static T uncheckedCastImpl(Ice.ObjectPrx obj, String facet, boolean explicitFacet, Class proxyCls,
Class> helperCls)
{
T d = null;
if(obj != null)
{
try
{
if(explicitFacet)
{
ObjectPrxHelperBase h = ObjectPrxHelperBase.class.cast(helperCls.getDeclaredConstructor().newInstance());
h._copyFrom(obj.ice_facet(facet));
d = proxyCls.cast(h);
}
else
{
if(proxyCls.isInstance(obj))
{
d = proxyCls.cast(obj);
}
else
{
ObjectPrxHelperBase h = ObjectPrxHelperBase.class.cast(helperCls.getDeclaredConstructor().newInstance());
h._copyFrom(obj);
d = proxyCls.cast(h);
}
}
}
catch(NoSuchMethodException ex)
{
throw new SyscallException(ex);
}
catch(java.lang.reflect.InvocationTargetException ex)
{
throw new SyscallException(ex);
}
catch(InstantiationException ex)
{
throw new SyscallException(ex);
}
catch(IllegalAccessException ex)
{
throw new SyscallException(ex);
}
}
return d;
}
protected IceInternal.OutgoingAsync
getOutgoingAsync(String operation, IceInternal.CallbackBase cb)
{
StreamCacheEntry cacheEntry = null;
if(_reference.getInstance().cacheMessageBuffers() > 0)
{
synchronized(this)
{
if(_streamCache != null && !_streamCache.isEmpty())
{
cacheEntry = _streamCache.remove(0);
}
}
}
if(cacheEntry == null)
{
return new IceInternal.OutgoingAsync(this, operation, cb);
}
else
{
return new IceInternal.OutgoingAsync(this, operation, cb, cacheEntry.is, cacheEntry.os);
}
}
private ObjectPrxHelperBase
newInstance(IceInternal.Reference ref)
{
try
{
ObjectPrxHelperBase proxy = getClass().getDeclaredConstructor().newInstance();
proxy._setup(ref);
return proxy;
}
catch(NoSuchMethodException e)
{
//
// Impossible
//
assert false;
return null;
}
catch(java.lang.reflect.InvocationTargetException e)
{
//
// Impossible
//
assert false;
return null;
}
catch(InstantiationException e)
{
//
// Impossible
//
assert false;
return null;
}
catch(IllegalAccessException e)
{
//
// Impossible
//
assert false;
return null;
}
}
private void
writeObject(java.io.ObjectOutputStream out)
throws java.io.IOException
{
out.writeUTF(toString());
}
private void
readObject(java.io.ObjectInputStream in)
throws java.io.IOException, ClassNotFoundException
{
String s = in.readUTF();
try
{
Communicator communicator = ((Ice.ObjectInputStream)in).getCommunicator();
if(communicator == null)
{
throw new java.io.IOException("Cannot deserialize proxy: no communicator provided");
}
ObjectPrxHelperBase proxy = (ObjectPrxHelperBase)communicator.stringToProxy(s);
_reference = proxy._reference;
assert(proxy._requestHandler == null);
}
catch(ClassCastException ex)
{
java.io.IOException e =
new java.io.IOException("Cannot deserialize proxy: Ice.ObjectInputStream not found");
e.initCause(ex);
throw e;
}
catch(LocalException ex)
{
java.io.IOException e = new java.io.IOException("Failure occurred while deserializing proxy");
e.initCause(ex);
throw e;
}
}
private static class StreamCacheEntry
{
StreamCacheEntry(InputStream is, OutputStream os)
{
this.is = is;
this.os = os;
}
InputStream is;
OutputStream os;
}
private transient IceInternal.Reference _reference;
private transient IceInternal.RequestHandler _requestHandler;
private transient IceInternal.BatchRequestQueue _batchRequestQueue;
private transient List _streamCache;
public static final long serialVersionUID = 0L;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy