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