File: DispatchInterceptor.h

package info (click to toggle)
zeroc-ice 3.7.8-2.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 82,840 kB
  • sloc: cpp: 360,403; java: 226,078; cs: 102,261; javascript: 35,028; python: 28,875; objc: 27,050; php: 7,543; ruby: 7,190; yacc: 2,946; ansic: 2,490; xml: 1,599; lex: 1,241; makefile: 465; sh: 52
file content (41 lines) | stat: -rw-r--r-- 1,174 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
//
// Copyright (c) ZeroC, Inc. All rights reserved.
//

#ifndef ICE_DISPATCH_INTERCEPTOR_H
#define ICE_DISPATCH_INTERCEPTOR_H

#include <Ice/Object.h>

namespace Ice
{

/**
 * Base class for a dispatch interceptor, which is a servant that dispatches requests
 * to another servant. A subclass must implement the dispatch method. A dispatch interceptor
 * can be registered with an object adapter just like any other servant.
 * \headerfile Ice/Ice.h
 */
class ICE_API DispatchInterceptor : public virtual Object
{
public:

    /**
     * Called by the Ice run time when a new request needs to be dispatched. The implementation
     * must eventually call ice_dispatch on the delegate servant and pass the given request object.
     * @param req An opaque object representing the request to be dispatched.
     * @return True if the request was dispatched synchronously, or false if the request was
     * dispatched asynchronously.
     */
    virtual bool dispatch(Request& req) = 0;

    /// \cond INTERNAL
    virtual bool _iceDispatch(IceInternal::Incoming&, const Current&);
    /// \endcond
};

ICE_DEFINE_PTR(DispatchInterceptorPtr, DispatchInterceptor);

}

#endif