cpp-common/bt2: add `bt2::BorrowedObjectProxy`
[babeltrace.git] / src / cpp-common / bt2 / field-class.hpp
CommitLineData
12435a68
PP
1/*
2 * Copyright (c) 2020 Philippe Proulx <pproulx@efficios.com>
3 *
4 * SPDX-License-Identifier: MIT
5 */
6
7#ifndef BABELTRACE_CPP_COMMON_BT2_FIELD_CLASS_HPP
8#define BABELTRACE_CPP_COMMON_BT2_FIELD_CLASS_HPP
9
12435a68 10#include <cstdint>
c802cacb
SM
11#include <type_traits>
12
12435a68
PP
13#include <babeltrace2/babeltrace.h>
14
15#include "common/assert.h"
12435a68
PP
16#include "cpp-common/optional.hpp"
17#include "cpp-common/string_view.hpp"
c802cacb 18
0d218157 19#include "borrowed-object.hpp"
8aee46a3 20#include "common-iterator.hpp"
39278ebc 21#include "exc.hpp"
12435a68 22#include "field-path.hpp"
c802cacb 23#include "integer-range-set.hpp"
c802cacb 24#include "internal/utils.hpp"
7f5cdaf0 25#include "shared-object.hpp"
096c6be7 26#include "value.hpp"
12435a68
PP
27
28namespace bt2 {
12435a68
PP
29namespace internal {
30
31struct FieldClassRefFuncs final
32{
c677c492 33 static void get(const bt_field_class * const libObjPtr) noexcept
12435a68
PP
34 {
35 bt_field_class_get_ref(libObjPtr);
36 }
37
c677c492 38 static void put(const bt_field_class * const libObjPtr) noexcept
12435a68
PP
39 {
40 bt_field_class_put_ref(libObjPtr);
41 }
42};
43
12435a68
PP
44template <typename LibObjT>
45struct CommonFieldClassSpec;
46
b5f55e9f 47/* Functions specific to mutable field classes */
12435a68
PP
48template <>
49struct CommonFieldClassSpec<bt_field_class> final
50{
51 static bt_value *userAttributes(bt_field_class * const libObjPtr) noexcept
52 {
53 return bt_field_class_borrow_user_attributes(libObjPtr);
54 }
55};
56
b5f55e9f 57/* Functions specific to constant field classes */
12435a68
PP
58template <>
59struct CommonFieldClassSpec<const bt_field_class> final
60{
61 static const bt_value *userAttributes(const bt_field_class * const libObjPtr) noexcept
62 {
63 return bt_field_class_borrow_user_attributes_const(libObjPtr);
64 }
65};
66
b5f55e9f 67} /* namespace internal */
12435a68 68
26b9d24c 69template <typename ObjT, typename LibObjT>
7f5cdaf0 70using SharedFieldClass = SharedObject<ObjT, LibObjT, internal::FieldClassRefFuncs>;
26b9d24c 71
12435a68
PP
72template <typename LibObjT>
73class CommonBitArrayFieldClass;
74
75template <typename LibObjT>
76class CommonIntegerFieldClass;
77
78template <typename LibObjT>
79class ConstEnumerationFieldClassMapping;
80
be6aa636
FD
81template <typename LibObjT>
82class CommonBaseEnumerationFieldClass;
83
12435a68
PP
84template <typename LibObjT, typename MappingT>
85class CommonEnumerationFieldClass;
86
87template <typename LibObjT>
88class CommonStructureFieldClass;
89
90template <typename LibObjT>
91class CommonArrayFieldClass;
92
93template <typename LibObjT>
94class CommonStaticArrayFieldClass;
95
96template <typename LibObjT>
97class CommonDynamicArrayWithLengthFieldClass;
98
99template <typename LibObjT>
100class CommonOptionFieldClass;
101
102template <typename LibObjT>
103class CommonOptionWithSelectorFieldClass;
104
105template <typename LibObjT>
106class CommonOptionWithBoolSelectorFieldClass;
107
108template <typename LibObjT>
109class CommonVariantFieldClass;
110
111template <typename LibObjT, typename RangeSetT>
112class CommonOptionWithIntegerSelectorFieldClass;
113
114template <typename LibObjT>
115class CommonVariantWithoutSelectorFieldClass;
116
cefe03a2
FD
117template <typename LibObjT>
118class CommonVariantWithSelectorFieldClass;
119
12435a68
PP
120template <typename LibObjT>
121class ConstVariantWithIntegerSelectorFieldClassOption;
122
123template <typename LibObjT, typename RangeSetT>
124class CommonVariantWithIntegerSelectorFieldClass;
125
74fc764d
PP
126template <typename LibObjT>
127class CommonEventClass;
128
129template <typename LibObjT>
130class CommonStreamClass;
131
132template <typename LibObjT>
133class CommonTraceClass;
134
12435a68
PP
135enum class FieldClassType
136{
137 BOOL = BT_FIELD_CLASS_TYPE_BOOL,
138 BIT_ARRAY = BT_FIELD_CLASS_TYPE_BIT_ARRAY,
139 UNSIGNED_INTEGER = BT_FIELD_CLASS_TYPE_UNSIGNED_INTEGER,
140 SIGNED_INTEGER = BT_FIELD_CLASS_TYPE_SIGNED_INTEGER,
141 UNSIGNED_ENUMERATION = BT_FIELD_CLASS_TYPE_UNSIGNED_ENUMERATION,
142 SIGNED_ENUMERATION = BT_FIELD_CLASS_TYPE_SIGNED_ENUMERATION,
143 SINGLE_PRECISION_REAL = BT_FIELD_CLASS_TYPE_SINGLE_PRECISION_REAL,
144 DOUBLE_PRECISION_REAL = BT_FIELD_CLASS_TYPE_DOUBLE_PRECISION_REAL,
145 STRING = BT_FIELD_CLASS_TYPE_STRING,
146 STRUCTURE = BT_FIELD_CLASS_TYPE_STRUCTURE,
147 STATIC_ARRAY = BT_FIELD_CLASS_TYPE_STATIC_ARRAY,
148 DYNAMIC_ARRAY_WITHOUT_LENGTH = BT_FIELD_CLASS_TYPE_DYNAMIC_ARRAY_WITHOUT_LENGTH_FIELD,
149 DYNAMIC_ARRAY_WITH_LENGTH = BT_FIELD_CLASS_TYPE_DYNAMIC_ARRAY_WITH_LENGTH_FIELD,
150 OPTION_WITHOUT_SELECTOR = BT_FIELD_CLASS_TYPE_OPTION_WITHOUT_SELECTOR_FIELD,
151 OPTION_WITH_BOOL_SELECTOR = BT_FIELD_CLASS_TYPE_OPTION_WITH_BOOL_SELECTOR_FIELD,
152 OPTION_WITH_UNSIGNED_INTEGER_SELECTOR =
153 BT_FIELD_CLASS_TYPE_OPTION_WITH_UNSIGNED_INTEGER_SELECTOR_FIELD,
154 OPTION_WITH_SIGNED_INTEGER_SELECTOR =
155 BT_FIELD_CLASS_TYPE_OPTION_WITH_SIGNED_INTEGER_SELECTOR_FIELD,
156 VARIANT_WITHOUT_SELECTOR = BT_FIELD_CLASS_TYPE_VARIANT_WITHOUT_SELECTOR_FIELD,
157 VARIANT_WITH_UNSIGNED_INTEGER_SELECTOR =
158 BT_FIELD_CLASS_TYPE_VARIANT_WITH_UNSIGNED_INTEGER_SELECTOR_FIELD,
159 VARIANT_WITH_SIGNED_INTEGER_SELECTOR =
160 BT_FIELD_CLASS_TYPE_VARIANT_WITH_SIGNED_INTEGER_SELECTOR_FIELD,
161};
162
163template <typename LibObjT>
0d218157 164class CommonFieldClass : public BorrowedObject<LibObjT>
12435a68 165{
12435a68 166private:
0d218157 167 using typename BorrowedObject<LibObjT>::_ThisBorrowedObject;
12435a68
PP
168
169protected:
0d218157 170 using typename BorrowedObject<LibObjT>::_LibObjPtr;
12435a68
PP
171 using _ThisCommonFieldClass = CommonFieldClass<LibObjT>;
172
173public:
26b9d24c 174 using Shared = SharedFieldClass<CommonFieldClass<LibObjT>, LibObjT>;
8047a175 175 using UserAttributes = internal::DepUserAttrs<LibObjT>;
12435a68 176
0d218157 177 explicit CommonFieldClass(const _LibObjPtr libObjPtr) noexcept : _ThisBorrowedObject {libObjPtr}
12435a68
PP
178 {
179 }
180
181 template <typename OtherLibObjT>
0d218157 182 CommonFieldClass(const CommonFieldClass<OtherLibObjT> fc) noexcept : _ThisBorrowedObject {fc}
12435a68
PP
183 {
184 }
185
186 template <typename OtherLibObjT>
100fa861 187 CommonFieldClass& operator=(const CommonFieldClass<OtherLibObjT> fc) noexcept
12435a68 188 {
0d218157 189 _ThisBorrowedObject::operator=(fc);
12435a68
PP
190 return *this;
191 }
192
328a274a
PP
193 CommonFieldClass<const bt_field_class> asConst() const noexcept
194 {
195 return CommonFieldClass<const bt_field_class> {*this};
196 }
197
12435a68
PP
198 FieldClassType type() const noexcept
199 {
341a67c4 200 return static_cast<FieldClassType>(bt_field_class_get_type(this->libObjPtr()));
12435a68
PP
201 }
202
203 bool isBool() const noexcept
204 {
205 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_BOOL);
206 }
207
208 bool isBitArray() const noexcept
209 {
210 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_BIT_ARRAY);
211 }
212
213 bool isInteger() const noexcept
214 {
215 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_INTEGER);
216 }
217
218 bool isUnsignedInteger() const noexcept
219 {
220 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_UNSIGNED_INTEGER);
221 }
222
223 bool isSignedInteger() const noexcept
224 {
225 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_SIGNED_INTEGER);
226 }
227
228 bool isEnumeration() const noexcept
229 {
230 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_ENUMERATION);
231 }
232
233 bool isUnsignedEnumeration() const noexcept
234 {
235 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_UNSIGNED_ENUMERATION);
236 }
237
238 bool isSignedEnumeration() const noexcept
239 {
240 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_SIGNED_ENUMERATION);
241 }
242
ff620936
FD
243 bool isReal() const noexcept
244 {
245 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_REAL);
246 }
247
12435a68
PP
248 bool isSinglePrecisionReal() const noexcept
249 {
250 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_SINGLE_PRECISION_REAL);
251 }
252
253 bool isDoublePrecisionReal() const noexcept
254 {
255 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_DOUBLE_PRECISION_REAL);
256 }
257
258 bool isString() const noexcept
259 {
260 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_STRING);
261 }
262
263 bool isStructure() const noexcept
264 {
265 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_STRUCTURE);
266 }
267
268 bool isArray() const noexcept
269 {
270 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_ARRAY);
271 }
272
273 bool isStaticArray() const noexcept
274 {
275 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_STATIC_ARRAY);
276 }
277
278 bool isDynamicArray() const noexcept
279 {
280 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_DYNAMIC_ARRAY);
281 }
282
283 bool isDynamicArrayWithoutLength() const noexcept
284 {
285 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_DYNAMIC_ARRAY_WITHOUT_LENGTH_FIELD);
286 }
287
288 bool isDynamicArrayWithLength() const noexcept
289 {
290 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_DYNAMIC_ARRAY_WITH_LENGTH_FIELD);
291 }
292
293 bool isOption() const noexcept
294 {
295 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION);
296 }
297
298 bool isOptionWithoutSelector() const noexcept
299 {
300 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION_WITHOUT_SELECTOR_FIELD);
301 }
302
303 bool isOptionWithSelector() const noexcept
304 {
305 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION_WITH_SELECTOR_FIELD);
306 }
307
308 bool isOptionWithBoolSelector() const noexcept
309 {
310 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION_WITH_BOOL_SELECTOR_FIELD);
311 }
312
313 bool isOptionWithIntegerSelector() const noexcept
314 {
315 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION_WITH_INTEGER_SELECTOR_FIELD);
316 }
317
318 bool isOptionWithUnsignedIntegerSelector() const noexcept
319 {
320 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION_WITH_UNSIGNED_INTEGER_SELECTOR_FIELD);
321 }
322
323 bool isOptionWithSignedIntegerSelector() const noexcept
324 {
325 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_OPTION_WITH_SIGNED_INTEGER_SELECTOR_FIELD);
326 }
327
328 bool isVariant() const noexcept
329 {
330 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_VARIANT);
331 }
332
333 bool isVariantWithoutSelector() const noexcept
334 {
335 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_VARIANT_WITHOUT_SELECTOR_FIELD);
336 }
337
338 bool isVariantWithSelector() const noexcept
339 {
340 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_VARIANT_WITH_SELECTOR_FIELD);
341 }
342
343 bool isVariantWithIntegerSelector() const noexcept
344 {
345 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_VARIANT_WITH_INTEGER_SELECTOR_FIELD);
346 }
347
348 bool isVariantWithUnsignedIntegerSelector() const noexcept
349 {
350 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_VARIANT_WITH_UNSIGNED_INTEGER_SELECTOR_FIELD);
351 }
352
353 bool isVariantWithSignedIntegerSelector() const noexcept
354 {
355 return this->_libTypeIs(BT_FIELD_CLASS_TYPE_VARIANT_WITH_SIGNED_INTEGER_SELECTOR_FIELD);
356 }
357
45e0ded5
PP
358 template <typename FieldClassT>
359 FieldClassT as() const noexcept
360 {
361 return FieldClassT {this->libObjPtr()};
362 }
363
12435a68
PP
364 CommonBitArrayFieldClass<LibObjT> asBitArray() const noexcept;
365 CommonIntegerFieldClass<LibObjT> asInteger() const noexcept;
be6aa636 366 CommonBaseEnumerationFieldClass<LibObjT> asEnumeration() const noexcept;
12435a68
PP
367 CommonEnumerationFieldClass<LibObjT, ConstEnumerationFieldClassMapping<
368 const bt_field_class_enumeration_unsigned_mapping>>
369 asUnsignedEnumeration() const noexcept;
370
371 CommonEnumerationFieldClass<
372 LibObjT, ConstEnumerationFieldClassMapping<const bt_field_class_enumeration_signed_mapping>>
373 asSignedEnumeration() const noexcept;
374
375 CommonStructureFieldClass<LibObjT> asStructure() const noexcept;
376 CommonArrayFieldClass<LibObjT> asArray() const noexcept;
377 CommonStaticArrayFieldClass<LibObjT> asStaticArray() const noexcept;
378 CommonDynamicArrayWithLengthFieldClass<LibObjT> asDynamicArrayWithLength() const noexcept;
379 CommonOptionFieldClass<LibObjT> asOption() const noexcept;
380 CommonOptionWithSelectorFieldClass<LibObjT> asOptionWithSelector() const noexcept;
381 CommonOptionWithBoolSelectorFieldClass<LibObjT> asOptionWithBoolSelector() const noexcept;
382
383 CommonOptionWithIntegerSelectorFieldClass<LibObjT, ConstUnsignedIntegerRangeSet>
384 asOptionWithUnsignedIntegerSelector() const noexcept;
385
386 CommonOptionWithIntegerSelectorFieldClass<LibObjT, ConstSignedIntegerRangeSet>
387 asOptionWithSignedIntegerSelector() const noexcept;
388
389 CommonVariantFieldClass<LibObjT> asVariant() const noexcept;
390 CommonVariantWithoutSelectorFieldClass<LibObjT> asVariantWithoutSelector() const noexcept;
cefe03a2 391 CommonVariantWithSelectorFieldClass<LibObjT> asVariantWithSelector() const noexcept;
12435a68
PP
392
393 CommonVariantWithIntegerSelectorFieldClass<
394 LibObjT, ConstVariantWithIntegerSelectorFieldClassOption<
395 const bt_field_class_variant_with_selector_field_integer_unsigned_option>>
396 asVariantWithUnsignedIntegerSelector() const noexcept;
397
398 CommonVariantWithIntegerSelectorFieldClass<
399 LibObjT, ConstVariantWithIntegerSelectorFieldClassOption<
400 const bt_field_class_variant_with_selector_field_integer_signed_option>>
401 asVariantWithSignedIntegerSelector() const noexcept;
402
403 template <typename LibValT>
b7ffa6f0 404 void userAttributes(const CommonMapValue<LibValT> userAttrs) const noexcept
12435a68 405 {
5c895f64 406 static_assert(!std::is_const<LibObjT>::value, "Not available with `bt2::ConstFieldClass`.");
12435a68 407
341a67c4 408 bt_field_class_set_user_attributes(this->libObjPtr(), userAttrs.libObjPtr());
12435a68
PP
409 }
410
dcb8ae9b 411 UserAttributes userAttributes() const noexcept
12435a68
PP
412 {
413 return UserAttributes {
341a67c4 414 internal::CommonFieldClassSpec<LibObjT>::userAttributes(this->libObjPtr())};
12435a68
PP
415 }
416
417 Shared shared() const noexcept
418 {
c9c0b6e2 419 return Shared::createWithRef(*this);
12435a68
PP
420 }
421
422protected:
423 bool _libTypeIs(const bt_field_class_type type) const noexcept
424 {
341a67c4 425 return bt_field_class_type_is(bt_field_class_get_type(this->libObjPtr()), type);
12435a68
PP
426 }
427};
428
429using FieldClass = CommonFieldClass<bt_field_class>;
430using ConstFieldClass = CommonFieldClass<const bt_field_class>;
431
4927bae7
PP
432namespace internal {
433
434struct FieldClassTypeDescr
435{
436 using Const = ConstFieldClass;
437 using NonConst = FieldClass;
438};
439
440template <>
441struct TypeDescr<FieldClass> : public FieldClassTypeDescr
442{
443};
444
445template <>
446struct TypeDescr<ConstFieldClass> : public FieldClassTypeDescr
447{
448};
449
450} /* namespace internal */
451
12435a68
PP
452template <typename LibObjT>
453class CommonBitArrayFieldClass final : public CommonFieldClass<LibObjT>
454{
455private:
456 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
457 using typename CommonFieldClass<LibObjT>::_ThisCommonFieldClass;
458
459public:
26b9d24c 460 using Shared = SharedFieldClass<CommonBitArrayFieldClass<LibObjT>, LibObjT>;
12435a68
PP
461
462 explicit CommonBitArrayFieldClass(const _LibObjPtr libObjPtr) noexcept :
463 _ThisCommonFieldClass {libObjPtr}
464 {
465 BT_ASSERT_DBG(this->isBitArray());
466 }
467
468 template <typename OtherLibObjT>
100fa861 469 CommonBitArrayFieldClass(const CommonBitArrayFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
470 _ThisCommonFieldClass {fc}
471 {
472 }
473
474 template <typename OtherLibObjT>
475 CommonBitArrayFieldClass<LibObjT>&
100fa861 476 operator=(const CommonBitArrayFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
477 {
478 _ThisCommonFieldClass::operator=(fc);
479 return *this;
480 }
481
328a274a
PP
482 CommonBitArrayFieldClass<const bt_field_class> asConst() const noexcept
483 {
484 return CommonBitArrayFieldClass<const bt_field_class> {*this};
485 }
486
12435a68
PP
487 std::uint64_t length() const noexcept
488 {
341a67c4 489 return bt_field_class_bit_array_get_length(this->libObjPtr());
12435a68
PP
490 }
491
492 Shared shared() const noexcept
493 {
c9c0b6e2 494 return Shared::createWithRef(*this);
12435a68
PP
495 }
496};
497
498using BitArrayFieldClass = CommonBitArrayFieldClass<bt_field_class>;
499using ConstBitArrayFieldClass = CommonBitArrayFieldClass<const bt_field_class>;
500
4927bae7
PP
501namespace internal {
502
503struct BitArrayFieldClassTypeDescr
504{
505 using Const = ConstBitArrayFieldClass;
506 using NonConst = BitArrayFieldClass;
507};
508
509template <>
510struct TypeDescr<BitArrayFieldClass> : public BitArrayFieldClassTypeDescr
511{
512};
513
514template <>
515struct TypeDescr<ConstBitArrayFieldClass> : public BitArrayFieldClassTypeDescr
516{
517};
518
519} /* namespace internal */
520
12435a68
PP
521enum class DisplayBase
522{
523 BINARY = BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_BINARY,
524 OCTAL = BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_OCTAL,
525 DECIMAL = BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_DECIMAL,
526 HEXADECIMAL = BT_FIELD_CLASS_INTEGER_PREFERRED_DISPLAY_BASE_HEXADECIMAL,
527};
528
529template <typename LibObjT>
530class CommonIntegerFieldClass : public CommonFieldClass<LibObjT>
531{
532private:
533 using typename CommonFieldClass<LibObjT>::_ThisCommonFieldClass;
534
535protected:
536 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
537 using _ThisCommonIntegerFieldClass = CommonIntegerFieldClass<LibObjT>;
538
539public:
26b9d24c 540 using Shared = SharedFieldClass<CommonIntegerFieldClass<LibObjT>, LibObjT>;
12435a68
PP
541
542 explicit CommonIntegerFieldClass(const _LibObjPtr libObjPtr) noexcept :
543 _ThisCommonFieldClass {libObjPtr}
544 {
545 BT_ASSERT_DBG(this->isInteger());
546 }
547
548 template <typename OtherLibObjT>
100fa861 549 CommonIntegerFieldClass(const CommonIntegerFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
550 _ThisCommonFieldClass {fc}
551 {
552 }
553
554 template <typename OtherLibObjT>
100fa861 555 CommonIntegerFieldClass& operator=(const CommonIntegerFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
556 {
557 _ThisCommonFieldClass::operator=(fc);
558 return *this;
559 }
560
328a274a
PP
561 CommonIntegerFieldClass<const bt_field_class> asConst() const noexcept
562 {
563 return CommonIntegerFieldClass<const bt_field_class> {*this};
564 }
565
dcb8ae9b 566 void fieldValueRange(const std::uint64_t n) const noexcept
12435a68 567 {
5c895f64
PP
568 static_assert(!std::is_const<LibObjT>::value,
569 "Not available with `bt2::ConstIntegerFieldClass`.");
12435a68 570
78017fef 571 bt_field_class_integer_set_field_value_range(this->libObjPtr(), n);
12435a68
PP
572 }
573
574 std::uint64_t fieldValueRange() const noexcept
575 {
341a67c4 576 return bt_field_class_integer_get_field_value_range(this->libObjPtr());
12435a68
PP
577 }
578
dcb8ae9b 579 void preferredDisplayBase(const DisplayBase base) const noexcept
12435a68 580 {
5c895f64
PP
581 static_assert(!std::is_const<LibObjT>::value,
582 "Not available with `bt2::ConstIntegerFieldClass`.");
12435a68
PP
583
584 bt_field_class_integer_set_preferred_display_base(
341a67c4 585 this->libObjPtr(), static_cast<bt_field_class_integer_preferred_display_base>(base));
12435a68
PP
586 }
587
588 DisplayBase preferredDisplayBase() const noexcept
589 {
590 return static_cast<DisplayBase>(
341a67c4 591 bt_field_class_integer_get_preferred_display_base(this->libObjPtr()));
12435a68
PP
592 }
593
594 Shared shared() const noexcept
595 {
c9c0b6e2 596 return Shared::createWithRef(*this);
12435a68
PP
597 }
598};
599
600using IntegerFieldClass = CommonIntegerFieldClass<bt_field_class>;
601using ConstIntegerFieldClass = CommonIntegerFieldClass<const bt_field_class>;
602
603namespace internal {
604
4927bae7
PP
605struct IntegerFieldClassTypeDescr
606{
607 using Const = ConstIntegerFieldClass;
608 using NonConst = IntegerFieldClass;
609};
610
611template <>
612struct TypeDescr<IntegerFieldClass> : public IntegerFieldClassTypeDescr
613{
614};
615
616template <>
617struct TypeDescr<ConstIntegerFieldClass> : public IntegerFieldClassTypeDescr
618{
619};
620
621} /* namespace internal */
622
623namespace internal {
624
12435a68
PP
625template <typename LibObjT>
626struct ConstEnumerationFieldClassMappingSpec;
627
b5f55e9f 628/* Functions specific to unsigned enumeration field class mappings */
12435a68
PP
629template <>
630struct ConstEnumerationFieldClassMappingSpec<const bt_field_class_enumeration_unsigned_mapping>
631 final
632{
633 static const bt_integer_range_set_unsigned *
634 ranges(const bt_field_class_enumeration_unsigned_mapping * const libObjPtr) noexcept
635 {
636 return bt_field_class_enumeration_unsigned_mapping_borrow_ranges_const(libObjPtr);
637 }
638
639 static const char *
640 label(const bt_field_class_enumeration_unsigned_mapping * const libObjPtr) noexcept
641 {
642 return bt_field_class_enumeration_mapping_get_label(
643 bt_field_class_enumeration_unsigned_mapping_as_mapping_const(libObjPtr));
644 }
645};
646
b5f55e9f 647/* Functions specific to signed enumeration field class mappings */
12435a68
PP
648template <>
649struct ConstEnumerationFieldClassMappingSpec<const bt_field_class_enumeration_signed_mapping> final
650{
651 static const bt_integer_range_set_signed *
652 ranges(const bt_field_class_enumeration_signed_mapping * const libObjPtr) noexcept
653 {
654 return bt_field_class_enumeration_signed_mapping_borrow_ranges_const(libObjPtr);
655 }
656
657 static const char *
658 label(const bt_field_class_enumeration_signed_mapping * const libObjPtr) noexcept
659 {
660 return bt_field_class_enumeration_mapping_get_label(
661 bt_field_class_enumeration_signed_mapping_as_mapping_const(libObjPtr));
662 }
663};
664
b5f55e9f 665} /* namespace internal */
12435a68
PP
666
667template <typename LibObjT>
0d218157 668class ConstEnumerationFieldClassMapping final : public BorrowedObject<LibObjT>
12435a68
PP
669{
670private:
0d218157
PP
671 using typename BorrowedObject<LibObjT>::_ThisBorrowedObject;
672 using typename BorrowedObject<LibObjT>::_LibObjPtr;
12435a68
PP
673
674public:
675 using RangeSet = typename std::conditional<
676 std::is_same<LibObjT, const bt_field_class_enumeration_unsigned_mapping>::value,
677 ConstUnsignedIntegerRangeSet, ConstSignedIntegerRangeSet>::type;
678
679 explicit ConstEnumerationFieldClassMapping(const _LibObjPtr libObjPtr) noexcept :
0d218157 680 _ThisBorrowedObject {libObjPtr}
12435a68
PP
681 {
682 }
683
0d6ad4d8 684 ConstEnumerationFieldClassMapping(const ConstEnumerationFieldClassMapping& mapping) noexcept :
0d218157 685 _ThisBorrowedObject {mapping}
12435a68
PP
686 {
687 }
688
0d6ad4d8
FD
689 ConstEnumerationFieldClassMapping&
690 operator=(const ConstEnumerationFieldClassMapping& mapping) noexcept
12435a68 691 {
0d218157 692 _ThisBorrowedObject::operator=(mapping);
12435a68
PP
693 return *this;
694 }
695
696 RangeSet ranges() const noexcept
697 {
698 return RangeSet {
341a67c4 699 internal::ConstEnumerationFieldClassMappingSpec<LibObjT>::ranges(this->libObjPtr())};
12435a68
PP
700 }
701
702 bpstd::string_view label() const noexcept
703 {
341a67c4 704 return internal::ConstEnumerationFieldClassMappingSpec<LibObjT>::label(this->libObjPtr());
12435a68
PP
705 }
706};
707
708using ConstUnsignedEnumerationFieldClassMapping =
709 ConstEnumerationFieldClassMapping<const bt_field_class_enumeration_unsigned_mapping>;
710
711using ConstSignedEnumerationFieldClassMapping =
712 ConstEnumerationFieldClassMapping<const bt_field_class_enumeration_signed_mapping>;
713
714namespace internal {
715
716template <typename MappingT>
717struct CommonEnumerationFieldClassSpec;
718
b5f55e9f 719/* Functions specific to unsigned enumeration field classes */
12435a68
PP
720template <>
721struct CommonEnumerationFieldClassSpec<ConstUnsignedEnumerationFieldClassMapping> final
722{
723 static const bt_field_class_enumeration_unsigned_mapping *
724 mappingByIndex(const bt_field_class * const libObjPtr, const std::uint64_t index) noexcept
725 {
726 return bt_field_class_enumeration_unsigned_borrow_mapping_by_index_const(libObjPtr, index);
727 }
728
729 static const bt_field_class_enumeration_unsigned_mapping *
730 mappingByLabel(const bt_field_class * const libObjPtr, const char * const label) noexcept
731 {
732 return bt_field_class_enumeration_unsigned_borrow_mapping_by_label_const(libObjPtr, label);
733 }
5d6ccdae
PP
734
735 static bt_field_class_enumeration_add_mapping_status
736 addMapping(bt_field_class * const libObjPtr, const char * const label,
737 const bt_integer_range_set_unsigned * const libRanges) noexcept
738 {
739 return bt_field_class_enumeration_unsigned_add_mapping(libObjPtr, label, libRanges);
740 }
12435a68
PP
741};
742
b5f55e9f 743/* Functions specific to signed enumeration field classes */
12435a68
PP
744template <>
745struct CommonEnumerationFieldClassSpec<ConstSignedEnumerationFieldClassMapping> final
746{
747 static const bt_field_class_enumeration_signed_mapping *
748 mappingByIndex(const bt_field_class * const libObjPtr, const std::uint64_t index) noexcept
749 {
750 return bt_field_class_enumeration_signed_borrow_mapping_by_index_const(libObjPtr, index);
751 }
752
753 static const bt_field_class_enumeration_signed_mapping *
754 mappingByLabel(const bt_field_class * const libObjPtr, const char * const label) noexcept
755 {
756 return bt_field_class_enumeration_signed_borrow_mapping_by_label_const(libObjPtr, label);
757 }
5d6ccdae
PP
758
759 static bt_field_class_enumeration_add_mapping_status
760 addMapping(bt_field_class * const libObjPtr, const char * const label,
761 const bt_integer_range_set_signed * const libRanges) noexcept
762 {
763 return bt_field_class_enumeration_signed_add_mapping(libObjPtr, label, libRanges);
764 }
12435a68
PP
765};
766
b5f55e9f 767} /* namespace internal */
12435a68 768
be6aa636
FD
769template <typename LibObjT>
770class CommonBaseEnumerationFieldClass : public CommonIntegerFieldClass<LibObjT>
771{
772private:
773 using typename CommonIntegerFieldClass<LibObjT>::_ThisCommonIntegerFieldClass;
774
775protected:
776 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
777 using _ThisCommonBaseEnumerationFieldClass = CommonBaseEnumerationFieldClass<LibObjT>;
778
779public:
26b9d24c 780 using Shared = SharedFieldClass<_ThisCommonBaseEnumerationFieldClass, LibObjT>;
be6aa636
FD
781
782 explicit CommonBaseEnumerationFieldClass(const _LibObjPtr libObjPtr) noexcept :
783 _ThisCommonIntegerFieldClass {libObjPtr}
784 {
785 BT_ASSERT_DBG(this->isEnumeration());
786 }
787
788 template <typename OtherLibObjT>
100fa861
PP
789 CommonBaseEnumerationFieldClass(const CommonBaseEnumerationFieldClass<OtherLibObjT> fc) noexcept
790 :
be6aa636
FD
791 _ThisCommonIntegerFieldClass {fc}
792 {
793 }
794
795 template <typename OtherLibObjT>
0d6ad4d8 796 CommonBaseEnumerationFieldClass&
100fa861 797 operator=(const CommonBaseEnumerationFieldClass<OtherLibObjT> fc) noexcept
be6aa636
FD
798 {
799 _ThisCommonIntegerFieldClass::operator=(fc);
800 return *this;
801 }
802
328a274a
PP
803 CommonBaseEnumerationFieldClass<const bt_field_class> asConst() const noexcept
804 {
805 return CommonBaseEnumerationFieldClass<const bt_field_class> {*this};
806 }
807
c0b73c63 808 std::uint64_t length() const noexcept
be6aa636 809 {
341a67c4 810 return bt_field_class_enumeration_get_mapping_count(this->libObjPtr());
be6aa636
FD
811 }
812
813 Shared shared() const noexcept
814 {
c9c0b6e2 815 return Shared::createWithRef(*this);
be6aa636
FD
816 }
817};
818
12435a68 819template <typename LibObjT, typename MappingT>
be6aa636 820class CommonEnumerationFieldClass final : public CommonBaseEnumerationFieldClass<LibObjT>
12435a68
PP
821{
822private:
823 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
be6aa636 824 using typename CommonBaseEnumerationFieldClass<LibObjT>::_ThisCommonBaseEnumerationFieldClass;
12435a68
PP
825 using _ThisCommonEnumerationFieldClass = CommonEnumerationFieldClass<LibObjT, MappingT>;
826
827public:
26b9d24c 828 using Shared = SharedFieldClass<_ThisCommonEnumerationFieldClass, LibObjT>;
e5a8a7c4 829 using Iterator = CommonIterator<CommonEnumerationFieldClass, MappingT>;
12435a68
PP
830 using Mapping = MappingT;
831
832 explicit CommonEnumerationFieldClass(const _LibObjPtr libObjPtr) noexcept :
be6aa636 833 _ThisCommonBaseEnumerationFieldClass {libObjPtr}
12435a68
PP
834 {
835 BT_ASSERT_DBG(this->isEnumeration());
836 }
837
838 template <typename OtherLibObjT>
839 CommonEnumerationFieldClass(
100fa861 840 const CommonEnumerationFieldClass<OtherLibObjT, MappingT> fc) noexcept :
be6aa636 841 _ThisCommonEnumerationFieldClass {fc}
12435a68
PP
842 {
843 }
844
845 template <typename OtherLibObjT>
0d6ad4d8 846 CommonEnumerationFieldClass&
100fa861 847 operator=(const CommonEnumerationFieldClass<OtherLibObjT, MappingT> fc) noexcept
12435a68 848 {
be6aa636 849 _ThisCommonEnumerationFieldClass::operator=(fc);
12435a68
PP
850 return *this;
851 }
852
12435a68
PP
853 Mapping operator[](const std::uint64_t index) const noexcept
854 {
855 return Mapping {internal::CommonEnumerationFieldClassSpec<MappingT>::mappingByIndex(
341a67c4 856 this->libObjPtr(), index)};
12435a68
PP
857 }
858
859 nonstd::optional<Mapping> operator[](const char * const label) const noexcept
860 {
861 const auto libObjPtr = internal::CommonEnumerationFieldClassSpec<MappingT>::mappingByLabel(
341a67c4 862 this->libObjPtr(), label);
12435a68
PP
863
864 if (libObjPtr) {
865 return Mapping {libObjPtr};
866 }
867
868 return nonstd::nullopt;
869 }
870
871 nonstd::optional<Mapping> operator[](const std::string& label) const noexcept
872 {
873 return (*this)[label.data()];
874 }
875
dcb8ae9b 876 void addMapping(const char * const label, const typename Mapping::RangeSet ranges) const
5d6ccdae
PP
877 {
878 const auto status = internal::CommonEnumerationFieldClassSpec<MappingT>::addMapping(
879 this->libObjPtr(), label, ranges.libObjPtr());
880
881 if (status == BT_FIELD_CLASS_ENUMERATION_ADD_MAPPING_STATUS_MEMORY_ERROR) {
39278ebc 882 throw MemoryError {};
5d6ccdae
PP
883 }
884 }
885
dcb8ae9b 886 void addMapping(const std::string& label, const typename Mapping::RangeSet ranges) const
5d6ccdae
PP
887 {
888 this->addMapping(label.data(), ranges);
889 }
890
e5a8a7c4
FD
891 Iterator begin() const noexcept
892 {
893 return Iterator {*this, 0};
894 }
895
896 Iterator end() const noexcept
897 {
c0b73c63 898 return Iterator {*this, this->length()};
e5a8a7c4
FD
899 }
900
12435a68
PP
901 Shared shared() const noexcept
902 {
c9c0b6e2 903 return Shared::createWithRef(*this);
12435a68
PP
904 }
905};
906
be6aa636
FD
907using EnumerationFieldClass = CommonBaseEnumerationFieldClass<bt_field_class>;
908using ConstEnumerationFieldClass = CommonBaseEnumerationFieldClass<const bt_field_class>;
909
12435a68
PP
910using UnsignedEnumerationFieldClass =
911 CommonEnumerationFieldClass<bt_field_class, ConstUnsignedEnumerationFieldClassMapping>;
912
913using ConstUnsignedEnumerationFieldClass =
914 CommonEnumerationFieldClass<const bt_field_class, ConstUnsignedEnumerationFieldClassMapping>;
915
916using SignedEnumerationFieldClass =
917 CommonEnumerationFieldClass<bt_field_class, ConstSignedEnumerationFieldClassMapping>;
918
919using ConstSignedEnumerationFieldClass =
920 CommonEnumerationFieldClass<const bt_field_class, ConstSignedEnumerationFieldClassMapping>;
921
922namespace internal {
923
4927bae7
PP
924struct UnsignedEnumerationFieldClassTypeDescr
925{
926 using Const = ConstUnsignedEnumerationFieldClass;
927 using NonConst = UnsignedEnumerationFieldClass;
928};
929
930template <>
931struct TypeDescr<UnsignedEnumerationFieldClass> : public UnsignedEnumerationFieldClassTypeDescr
932{
933};
934
935template <>
936struct TypeDescr<ConstUnsignedEnumerationFieldClass> : public UnsignedEnumerationFieldClassTypeDescr
937{
938};
939
940struct SignedEnumerationFieldClassTypeDescr
941{
942 using Const = ConstSignedEnumerationFieldClass;
943 using NonConst = SignedEnumerationFieldClass;
944};
945
946template <>
947struct TypeDescr<SignedEnumerationFieldClass> : public SignedEnumerationFieldClassTypeDescr
948{
949};
950
951template <>
952struct TypeDescr<ConstSignedEnumerationFieldClass> : public SignedEnumerationFieldClassTypeDescr
953{
954};
955
12435a68
PP
956template <typename LibObjT>
957struct CommonStructureFieldClassMemberSpec;
958
b5f55e9f 959/* Functions specific to mutable structure field class members */
12435a68
PP
960template <>
961struct CommonStructureFieldClassMemberSpec<bt_field_class_structure_member> final
962{
963 static bt_field_class *fieldClass(bt_field_class_structure_member * const libObjPtr) noexcept
964 {
965 return bt_field_class_structure_member_borrow_field_class(libObjPtr);
966 }
8e557120
PP
967
968 static bt_value *userAttributes(bt_field_class_structure_member * const libObjPtr) noexcept
969 {
970 return bt_field_class_structure_member_borrow_user_attributes(libObjPtr);
971 }
12435a68
PP
972};
973
b5f55e9f 974/* Functions specific to constant structure field class members */
12435a68
PP
975template <>
976struct CommonStructureFieldClassMemberSpec<const bt_field_class_structure_member> final
977{
978 static const bt_field_class *
979 fieldClass(const bt_field_class_structure_member * const libObjPtr) noexcept
980 {
981 return bt_field_class_structure_member_borrow_field_class_const(libObjPtr);
982 }
8e557120
PP
983
984 static const bt_value *
985 userAttributes(const bt_field_class_structure_member * const libObjPtr) noexcept
986 {
987 return bt_field_class_structure_member_borrow_user_attributes_const(libObjPtr);
988 }
12435a68
PP
989};
990
b5f55e9f 991} /* namespace internal */
12435a68
PP
992
993template <typename LibObjT>
0d218157 994class CommonStructureFieldClassMember final : public BorrowedObject<LibObjT>
12435a68
PP
995{
996private:
0d218157
PP
997 using typename BorrowedObject<LibObjT>::_LibObjPtr;
998 using typename BorrowedObject<LibObjT>::_ThisBorrowedObject;
8047a175 999 using _FieldClass = internal::DepFc<LibObjT>;
12435a68
PP
1000
1001public:
8047a175 1002 using UserAttributes = internal::DepUserAttrs<LibObjT>;
8e557120 1003
12435a68 1004 explicit CommonStructureFieldClassMember(const _LibObjPtr libObjPtr) noexcept :
0d218157 1005 _ThisBorrowedObject {libObjPtr}
12435a68
PP
1006 {
1007 }
1008
1009 template <typename OtherLibObjT>
100fa861
PP
1010 CommonStructureFieldClassMember(const CommonStructureFieldClassMember<OtherLibObjT> fc) noexcept
1011 :
0d218157 1012 _ThisBorrowedObject {fc}
12435a68
PP
1013 {
1014 }
1015
1016 template <typename OtherLibObjT>
1017 CommonStructureFieldClassMember<LibObjT>&
100fa861 1018 operator=(const CommonStructureFieldClassMember<OtherLibObjT> fc) noexcept
12435a68 1019 {
0d218157 1020 _ThisBorrowedObject::operator=(fc);
12435a68
PP
1021 return *this;
1022 }
1023
328a274a
PP
1024 CommonStructureFieldClassMember<const bt_field_class_structure_member> asConst() const noexcept
1025 {
1026 return CommonStructureFieldClassMember<const bt_field_class_structure_member> {*this};
1027 }
1028
12435a68
PP
1029 bpstd::string_view name() const noexcept
1030 {
341a67c4 1031 return bt_field_class_structure_member_get_name(this->libObjPtr());
12435a68
PP
1032 }
1033
dcb8ae9b 1034 _FieldClass fieldClass() const noexcept
12435a68
PP
1035 {
1036 return _FieldClass {
341a67c4 1037 internal::CommonStructureFieldClassMemberSpec<LibObjT>::fieldClass(this->libObjPtr())};
12435a68 1038 }
8e557120
PP
1039
1040 template <typename LibValT>
b7ffa6f0 1041 void userAttributes(const CommonMapValue<LibValT> userAttrs) const noexcept
8e557120 1042 {
5c895f64
PP
1043 static_assert(!std::is_const<LibObjT>::value,
1044 "Not available with `bt2::ConstStructureFieldClassMember`.");
8e557120
PP
1045
1046 bt_field_class_structure_member_set_user_attributes(this->libObjPtr(),
1047 userAttrs.libObjPtr());
1048 }
1049
dcb8ae9b 1050 UserAttributes userAttributes() const noexcept
8e557120
PP
1051 {
1052 return UserAttributes {
1053 internal::CommonStructureFieldClassMemberSpec<LibObjT>::userAttributes(
1054 this->libObjPtr())};
1055 }
12435a68
PP
1056};
1057
1058using StructureFieldClassMember = CommonStructureFieldClassMember<bt_field_class_structure_member>;
1059
1060using ConstStructureFieldClassMember =
1061 CommonStructureFieldClassMember<const bt_field_class_structure_member>;
1062
1063namespace internal {
1064
4927bae7
PP
1065struct StructureFieldClassMemberTypeDescr
1066{
1067 using Const = ConstStructureFieldClassMember;
1068 using NonConst = StructureFieldClassMember;
1069};
1070
1071template <>
1072struct TypeDescr<StructureFieldClassMember> : public StructureFieldClassMemberTypeDescr
1073{
1074};
1075
1076template <>
1077struct TypeDescr<ConstStructureFieldClassMember> : public StructureFieldClassMemberTypeDescr
1078{
1079};
1080
12435a68
PP
1081template <typename LibObjT>
1082struct CommonStructureFieldClassSpec;
1083
b5f55e9f 1084/* Functions specific to mutable structure field classes */
12435a68
PP
1085template <>
1086struct CommonStructureFieldClassSpec<bt_field_class> final
1087{
1088 static bt_field_class_structure_member *memberByIndex(bt_field_class * const libObjPtr,
1089 const std::uint64_t index) noexcept
1090 {
1091 return bt_field_class_structure_borrow_member_by_index(libObjPtr, index);
1092 }
1093
1094 static bt_field_class_structure_member *memberByName(bt_field_class * const libObjPtr,
1095 const char * const name) noexcept
1096 {
1097 return bt_field_class_structure_borrow_member_by_name(libObjPtr, name);
1098 }
1099};
1100
b5f55e9f 1101/* Functions specific to constant structure field classes */
12435a68
PP
1102template <>
1103struct CommonStructureFieldClassSpec<const bt_field_class> final
1104{
1105 static const bt_field_class_structure_member *
1106 memberByIndex(const bt_field_class * const libObjPtr, const std::uint64_t index) noexcept
1107 {
1108 return bt_field_class_structure_borrow_member_by_index_const(libObjPtr, index);
1109 }
1110
1111 static const bt_field_class_structure_member *
1112 memberByName(const bt_field_class * const libObjPtr, const char * const name) noexcept
1113 {
1114 return bt_field_class_structure_borrow_member_by_name_const(libObjPtr, name);
1115 }
1116};
1117
b5f55e9f 1118} /* namespace internal */
12435a68
PP
1119
1120template <typename LibObjT>
1121class CommonStructureFieldClass final : public CommonFieldClass<LibObjT>
1122{
1123private:
1124 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1125 using typename CommonFieldClass<LibObjT>::_ThisCommonFieldClass;
1126
1127public:
26b9d24c 1128 using Shared = SharedFieldClass<CommonStructureFieldClass<LibObjT>, LibObjT>;
8047a175 1129
12435a68 1130 using Member =
8047a175 1131 internal::DepType<LibObjT, StructureFieldClassMember, ConstStructureFieldClassMember>;
12435a68 1132
5046c776
FD
1133 using Iterator = CommonIterator<CommonStructureFieldClass<LibObjT>, Member>;
1134
12435a68
PP
1135 explicit CommonStructureFieldClass(const _LibObjPtr libObjPtr) noexcept :
1136 _ThisCommonFieldClass {libObjPtr}
1137 {
1138 BT_ASSERT_DBG(this->isStructure());
1139 }
1140
1141 template <typename OtherLibObjT>
100fa861 1142 CommonStructureFieldClass(const CommonStructureFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1143 _ThisCommonFieldClass {fc}
1144 {
1145 }
1146
1147 template <typename OtherLibObjT>
100fa861 1148 CommonStructureFieldClass& operator=(const CommonStructureFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1149 {
1150 _ThisCommonFieldClass::operator=(fc);
1151 return *this;
1152 }
1153
328a274a
PP
1154 CommonStructureFieldClass<const bt_field_class> asConst() const noexcept
1155 {
1156 return CommonStructureFieldClass<const bt_field_class> {*this};
1157 }
1158
dcb8ae9b 1159 void appendMember(const char * const name, const FieldClass fc) const
12435a68 1160 {
5c895f64
PP
1161 static_assert(!std::is_const<LibObjT>::value,
1162 "Not available with `bt2::ConstStructureFieldClass`.");
12435a68
PP
1163
1164 const auto status =
341a67c4 1165 bt_field_class_structure_append_member(this->libObjPtr(), name, fc.libObjPtr());
12435a68
PP
1166
1167 if (status == BT_FIELD_CLASS_STRUCTURE_APPEND_MEMBER_STATUS_MEMORY_ERROR) {
39278ebc 1168 throw MemoryError {};
12435a68
PP
1169 }
1170 }
1171
dcb8ae9b 1172 void appendMember(const std::string& name, const FieldClass fc) const
12435a68
PP
1173 {
1174 this->appendMember(name.data(), fc);
1175 }
1176
c0b73c63 1177 std::uint64_t length() const noexcept
12435a68 1178 {
341a67c4 1179 return bt_field_class_structure_get_member_count(this->libObjPtr());
12435a68
PP
1180 }
1181
5046c776
FD
1182 Iterator begin() const noexcept
1183 {
1184 return Iterator {*this, 0};
1185 }
1186
1187 Iterator end() const noexcept
1188 {
c0b73c63 1189 return Iterator {*this, this->length()};
5046c776
FD
1190 }
1191
dcb8ae9b 1192 Member operator[](const std::uint64_t index) const noexcept
12435a68
PP
1193 {
1194 return Member {internal::CommonStructureFieldClassSpec<LibObjT>::memberByIndex(
341a67c4 1195 this->libObjPtr(), index)};
12435a68
PP
1196 }
1197
dcb8ae9b 1198 nonstd::optional<Member> operator[](const char * const name) const noexcept
12435a68 1199 {
341a67c4
FD
1200 const auto libObjPtr =
1201 internal::CommonStructureFieldClassSpec<LibObjT>::memberByName(this->libObjPtr(), name);
12435a68
PP
1202
1203 if (libObjPtr) {
1204 return Member {libObjPtr};
1205 }
1206
1207 return nonstd::nullopt;
1208 }
1209
dcb8ae9b 1210 nonstd::optional<Member> operator[](const std::string& name) const noexcept
12435a68
PP
1211 {
1212 return (*this)[name.data()];
1213 }
1214
1215 Shared shared() const noexcept
1216 {
c9c0b6e2 1217 return Shared::createWithRef(*this);
12435a68
PP
1218 }
1219};
1220
1221using StructureFieldClass = CommonStructureFieldClass<bt_field_class>;
1222using ConstStructureFieldClass = CommonStructureFieldClass<const bt_field_class>;
1223
1224namespace internal {
1225
4927bae7
PP
1226struct StructureFieldClassTypeDescr
1227{
1228 using Const = ConstStructureFieldClass;
1229 using NonConst = StructureFieldClass;
1230};
1231
1232template <>
1233struct TypeDescr<StructureFieldClass> : public StructureFieldClassTypeDescr
1234{
1235};
1236
1237template <>
1238struct TypeDescr<ConstStructureFieldClass> : public StructureFieldClassTypeDescr
1239{
1240};
1241
12435a68
PP
1242template <typename LibObjT>
1243struct CommonArrayFieldClassSpec;
1244
b5f55e9f 1245/* Functions specific to mutable array field classes */
12435a68
PP
1246template <>
1247struct CommonArrayFieldClassSpec<bt_field_class> final
1248{
1249 static bt_field_class *elementFieldClass(bt_field_class * const libObjPtr) noexcept
1250 {
1251 return bt_field_class_array_borrow_element_field_class(libObjPtr);
1252 }
1253};
1254
b5f55e9f 1255/* Functions specific to constant array field classes */
12435a68
PP
1256template <>
1257struct CommonArrayFieldClassSpec<const bt_field_class> final
1258{
1259 static const bt_field_class *elementFieldClass(const bt_field_class * const libObjPtr) noexcept
1260 {
1261 return bt_field_class_array_borrow_element_field_class_const(libObjPtr);
1262 }
1263};
1264
b5f55e9f 1265} /* namespace internal */
12435a68
PP
1266
1267template <typename LibObjT>
1268class CommonArrayFieldClass : public CommonFieldClass<LibObjT>
1269{
1270private:
1271 using typename CommonFieldClass<LibObjT>::_ThisCommonFieldClass;
8047a175 1272 using _FieldClass = internal::DepFc<LibObjT>;
12435a68
PP
1273
1274protected:
1275 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1276 using _ThisCommonArrayFieldClass = CommonArrayFieldClass<LibObjT>;
1277
1278public:
26b9d24c 1279 using Shared = SharedFieldClass<CommonArrayFieldClass<LibObjT>, LibObjT>;
12435a68
PP
1280
1281 explicit CommonArrayFieldClass(const _LibObjPtr libObjPtr) noexcept :
1282 _ThisCommonFieldClass {libObjPtr}
1283 {
1284 BT_ASSERT_DBG(this->isArray());
1285 }
1286
1287 template <typename OtherLibObjT>
100fa861 1288 CommonArrayFieldClass(const CommonArrayFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1289 _ThisCommonFieldClass {fc}
1290 {
1291 }
1292
1293 template <typename OtherLibObjT>
100fa861 1294 CommonArrayFieldClass& operator=(const CommonArrayFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1295 {
1296 _ThisCommonFieldClass::operator=(fc);
1297 return *this;
1298 }
1299
328a274a
PP
1300 CommonArrayFieldClass<const bt_field_class> asConst() const noexcept
1301 {
1302 return CommonArrayFieldClass<const bt_field_class> {*this};
1303 }
1304
dcb8ae9b 1305 _FieldClass elementFieldClass() const noexcept
12435a68
PP
1306 {
1307 return _FieldClass {
341a67c4 1308 internal::CommonArrayFieldClassSpec<LibObjT>::elementFieldClass(this->libObjPtr())};
12435a68
PP
1309 }
1310
1311 Shared shared() const noexcept
1312 {
c9c0b6e2 1313 return Shared::createWithRef(*this);
12435a68
PP
1314 }
1315};
1316
1317using ArrayFieldClass = CommonArrayFieldClass<bt_field_class>;
1318using ConstArrayFieldClass = CommonArrayFieldClass<const bt_field_class>;
1319
4927bae7
PP
1320namespace internal {
1321
1322struct ArrayFieldClassTypeDescr
1323{
1324 using Const = ConstArrayFieldClass;
1325 using NonConst = ArrayFieldClass;
1326};
1327
1328template <>
1329struct TypeDescr<ArrayFieldClass> : public ArrayFieldClassTypeDescr
1330{
1331};
1332
1333template <>
1334struct TypeDescr<ConstArrayFieldClass> : public ArrayFieldClassTypeDescr
1335{
1336};
1337
1338} /* namespace internal */
1339
12435a68
PP
1340template <typename LibObjT>
1341class CommonStaticArrayFieldClass final : public CommonArrayFieldClass<LibObjT>
1342{
1343private:
1344 using typename CommonArrayFieldClass<LibObjT>::_ThisCommonArrayFieldClass;
1345 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1346
1347public:
26b9d24c 1348 using Shared = SharedFieldClass<CommonStaticArrayFieldClass<LibObjT>, LibObjT>;
12435a68
PP
1349
1350 explicit CommonStaticArrayFieldClass(const _LibObjPtr libObjPtr) noexcept :
1351 _ThisCommonArrayFieldClass {libObjPtr}
1352 {
1353 BT_ASSERT_DBG(this->isStaticArray());
1354 }
1355
1356 template <typename OtherLibObjT>
100fa861 1357 CommonStaticArrayFieldClass(const CommonStaticArrayFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1358 _ThisCommonArrayFieldClass {fc}
1359 {
1360 }
1361
1362 template <typename OtherLibObjT>
0d6ad4d8 1363 CommonStaticArrayFieldClass&
100fa861 1364 operator=(const CommonStaticArrayFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1365 {
1366 _ThisCommonArrayFieldClass::operator=(fc);
1367 return *this;
1368 }
1369
328a274a
PP
1370 CommonStaticArrayFieldClass<const bt_field_class> asConst() const noexcept
1371 {
1372 return CommonStaticArrayFieldClass<const bt_field_class> {*this};
1373 }
1374
12435a68
PP
1375 std::uint64_t length() const noexcept
1376 {
341a67c4 1377 return bt_field_class_array_static_get_length(this->libObjPtr());
12435a68
PP
1378 }
1379
1380 Shared shared() const noexcept
1381 {
c9c0b6e2 1382 return Shared::createWithRef(*this);
12435a68
PP
1383 }
1384};
1385
1386using StaticArrayFieldClass = CommonStaticArrayFieldClass<bt_field_class>;
1387using ConstStaticArrayFieldClass = CommonStaticArrayFieldClass<const bt_field_class>;
1388
4927bae7
PP
1389namespace internal {
1390
1391struct StaticArrayFieldClassTypeDescr
1392{
1393 using Const = ConstStaticArrayFieldClass;
1394 using NonConst = StaticArrayFieldClass;
1395};
1396
1397template <>
1398struct TypeDescr<StaticArrayFieldClass> : public StaticArrayFieldClassTypeDescr
1399{
1400};
1401
1402template <>
1403struct TypeDescr<ConstStaticArrayFieldClass> : public StaticArrayFieldClassTypeDescr
1404{
1405};
1406
1407} /* namespace internal */
1408
12435a68
PP
1409template <typename LibObjT>
1410class CommonDynamicArrayWithLengthFieldClass final : public CommonArrayFieldClass<LibObjT>
1411{
1412private:
1413 using typename CommonArrayFieldClass<LibObjT>::_ThisCommonArrayFieldClass;
1414 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1415
1416public:
26b9d24c 1417 using Shared = SharedFieldClass<CommonDynamicArrayWithLengthFieldClass<LibObjT>, LibObjT>;
12435a68
PP
1418
1419 explicit CommonDynamicArrayWithLengthFieldClass(const _LibObjPtr libObjPtr) noexcept :
1420 _ThisCommonArrayFieldClass {libObjPtr}
1421 {
1422 BT_ASSERT_DBG(this->isDynamicArrayWithLength());
1423 }
1424
1425 template <typename OtherLibObjT>
1426 CommonDynamicArrayWithLengthFieldClass(
100fa861 1427 const CommonDynamicArrayWithLengthFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1428 _ThisCommonArrayFieldClass {fc}
1429 {
1430 }
1431
1432 template <typename OtherLibObjT>
0d6ad4d8 1433 CommonDynamicArrayWithLengthFieldClass&
100fa861 1434 operator=(const CommonDynamicArrayWithLengthFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1435 {
1436 _ThisCommonArrayFieldClass::operator=(fc);
1437 return *this;
1438 }
1439
328a274a
PP
1440 CommonDynamicArrayWithLengthFieldClass<const bt_field_class> asConst() const noexcept
1441 {
1442 return CommonDynamicArrayWithLengthFieldClass<const bt_field_class> {*this};
1443 }
1444
12435a68
PP
1445 ConstFieldPath lengthFieldPath() const noexcept
1446 {
1447 return ConstFieldPath {
1448 bt_field_class_array_dynamic_with_length_field_borrow_length_field_path_const(
341a67c4 1449 this->libObjPtr())};
12435a68
PP
1450 }
1451
1452 Shared shared() const noexcept
1453 {
c9c0b6e2 1454 return Shared::createWithRef(*this);
12435a68
PP
1455 }
1456};
1457
1458using DynamicArrayWithLengthFieldClass = CommonDynamicArrayWithLengthFieldClass<bt_field_class>;
1459
1460using ConstDynamicArrayWithLengthFieldClass =
1461 CommonDynamicArrayWithLengthFieldClass<const bt_field_class>;
1462
1463namespace internal {
1464
4927bae7
PP
1465struct DynamicArrayWithLengthFieldClassTypeDescr
1466{
1467 using Const = ConstDynamicArrayWithLengthFieldClass;
1468 using NonConst = DynamicArrayWithLengthFieldClass;
1469};
1470
1471template <>
1472struct TypeDescr<DynamicArrayWithLengthFieldClass> :
1473 public DynamicArrayWithLengthFieldClassTypeDescr
1474{
1475};
1476
1477template <>
1478struct TypeDescr<ConstDynamicArrayWithLengthFieldClass> :
1479 public DynamicArrayWithLengthFieldClassTypeDescr
1480{
1481};
1482
12435a68
PP
1483template <typename LibObjT>
1484struct CommonOptionFieldClassSpec;
1485
b5f55e9f 1486/* Functions specific to mutable option field classes */
12435a68
PP
1487template <>
1488struct CommonOptionFieldClassSpec<bt_field_class> final
1489{
1490 static bt_field_class *fieldClass(bt_field_class * const libObjPtr) noexcept
1491 {
1492 return bt_field_class_option_borrow_field_class(libObjPtr);
1493 }
1494};
1495
b5f55e9f 1496/* Functions specific to constant option field classes */
12435a68
PP
1497template <>
1498struct CommonOptionFieldClassSpec<const bt_field_class> final
1499{
1500 static const bt_field_class *fieldClass(const bt_field_class * const libObjPtr) noexcept
1501 {
1502 return bt_field_class_option_borrow_field_class_const(libObjPtr);
1503 }
1504};
1505
b5f55e9f 1506} /* namespace internal */
12435a68
PP
1507
1508template <typename LibObjT>
1509class CommonOptionFieldClass : public CommonFieldClass<LibObjT>
1510{
1511private:
1512 using typename CommonFieldClass<LibObjT>::_ThisCommonFieldClass;
8047a175 1513 using _FieldClass = internal::DepFc<LibObjT>;
12435a68
PP
1514
1515protected:
1516 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1517 using _ThisCommonOptionFieldClass = CommonOptionFieldClass<LibObjT>;
1518
1519public:
26b9d24c 1520 using Shared = SharedFieldClass<CommonOptionFieldClass<LibObjT>, LibObjT>;
12435a68
PP
1521
1522 explicit CommonOptionFieldClass(const _LibObjPtr libObjPtr) noexcept :
1523 _ThisCommonFieldClass {libObjPtr}
1524 {
1525 BT_ASSERT_DBG(this->isOption());
1526 }
1527
1528 template <typename OtherLibObjT>
100fa861 1529 CommonOptionFieldClass(const CommonOptionFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1530 _ThisCommonFieldClass {fc}
1531 {
1532 }
1533
1534 template <typename OtherLibObjT>
100fa861 1535 CommonOptionFieldClass& operator=(const CommonOptionFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1536 {
1537 _ThisCommonFieldClass::operator=(fc);
1538 return *this;
1539 }
1540
328a274a
PP
1541 CommonOptionFieldClass<const bt_field_class> asConst() const noexcept
1542 {
1543 return CommonOptionFieldClass<const bt_field_class> {*this};
1544 }
1545
dcb8ae9b 1546 _FieldClass fieldClass() const noexcept
12435a68
PP
1547 {
1548 return _FieldClass {
341a67c4 1549 internal::CommonOptionFieldClassSpec<LibObjT>::fieldClass(this->libObjPtr())};
12435a68
PP
1550 }
1551
1552 Shared shared() const noexcept
1553 {
c9c0b6e2 1554 return Shared::createWithRef(*this);
12435a68
PP
1555 }
1556};
1557
1558using OptionFieldClass = CommonOptionFieldClass<bt_field_class>;
1559using ConstOptionFieldClass = CommonOptionFieldClass<const bt_field_class>;
1560
4927bae7
PP
1561namespace internal {
1562
1563struct OptionFieldClassTypeDescr
1564{
1565 using Const = ConstOptionFieldClass;
1566 using NonConst = OptionFieldClass;
1567};
1568
1569template <>
1570struct TypeDescr<OptionFieldClass> : public OptionFieldClassTypeDescr
1571{
1572};
1573
1574template <>
1575struct TypeDescr<ConstOptionFieldClass> : public OptionFieldClassTypeDescr
1576{
1577};
1578
1579} /* namespace internal */
1580
12435a68
PP
1581template <typename LibObjT>
1582class CommonOptionWithSelectorFieldClass : public CommonOptionFieldClass<LibObjT>
1583{
1584private:
1585 using typename CommonOptionFieldClass<LibObjT>::_ThisCommonOptionFieldClass;
1586
1587protected:
1588 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1589 using _ThisCommonOptionWithSelectorFieldClass = CommonOptionWithSelectorFieldClass<LibObjT>;
1590
1591public:
26b9d24c 1592 using Shared = SharedFieldClass<CommonOptionWithSelectorFieldClass<LibObjT>, LibObjT>;
12435a68
PP
1593
1594 explicit CommonOptionWithSelectorFieldClass(const _LibObjPtr libObjPtr) noexcept :
1595 _ThisCommonOptionFieldClass {libObjPtr}
1596 {
1597 BT_ASSERT_DBG(this->isOptionWithSelector());
1598 }
1599
1600 template <typename OtherLibObjT>
1601 CommonOptionWithSelectorFieldClass(
100fa861 1602 const CommonOptionWithSelectorFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1603 _ThisCommonOptionFieldClass {fc}
1604 {
1605 }
1606
1607 template <typename OtherLibObjT>
0d6ad4d8 1608 CommonOptionWithSelectorFieldClass&
100fa861 1609 operator=(const CommonOptionWithSelectorFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1610 {
1611 _ThisCommonOptionFieldClass::operator=(fc);
1612 return *this;
1613 }
1614
328a274a
PP
1615 CommonOptionWithSelectorFieldClass<const bt_field_class> asConst() const noexcept
1616 {
1617 return CommonOptionWithSelectorFieldClass<const bt_field_class> {*this};
1618 }
1619
12435a68
PP
1620 ConstFieldPath selectorFieldPath() const noexcept
1621 {
1622 return ConstFieldPath {
1623 bt_field_class_option_with_selector_field_borrow_selector_field_path_const(
341a67c4 1624 this->libObjPtr())};
12435a68
PP
1625 }
1626
1627 Shared shared() const noexcept
1628 {
c9c0b6e2 1629 return Shared::createWithRef(*this);
12435a68
PP
1630 }
1631};
1632
1633using OptionWithSelectorFieldClass = CommonOptionWithSelectorFieldClass<bt_field_class>;
1634using ConstOptionWithSelectorFieldClass = CommonOptionWithSelectorFieldClass<const bt_field_class>;
1635
4927bae7
PP
1636namespace internal {
1637
1638struct OptionWithSelectorFieldClassTypeDescr
1639{
1640 using Const = ConstOptionWithSelectorFieldClass;
1641 using NonConst = OptionWithSelectorFieldClass;
1642};
1643
1644template <>
1645struct TypeDescr<OptionWithSelectorFieldClass> : public OptionWithSelectorFieldClassTypeDescr
1646{
1647};
1648
1649template <>
1650struct TypeDescr<ConstOptionWithSelectorFieldClass> : public OptionWithSelectorFieldClassTypeDescr
1651{
1652};
1653
1654} /* namespace internal */
1655
12435a68
PP
1656template <typename LibObjT>
1657class CommonOptionWithBoolSelectorFieldClass : public CommonOptionWithSelectorFieldClass<LibObjT>
1658{
1659private:
1660 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1661
1662 using typename CommonOptionWithSelectorFieldClass<
1663 LibObjT>::_ThisCommonOptionWithSelectorFieldClass;
1664
1665public:
26b9d24c 1666 using Shared = SharedFieldClass<CommonOptionWithBoolSelectorFieldClass<LibObjT>, LibObjT>;
12435a68
PP
1667
1668 explicit CommonOptionWithBoolSelectorFieldClass(const _LibObjPtr libObjPtr) noexcept :
1669 _ThisCommonOptionWithSelectorFieldClass {libObjPtr}
1670 {
1671 BT_ASSERT_DBG(this->isOptionWithBoolSelector());
1672 }
1673
1674 template <typename OtherLibObjT>
1675 CommonOptionWithBoolSelectorFieldClass(
100fa861 1676 const CommonOptionWithBoolSelectorFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
1677 _ThisCommonOptionWithSelectorFieldClass {fc}
1678 {
1679 }
1680
1681 template <typename OtherLibObjT>
0d6ad4d8 1682 CommonOptionWithBoolSelectorFieldClass&
100fa861 1683 operator=(const CommonOptionWithBoolSelectorFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
1684 {
1685 _ThisCommonOptionWithSelectorFieldClass::operator=(fc);
1686 return *this;
1687 }
1688
328a274a
PP
1689 CommonOptionWithBoolSelectorFieldClass<const bt_field_class> asConst() const noexcept
1690 {
1691 return CommonOptionWithBoolSelectorFieldClass<const bt_field_class> {*this};
1692 }
1693
12435a68
PP
1694 bool selectorIsReversed() const noexcept
1695 {
1696 return bt_field_class_option_with_selector_field_bool_selector_is_reversed(
341a67c4 1697 this->libObjPtr());
12435a68
PP
1698 }
1699
1700 Shared shared() const noexcept
1701 {
c9c0b6e2 1702 return Shared::createWithRef(*this);
12435a68
PP
1703 }
1704};
1705
1706using OptionWithBoolSelectorFieldClass = CommonOptionWithBoolSelectorFieldClass<bt_field_class>;
1707
1708using ConstOptionWithBoolSelectorFieldClass =
1709 CommonOptionWithBoolSelectorFieldClass<const bt_field_class>;
1710
1711namespace internal {
1712
4927bae7
PP
1713struct OptionWithBoolSelectorFieldClassTypeDescr
1714{
1715 using Const = ConstOptionWithBoolSelectorFieldClass;
1716 using NonConst = OptionWithBoolSelectorFieldClass;
1717};
1718
1719template <>
1720struct TypeDescr<OptionWithBoolSelectorFieldClass> :
1721 public OptionWithBoolSelectorFieldClassTypeDescr
1722{
1723};
1724
1725template <>
1726struct TypeDescr<ConstOptionWithBoolSelectorFieldClass> :
1727 public OptionWithBoolSelectorFieldClassTypeDescr
1728{
1729};
1730
12435a68
PP
1731template <typename RangeSetT>
1732struct CommonOptionWithIntegerSelectorFieldClassSpec;
1733
b5f55e9f 1734/* Functions specific to option field classes with unsigned integer ranges */
12435a68
PP
1735template <>
1736struct CommonOptionWithIntegerSelectorFieldClassSpec<ConstUnsignedIntegerRangeSet> final
1737{
1738 static const bt_integer_range_set_unsigned *
1739 ranges(const bt_field_class * const libObjPtr) noexcept
1740 {
1741 return bt_field_class_option_with_selector_field_integer_unsigned_borrow_selector_ranges_const(
1742 libObjPtr);
1743 }
1744};
1745
b5f55e9f 1746/* Functions specific to option field classes with signed ranges */
12435a68
PP
1747template <>
1748struct CommonOptionWithIntegerSelectorFieldClassSpec<ConstSignedIntegerRangeSet> final
1749{
1750 static const bt_integer_range_set_signed *
1751 ranges(const bt_field_class * const libObjPtr) noexcept
1752 {
1753 return bt_field_class_option_with_selector_field_integer_signed_borrow_selector_ranges_const(
1754 libObjPtr);
1755 }
1756};
1757
b5f55e9f 1758} /* namespace internal */
12435a68
PP
1759
1760template <typename LibObjT, typename RangeSetT>
1761class CommonOptionWithIntegerSelectorFieldClass : public CommonOptionWithSelectorFieldClass<LibObjT>
1762{
1763private:
1764 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
1765
1766 using typename CommonOptionWithSelectorFieldClass<
1767 LibObjT>::_ThisCommonOptionWithSelectorFieldClass;
1768
1769 using _ThisCommonOptionWithIntegerSelectorFieldClass =
1770 CommonOptionWithIntegerSelectorFieldClass<LibObjT, RangeSetT>;
1771
1772public:
26b9d24c 1773 using Shared = SharedFieldClass<_ThisCommonOptionWithIntegerSelectorFieldClass, LibObjT>;
12435a68
PP
1774
1775 using RangeSet = RangeSetT;
1776
1777 explicit CommonOptionWithIntegerSelectorFieldClass(const _LibObjPtr libObjPtr) noexcept :
1778 _ThisCommonOptionWithSelectorFieldClass {libObjPtr}
1779 {
1780 BT_ASSERT_DBG(this->isOptionWithIntegerSelector());
1781 }
1782
1783 template <typename OtherLibObjT>
1784 CommonOptionWithIntegerSelectorFieldClass(
100fa861 1785 const CommonOptionWithIntegerSelectorFieldClass<OtherLibObjT, RangeSetT> fc) noexcept :
12435a68
PP
1786 _ThisCommonOptionWithSelectorFieldClass {fc}
1787 {
1788 }
1789
1790 template <typename OtherLibObjT>
0d6ad4d8 1791 CommonOptionWithIntegerSelectorFieldClass&
100fa861 1792 operator=(const CommonOptionWithIntegerSelectorFieldClass<OtherLibObjT, RangeSetT> fc) noexcept
12435a68
PP
1793 {
1794 _ThisCommonOptionWithSelectorFieldClass::operator=(fc);
1795 return *this;
1796 }
1797
1798 RangeSet ranges() const noexcept
1799 {
1800 return RangeSet {internal::CommonOptionWithIntegerSelectorFieldClassSpec<RangeSetT>::ranges(
341a67c4 1801 this->libObjPtr())};
12435a68
PP
1802 }
1803
1804 Shared shared() const noexcept
1805 {
c9c0b6e2 1806 return Shared::createWithRef(*this);
12435a68
PP
1807 }
1808};
1809
1810using OptionWithUnsignedIntegerSelectorFieldClass =
1811 CommonOptionWithIntegerSelectorFieldClass<bt_field_class, ConstUnsignedIntegerRangeSet>;
1812
1813using ConstOptionWithUnsignedIntegerSelectorFieldClass =
1814 CommonOptionWithIntegerSelectorFieldClass<const bt_field_class, ConstUnsignedIntegerRangeSet>;
1815
1816using OptionWithSignedIntegerSelectorFieldClass =
1817 CommonOptionWithIntegerSelectorFieldClass<bt_field_class, ConstSignedIntegerRangeSet>;
1818
1819using ConstOptionWithSignedIntegerSelectorFieldClass =
1820 CommonOptionWithIntegerSelectorFieldClass<const bt_field_class, ConstSignedIntegerRangeSet>;
1821
1822namespace internal {
1823
4927bae7
PP
1824struct OptionWithUnsignedIntegerSelectorFieldClassTypeDescr
1825{
1826 using Const = ConstOptionWithUnsignedIntegerSelectorFieldClass;
1827 using NonConst = OptionWithUnsignedIntegerSelectorFieldClass;
1828};
1829
1830template <>
1831struct TypeDescr<OptionWithUnsignedIntegerSelectorFieldClass> :
1832 public OptionWithUnsignedIntegerSelectorFieldClassTypeDescr
1833{
1834};
1835
1836template <>
1837struct TypeDescr<ConstOptionWithUnsignedIntegerSelectorFieldClass> :
1838 public OptionWithUnsignedIntegerSelectorFieldClassTypeDescr
1839{
1840};
1841
1842struct OptionWithSignedIntegerSelectorFieldClassTypeDescr
1843{
1844 using Const = ConstOptionWithSignedIntegerSelectorFieldClass;
1845 using NonConst = OptionWithSignedIntegerSelectorFieldClass;
1846};
1847
1848template <>
1849struct TypeDescr<OptionWithSignedIntegerSelectorFieldClass> :
1850 public OptionWithSignedIntegerSelectorFieldClassTypeDescr
1851{
1852};
1853
1854template <>
1855struct TypeDescr<ConstOptionWithSignedIntegerSelectorFieldClass> :
1856 public OptionWithSignedIntegerSelectorFieldClassTypeDescr
1857{
1858};
1859
12435a68
PP
1860template <typename LibObjT>
1861struct CommonVariantFieldClassOptionSpec;
1862
b5f55e9f 1863/* Functions specific to mutable variant field class options */
12435a68
PP
1864template <>
1865struct CommonVariantFieldClassOptionSpec<bt_field_class_variant_option> final
1866{
1867 static bt_field_class *fieldClass(bt_field_class_variant_option * const libObjPtr) noexcept
1868 {
1869 return bt_field_class_variant_option_borrow_field_class(libObjPtr);
1870 }
8e557120
PP
1871
1872 static bt_value *userAttributes(bt_field_class_variant_option * const libObjPtr) noexcept
1873 {
1874 return bt_field_class_variant_option_borrow_user_attributes(libObjPtr);
1875 }
12435a68
PP
1876};
1877
b5f55e9f 1878/* Functions specific to constant variant field class options */
12435a68
PP
1879template <>
1880struct CommonVariantFieldClassOptionSpec<const bt_field_class_variant_option> final
1881{
1882 static const bt_field_class *
1883 fieldClass(const bt_field_class_variant_option * const libObjPtr) noexcept
1884 {
1885 return bt_field_class_variant_option_borrow_field_class_const(libObjPtr);
1886 }
8e557120
PP
1887
1888 static const bt_value *
1889 userAttributes(const bt_field_class_variant_option * const libObjPtr) noexcept
1890 {
1891 return bt_field_class_variant_option_borrow_user_attributes_const(libObjPtr);
1892 }
12435a68
PP
1893};
1894
b5f55e9f 1895} /* namespace internal */
12435a68
PP
1896
1897template <typename LibObjT>
0d218157 1898class CommonVariantFieldClassOption : public BorrowedObject<LibObjT>
12435a68
PP
1899{
1900private:
0d218157
PP
1901 using typename BorrowedObject<LibObjT>::_ThisBorrowedObject;
1902 using typename BorrowedObject<LibObjT>::_LibObjPtr;
8047a175 1903 using _FieldClass = internal::DepFc<LibObjT>;
12435a68
PP
1904
1905public:
8047a175 1906 using UserAttributes = internal::DepUserAttrs<LibObjT>;
8e557120 1907
12435a68 1908 explicit CommonVariantFieldClassOption(const _LibObjPtr libObjPtr) noexcept :
0d218157 1909 _ThisBorrowedObject {libObjPtr}
12435a68
PP
1910 {
1911 }
1912
1913 template <typename OtherLibObjT>
100fa861 1914 CommonVariantFieldClassOption(const CommonVariantFieldClassOption<OtherLibObjT> fc) noexcept :
0d218157 1915 _ThisBorrowedObject {fc}
12435a68
PP
1916 {
1917 }
1918
1919 template <typename OtherLibObjT>
0d6ad4d8 1920 CommonVariantFieldClassOption&
100fa861 1921 operator=(const CommonVariantFieldClassOption<OtherLibObjT> fc) noexcept
12435a68 1922 {
0d218157 1923 _ThisBorrowedObject::operator=(fc);
12435a68
PP
1924 return *this;
1925 }
1926
328a274a
PP
1927 CommonVariantFieldClassOption<const bt_field_class_variant_option> asConst() const noexcept
1928 {
1929 return CommonVariantFieldClassOption<const bt_field_class_variant_option> {*this};
1930 }
1931
41c4bedf 1932 nonstd::optional<bpstd::string_view> name() const noexcept
12435a68 1933 {
41c4bedf
PP
1934 const auto name = bt_field_class_variant_option_get_name(this->libObjPtr());
1935
1936 if (name) {
1937 return name;
1938 }
1939
1940 return nonstd::nullopt;
12435a68
PP
1941 }
1942
dcb8ae9b 1943 _FieldClass fieldClass() const noexcept
12435a68
PP
1944 {
1945 return _FieldClass {
341a67c4 1946 internal::CommonVariantFieldClassOptionSpec<LibObjT>::fieldClass(this->libObjPtr())};
12435a68 1947 }
8e557120
PP
1948
1949 template <typename LibValT>
b7ffa6f0 1950 void userAttributes(const CommonMapValue<LibValT> userAttrs) const noexcept
8e557120 1951 {
5c895f64
PP
1952 static_assert(!std::is_const<LibObjT>::value,
1953 "Not available with `bt2::ConstVariantFieldClassOption`.");
8e557120
PP
1954
1955 bt_field_class_variant_option_set_user_attributes(this->libObjPtr(), userAttrs.libObjPtr());
1956 }
1957
dcb8ae9b 1958 UserAttributes userAttributes() const noexcept
8e557120
PP
1959 {
1960 return UserAttributes {internal::CommonVariantFieldClassOptionSpec<LibObjT>::userAttributes(
1961 this->libObjPtr())};
1962 }
12435a68
PP
1963};
1964
1965using VariantFieldClassOption = CommonVariantFieldClassOption<bt_field_class_variant_option>;
1966
1967using ConstVariantFieldClassOption =
1968 CommonVariantFieldClassOption<const bt_field_class_variant_option>;
1969
1970namespace internal {
1971
4927bae7
PP
1972struct VariantFieldClassOptionTypeDescr
1973{
1974 using Const = ConstVariantFieldClassOption;
1975 using NonConst = VariantFieldClassOption;
1976};
1977
1978template <>
1979struct TypeDescr<VariantFieldClassOption> : public VariantFieldClassOptionTypeDescr
1980{
1981};
1982
1983template <>
1984struct TypeDescr<ConstVariantFieldClassOption> : public VariantFieldClassOptionTypeDescr
1985{
1986};
1987
12435a68
PP
1988template <typename LibObjT>
1989struct ConstVariantWithIntegerSelectorFieldClassOptionSpec;
1990
b5f55e9f 1991/* Functions specific to variant field class options with unsigned integer selector */
12435a68
PP
1992template <>
1993struct ConstVariantWithIntegerSelectorFieldClassOptionSpec<
1994 const bt_field_class_variant_with_selector_field_integer_unsigned_option>
1995 final
1996{
1997 static const bt_integer_range_set_unsigned *
1998 ranges(const bt_field_class_variant_with_selector_field_integer_unsigned_option
1999 * const libObjPtr) noexcept
2000 {
2001 return bt_field_class_variant_with_selector_field_integer_unsigned_option_borrow_ranges_const(
2002 libObjPtr);
2003 }
2004
2005 static const bt_field_class_variant_option *
2006 asBaseOption(const bt_field_class_variant_with_selector_field_integer_unsigned_option
2007 * const libObjPtr) noexcept
2008 {
2009 return bt_field_class_variant_with_selector_field_integer_unsigned_option_as_option_const(
2010 libObjPtr);
2011 }
2012};
2013
b5f55e9f 2014/* Functions specific to variant field class options with signed integer selector */
12435a68
PP
2015template <>
2016struct ConstVariantWithIntegerSelectorFieldClassOptionSpec<
2017 const bt_field_class_variant_with_selector_field_integer_signed_option>
2018 final
2019{
2020 static const bt_integer_range_set_signed *
2021 ranges(const bt_field_class_variant_with_selector_field_integer_signed_option
2022 * const libObjPtr) noexcept
2023 {
2024 return bt_field_class_variant_with_selector_field_integer_signed_option_borrow_ranges_const(
2025 libObjPtr);
2026 }
2027
2028 static const bt_field_class_variant_option *
2029 asBaseOption(const bt_field_class_variant_with_selector_field_integer_signed_option
2030 * const libObjPtr) noexcept
2031 {
2032 return bt_field_class_variant_with_selector_field_integer_signed_option_as_option_const(
2033 libObjPtr);
2034 }
2035};
2036
b5f55e9f 2037} /* namespace internal */
12435a68
PP
2038
2039template <typename LibObjT>
0d218157 2040class ConstVariantWithIntegerSelectorFieldClassOption : public BorrowedObject<LibObjT>
12435a68
PP
2041{
2042private:
0d218157
PP
2043 using typename BorrowedObject<LibObjT>::_ThisBorrowedObject;
2044 using typename BorrowedObject<LibObjT>::_LibObjPtr;
12435a68
PP
2045 using _Spec = internal::ConstVariantWithIntegerSelectorFieldClassOptionSpec<LibObjT>;
2046
2047public:
2048 using RangeSet = typename std::conditional<
2049 std::is_same<
2050 LibObjT,
2051 const bt_field_class_variant_with_selector_field_integer_unsigned_option>::value,
2052 ConstUnsignedIntegerRangeSet, ConstSignedIntegerRangeSet>::type;
2053
2054 explicit ConstVariantWithIntegerSelectorFieldClassOption(const _LibObjPtr libObjPtr) noexcept :
0d218157 2055 _ThisBorrowedObject {libObjPtr}
12435a68
PP
2056 {
2057 }
2058
2059 template <typename OtherLibObjT>
2060 ConstVariantWithIntegerSelectorFieldClassOption(
100fa861 2061 const ConstVariantWithIntegerSelectorFieldClassOption<OtherLibObjT> fc) noexcept :
0d218157 2062 _ThisBorrowedObject {fc}
12435a68
PP
2063 {
2064 }
2065
2066 template <typename OtherLibObjT>
0d6ad4d8 2067 ConstVariantWithIntegerSelectorFieldClassOption&
100fa861 2068 operator=(const ConstVariantWithIntegerSelectorFieldClassOption<OtherLibObjT> fc) noexcept
12435a68 2069 {
0d218157 2070 _ThisBorrowedObject::operator=(fc);
12435a68
PP
2071 return *this;
2072 }
2073
2074 ConstVariantFieldClassOption asBaseOption() const noexcept
2075 {
341a67c4 2076 return ConstVariantFieldClassOption {_Spec::asBaseOption(this->libObjPtr())};
12435a68
PP
2077 }
2078
41c4bedf 2079 nonstd::optional<bpstd::string_view> name() const noexcept
12435a68
PP
2080 {
2081 return this->asBaseOption().name();
2082 }
2083
2084 ConstFieldClass fieldClass() const noexcept
2085 {
2086 return this->asBaseOption().fieldClass();
2087 }
2088
2089 RangeSet ranges() const noexcept
2090 {
341a67c4 2091 return RangeSet {_Spec::ranges(this->libObjPtr())};
12435a68
PP
2092 }
2093};
2094
2095using ConstVariantWithUnsignedIntegerSelectorFieldClassOption =
2096 ConstVariantWithIntegerSelectorFieldClassOption<
2097 const bt_field_class_variant_with_selector_field_integer_unsigned_option>;
2098
2099using ConstVariantWithSignedIntegerSelectorFieldClassOption =
2100 ConstVariantWithIntegerSelectorFieldClassOption<
2101 const bt_field_class_variant_with_selector_field_integer_signed_option>;
2102
2103namespace internal {
2104
2105template <typename LibObjT>
2106struct CommonVariantFieldClassSpec;
2107
b5f55e9f 2108/* Functions specific to mutable variant field classes */
12435a68
PP
2109template <>
2110struct CommonVariantFieldClassSpec<bt_field_class> final
2111{
2112 static bt_field_class_variant_option *optionByIndex(bt_field_class * const libObjPtr,
2113 const std::uint64_t index) noexcept
2114 {
2115 return bt_field_class_variant_borrow_option_by_index(libObjPtr, index);
2116 }
2117
2118 static bt_field_class_variant_option *optionByName(bt_field_class * const libObjPtr,
2119 const char * const name) noexcept
2120 {
2121 return bt_field_class_variant_borrow_option_by_name(libObjPtr, name);
2122 }
2123};
2124
b5f55e9f 2125/* Functions specific to constant variant field classes */
12435a68
PP
2126template <>
2127struct CommonVariantFieldClassSpec<const bt_field_class> final
2128{
2129 static const bt_field_class_variant_option *
2130 optionByIndex(const bt_field_class * const libObjPtr, const std::uint64_t index) noexcept
2131 {
2132 return bt_field_class_variant_borrow_option_by_index_const(libObjPtr, index);
2133 }
2134
2135 static const bt_field_class_variant_option *optionByName(const bt_field_class * const libObjPtr,
2136 const char * const name) noexcept
2137 {
2138 return bt_field_class_variant_borrow_option_by_name_const(libObjPtr, name);
2139 }
2140};
2141
b5f55e9f 2142} /* namespace internal */
12435a68
PP
2143
2144template <typename LibObjT>
2145class CommonVariantFieldClass : public CommonFieldClass<LibObjT>
2146{
2147private:
2148 using typename CommonFieldClass<LibObjT>::_ThisCommonFieldClass;
2149
2150protected:
2151 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
2152 using _ThisCommonVariantFieldClass = CommonVariantFieldClass<LibObjT>;
2153
2154public:
26b9d24c 2155 using Shared = SharedFieldClass<CommonVariantFieldClass<LibObjT>, LibObjT>;
12435a68
PP
2156
2157 using Option =
8047a175 2158 internal::DepType<LibObjT, VariantFieldClassOption, ConstVariantFieldClassOption>;
12435a68 2159
3c02a7cb 2160 using Iterator = CommonIterator<CommonVariantFieldClass, Option>;
5046c776 2161
12435a68
PP
2162 explicit CommonVariantFieldClass(const _LibObjPtr libObjPtr) noexcept :
2163 _ThisCommonFieldClass {libObjPtr}
2164 {
2165 BT_ASSERT_DBG(this->isVariant());
2166 }
2167
2168 template <typename OtherLibObjT>
100fa861 2169 CommonVariantFieldClass(const CommonVariantFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
2170 _ThisCommonFieldClass {fc}
2171 {
2172 }
2173
2174 template <typename OtherLibObjT>
100fa861 2175 CommonVariantFieldClass& operator=(const CommonVariantFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
2176 {
2177 _ThisCommonFieldClass::operator=(fc);
2178 return *this;
2179 }
2180
328a274a
PP
2181 CommonVariantFieldClass<const bt_field_class> asConst() const noexcept
2182 {
2183 return CommonVariantFieldClass<const bt_field_class> {*this};
2184 }
2185
c0b73c63 2186 std::uint64_t length() const noexcept
12435a68 2187 {
341a67c4 2188 return bt_field_class_variant_get_option_count(this->libObjPtr());
12435a68
PP
2189 }
2190
5046c776
FD
2191 Iterator begin() const noexcept
2192 {
2193 return Iterator {*this, 0};
2194 }
2195
2196 Iterator end() const noexcept
2197 {
c0b73c63 2198 return Iterator {*this, this->length()};
5046c776
FD
2199 }
2200
dcb8ae9b 2201 Option operator[](const std::uint64_t index) const noexcept
12435a68
PP
2202 {
2203 return Option {internal::CommonVariantFieldClassSpec<LibObjT>::optionByIndex(
341a67c4 2204 this->libObjPtr(), index)};
12435a68
PP
2205 }
2206
dcb8ae9b 2207 nonstd::optional<Option> operator[](const char * const name) const noexcept
12435a68
PP
2208 {
2209 const auto libObjPtr =
341a67c4 2210 internal::CommonVariantFieldClassSpec<LibObjT>::optionByName(this->libObjPtr(), name);
12435a68
PP
2211
2212 if (libObjPtr) {
2213 return Option {libObjPtr};
2214 }
2215
2216 return nonstd::nullopt;
2217 }
2218
dcb8ae9b 2219 nonstd::optional<Option> operator[](const std::string& name) const noexcept
12435a68
PP
2220 {
2221 return (*this)[name.data()];
2222 }
2223
2224 Shared shared() const noexcept
2225 {
c9c0b6e2 2226 return Shared::createWithRef(*this);
12435a68
PP
2227 }
2228};
2229
2230using VariantFieldClass = CommonVariantFieldClass<bt_field_class>;
2231using ConstVariantFieldClass = CommonVariantFieldClass<const bt_field_class>;
2232
4927bae7
PP
2233namespace internal {
2234
2235struct VariantFieldClassTypeDescr
2236{
2237 using Const = ConstVariantFieldClass;
2238 using NonConst = VariantFieldClass;
2239};
2240
2241template <>
2242struct TypeDescr<VariantFieldClass> : public VariantFieldClassTypeDescr
2243{
2244};
2245
2246template <>
2247struct TypeDescr<ConstVariantFieldClass> : public VariantFieldClassTypeDescr
2248{
2249};
2250
2251} /* namespace internal */
2252
12435a68
PP
2253template <typename LibObjT>
2254class CommonVariantWithoutSelectorFieldClass : public CommonVariantFieldClass<LibObjT>
2255{
2256private:
2257 using typename CommonVariantFieldClass<LibObjT>::_ThisCommonVariantFieldClass;
2258 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
2259
2260public:
26b9d24c 2261 using Shared = SharedFieldClass<CommonVariantWithoutSelectorFieldClass<LibObjT>, LibObjT>;
12435a68
PP
2262
2263 explicit CommonVariantWithoutSelectorFieldClass(const _LibObjPtr libObjPtr) noexcept :
2264 _ThisCommonVariantFieldClass {libObjPtr}
2265 {
2266 BT_ASSERT_DBG(this->isVariantWithoutSelector());
2267 }
2268
2269 template <typename OtherLibObjT>
2270 CommonVariantWithoutSelectorFieldClass(
100fa861 2271 const CommonVariantWithoutSelectorFieldClass<OtherLibObjT> fc) noexcept :
12435a68
PP
2272 _ThisCommonVariantFieldClass {fc}
2273 {
2274 }
2275
2276 template <typename OtherLibObjT>
0d6ad4d8 2277 CommonVariantWithoutSelectorFieldClass&
100fa861 2278 operator=(const CommonVariantWithoutSelectorFieldClass<OtherLibObjT> fc) noexcept
12435a68
PP
2279 {
2280 _ThisCommonVariantFieldClass::operator=(fc);
2281 return *this;
2282 }
2283
328a274a
PP
2284 CommonVariantWithoutSelectorFieldClass<const bt_field_class> asConst() const noexcept
2285 {
2286 return CommonVariantWithoutSelectorFieldClass<const bt_field_class> {*this};
2287 }
2288
dcb8ae9b 2289 void appendOption(const char * const name, const FieldClass fc) const
12435a68 2290 {
5c895f64
PP
2291 static_assert(!std::is_const<LibObjT>::value,
2292 "Not available with `bt2::ConstVariantWithoutSelectorFieldClass`.");
12435a68
PP
2293
2294 const auto status = bt_field_class_variant_without_selector_append_option(
341a67c4 2295 this->libObjPtr(), name, fc.libObjPtr());
12435a68
PP
2296
2297 if (status ==
2298 BT_FIELD_CLASS_VARIANT_WITHOUT_SELECTOR_FIELD_APPEND_OPTION_STATUS_MEMORY_ERROR) {
39278ebc 2299 throw MemoryError {};
12435a68
PP
2300 }
2301 }
2302
dcb8ae9b 2303 void appendOption(const nonstd::optional<std::string>& name, const FieldClass fc) const
12435a68 2304 {
41c4bedf 2305 this->appendOption(name ? name->data() : nullptr, fc);
12435a68
PP
2306 }
2307
2308 Shared shared() const noexcept
2309 {
c9c0b6e2 2310 return Shared::createWithRef(*this);
12435a68
PP
2311 }
2312};
2313
2314using VariantWithoutSelectorFieldClass = CommonVariantWithoutSelectorFieldClass<bt_field_class>;
2315using ConstVariantWithoutSelectorFieldClass =
2316 CommonVariantWithoutSelectorFieldClass<const bt_field_class>;
2317
2318namespace internal {
2319
4927bae7
PP
2320struct VariantWithoutSelectorFieldClassTypeDescr
2321{
2322 using Const = ConstVariantWithoutSelectorFieldClass;
2323 using NonConst = VariantWithoutSelectorFieldClass;
2324};
2325
2326template <>
2327struct TypeDescr<VariantWithoutSelectorFieldClass> :
2328 public VariantWithoutSelectorFieldClassTypeDescr
2329{
2330};
2331
2332template <>
2333struct TypeDescr<ConstVariantWithoutSelectorFieldClass> :
2334 public VariantWithoutSelectorFieldClassTypeDescr
2335{
2336};
2337
12435a68
PP
2338template <typename OptionT>
2339struct CommonVariantWithIntegerSelectorFieldClassSpec;
2340
b5f55e9f 2341/* Functions specific to variant field classes with unsigned integer selector */
12435a68
PP
2342template <>
2343struct CommonVariantWithIntegerSelectorFieldClassSpec<
2344 ConstVariantWithUnsignedIntegerSelectorFieldClassOption>
2345 final
2346{
2347 static const bt_field_class_variant_with_selector_field_integer_unsigned_option *
2348 optionByIndex(const bt_field_class * const libObjPtr, const std::uint64_t index) noexcept
2349 {
2350 return bt_field_class_variant_with_selector_field_integer_unsigned_borrow_option_by_index_const(
2351 libObjPtr, index);
2352 }
2353
2354 static const bt_field_class_variant_with_selector_field_integer_unsigned_option *
2355 optionByName(const bt_field_class * const libObjPtr, const char * const name) noexcept
2356 {
2357 return bt_field_class_variant_with_selector_field_integer_unsigned_borrow_option_by_name_const(
2358 libObjPtr, name);
2359 }
2360
2361 static bt_field_class_variant_with_selector_field_integer_append_option_status
2362 appendOption(bt_field_class * const libObjPtr, const char * const name,
2363 bt_field_class * const libOptFcPtr,
2364 const bt_integer_range_set_unsigned * const libRangesPtr)
2365 {
2366 return bt_field_class_variant_with_selector_field_integer_unsigned_append_option(
2367 libObjPtr, name, libOptFcPtr, libRangesPtr);
2368 }
2369};
2370
b5f55e9f 2371/* Functions specific to variant field classes with signed integer selector */
12435a68
PP
2372template <>
2373struct CommonVariantWithIntegerSelectorFieldClassSpec<
2374 ConstVariantWithSignedIntegerSelectorFieldClassOption>
2375 final
2376{
2377 static const bt_field_class_variant_with_selector_field_integer_signed_option *
2378 optionByIndex(const bt_field_class * const libObjPtr, const std::uint64_t index) noexcept
2379 {
2380 return bt_field_class_variant_with_selector_field_integer_signed_borrow_option_by_index_const(
2381 libObjPtr, index);
2382 }
2383
2384 static const bt_field_class_variant_with_selector_field_integer_signed_option *
2385 optionByName(const bt_field_class * const libObjPtr, const char * const name) noexcept
2386 {
2387 return bt_field_class_variant_with_selector_field_integer_signed_borrow_option_by_name_const(
2388 libObjPtr, name);
2389 }
2390
2391 static bt_field_class_variant_with_selector_field_integer_append_option_status
2392 appendOption(bt_field_class * const libObjPtr, const char * const name,
2393 bt_field_class * const libOptFcPtr,
2394 const bt_integer_range_set_signed * const libRangesPtr)
2395 {
2396 return bt_field_class_variant_with_selector_field_integer_signed_append_option(
2397 libObjPtr, name, libOptFcPtr, libRangesPtr);
2398 }
2399};
2400
b5f55e9f 2401} /* namespace internal */
12435a68 2402
cefe03a2
FD
2403template <typename LibObjT>
2404class CommonVariantWithSelectorFieldClass : public CommonVariantFieldClass<LibObjT>
12435a68
PP
2405{
2406private:
2407 using typename CommonVariantFieldClass<LibObjT>::_ThisCommonVariantFieldClass;
cefe03a2
FD
2408
2409protected:
12435a68 2410 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
cefe03a2
FD
2411 using _ThisCommonVariantWithSelectorFieldClass = CommonVariantWithSelectorFieldClass<LibObjT>;
2412
2413public:
26b9d24c 2414 using Shared = SharedFieldClass<_ThisCommonVariantWithSelectorFieldClass, LibObjT>;
cefe03a2
FD
2415
2416 explicit CommonVariantWithSelectorFieldClass(const _LibObjPtr libObjPtr) noexcept :
2417 _ThisCommonVariantFieldClass {libObjPtr}
2418 {
2419 BT_ASSERT_DBG(this->isVariantWithSelector());
2420 }
2421
2422 template <typename OtherLibObjT>
2423 CommonVariantWithSelectorFieldClass(
100fa861 2424 const CommonVariantWithSelectorFieldClass<OtherLibObjT> fc) noexcept :
cefe03a2
FD
2425 _ThisCommonVariantFieldClass {fc}
2426 {
2427 }
2428
2429 template <typename OtherLibObjT>
0d6ad4d8 2430 CommonVariantWithSelectorFieldClass&
100fa861 2431 operator=(const CommonVariantWithSelectorFieldClass<OtherLibObjT> fc) noexcept
cefe03a2
FD
2432 {
2433 _ThisCommonVariantFieldClass::operator=(fc);
2434 return *this;
2435 }
2436
328a274a
PP
2437 CommonVariantWithSelectorFieldClass<const bt_field_class> asConst() const noexcept
2438 {
2439 return CommonVariantWithSelectorFieldClass<const bt_field_class> {*this};
2440 }
2441
cefe03a2
FD
2442 ConstFieldPath selectorFieldPath() const noexcept
2443 {
2444 return ConstFieldPath {
2445 bt_field_class_variant_with_selector_field_borrow_selector_field_path_const(
341a67c4 2446 this->libObjPtr())};
cefe03a2
FD
2447 }
2448
2449 Shared shared() const noexcept
2450 {
c9c0b6e2 2451 return Shared::createWithRef(*this);
cefe03a2
FD
2452 }
2453};
12435a68 2454
3c02a7cb
FD
2455using VariantWithSelectorFieldClass = CommonVariantWithSelectorFieldClass<bt_field_class>;
2456using ConstVariantWithSelectorFieldClass =
2457 CommonVariantWithSelectorFieldClass<const bt_field_class>;
2458
cefe03a2
FD
2459template <typename LibObjT, typename OptionT>
2460class CommonVariantWithIntegerSelectorFieldClass :
2461 public CommonVariantWithSelectorFieldClass<LibObjT>
2462{
2463private:
2464 using typename CommonVariantWithSelectorFieldClass<
2465 LibObjT>::_ThisCommonVariantWithSelectorFieldClass;
2466 using typename CommonFieldClass<LibObjT>::_LibObjPtr;
12435a68
PP
2467 using _ThisCommonVariantWithIntegerSelectorFieldClass =
2468 CommonVariantWithIntegerSelectorFieldClass<LibObjT, OptionT>;
2469
2470 using _Spec = internal::CommonVariantWithIntegerSelectorFieldClassSpec<OptionT>;
2471
2472public:
26b9d24c 2473 using Shared = SharedFieldClass<_ThisCommonVariantWithIntegerSelectorFieldClass, LibObjT>;
12435a68
PP
2474
2475 using Option = OptionT;
3c02a7cb
FD
2476 using Iterator =
2477 CommonIterator<CommonVariantWithIntegerSelectorFieldClass<LibObjT, Option>, Option>;
12435a68
PP
2478
2479 explicit CommonVariantWithIntegerSelectorFieldClass(const _LibObjPtr libObjPtr) noexcept :
cefe03a2 2480 _ThisCommonVariantWithSelectorFieldClass {libObjPtr}
12435a68
PP
2481 {
2482 BT_ASSERT_DBG(this->isVariant());
2483 }
2484
2485 template <typename OtherLibObjT>
2486 CommonVariantWithIntegerSelectorFieldClass(
100fa861 2487 const CommonVariantWithIntegerSelectorFieldClass<OtherLibObjT, OptionT> fc) noexcept :
cefe03a2 2488 _ThisCommonVariantWithSelectorFieldClass {fc}
12435a68
PP
2489 {
2490 }
2491
2492 template <typename OtherLibObjT>
0d6ad4d8 2493 CommonVariantWithIntegerSelectorFieldClass&
100fa861 2494 operator=(const CommonVariantWithIntegerSelectorFieldClass<OtherLibObjT, OptionT> fc) noexcept
12435a68 2495 {
cefe03a2 2496 _ThisCommonVariantWithSelectorFieldClass::operator=(fc);
12435a68
PP
2497 return *this;
2498 }
2499
12435a68
PP
2500 Option operator[](const std::uint64_t index) const noexcept
2501 {
341a67c4 2502 return Option {_Spec::optionByIndex(this->libObjPtr(), index)};
12435a68
PP
2503 }
2504
2505 nonstd::optional<Option> operator[](const char * const name) const noexcept
2506 {
341a67c4 2507 const auto libObjPtr = _Spec::optionByName(this->libObjPtr(), name);
12435a68
PP
2508
2509 if (libObjPtr) {
2510 return Option {libObjPtr};
2511 }
2512
2513 return nonstd::nullopt;
2514 }
2515
2516 nonstd::optional<Option> operator[](const std::string& name) const noexcept
2517 {
2518 return (*this)[name.data()];
2519 }
2520
100fa861 2521 void appendOption(const char * const name, const FieldClass fc,
dcb8ae9b 2522 const typename Option::RangeSet ranges) const
12435a68 2523 {
5c895f64
PP
2524 static_assert(
2525 !std::is_const<LibObjT>::value,
2526 "Not available with `bt2::ConstVariantWithUnsignedIntegerSelectorFieldClass`.");
12435a68
PP
2527
2528 const auto status =
341a67c4 2529 _Spec::appendOption(this->libObjPtr(), name, fc.libObjPtr(), ranges.libObjPtr());
12435a68
PP
2530
2531 if (status ==
2532 BT_FIELD_CLASS_VARIANT_WITH_SELECTOR_FIELD_APPEND_OPTION_STATUS_MEMORY_ERROR) {
39278ebc 2533 throw MemoryError {};
12435a68
PP
2534 }
2535 }
2536
100fa861 2537 void appendOption(const nonstd::optional<std::string>& name, const FieldClass fc,
dcb8ae9b 2538 const typename Option::RangeSet ranges) const
12435a68 2539 {
41c4bedf 2540 this->appendOption(name ? name->data() : nullptr, fc, ranges);
12435a68
PP
2541 }
2542
3c02a7cb
FD
2543 Iterator begin() const noexcept
2544 {
2545 return Iterator {*this, 0};
2546 }
2547
2548 Iterator end() const noexcept
2549 {
c0b73c63 2550 return Iterator {*this, this->length()};
3c02a7cb
FD
2551 }
2552
12435a68
PP
2553 Shared shared() const noexcept
2554 {
c9c0b6e2 2555 return Shared::createWithRef(*this);
12435a68
PP
2556 }
2557};
2558
2559using VariantWithUnsignedIntegerSelectorFieldClass = CommonVariantWithIntegerSelectorFieldClass<
2560 bt_field_class, ConstVariantWithUnsignedIntegerSelectorFieldClassOption>;
2561
2562using ConstVariantWithUnsignedIntegerSelectorFieldClass =
2563 CommonVariantWithIntegerSelectorFieldClass<
2564 const bt_field_class, ConstVariantWithUnsignedIntegerSelectorFieldClassOption>;
2565
2566using VariantWithSignedIntegerSelectorFieldClass = CommonVariantWithIntegerSelectorFieldClass<
2567 bt_field_class, ConstVariantWithSignedIntegerSelectorFieldClassOption>;
2568
2569using ConstVariantWithSignedIntegerSelectorFieldClass = CommonVariantWithIntegerSelectorFieldClass<
2570 const bt_field_class, ConstVariantWithSignedIntegerSelectorFieldClassOption>;
2571
4927bae7
PP
2572namespace internal {
2573
2574struct VariantWithUnsignedIntegerSelectorFieldClassTypeDescr
2575{
2576 using Const = ConstVariantWithUnsignedIntegerSelectorFieldClass;
2577 using NonConst = VariantWithUnsignedIntegerSelectorFieldClass;
2578};
2579
2580template <>
2581struct TypeDescr<VariantWithUnsignedIntegerSelectorFieldClass> :
2582 public VariantWithUnsignedIntegerSelectorFieldClassTypeDescr
2583{
2584};
2585
2586template <>
2587struct TypeDescr<ConstVariantWithUnsignedIntegerSelectorFieldClass> :
2588 public VariantWithUnsignedIntegerSelectorFieldClassTypeDescr
2589{
2590};
2591
2592struct VariantWithSignedIntegerSelectorFieldClassTypeDescr
2593{
2594 using Const = ConstVariantWithSignedIntegerSelectorFieldClass;
2595 using NonConst = VariantWithSignedIntegerSelectorFieldClass;
2596};
2597
2598template <>
2599struct TypeDescr<VariantWithSignedIntegerSelectorFieldClass> :
2600 public VariantWithSignedIntegerSelectorFieldClassTypeDescr
2601{
2602};
2603
2604template <>
2605struct TypeDescr<ConstVariantWithSignedIntegerSelectorFieldClass> :
2606 public VariantWithSignedIntegerSelectorFieldClassTypeDescr
2607{
2608};
2609
2610} /* namespace internal */
2611
12435a68
PP
2612template <typename LibObjT>
2613CommonBitArrayFieldClass<LibObjT> CommonFieldClass<LibObjT>::asBitArray() const noexcept
2614{
2615 BT_ASSERT_DBG(this->isBitArray());
341a67c4 2616 return CommonBitArrayFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2617}
2618
2619template <typename LibObjT>
2620CommonIntegerFieldClass<LibObjT> CommonFieldClass<LibObjT>::asInteger() const noexcept
2621{
2622 BT_ASSERT_DBG(this->isInteger());
341a67c4 2623 return CommonIntegerFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2624}
2625
be6aa636
FD
2626template <typename LibObjT>
2627CommonBaseEnumerationFieldClass<LibObjT> CommonFieldClass<LibObjT>::asEnumeration() const noexcept
2628{
2629 BT_ASSERT_DBG(this->isEnumeration());
341a67c4 2630 return CommonBaseEnumerationFieldClass<LibObjT> {this->libObjPtr()};
be6aa636
FD
2631}
2632
12435a68
PP
2633template <typename LibObjT>
2634CommonEnumerationFieldClass<LibObjT, ConstUnsignedEnumerationFieldClassMapping>
2635CommonFieldClass<LibObjT>::asUnsignedEnumeration() const noexcept
2636{
2637 BT_ASSERT_DBG(this->isUnsignedEnumeration());
2638 return CommonEnumerationFieldClass<LibObjT, ConstUnsignedEnumerationFieldClassMapping> {
341a67c4 2639 this->libObjPtr()};
12435a68
PP
2640}
2641
2642template <typename LibObjT>
2643CommonEnumerationFieldClass<LibObjT, ConstSignedEnumerationFieldClassMapping>
2644CommonFieldClass<LibObjT>::asSignedEnumeration() const noexcept
2645{
2646 BT_ASSERT_DBG(this->isSignedEnumeration());
2647 return CommonEnumerationFieldClass<LibObjT, ConstSignedEnumerationFieldClassMapping> {
341a67c4 2648 this->libObjPtr()};
12435a68
PP
2649}
2650
2651template <typename LibObjT>
2652CommonStructureFieldClass<LibObjT> CommonFieldClass<LibObjT>::asStructure() const noexcept
2653{
2654 BT_ASSERT_DBG(this->isStructure());
341a67c4 2655 return CommonStructureFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2656}
2657
2658template <typename LibObjT>
2659CommonArrayFieldClass<LibObjT> CommonFieldClass<LibObjT>::asArray() const noexcept
2660{
2661 BT_ASSERT_DBG(this->isArray());
341a67c4 2662 return CommonArrayFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2663}
2664
2665template <typename LibObjT>
2666CommonStaticArrayFieldClass<LibObjT> CommonFieldClass<LibObjT>::asStaticArray() const noexcept
2667{
2668 BT_ASSERT_DBG(this->isStaticArray());
341a67c4 2669 return CommonStaticArrayFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2670}
2671
2672template <typename LibObjT>
2673CommonDynamicArrayWithLengthFieldClass<LibObjT>
2674CommonFieldClass<LibObjT>::asDynamicArrayWithLength() const noexcept
2675{
2676 BT_ASSERT_DBG(this->isDynamicArrayWithLength());
341a67c4 2677 return CommonDynamicArrayWithLengthFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2678}
2679
2680template <typename LibObjT>
2681CommonOptionFieldClass<LibObjT> CommonFieldClass<LibObjT>::asOption() const noexcept
2682{
2683 BT_ASSERT_DBG(this->isOption());
341a67c4 2684 return CommonOptionFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2685}
2686
2687template <typename LibObjT>
2688CommonOptionWithSelectorFieldClass<LibObjT>
2689CommonFieldClass<LibObjT>::asOptionWithSelector() const noexcept
2690{
2691 BT_ASSERT_DBG(this->isOptionWithSelector());
341a67c4 2692 return CommonOptionWithSelectorFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2693}
2694
2695template <typename LibObjT>
2696CommonOptionWithBoolSelectorFieldClass<LibObjT>
2697CommonFieldClass<LibObjT>::asOptionWithBoolSelector() const noexcept
2698{
2699 BT_ASSERT_DBG(this->isOptionWithBoolSelector());
341a67c4 2700 return CommonOptionWithBoolSelectorFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2701}
2702
2703template <typename LibObjT>
2704CommonOptionWithIntegerSelectorFieldClass<LibObjT, ConstUnsignedIntegerRangeSet>
2705CommonFieldClass<LibObjT>::asOptionWithUnsignedIntegerSelector() const noexcept
2706{
2707 BT_ASSERT_DBG(this->isOptionWithUnsignedIntegerSelector());
2708 return CommonOptionWithIntegerSelectorFieldClass<LibObjT, ConstUnsignedIntegerRangeSet> {
341a67c4 2709 this->libObjPtr()};
12435a68
PP
2710}
2711
2712template <typename LibObjT>
2713CommonOptionWithIntegerSelectorFieldClass<LibObjT, ConstSignedIntegerRangeSet>
2714CommonFieldClass<LibObjT>::asOptionWithSignedIntegerSelector() const noexcept
2715{
2716 BT_ASSERT_DBG(this->isOptionWithSignedIntegerSelector());
2717 return CommonOptionWithIntegerSelectorFieldClass<LibObjT, ConstSignedIntegerRangeSet> {
341a67c4 2718 this->libObjPtr()};
12435a68
PP
2719}
2720
2721template <typename LibObjT>
2722CommonVariantFieldClass<LibObjT> CommonFieldClass<LibObjT>::asVariant() const noexcept
2723{
2724 BT_ASSERT_DBG(this->isVariant());
341a67c4 2725 return CommonVariantFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2726}
2727
2728template <typename LibObjT>
2729CommonVariantWithoutSelectorFieldClass<LibObjT>
2730CommonFieldClass<LibObjT>::asVariantWithoutSelector() const noexcept
2731{
2732 BT_ASSERT_DBG(this->isVariantWithoutSelector());
341a67c4 2733 return CommonVariantWithoutSelectorFieldClass<LibObjT> {this->libObjPtr()};
12435a68
PP
2734}
2735
2736template <typename LibObjT>
cefe03a2
FD
2737CommonVariantWithSelectorFieldClass<LibObjT>
2738CommonFieldClass<LibObjT>::asVariantWithSelector() const noexcept
2739{
2740 BT_ASSERT_DBG(this->isVariantWithSelector());
341a67c4 2741 return CommonVariantWithSelectorFieldClass<LibObjT> {this->libObjPtr()};
cefe03a2
FD
2742}
2743
2744template <typename LibObjT>
12435a68
PP
2745CommonVariantWithIntegerSelectorFieldClass<LibObjT,
2746 ConstVariantWithUnsignedIntegerSelectorFieldClassOption>
2747CommonFieldClass<LibObjT>::asVariantWithUnsignedIntegerSelector() const noexcept
2748{
2749 BT_ASSERT_DBG(this->isVariantWithUnsignedIntegerSelector());
2750 return CommonVariantWithIntegerSelectorFieldClass<
341a67c4 2751 LibObjT, ConstVariantWithUnsignedIntegerSelectorFieldClassOption> {this->libObjPtr()};
12435a68
PP
2752}
2753
2754template <typename LibObjT>
2755CommonVariantWithIntegerSelectorFieldClass<LibObjT,
2756 ConstVariantWithSignedIntegerSelectorFieldClassOption>
2757CommonFieldClass<LibObjT>::asVariantWithSignedIntegerSelector() const noexcept
2758{
2759 BT_ASSERT_DBG(this->isVariantWithSignedIntegerSelector());
2760 return CommonVariantWithIntegerSelectorFieldClass<
341a67c4 2761 LibObjT, ConstVariantWithSignedIntegerSelectorFieldClassOption> {this->libObjPtr()};
12435a68
PP
2762}
2763
b5f55e9f 2764} /* namespace bt2 */
12435a68 2765
b5f55e9f 2766#endif /* BABELTRACE_CPP_COMMON_BT2_FIELD_CLASS_HPP */
This page took 0.166559 seconds and 4 git commands to generate.