forked from facebook/fbthrift
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfolly_dynamic.h
198 lines (174 loc) · 5.56 KB
/
folly_dynamic.h
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
/*
* Copyright 2016-present Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef THRIFT_FATAL_FOLLY_DYNAMIC_H_
#define THRIFT_FATAL_FOLLY_DYNAMIC_H_ 1
#include <type_traits>
#include <utility>
#include <fatal/type/transform.h>
#include <folly/Traits.h>
#include <folly/dynamic.h>
#include <thrift/lib/cpp2/reflection/reflection.h>
#include <thrift/lib/cpp2/reflection/internal/folly_dynamic-inl-pre.h>
/**
* READ ME FIRST: this header enhances Thrift support for the `folly::dynamic`
* container.
*
* Please refer to the top of `thrift/lib/cpp2/reflection/reflection.h` on how
* to enable compile-time reflection for Thrift types. The present header relies
* on it for its functionality.
*
* TROUBLESHOOTING:
* - make sure you've followed the instructions on `reflection.h` to enable
* generation of compile-time reflection;
* - make sure you've included the metadata for your Thrift types, as specified
* in `reflection.h`.
*
* @author: Marcelo Juchem <[email protected]>
*/
namespace apache {
namespace thrift {
/**
* Describes the format of the data contained in the `folly::dynamic`.
*
* @author: Marcelo Juchem <[email protected]>
*/
enum class dynamic_format {
/**
* A data format that's aimed at being more portable and easier to read by
* humans.
*
* @author: Marcelo Juchem <[email protected]>
*/
PORTABLE,
/**
* A data format that's compatible with `readFromJson()` and
* `TSimpleJSONProtocol` from Thrift 1.
*
* @author: Marcelo Juchem <[email protected]>
*/
JSON_1
};
/**
* Tells how much a decoder should adhere to the data format specification.
*
* @author: Marcelo Juchem <[email protected]>
*/
enum class format_adherence {
/**
* Demands the data to strictly follow the given format. Any deviation from
* the format will be rejected.
*
* @author: Marcelo Juchem <[email protected]>
*/
STRICT,
/**
* Accepts data that deviates from the format, as long as the deviation is not
* ambiguous and can be safely interpreted by the decoder.
*
* @author: Marcelo Juchem <[email protected]>
*/
LENIENT
};
/**
* Converts an object to its `folly::dynamic` representation using Thrift's
* reflection support.
*
* All Thrift types are required to be generated using the 'fatal' cpp2 flag,
* otherwise compile-time reflection metadata won't be available.
*
* The root object is output to the given `folly::dynamic` output parameter.
*
* @author: Marcelo Juchem <[email protected]>
*/
template <typename T>
void to_dynamic(folly::dynamic& out, T&& input, dynamic_format format) {
using impl = detail::dynamic_converter_impl<
reflect_type_class<folly::remove_cvref_t<T>>>;
static_assert(
fatal::is_complete<impl>::value, "to_dynamic: unsupported type");
impl::to(out, std::forward<T>(input), format);
}
/**
* Converts an object to its `folly::dynamic` representation using Thrift's
* reflection support.
*
* All Thrift types are required to be generated using the 'fatal' cpp2 flag,
* otherwise compile-time reflection metadata won't be available.
*
* @author: Marcelo Juchem <[email protected]>
*/
template <typename T>
folly::dynamic to_dynamic(T&& input, dynamic_format format) {
folly::dynamic result(folly::dynamic::object);
to_dynamic(result, std::forward<T>(input), format);
return result;
}
/**
* Converts an object from its `folly::dynamic` representation using Thrift's
* reflection support.
*
* All Thrift types are required to be generated using the 'fatal' cpp2 flag,
* otherwise compile-time reflection metadata won't be available.
*
* The decoded object is output to the given `out` parameter.
*
* @author: Marcelo Juchem <[email protected]>
*/
template <typename T>
void from_dynamic(
T& out,
folly::dynamic const& input,
dynamic_format format,
format_adherence adherence = format_adherence::STRICT) {
using impl = detail::dynamic_converter_impl<
reflect_type_class<folly::remove_cvref_t<T>>>;
static_assert(
fatal::is_complete<impl>::value, "from_dynamic: unsupported type");
impl::from(out, input, format, adherence);
}
template <typename T>
void from_dynamic(
T& out,
folly::StringPiece input,
dynamic_format format,
format_adherence adherence = format_adherence::STRICT) = delete;
/**
* Converts an object from its `folly::dynamic` representation using Thrift's
* reflection support.
*
* All Thrift types are required to be generated using the 'fatal' cpp2 flag,
* otherwise compile-time reflection metadata won't be available.
*
* @author: Marcelo Juchem <[email protected]>
*/
template <typename T>
T from_dynamic(
folly::dynamic const& input,
dynamic_format format,
format_adherence adherence = format_adherence::STRICT) {
T result;
from_dynamic(result, input, format, adherence);
return result;
}
template <typename T>
T from_dynamic(
folly::StringPiece input,
dynamic_format format,
format_adherence adherence = format_adherence::STRICT) = delete;
} // namespace thrift
} // namespace apache
#include <thrift/lib/cpp2/reflection/internal/folly_dynamic-inl-post.h>
#endif // THRIFT_FATAL_FOLLY_DYNAMIC_H_