COMMS
Template library intended to help with implementation of communication protocols.
Loading...
Searching...
No Matches
Bitfield.h
Go to the documentation of this file.
1//
2// Copyright 2015 - 2026 (C). Alex Robenko. All rights reserved.
3//
4// SPDX-License-Identifier: MPL-2.0
5//
6// This Source Code Form is subject to the terms of the Mozilla Public
7// License, v. 2.0. If a copy of the MPL was not distributed with this
8// file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
12
13#pragma once
14
15#include "comms/ErrorStatus.h"
16#include "comms/field/basic/Bitfield.h"
17#include "comms/field/details/AdaptBasicField.h"
18#include "comms/options.h"
19
20#include <cstddef>
21#include <type_traits>
22#include <utility>
23
24namespace comms
25{
26
27namespace field
28{
29
87
97template <typename TFieldBase, typename TMembers, typename... TOptions>
98class Bitfield : public
99 details::AdaptBasicFieldT<
100 basic::Bitfield<
101 TFieldBase,
102 details::OptionsParser<TOptions...>::ForcedMembersVersionDependency,
103 TMembers
104 >,
105 TOptions...
106 >
107{
108 using BaseImpl =
109 details::AdaptBasicFieldT<
110 basic::Bitfield<
111 TFieldBase,
112 details::OptionsParser<TOptions...>::ForcedMembersVersionDependency,
113 TMembers
114 >,
115 TOptions...
116 >;
117
118public:
120 using FieldBase = TFieldBase;
121
123 using Endian = typename BaseImpl::Endian;
124
126 using VersionType = typename BaseImpl::VersionType;
127
129 using ParsedOptions = details::OptionsParser<TOptions...>;
130
132 using CommsTag = typename BaseImpl::CommsTag;
133
137 using ValueType = typename BaseImpl::ValueType;
138
142 using FieldType = typename ParsedOptions::FieldType;
143
146 Bitfield() = default;
147
150 explicit Bitfield(const ValueType& val)
151 : BaseImpl(val)
152 {
153 }
154
157 explicit Bitfield(ValueType&& val)
158 : BaseImpl(std::move(val))
159 {
160 }
161
164 static constexpr bool hasFailOnInvalid()
165 {
166 return ParsedOptions::HasFailOnInvalid;
167 }
168
171 static constexpr bool hasIgnoreInvalid()
172 {
173 return ParsedOptions::HasIgnoreInvalid;
174 }
175
178 static constexpr bool hasEmptySerialization()
179 {
180 return ParsedOptions::HasEmptySerialization;
181 }
182
185 static constexpr bool hasFieldType()
186 {
187 return ParsedOptions::HasFieldType;
188 }
189
192 static constexpr bool hasFixedValue()
193 {
194 return ParsedOptions::HasFixedValue;
195 }
196
199 static constexpr bool hasName()
200 {
201 return ParsedOptions::HasName;
202 }
203
208 template <std::size_t TIdx>
209 static constexpr std::size_t memberBitLength()
210 {
211 return BaseImpl::template memberBitLength<TIdx>();
212 }
213
216 const ValueType& value() const
217 {
218 return BaseImpl::value();
219 }
220
224 {
225 return BaseImpl::value();
226 }
227
230 const ValueType& getValue() const
231 {
232 return BaseImpl::getValue();
233 }
234
237 template <typename U>
238 void setValue(U&& val)
239 {
240 BaseImpl::setValue(std::forward<U>(val));
241 }
242
245 constexpr std::size_t length() const
246 {
247 return BaseImpl::length();
248 }
249
252 static constexpr std::size_t minLength()
253 {
254 return BaseImpl::minLength();
255 }
256
259 static constexpr std::size_t maxLength()
260 {
261 return BaseImpl::maxLength();
262 }
263
269 template <typename TIter>
270 ErrorStatus read(TIter& iter, std::size_t size)
271 {
272 return BaseImpl::read(iter, size);
273 }
274
277 static constexpr bool hasReadNoStatus()
278 {
279 return BaseImpl::hasReadNoStatus();
280 }
281
287 template <typename TIter>
288 void readNoStatus(TIter& iter)
289 {
290 BaseImpl::readNoStatus(iter);
291 }
292
294 bool canWrite() const
295 {
296 return BaseImpl::canWrite();
297 }
298
304 template <typename TIter>
305 ErrorStatus write(TIter& iter, std::size_t size) const
306 {
307 return BaseImpl::write(iter, size);
308 }
309
312 static constexpr bool hasWriteNoStatus()
313 {
314 return BaseImpl::hasWriteNoStatus();
315 }
316
322 template <typename TIter>
323 void writeNoStatus(TIter& iter) const
324 {
325 BaseImpl::writeNoStatus(iter);
326 }
327
329 bool valid() const
330 {
331 return BaseImpl::valid();
332 }
333
337 bool refresh()
338 {
339 return BaseImpl::refresh();
340 }
341
343 static constexpr bool isVersionDependent()
344 {
345 return ParsedOptions::HasCustomVersionUpdate || BaseImpl::isVersionDependent();
346 }
347
349 static constexpr bool hasNonDefaultRefresh()
350 {
351 return BaseImpl::hasNonDefaultRefresh();
352 }
353
357 {
358 return BaseImpl::getVersion();
359 }
360
364 {
365 return BaseImpl::setVersion(version);
366 }
367
368protected:
369 using BaseImpl::readData;
370 using BaseImpl::writeData;
371
372private:
373 static_assert(!ParsedOptions::HasSerOffset,
374 "comms::option::def::NumValueSerOffset option is not applicable to Bitfield field");
375 static_assert(!ParsedOptions::HasFixedLengthLimit,
376 "comms::option::def::FixedLength option is not applicable to Bitfield field");
377 static_assert(!ParsedOptions::HasFixedBitLengthLimit,
378 "comms::option::def::FixedBitLength option is not applicable to Bitfield field");
379 static_assert(!ParsedOptions::HasVarLengthLimits,
380 "comms::option::def::VarLength option is not applicable to Bitfield field");
381 static_assert(!ParsedOptions::HasAvailableLengthLimit,
382 "comms::option::def::AvailableLengthLimit option is not applicable to Bitfield field");
383 static_assert(!ParsedOptions::HasSequenceElemLengthForcing,
384 "comms::option::def::SequenceElemLengthForcingEnabled option is not applicable to Bitfield field");
385 static_assert(!ParsedOptions::HasSequenceSizeForcing,
386 "comms::option::def::SequenceSizeForcingEnabled option is not applicable to Bitfield field");
387 static_assert(!ParsedOptions::HasSequenceLengthForcing,
388 "comms::option::def::SequenceLengthorcingEnabled option is not applicable to Bitfield field");
389 static_assert(!ParsedOptions::HasSequenceFixedSize,
390 "comms::option::def::SequenceFixedSize option is not applicable to Bitfield field");
391 static_assert(!ParsedOptions::HasSequenceFixedSizeUseFixedSizeStorage,
392 "comms::option::app::SequenceFixedSizeUseFixedSizeStorage option is not applicable to Bitfield field");
393 static_assert(!ParsedOptions::HasSequenceSizeFieldPrefix,
394 "comms::option::def::SequenceSizeFieldPrefix option is not applicable to Bitfield field");
395 static_assert(!ParsedOptions::HasSequenceSerLengthFieldPrefix,
396 "comms::option::def::SequenceSerLengthFieldPrefix option is not applicable to Bitfield field");
397 static_assert(!ParsedOptions::HasSequenceElemSerLengthFieldPrefix,
398 "comms::option::def::SequenceElemSerLengthFieldPrefix option is not applicable to Bitfield field");
399 static_assert(!ParsedOptions::HasSequenceElemFixedSerLengthFieldPrefix,
400 "comms::option::def::SequenceElemSerLengthFixedFieldPrefix option is not applicable to Bitfield field");
401 static_assert(!ParsedOptions::HasSequenceTrailingFieldSuffix,
402 "comms::option::def::SequenceTrailingFieldSuffix option is not applicable to Bitfield field");
403 static_assert(!ParsedOptions::HasSequenceTerminationFieldSuffix,
404 "comms::option::def::SequenceTerminationFieldSuffix option is not applicable to Bitfield field");
405 static_assert(!ParsedOptions::HasFixedSizeStorage,
406 "comms::option::app::FixedSizeStorage option is not applicable to Bitfield field");
407 static_assert(!ParsedOptions::HasCustomStorageType,
408 "comms::option::app::CustomStorageType option is not applicable to Bitfield field");
409 static_assert(!ParsedOptions::HasScalingRatio,
410 "comms::option::def::ScalingRatio option is not applicable to Bitfield field");
411 static_assert(!ParsedOptions::HasUnits,
412 "comms::option::def::Units option is not applicable to Bitfield field");
413 static_assert(!ParsedOptions::HasOrigDataView,
414 "comms::option::app::OrigDataView option is not applicable to Bitfield field");
415 static_assert(!ParsedOptions::HasMultiRangeValidation,
416 "comms::option::def::ValidNumValueRange (or similar) option is not applicable to Bitfield field");
417 static_assert(!ParsedOptions::HasVersionsRange,
418 "comms::option::def::ExistsBetweenVersions (or similar) option is not applicable to Bitfield field");
419 static_assert(!ParsedOptions::HasInvalidByDefault,
420 "comms::option::def::InvalidByDefault option is not applicable to Bitfield field");
421 static_assert(!ParsedOptions::HasMissingOnReadFail,
422 "comms::option::def::MissingOnReadFail option is not applicable to Bitfield field");
423 static_assert(!ParsedOptions::HasMissingOnInvalid,
424 "comms::option::def::MissingOnInvalid option is not applicable to Bitfield field");
425};
426
432template <typename TFieldBase, typename TMembers, typename... TOptions>
435 const Bitfield<TFieldBase, TMembers, TOptions...>& field2) noexcept
436{
437 return field1.value() == field2.value();
438}
439
445template <typename TFieldBase, typename TMembers, typename... TOptions>
448 const Bitfield<TFieldBase, TMembers, TOptions...>& field2) noexcept
449{
450 return field1.value() != field2.value();
451}
452
458template <typename TFieldBase, typename TMembers, typename... TOptions>
461 const Bitfield<TFieldBase, TMembers, TOptions...>& field2) noexcept
462{
463 return field1.value() < field2.value();
464}
465
471template <typename T>
472constexpr bool isBitfield()
473{
474 return std::is_same<typename T::CommsTag, tag::Bitfield>::value;
475}
476
480template <typename TFieldBase, typename TMembers, typename... TOptions>
481inline
482Bitfield<TFieldBase, TMembers, TOptions...>&
487
491template <typename TFieldBase, typename TMembers, typename... TOptions>
492inline
493const Bitfield<TFieldBase, TMembers, TOptions...>&
495{
496 return field;
497}
498
499} // namespace field
500
501} // namespace comms
502
This file contain definition of error statuses used by comms module.
Bitfield field.
Definition Bitfield.h:107
const ValueType & value() const
Get access to the stored tuple of fields.
Definition Bitfield.h:216
typename BaseImpl::Endian Endian
Endian used for serialisation.
Definition Bitfield.h:123
ErrorStatus read(TIter &iter, std::size_t size)
Read field value from input data sequence.
Definition Bitfield.h:270
static constexpr bool hasFixedValue()
Compile time inquiry of whether comms::option::def::FixedValue option has been used.
Definition Bitfield.h:192
typename BaseImpl::CommsTag CommsTag
Tag indicating type of the field.
Definition Bitfield.h:132
Bitfield()=default
Default constructor.
VersionType getVersion() const
Get version of the field.
Definition Bitfield.h:356
constexpr std::size_t length() const
Get length required to serialise the current field value.
Definition Bitfield.h:245
Bitfield(const ValueType &val)
Constructor.
Definition Bitfield.h:150
static constexpr bool hasEmptySerialization()
Compile time inquiry of whether comms::option::def::EmptySerialization option has been used.
Definition Bitfield.h:178
Bitfield< TFieldBase, TMembers, TOptions... > & toFieldBase(Bitfield< TFieldBase, TMembers, TOptions... > &field)
Upcast type of the field definition to its parent comms::field::Bitfield type in order to have access...
Definition Bitfield.h:483
bool operator==(const Bitfield< TFieldBase, TMembers, TOptions... > &field1, const Bitfield< TFieldBase, TMembers, TOptions... > &field2) noexcept
Equality comparison operator.
Definition Bitfield.h:433
void readNoStatus(TIter &iter)
Read field value from input data sequence without error check and status report.
Definition Bitfield.h:288
TFieldBase FieldBase
Base class provided in the first template parameter.
Definition Bitfield.h:120
constexpr bool isBitfield()
Compile time check function of whether a provided type is any variant of comms::field::Bitfield.
Definition Bitfield.h:472
ErrorStatus write(TIter &iter, std::size_t size) const
Write current field value to output data sequence.
Definition Bitfield.h:305
static constexpr std::size_t minLength()
Get minimal length that is required to serialise field of this type.
Definition Bitfield.h:252
Bitfield(ValueType &&val)
Constructor.
Definition Bitfield.h:157
bool refresh()
Refresh the field's contents.
Definition Bitfield.h:337
static constexpr bool hasIgnoreInvalid()
Compile time inquiry of whether comms::option::def::IgnoreInvalid option has been used.
Definition Bitfield.h:171
static constexpr bool hasFieldType()
Compile time inquiry of whether comms::option::def::FieldType option has been used.
Definition Bitfield.h:185
void writeNoStatus(TIter &iter) const
Write current field value to output data sequence without error check and status report.
Definition Bitfield.h:323
typename BaseImpl::ValueType ValueType
Value type.
Definition Bitfield.h:137
bool operator<(const Bitfield< TFieldBase, TMembers, TOptions... > &field1, const Bitfield< TFieldBase, TMembers, TOptions... > &field2) noexcept
Equivalence comparison operator.
Definition Bitfield.h:459
bool canWrite() const
Check of whether the field has a consistent value for writing.
Definition Bitfield.h:294
bool operator!=(const Bitfield< TFieldBase, TMembers, TOptions... > &field1, const Bitfield< TFieldBase, TMembers, TOptions... > &field2) noexcept
Non-equality comparison operator.
Definition Bitfield.h:446
const Bitfield< TFieldBase, TMembers, TOptions... > & toFieldBase(const Bitfield< TFieldBase, TMembers, TOptions... > &field)
Upcast type of the field definition to its parent comms::field::Bitfield type in order to have access...
Definition Bitfield.h:494
static constexpr std::size_t maxLength()
Get maximal length that is required to serialise field of this type.
Definition Bitfield.h:259
ValueType & value()
Get access to the stored tuple of fields.
Definition Bitfield.h:223
details::OptionsParser< TOptions... > ParsedOptions
All the options provided to this class bundled into struct.
Definition Bitfield.h:129
void setValue(U &&val)
Set value.
Definition Bitfield.h:238
static constexpr bool isVersionDependent()
Compile time check if this class is version dependent.
Definition Bitfield.h:343
bool setVersion(VersionType version)
Default implementation of version update.
Definition Bitfield.h:363
static constexpr bool hasFailOnInvalid()
Compile time inquiry of whether comms::option::def::FailOnInvalid option has been used.
Definition Bitfield.h:164
typename BaseImpl::VersionType VersionType
Version type.
Definition Bitfield.h:126
typename ParsedOptions::FieldType FieldType
Type of actual extending field specified via comms::option::def::FieldType.
Definition Bitfield.h:142
static constexpr bool hasWriteNoStatus()
Compile time check of whether the field has proper writeNoStatus() member function.
Definition Bitfield.h:312
const ValueType & getValue() const
Get value.
Definition Bitfield.h:230
static constexpr std::size_t memberBitLength()
Retrieve number of bits specified member field consumes.
Definition Bitfield.h:209
static constexpr bool hasNonDefaultRefresh()
Compile time check if this class has non-default refresh functionality.
Definition Bitfield.h:349
static constexpr bool hasReadNoStatus()
Compile time check of whether the field has proper readNoStatus() member function.
Definition Bitfield.h:277
static constexpr bool hasName()
Compile time inquiry of whether comms::option::def::HasName option has been used.
Definition Bitfield.h:199
bool valid() const
Check validity of the field value.
Definition Bitfield.h:329
Main namespace for all classes / functions of COMMS library.
ErrorStatus
Error statuses reported by the Communication module.
Definition ErrorStatus.h:19
constexpr unsigned version()
Version of the COMMS library as single numeric value.
Definition version.h:66
STL namespace.
Contains definition of all the options used by the COMMS library.