From 47f800495093fd7679a315e2d730fea22f6135b7 Mon Sep 17 00:00:00 2001 From: Benoit Foucher Date: Tue, 27 Nov 2007 11:58:35 +0100 Subject: - Added support for non-blocking AMI/batch requests, connection creation. - Added support for AMI oneway requests. - Changed collocation optimization to not perform any DNS lookups. --- cpp/src/Ice/ConnectionRequestHandler.cpp | 107 +++++++++++++++++++++++++++++++ 1 file changed, 107 insertions(+) create mode 100644 cpp/src/Ice/ConnectionRequestHandler.cpp (limited to 'cpp/src/Ice/ConnectionRequestHandler.cpp') diff --git a/cpp/src/Ice/ConnectionRequestHandler.cpp b/cpp/src/Ice/ConnectionRequestHandler.cpp new file mode 100644 index 00000000000..dffab29e69b --- /dev/null +++ b/cpp/src/Ice/ConnectionRequestHandler.cpp @@ -0,0 +1,107 @@ +// ********************************************************************** +// +// Copyright (c) 2003-2007 ZeroC, Inc. All rights reserved. +// +// This copy of Ice is licensed to you under the terms described in the +// ICE_LICENSE file included in this distribution. +// +// ********************************************************************** + +#include +#include +#include +#include +#include +#include +#include + +using namespace std; +using namespace IceInternal; + +ConnectionRequestHandler::ConnectionRequestHandler(const ReferencePtr& reference, const Ice::ObjectPrx& proxy) : + RequestHandler(reference), + _response(reference->getMode() == Reference::ModeTwoway) +{ + _connection = _reference->getConnection(_compress); + RouterInfoPtr ri = reference->getRouterInfo(); + if(ri) + { + ri->addProxy(proxy); + } +} + +ConnectionRequestHandler::ConnectionRequestHandler(const ReferencePtr& reference, + const Ice::ConnectionIPtr& connection, + bool compress) : + RequestHandler(reference), + _response(reference->getMode() == Reference::ModeTwoway), + _connection(connection), + _compress(compress) +{ +} + +void +ConnectionRequestHandler::prepareBatchRequest(BasicStream* out) +{ + _connection->prepareBatchRequest(out); +} + +void +ConnectionRequestHandler::finishBatchRequest(BasicStream* out) +{ + _connection->finishBatchRequest(out, _compress); +} + +void +ConnectionRequestHandler::abortBatchRequest() +{ + _connection->abortBatchRequest(); +} + +Ice::ConnectionI* +ConnectionRequestHandler::sendRequest(Outgoing* out) +{ + return (!_connection->sendRequest(out, _compress, _response) || _response) ? _connection.get() : 0; +} + +void +ConnectionRequestHandler::sendAsyncRequest(const OutgoingAsyncPtr& out) +{ + try + { + _connection->sendAsyncRequest(out, _compress, _response); + } + catch(const LocalExceptionWrapper& ex) + { + out->__finished(ex); + } + catch(const Ice::LocalException& ex) + { + out->__finished(ex); + } +} + +bool +ConnectionRequestHandler::flushBatchRequests(BatchOutgoing* out) +{ + return _connection->flushBatchRequests(out); +} + +void +ConnectionRequestHandler::flushAsyncBatchRequests(const BatchOutgoingAsyncPtr& out) +{ + try + { + _connection->flushAsyncBatchRequests(out); + } + catch(const Ice::LocalException& ex) + { + out->__finished(ex); + } +} + +Ice::ConnectionIPtr +ConnectionRequestHandler::getConnection(bool wait) +{ + return _connection; +} -- cgit v1.2.3