activemq-cpp-3.9.5
ResponseCorrelator.h
Go to the documentation of this file.
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements. See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#ifndef _ACTIVEMQ_TRANSPORT_CORRELATOR_RESPONSECORRELATOR_H_
19#define _ACTIVEMQ_TRANSPORT_CORRELATOR_RESPONSECORRELATOR_H_
20
27
29#include <decaf/lang/Pointer.h>
30
31namespace activemq {
32namespace transport {
33namespace correlator {
34
38
39 class CorrelatorData;
40
46 class AMQCPP_API ResponseCorrelator : public TransportFilter {
47 private:
48
49 CorrelatorData* impl;
50
51 private:
52
53 ResponseCorrelator(const ResponseCorrelator&);
54 ResponseCorrelator& operator= (const ResponseCorrelator&);
55
56 public:
57
67
69
70 public: // Transport Methods
71
72 virtual void oneway(const Pointer<Command> command);
73
75 const Pointer<ResponseCallback> responseCallback);
76
78
79 virtual Pointer<Response> request(const Pointer<Command> command, unsigned int timeout);
80
90 virtual void onCommand(const Pointer<Command> command);
91
100 virtual void onException(const decaf::lang::Exception& ex);
101
102 protected:
103
104 virtual void doClose();
105
106 private:
107
108 void dispose(Pointer<decaf::lang::Exception> ex);
109
110 };
111
112}}}
113
114#endif /*_ACTIVEMQ_TRANSPORT_CORRELATOR_RESPONSECORRELATOR_H_*/
#define AMQCPP_API
Definition Config.h:30
Definition Command.h:33
Definition Response.h:46
Pointer< Transport > next
The transport that this filter wraps around.
Definition TransportFilter.h:54
virtual void onException(const decaf::lang::Exception &ex)
Event handler for an exception from a command transport.
virtual Pointer< Response > request(const Pointer< Command > command)
Sends the given command to the broker and then waits for the response.
virtual Pointer< Response > request(const Pointer< Command > command, unsigned int timeout)
Sends the given command to the broker and then waits for the response.
virtual void oneway(const Pointer< Command > command)
Sends a one-way command.
ResponseCorrelator(Pointer< Transport > next)
Creates a new ResponseCorrelator transport filter that wraps the given transport.
virtual Pointer< FutureResponse > asyncRequest(const Pointer< Command > command, const Pointer< ResponseCallback > responseCallback)
Sends a commands asynchronously, returning a FutureResponse object that the caller can use to check t...
virtual void onCommand(const Pointer< Command > command)
This is called in the context of the nested transport's reading thread.
virtual void doClose()
Subclasses can override this method to do their own close work.
Definition Exception.h:38
Decaf's implementation of a Smart Pointer that is a template on a Type and is Thread Safe if the defa...
Definition Pointer.h:53
Definition ResponseCorrelator.h:33
Definition AbstractTransportFactory.h:30
Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements.
Definition CachedConsumer.h:24