MongoDB C++ Driver current
Loading...
Searching...
No Matches
core.hpp
1// Copyright 2014 MongoDB Inc.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15#pragma once
16
17#include <memory>
18#include <stdexcept>
19#include <type_traits>
20
21#include <bsoncxx/array/value.hpp>
22#include <bsoncxx/array/view.hpp>
23#include <bsoncxx/document/value.hpp>
24#include <bsoncxx/document/view.hpp>
25#include <bsoncxx/stdx/string_view.hpp>
26#include <bsoncxx/types.hpp>
27
28#include <bsoncxx/config/prelude.hpp>
29
30namespace bsoncxx {
31BSONCXX_INLINE_NAMESPACE_BEGIN
32namespace builder {
33
42class BSONCXX_API core {
43 public:
44 class BSONCXX_PRIVATE impl;
45
52 explicit core(bool is_array);
53
54 core(core&& rhs) noexcept;
55 core& operator=(core&& rhs) noexcept;
56
57 ~core();
58
79 core& key_view(stdx::string_view key);
80
94 core& key_owned(std::string key);
95
108
121
132
143
162
176
190
204
217 core& append(const types::b_array& value);
218
232
246
259 core& append(const types::b_oid& value);
260
273 core& append(const types::b_bool& value);
274
287 core& append(const types::b_date& value);
288
301 core& append(const types::b_null& value);
302
315 core& append(const types::b_regex& value);
316
330
343 core& append(const types::b_code& value);
344
358
372
385 core& append(const types::b_int32& value);
386
400
413 core& append(const types::b_int64& value);
414
428
442
456
469
481 core& append(std::string str);
482
494 core& append(stdx::string_view str);
495
509 template <typename T>
510 BSONCXX_INLINE core& append(T* v) {
511 static_assert(std::is_same<typename std::remove_const<T>::type, char>::value,
512 "append is disabled for non-char pointer types");
513 append(types::b_string{v});
514
515 return *this;
516 }
517
529 core& append(bool value);
530
542 core& append(double value);
543
555 core& append(std::int32_t value);
556
568 core& append(std::int64_t value);
569
581 core& append(const oid& value);
582
595
608
621
635
648
666
683
688 void clear();
689
690 private:
691 std::unique_ptr<impl> _impl;
692};
693
694} // namespace builder
695BSONCXX_INLINE_NAMESPACE_END
696} // namespace bsoncxx
697
698#include <bsoncxx/config/postlude.hpp>
A read-only BSON array that owns its underlying buffer.
Definition value.hpp:34
A read-only, non-owning view of a BSON document.
Definition view.hpp:40
A low-level interface for constructing BSON documents and arrays.
Definition core.hpp:42
core & append(const types::b_symbol &value)
Appends a BSON symbol.
core & append(const types::b_oid &value)
Appends a BSON ObjectId.
core & append(const types::b_timestamp &value)
Appends a BSON replication timestamp.
core & append(double value)
Appends a native double as a BSON double.
core & open_document()
Opens a sub-document within this BSON datum.
core & append(std::string str)
Appends an STL string as a BSON UTF-8 string.
core & append(const types::b_null &value)
Appends a BSON null.
core & append(const types::b_code &value)
Appends a BSON JavaScript code.
core & append(const types::b_bool &value)
Appends a BSON boolean.
core & key_owned(std::string key)
Appends a key passed as an STL string.
core & key_view(stdx::string_view key)
Appends a key passed as a non-owning stdx::string_view.
core & append(const types::b_array &value)
Appends a BSON array.
document::view view_document() const
Gets a view over the document.
core & append(std::int32_t value)
Appends a native int32_t as a BSON 32-bit signed integer.
core & append(const types::b_maxkey &value)
Appends a BSON max-key.
core & concatenate(const document::view &view)
Appends the keys from a BSON document into this BSON datum.
core & append(const oid &value)
Appends an oid as a BSON ObjectId.
core & close_array()
Closes the current sub-array within this BSON datum.
core & append(const types::b_dbpointer &value)
Appends a BSON DBPointer.
core(bool is_array)
Constructs an empty BSON datum.
core & append(std::int64_t value)
Appends a native int64_t as a BSON 64-bit signed integer.
core & append(const types::b_string &value)
Append a BSON UTF-8 string.
core & append(T *v)
Appends a char* or const char*.
Definition core.hpp:510
core & append(array::view view)
Appends the given array view.
core & append(document::view view)
Appends the given document view.
core & append(const types::b_document &value)
Appends a BSON document.
core & open_array()
Opens a sub-array within this BSON datum.
core & close_document()
Closes the current sub-document within this BSON datum.
core & append(const types::b_int64 &value)
Appends a BSON 64-bit signed integer.
core & append(stdx::string_view str)
Appends a string view as a BSON UTF-8 string.
core & append(const types::b_codewscope &value)
Appends a BSON JavaScript code with scope.
core & append(const types::b_int32 &value)
Appends a BSON 32-bit signed integer.
core & append(const types::b_regex &value)
Appends a BSON regex.
core & append(const types::b_decimal128 &value)
Appends a BSON Decimal128.
array::view view_array() const
Gets a view over the array.
core & append(const types::b_undefined &value)
Appends a BSON undefined.
core & append(const types::bson_value::view &value)
Appends a BSON variant value.
core & append(const types::b_binary &value)
Appends a BSON binary datum.
core & append(bool value)
Appends a native boolean as a BSON boolean.
document::value extract_document()
Transfers ownership of the underlying document to the caller.
core & append(decimal128 value)
Appends a decimal128 object as a BSON Decimal128.
core & append(const types::b_double &value)
Appends a BSON double.
array::value extract_array()
Transfers ownership of the underlying document to the caller.
void clear()
Deletes the contents of the underlying BSON datum.
core & append(const types::b_date &value)
Appends a BSON date.
core & append(const types::b_minkey &value)
Appends a BSON min-key.
Represents an IEEE 754-2008 BSON Decimal128 value in a platform-independent way.
Definition decimal128.hpp:30
A read-only BSON document that owns its underlying buffer.
Definition value.hpp:34
A read-only, non-owning view of a BSON document.
Definition view.hpp:33
Represents a MongoDB ObjectId.
Definition oid.hpp:38
A view-only variant that can contain any BSON type.
Definition view.hpp:44
Top level namespace for MongoDB C++ BSON functionality.
Definition element.hpp:24
A BSON array value.
Definition types.hpp:197
A BSON binary data value.
Definition types.hpp:222
A BSON boolean value.
Definition types.hpp:280
A BSON JavaScript code value.
Definition types.hpp:437
A BSON JavaScript code with scope value.
Definition types.hpp:512
A BSON date value.
Definition types.hpp:305
A BSON DBPointer value.
Definition types.hpp:418
A BSON Decimal128 value.
Definition types.hpp:617
A BSON document value.
Definition types.hpp:165
A BSON double value.
Definition types.hpp:97
A BSON signed 32-bit integer value.
Definition types.hpp:548
A BSON 64-bit signed integer value.
Definition types.hpp:592
A BSON max-key value.
Definition types.hpp:663
A BSON min-key value.
Definition types.hpp:647
A BSON null value.
Definition types.hpp:364
A BSON ObjectId value.
Definition types.hpp:262
A BSON regex value.
Definition types.hpp:380
A BSON UTF-8 encoded string value.
Definition types.hpp:122
A BSON Symbol value.
Definition types.hpp:476
A BSON replication timestamp value.
Definition types.hpp:573
A BSON undefined value.
Definition types.hpp:246