Hazelcast C++ Client
Hazelcast C++ Client Library
serialization_config.h
1 /*
2  * Copyright (c) 2008-2022, 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 #pragma once
17 
18 #include <memory>
19 #include <boost/endian/conversion.hpp>
20 
21 #include "hazelcast/util/export.h"
22 
23 #if defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
24 #pragma warning(push)
25 #pragma warning(disable : 4251) // for dll export
26 #endif
27 
28 namespace hazelcast {
29 namespace client {
30 namespace serialization {
31 struct global_serializer;
32 }
33 
38 class HAZELCAST_API serialization_config
39 {
40 public:
46 
53  int get_portable_version() const;
54 
60  serialization_config& set_portable_version(int v);
61 
62  std::shared_ptr<serialization::global_serializer> get_global_serializer()
63  const;
64 
70  serialization_config& set_global_serializer(
71  const std::shared_ptr<serialization::global_serializer>&
72  global_serializer);
73 
79  serialization_config& set_byte_order(boost::endian::order byte_order);
80 
85  boost::endian::order get_byte_order() const;
86 
87 private:
88  int version_;
89  std::shared_ptr<serialization::global_serializer> global_serializer_;
90  boost::endian::order byte_order_ = boost::endian::order::big;
91 };
92 } // namespace client
93 } // namespace hazelcast
94 
95 #if defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
96 #pragma warning(pop)
97 #endif
SerializationConfig is used to.