static_resource.hpp
5.81 KB
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
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
//
// Copyright (c) 2020 Vinnie Falco (vinnie.falco@gmail.com)
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
// Official repository: https://github.com/boostorg/json
//
#ifndef BOOST_JSON_STATIC_RESOURCE_HPP
#define BOOST_JSON_STATIC_RESOURCE_HPP
#include <boost/json/detail/config.hpp>
#include <boost/json/memory_resource.hpp>
#include <cstddef>
BOOST_JSON_NS_BEGIN
#ifdef _MSC_VER
#pragma warning(push)
#pragma warning(disable: 4275) // non dll-interface class used as base for dll-interface class
#endif
//----------------------------------------------------------
/** A resource using a caller-owned buffer, with a trivial deallocate
This memory resource is a special-purpose resource
that releases allocated memory only when the resource
is destroyed (or when @ref release is called).
It has a trivial deallocate function; that is, the
metafunction @ref is_deallocate_trivial returns `true`.
\n
The resource is constructed from a caller-owned buffer
from which subsequent calls to allocate are apportioned.
When a memory request cannot be satisfied from the
free bytes remaining in the buffer, the allocation
request fails with the exception `std::bad_alloc`.
\n
@par Example
This parses a JSON into a value which uses a local
stack buffer, then prints the result.
@code
unsigned char buf[ 4000 ];
static_resource mr( buf );
// Parse the string, using our memory resource
value const jv = parse( "[1,2,3]", &mr );
// Print the JSON
std::cout << jv;
@endcode
@par Thread Safety
Members of the same instance may not be
called concurrently.
@see
https://en.wikipedia.org/wiki/Region-based_memory_management
*/
class BOOST_JSON_CLASS_DECL
static_resource final
: public memory_resource
{
void* p_;
std::size_t n_;
std::size_t size_;
public:
/// Copy constructor (deleted)
static_resource(
static_resource const&) = delete;
/// Copy assignment (deleted)
static_resource& operator=(
static_resource const&) = delete;
/** Destructor
@par Complexity
Constant.
@par Exception Safety
No-throw guarantee.
*/
~static_resource() noexcept;
/** Constructor
This constructs the resource to use the specified
buffer for subsequent calls to allocate. When the
buffer is exhausted, allocate will throw
`std::bad_alloc`.
@par Complexity
Constant.
@par Exception Safety
No-throw guarantee.
@param buffer The buffer to use.
Ownership is not transferred; the caller is
responsible for ensuring that the lifetime of
the buffer extends until the resource is destroyed.
@param size The number of valid bytes pointed
to by `buffer`.
*/
/** @{ */
static_resource(
unsigned char* buffer,
std::size_t size) noexcept;
#if defined(__cpp_lib_byte) || defined(BOOST_JSON_DOCS)
static_resource(
std::byte* buffer,
std::size_t size) noexcept
: static_resource(reinterpret_cast<
unsigned char*>(buffer), size)
{
}
#endif
/** @} */
/** Constructor
This constructs the resource to use the specified
buffer for subsequent calls to allocate. When the
buffer is exhausted, allocate will throw
`std::bad_alloc`.
@par Complexity
Constant.
@par Exception Safety
No-throw guarantee.
@param buffer The buffer to use.
Ownership is not transferred; the caller is
responsible for ensuring that the lifetime of
the buffer extends until the resource is destroyed.
*/
/** @{ */
template<std::size_t N>
explicit
static_resource(
unsigned char(&buffer)[N]) noexcept
: static_resource(&buffer[0], N)
{
}
#if defined(__cpp_lib_byte) || defined(BOOST_JSON_DOCS)
template<std::size_t N>
explicit
static_resource(
std::byte(&buffer)[N]) noexcept
: static_resource(&buffer[0], N)
{
}
#endif
/** @} */
#ifndef BOOST_JSON_DOCS
// Safety net for accidental buffer overflows
template<std::size_t N>
static_resource(
unsigned char(&buffer)[N], std::size_t n) noexcept
: static_resource(&buffer[0], n)
{
// If this goes off, check your parameters
// closely, chances are you passed an array
// thinking it was a pointer.
BOOST_ASSERT(n <= N);
}
#ifdef __cpp_lib_byte
// Safety net for accidental buffer overflows
template<std::size_t N>
static_resource(
std::byte(&buffer)[N], std::size_t n) noexcept
: static_resource(&buffer[0], n)
{
// If this goes off, check your parameters
// closely, chances are you passed an array
// thinking it was a pointer.
BOOST_ASSERT(n <= N);
}
#endif
#endif
/** Release all allocated memory.
This function resets the buffer provided upon
construction so that all of the valid bytes are
available for subsequent allocation.
@par Complexity
Constant
@par Exception Safety
No-throw guarantee.
*/
void
release() noexcept;
protected:
#ifndef BOOST_JSON_DOCS
void*
do_allocate(
std::size_t n,
std::size_t align) override;
void
do_deallocate(
void* p,
std::size_t n,
std::size_t align) override;
bool
do_is_equal(
memory_resource const& mr
) const noexcept override;
#endif
};
#ifdef _MSC_VER
#pragma warning(pop)
#endif
template<>
struct is_deallocate_trivial<
static_resource>
{
static constexpr bool value = true;
};
BOOST_JSON_NS_END
#endif