diff options
author | Benoit Foucher <benoit@zeroc.com> | 2007-11-27 11:58:35 +0100 |
---|---|---|
committer | Benoit Foucher <benoit@zeroc.com> | 2007-11-27 11:58:35 +0100 |
commit | 47f800495093fd7679a315e2d730fea22f6135b7 (patch) | |
tree | a7b8d3488f3841367dd03d10cae293f36fd10481 /cpp/src/Ice/RequestHandler.h | |
parent | Fixed SystemException to no longer derive from LocalException (diff) | |
download | ice-47f800495093fd7679a315e2d730fea22f6135b7.tar.bz2 ice-47f800495093fd7679a315e2d730fea22f6135b7.tar.xz ice-47f800495093fd7679a315e2d730fea22f6135b7.zip |
- 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.
Diffstat (limited to 'cpp/src/Ice/RequestHandler.h')
-rw-r--r-- | cpp/src/Ice/RequestHandler.h | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/cpp/src/Ice/RequestHandler.h b/cpp/src/Ice/RequestHandler.h new file mode 100644 index 00000000000..1b22794930c --- /dev/null +++ b/cpp/src/Ice/RequestHandler.h @@ -0,0 +1,55 @@ +// ********************************************************************** +// +// 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. +// +// ********************************************************************** + +#ifndef ICE_REQUEST_HANDLER_H +#define ICE_REQUEST_HANDLER_H + +#include <IceUtil/Shared.h> + +#include <Ice/RequestHandlerF.h> +#include <Ice/ReferenceF.h> +#include <Ice/OutgoingAsyncF.h> +#include <Ice/ConnectionIF.h> + +namespace IceInternal +{ + +class BasicStream; +class Outgoing; +class BatchOutgoing; + +class RequestHandler : virtual public ::IceUtil::Shared +{ +public: + + virtual ~RequestHandler(); + + virtual void prepareBatchRequest(BasicStream*) = 0; + virtual void finishBatchRequest(BasicStream*) = 0; + virtual void abortBatchRequest() = 0; + + virtual Ice::ConnectionI* sendRequest(Outgoing*) = 0; + virtual void sendAsyncRequest(const OutgoingAsyncPtr&) = 0; + + virtual bool flushBatchRequests(BatchOutgoing*) = 0; + virtual void flushAsyncBatchRequests(const BatchOutgoingAsyncPtr&) = 0; + + const ReferencePtr& getReference() const { return _reference; } // Inlined for performances. + + virtual Ice::ConnectionIPtr getConnection(bool) = 0; + +protected: + + RequestHandler(const ReferencePtr&); + const ReferencePtr _reference; +}; + +} + +#endif |