1BSON_T(3) libbson BSON_T(3)
2
3
4
6 bson_t - bson_t
7
8 BSON Document Abstraction
9
11 #include <bson/bson.h>
12
13 /**
14 * bson_empty:
15 * @b: a bson_t.
16 *
17 * Checks to see if @b is an empty BSON document. An empty BSON document is
18 * a 5 byte document which contains the length (4 bytes) and a single NUL
19 * byte indicating end of fields.
20 */
21 #define bson_empty(b) /* ... */
22
23 /**
24 * bson_empty0:
25 *
26 * Like bson_empty() but treats NULL the same as an empty bson_t document.
27 */
28 #define bson_empty0(b) /* ... */
29
30 /**
31 * bson_clear:
32 *
33 * Easily free a bson document and set it to NULL. Use like:
34 *
35 * bson_t *doc = bson_new();
36 * bson_clear (&doc);
37 * BSON_ASSERT (doc == NULL);
38 */
39 #define bson_clear(bptr) /* ... */
40
41 /**
42 * BSON_MAX_SIZE:
43 *
44 * The maximum size in bytes of a BSON document.
45 */
46 #define BSON_MAX_SIZE /* ... */
47
48 #define BSON_APPEND_ARRAY(b, key, val) \
49 bson_append_array (b, key, (int) strlen (key), val)
50
51 #define BSON_APPEND_ARRAY_BEGIN(b, key, child) \
52 bson_append_array_begin (b, key, (int) strlen (key), child)
53
54 #define BSON_APPEND_BINARY(b, key, subtype, val, len) \
55 bson_append_binary (b, key, (int) strlen (key), subtype, val, len)
56
57 #define BSON_APPEND_BOOL(b, key, val) \
58 bson_append_bool (b, key, (int) strlen (key), val)
59
60 #define BSON_APPEND_CODE(b, key, val) \
61 bson_append_code (b, key, (int) strlen (key), val)
62
63 #define BSON_APPEND_CODE_WITH_SCOPE(b, key, val, scope) \
64 bson_append_code_with_scope (b, key, (int) strlen (key), val, scope)
65
66 #define BSON_APPEND_DBPOINTER(b, key, coll, oid) \
67 bson_append_dbpointer (b, key, (int) strlen (key), coll, oid)
68
69 #define BSON_APPEND_DOCUMENT_BEGIN(b, key, child) \
70 bson_append_document_begin (b, key, (int) strlen (key), child)
71
72 #define BSON_APPEND_DOUBLE(b, key, val) \
73 bson_append_double (b, key, (int) strlen (key), val)
74
75 #define BSON_APPEND_DOCUMENT(b, key, val) \
76 bson_append_document (b, key, (int) strlen (key), val)
77
78 #define BSON_APPEND_INT32(b, key, val) \
79 bson_append_int32 (b, key, (int) strlen (key), val)
80
81 #define BSON_APPEND_INT64(b, key, val) \
82 bson_append_int64 (b, key, (int) strlen (key), val)
83
84 #define BSON_APPEND_MINKEY(b, key) \
85 bson_append_minkey (b, key, (int) strlen (key))
86
87 #define BSON_APPEND_DECIMAL128(b, key, val) \
88 bson_append_decimal128 (b, key, (int) strlen (key), val)
89
90 #define BSON_APPEND_MAXKEY(b, key) \
91 bson_append_maxkey (b, key, (int) strlen (key))
92
93 #define BSON_APPEND_NULL(b, key) bson_append_null (b, key, (int) strlen (key))
94
95 #define BSON_APPEND_OID(b, key, val) \
96 bson_append_oid (b, key, (int) strlen (key), val)
97
98 #define BSON_APPEND_REGEX(b, key, val, opt) \
99 bson_append_regex (b, key, (int) strlen (key), val, opt)
100
101 #define BSON_APPEND_UTF8(b, key, val) \
102 bson_append_utf8 (b, key, (int) strlen (key), val, (int) strlen (val))
103
104 #define BSON_APPEND_SYMBOL(b, key, val) \
105 bson_append_symbol (b, key, (int) strlen (key), val, (int) strlen (val))
106
107 #define BSON_APPEND_TIME_T(b, key, val) \
108 bson_append_time_t (b, key, (int) strlen (key), val)
109
110 #define BSON_APPEND_TIMEVAL(b, key, val) \
111 bson_append_timeval (b, key, (int) strlen (key), val)
112
113 #define BSON_APPEND_DATE_TIME(b, key, val) \
114 bson_append_date_time (b, key, (int) strlen (key), val)
115
116 #define BSON_APPEND_TIMESTAMP(b, key, val, inc) \
117 bson_append_timestamp (b, key, (int) strlen (key), val, inc)
118
119 #define BSON_APPEND_UNDEFINED(b, key) \
120 bson_append_undefined (b, key, (int) strlen (key))
121
122 #define BSON_APPEND_VALUE(b, key, val) \
123 bson_append_value (b, key, (int) strlen (key), (val))
124
125 BSON_ALIGNED_BEGIN (128)
126 typedef struct {
127 uint32_t flags; /* Internal flags for the bson_t. */
128 uint32_t len; /* Length of BSON data. */
129 uint8_t padding[120]; /* Padding for stack allocation. */
130 } bson_t BSON_ALIGNED_END (128);
131
133 The bson_t structure represents a BSON document. This structure manages
134 the underlying BSON encoded buffer. For mutable documents, it can ap‐
135 pend new data to the document.
136
138 The bson_t structure attempts to use an inline allocation within the
139 structure to speed up performance of small documents. When this inter‐
140 nal buffer has been exhausted, a heap allocated buffer will be dynami‐
141 cally allocated. Therefore, it is essential to call bson_destroy() on
142 allocated documents.
143
145 The BSON specification allows BSON documents to have duplicate keys.
146 Documents are stored as an ordered list of key-value pairs. A bson_t
147 may contain duplicate keys. Applications should refrain from generating
148 such documents, because MongoDB server behavior is undefined when a
149 BSON document contains duplicate keys.
150
152 static void
153 create_on_heap (void)
154 {
155 bson_t *b = bson_new ();
156
157 BSON_APPEND_INT32 (b, "foo", 123);
158 BSON_APPEND_UTF8 (b, "bar", "foo");
159 BSON_APPEND_DOUBLE (b, "baz", 1.23f);
160
161 bson_destroy (b);
162 }
163
165 MongoDB, Inc
166
168 2017-present, MongoDB, Inc
169
170
171
172
1731.24.3 Aug 17, 2023 BSON_T(3)