// ********************************************************************** // // Copyright (c) 2003-2010 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_OUTGOING_H #define ICE_OUTGOING_H #include #include #include #include #include #include #include #include #include namespace Ice { class LocalException; } namespace IceInternal { // // An exception wrapper, which is used for local exceptions that // require special retry considerations. // class ICE_API LocalExceptionWrapper { public: LocalExceptionWrapper(const Ice::LocalException&, bool); LocalExceptionWrapper(const LocalExceptionWrapper&); const Ice::LocalException* get() const; // // If true, always repeat the request. Don't take retry settings // or "at-most-once" guarantees into account. // // If false, only repeat the request if the retry settings allow // to do so, and if "at-most-once" does not need to be guaranteed. // bool retry() const; static void throwWrapper(const ::std::exception&); private: const LocalExceptionWrapper& operator=(const LocalExceptionWrapper&); std::auto_ptr _ex; bool _retry; }; class ICE_API OutgoingMessageCallback : private IceUtil::noncopyable { public: virtual ~OutgoingMessageCallback() { } virtual void sent(bool) = 0; virtual void finished(const Ice::LocalException&, bool) = 0; }; class ICE_API Outgoing : public OutgoingMessageCallback { public: Outgoing(RequestHandler*, const std::string&, Ice::OperationMode, const Ice::Context*); bool invoke(); // Returns true if ok, false if user exception. void abort(const Ice::LocalException&); virtual void sent(bool); virtual void finished(BasicStream&); void finished(const Ice::LocalException&, bool); // Inlined for speed optimization. BasicStream* is() { return &_is; } BasicStream* os() { return &_os; } void throwUserException(); private: // // Optimization. The request handler and the reference may not be // deleted while a stack-allocated Outgoing still holds it. // RequestHandler* _handler; std::auto_ptr _exception; enum { StateUnsent, StateInProgress, StateOK, StateUserException, StateLocalException, StateFailed } _state; BasicStream _is; BasicStream _os; bool _sent; // // NOTE: we use an attribute for the monitor instead of inheriting // from the monitor template. Otherwise, the template would be // exported from the DLL on Windows and could cause linker errors // because of multiple definition of IceUtil::Monitor, // see bug 1541. // IceUtil::Monitor _monitor; }; class BatchOutgoing : public OutgoingMessageCallback { public: BatchOutgoing(RequestHandler*); BatchOutgoing(Ice::ConnectionI*, Instance*); void invoke(); virtual void sent(bool); virtual void finished(const Ice::LocalException&, bool); BasicStream* os() { return &_os; } private: IceUtil::Monitor _monitor; RequestHandler* _handler; Ice::ConnectionI* _connection; bool _sent; std::auto_ptr _exception; BasicStream _os; }; } #endif