Hazelcast C++ Client
MultiExecutionCallback.h
1 /*
2  * Copyright (c) 2008-2019, Hazelcast, Inc. All Rights Reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef HAZELCAST_CLIENT_MULTIEXECUTIONCALLBACK_H_
18 #define HAZELCAST_CLIENT_MULTIEXECUTIONCALLBACK_H_
19 
20 #include <map>
21 #include <boost/shared_ptr.hpp>
22 
23 #include "hazelcast/util/HazelcastDll.h"
24 #include "hazelcast/client/Member.h"
25 
26 #if defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
27 #pragma warning(push)
28 #pragma warning(disable: 4251) //for dll export
29 #endif
30 
31 namespace hazelcast {
32  namespace client {
41  template<typename V>
43  public:
44  virtual ~MultiExecutionCallback() {}
45 
52  virtual void onResponse(const Member &member, const boost::shared_ptr<V> &response) = 0;
53 
60  virtual void onFailure(const Member &member, const boost::shared_ptr<exception::IException> &exception) = 0;
61 
68  virtual void onComplete(const std::map<Member, boost::shared_ptr<V> > &values,
69  const std::map<Member, boost::shared_ptr<exception::IException> > &exceptions) = 0;
70  };
71  }
72 }
73 
74 #if defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
75 #pragma warning(pop)
76 #endif
77 
78 #endif //HAZELCAST_CLIENT_MULTIEXECUTIONCALLBACK_H_
79 
virtual void onFailure(const Member &member, const boost::shared_ptr< exception::IException > &exception)=0
Called when an execution is completed with an exception on a member.
virtual void onComplete(const std::map< Member, boost::shared_ptr< V > > &values, const std::map< Member, boost::shared_ptr< exception::IException > > &exceptions)=0
Called after all executions are completed.
MultiExecutionCallback provides notification for when an execution is completed on each member that a...
Definition: MultiExecutionCallback.h:42
virtual void onResponse(const Member &member, const boost::shared_ptr< V > &response)=0
Called when an execution is completed on a member.
Cluster member class.
Definition: Member.h:43
PN (Positive-Negative) CRDT counter.
Definition: MapEntryView.h:32