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 - 2025 (C). Alex Robenko. All rights reserved.
3//
4// This Source Code Form is subject to the terms of the Mozilla Public
5// License, v. 2.0. If a copy of the MPL was not distributed with this
6// file, You can obtain one at http://mozilla.org/MPL/2.0/.
7
10
11#pragma once
12
13#include "comms/ErrorStatus.h"
14#include "comms/options.h"
15#include "basic/Bitfield.h"
16#include "details/AdaptBasicField.h"
17
18namespace comms
19{
20
21namespace field
22{
23
81
91template <typename TFieldBase, typename TMembers, typename... TOptions>
92class Bitfield : public
93 details::AdaptBasicFieldT<
94 basic::Bitfield<
95 TFieldBase,
96 details::OptionsParser<TOptions...>::ForcedMembersVersionDependency,
97 TMembers
98 >,
99 TOptions...
100 >
101{
102 using BaseImpl =
103 details::AdaptBasicFieldT<
104 basic::Bitfield<
105 TFieldBase,
106 details::OptionsParser<TOptions...>::ForcedMembersVersionDependency,
107 TMembers
108 >,
109 TOptions...
110 >;
111
112public:
114 using FieldBase = TFieldBase;
115
117 using Endian = typename BaseImpl::Endian;
118
120 using VersionType = typename BaseImpl::VersionType;
121
123 using ParsedOptions = details::OptionsParser<TOptions...>;
124
126 using CommsTag = typename BaseImpl::CommsTag;
127
131 using ValueType = typename BaseImpl::ValueType;
132
136 using FieldType = typename ParsedOptions::FieldType;
137
140 Bitfield() = default;
141
144 explicit Bitfield(const ValueType& val)
145 : BaseImpl(val)
146 {
147 }
148
151 explicit Bitfield(ValueType&& val)
152 : BaseImpl(std::move(val))
153 {
154 }
155
158 static constexpr bool hasFailOnInvalid()
159 {
160 return ParsedOptions::HasFailOnInvalid;
161 }
162
165 static constexpr bool hasIgnoreInvalid()
166 {
167 return ParsedOptions::HasIgnoreInvalid;
168 }
169
172 static constexpr bool hasEmptySerialization()
173 {
174 return ParsedOptions::HasEmptySerialization;
175 }
176
179 static constexpr bool hasFieldType()
180 {
181 return ParsedOptions::HasFieldType;
182 }
183
186 static constexpr bool hasFixedValue()
187 {
188 return ParsedOptions::HasFixedValue;
189 }
190
193 static constexpr bool hasName()
194 {
195 return ParsedOptions::HasName;
196 }
197
202 template <std::size_t TIdx>
203 static constexpr std::size_t memberBitLength()
204 {
205 return BaseImpl::template memberBitLength<TIdx>();
206 }
207
208
211 const ValueType& value() const
212 {
213 return BaseImpl::value();
214 }
215
219 {
220 return BaseImpl::value();
221 }
222
225 const ValueType& getValue() const
226 {
227 return BaseImpl::getValue();
228 }
229
232 template <typename U>
233 void setValue(U&& val)
234 {
235 BaseImpl::setValue(std::forward<U>(val));
236 }
237
240 constexpr std::size_t length() const
241 {
242 return BaseImpl::length();
243 }
244
247 static constexpr std::size_t minLength()
248 {
249 return BaseImpl::minLength();
250 }
251
254 static constexpr std::size_t maxLength()
255 {
256 return BaseImpl::maxLength();
257 }
258
264 template <typename TIter>
265 ErrorStatus read(TIter& iter, std::size_t size)
266 {
267 return BaseImpl::read(iter, size);
268 }
269
272 static constexpr bool hasReadNoStatus()
273 {
274 return BaseImpl::hasReadNoStatus();
275 }
276
282 template <typename TIter>
283 void readNoStatus(TIter& iter)
284 {
285 BaseImpl::readNoStatus(iter);
286 }
287
289 bool canWrite() const
290 {
291 return BaseImpl::canWrite();
292 }
293
299 template <typename TIter>
300 ErrorStatus write(TIter& iter, std::size_t size) const
301 {
302 return BaseImpl::write(iter, size);
303 }
304
307 static constexpr bool hasWriteNoStatus()
308 {
309 return BaseImpl::hasWriteNoStatus();
310 }
311
317 template <typename TIter>
318 void writeNoStatus(TIter& iter) const
319 {
320 BaseImpl::writeNoStatus(iter);
321 }
322
324 bool valid() const
325 {
326 return BaseImpl::valid();
327 }
328
332 bool refresh()
333 {
334 return BaseImpl::refresh();
335 }
336
338 static constexpr bool isVersionDependent()
339 {
340 return ParsedOptions::HasCustomVersionUpdate || BaseImpl::isVersionDependent();
341 }
342
344 static constexpr bool hasNonDefaultRefresh()
345 {
346 return BaseImpl::hasNonDefaultRefresh();
347 }
348
352 {
353 return BaseImpl::getVersion();
354 }
355
359 {
360 return BaseImpl::setVersion(version);
361 }
362
363protected:
364 using BaseImpl::readData;
365 using BaseImpl::writeData;
366
367private:
368 static_assert(!ParsedOptions::HasSerOffset,
369 "comms::option::def::NumValueSerOffset option is not applicable to Bitfield field");
370 static_assert(!ParsedOptions::HasFixedLengthLimit,
371 "comms::option::def::FixedLength option is not applicable to Bitfield field");
372 static_assert(!ParsedOptions::HasFixedBitLengthLimit,
373 "comms::option::def::FixedBitLength option is not applicable to Bitfield field");
374 static_assert(!ParsedOptions::HasVarLengthLimits,
375 "comms::option::def::VarLength option is not applicable to Bitfield field");
376 static_assert(!ParsedOptions::HasAvailableLengthLimit,
377 "comms::option::def::AvailableLengthLimit option is not applicable to Bitfield field");
378 static_assert(!ParsedOptions::HasSequenceElemLengthForcing,
379 "comms::option::def::SequenceElemLengthForcingEnabled option is not applicable to Bitfield field");
380 static_assert(!ParsedOptions::HasSequenceSizeForcing,
381 "comms::option::def::SequenceSizeForcingEnabled option is not applicable to Bitfield field");
382 static_assert(!ParsedOptions::HasSequenceLengthForcing,
383 "comms::option::def::SequenceLengthorcingEnabled option is not applicable to Bitfield field");
384 static_assert(!ParsedOptions::HasSequenceFixedSize,
385 "comms::option::def::SequenceFixedSize option is not applicable to Bitfield field");
386 static_assert(!ParsedOptions::HasSequenceFixedSizeUseFixedSizeStorage,
387 "comms::option::app::SequenceFixedSizeUseFixedSizeStorage option is not applicable to Bitfield field");
388 static_assert(!ParsedOptions::HasSequenceSizeFieldPrefix,
389 "comms::option::def::SequenceSizeFieldPrefix option is not applicable to Bitfield field");
390 static_assert(!ParsedOptions::HasSequenceSerLengthFieldPrefix,
391 "comms::option::def::SequenceSerLengthFieldPrefix option is not applicable to Bitfield field");
392 static_assert(!ParsedOptions::HasSequenceElemSerLengthFieldPrefix,
393 "comms::option::def::SequenceElemSerLengthFieldPrefix option is not applicable to Bitfield field");
394 static_assert(!ParsedOptions::HasSequenceElemFixedSerLengthFieldPrefix,
395 "comms::option::def::SequenceElemSerLengthFixedFieldPrefix option is not applicable to Bitfield field");
396 static_assert(!ParsedOptions::HasSequenceTrailingFieldSuffix,
397 "comms::option::def::SequenceTrailingFieldSuffix option is not applicable to Bitfield field");
398 static_assert(!ParsedOptions::HasSequenceTerminationFieldSuffix,
399 "comms::option::def::SequenceTerminationFieldSuffix option is not applicable to Bitfield field");
400 static_assert(!ParsedOptions::HasFixedSizeStorage,
401 "comms::option::app::FixedSizeStorage option is not applicable to Bitfield field");
402 static_assert(!ParsedOptions::HasCustomStorageType,
403 "comms::option::app::CustomStorageType option is not applicable to Bitfield field");
404 static_assert(!ParsedOptions::HasScalingRatio,
405 "comms::option::def::ScalingRatio option is not applicable to Bitfield field");
406 static_assert(!ParsedOptions::HasUnits,
407 "comms::option::def::Units option is not applicable to Bitfield field");
408 static_assert(!ParsedOptions::HasOrigDataView,
409 "comms::option::app::OrigDataView option is not applicable to Bitfield field");
410 static_assert(!ParsedOptions::HasMultiRangeValidation,
411 "comms::option::def::ValidNumValueRange (or similar) option is not applicable to Bitfield field");
412 static_assert(!ParsedOptions::HasVersionsRange,
413 "comms::option::def::ExistsBetweenVersions (or similar) option is not applicable to Bitfield field");
414 static_assert(!ParsedOptions::HasInvalidByDefault,
415 "comms::option::def::InvalidByDefault option is not applicable to Bitfield field");
416 static_assert(!ParsedOptions::HasMissingOnReadFail,
417 "comms::option::def::MissingOnReadFail option is not applicable to Bitfield field");
418 static_assert(!ParsedOptions::HasMissingOnInvalid,
419 "comms::option::def::MissingOnInvalid option is not applicable to Bitfield field");
420};
421
427template <typename TFieldBase, typename TMembers, typename... TOptions>
430 const Bitfield<TFieldBase, TMembers, TOptions...>& field2) noexcept
431{
432 return field1.value() == field2.value();
433}
434
440template <typename TFieldBase, typename TMembers, typename... TOptions>
443 const Bitfield<TFieldBase, TMembers, TOptions...>& field2) noexcept
444{
445 return field1.value() != field2.value();
446}
447
453template <typename TFieldBase, typename TMembers, typename... TOptions>
456 const Bitfield<TFieldBase, TMembers, TOptions...>& field2) noexcept
457{
458 return field1.value() < field2.value();
459}
460
466template <typename T>
467constexpr bool isBitfield()
468{
469 return std::is_same<typename T::CommsTag, tag::Bitfield>::value;
470}
471
475template <typename TFieldBase, typename TMembers, typename... TOptions>
476inline
477Bitfield<TFieldBase, TMembers, TOptions...>&
482
486template <typename TFieldBase, typename TMembers, typename... TOptions>
487inline
488const Bitfield<TFieldBase, TMembers, TOptions...>&
490{
491 return field;
492}
493
494} // namespace field
495
496} // namespace comms
497
498
This file contain definition of error statuses used by comms module.
Bitfield field.
Definition Bitfield.h:101
const ValueType & value() const
Get access to the stored tuple of fields.
Definition Bitfield.h:211
typename BaseImpl::Endian Endian
Endian used for serialisation.
Definition Bitfield.h:117
ErrorStatus read(TIter &iter, std::size_t size)
Read field value from input data sequence.
Definition Bitfield.h:265
static constexpr bool hasFixedValue()
Compile time inquiry of whether comms::option::def::FixedValue option has been used.
Definition Bitfield.h:186
typename BaseImpl::CommsTag CommsTag
Tag indicating type of the field.
Definition Bitfield.h:126
Bitfield()=default
Default constructor.
VersionType getVersion() const
Get version of the field.
Definition Bitfield.h:351
constexpr std::size_t length() const
Get length required to serialise the current field value.
Definition Bitfield.h:240
Bitfield(const ValueType &val)
Constructor.
Definition Bitfield.h:144
static constexpr bool hasEmptySerialization()
Compile time inquiry of whether comms::option::def::EmptySerialization option has been used.
Definition Bitfield.h:172
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:478
bool operator==(const Bitfield< TFieldBase, TMembers, TOptions... > &field1, const Bitfield< TFieldBase, TMembers, TOptions... > &field2) noexcept
Equality comparison operator.
Definition Bitfield.h:428
void readNoStatus(TIter &iter)
Read field value from input data sequence without error check and status report.
Definition Bitfield.h:283
TFieldBase FieldBase
Base class provided in the first template parameter.
Definition Bitfield.h:114
constexpr bool isBitfield()
Compile time check function of whether a provided type is any variant of comms::field::Bitfield.
Definition Bitfield.h:467
ErrorStatus write(TIter &iter, std::size_t size) const
Write current field value to output data sequence.
Definition Bitfield.h:300
static constexpr std::size_t minLength()
Get minimal length that is required to serialise field of this type.
Definition Bitfield.h:247
Bitfield(ValueType &&val)
Constructor.
Definition Bitfield.h:151
bool refresh()
Refresh the field's contents.
Definition Bitfield.h:332
static constexpr bool hasIgnoreInvalid()
Compile time inquiry of whether comms::option::def::IgnoreInvalid option has been used.
Definition Bitfield.h:165
static constexpr bool hasFieldType()
Compile time inquiry of whether comms::option::def::FieldType option has been used.
Definition Bitfield.h:179
void writeNoStatus(TIter &iter) const
Write current field value to output data sequence without error check and status report.
Definition Bitfield.h:318
typename BaseImpl::ValueType ValueType
Value type.
Definition Bitfield.h:131
bool operator<(const Bitfield< TFieldBase, TMembers, TOptions... > &field1, const Bitfield< TFieldBase, TMembers, TOptions... > &field2) noexcept
Equivalence comparison operator.
Definition Bitfield.h:454
bool canWrite() const
Check of whether the field has a consistent value for writing.
Definition Bitfield.h:289
bool operator!=(const Bitfield< TFieldBase, TMembers, TOptions... > &field1, const Bitfield< TFieldBase, TMembers, TOptions... > &field2) noexcept
Non-equality comparison operator.
Definition Bitfield.h:441
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:489
static constexpr std::size_t maxLength()
Get maximal length that is required to serialise field of this type.
Definition Bitfield.h:254
ValueType & value()
Get access to the stored tuple of fields.
Definition Bitfield.h:218
details::OptionsParser< TOptions... > ParsedOptions
All the options provided to this class bundled into struct.
Definition Bitfield.h:123
void setValue(U &&val)
Set value.
Definition Bitfield.h:233
static constexpr bool isVersionDependent()
Compile time check if this class is version dependent.
Definition Bitfield.h:338
bool setVersion(VersionType version)
Default implementation of version update.
Definition Bitfield.h:358
static constexpr bool hasFailOnInvalid()
Compile time inquiry of whether comms::option::def::FailOnInvalid option has been used.
Definition Bitfield.h:158
typename BaseImpl::VersionType VersionType
Version type.
Definition Bitfield.h:120
typename ParsedOptions::FieldType FieldType
Type of actual extending field specified via comms::option::def::FieldType.
Definition Bitfield.h:136
static constexpr bool hasWriteNoStatus()
Compile time check of whether the field has proper writeNoStatus() member function.
Definition Bitfield.h:307
const ValueType & getValue() const
Get value.
Definition Bitfield.h:225
static constexpr std::size_t memberBitLength()
Retrieve number of bits specified member field consumes.
Definition Bitfield.h:203
static constexpr bool hasNonDefaultRefresh()
Compile time check if this class has non-default refresh functionality.
Definition Bitfield.h:344
static constexpr bool hasReadNoStatus()
Compile time check of whether the field has proper readNoStatus() member function.
Definition Bitfield.h:272
static constexpr bool hasName()
Compile time inquiry of whether comms::option::def::HasName option has been used.
Definition Bitfield.h:193
bool valid() const
Check validity of the field value.
Definition Bitfield.h:324
Main namespace for all classes / functions of COMMS library.
ErrorStatus
Error statuses reported by the Communication module.
Definition ErrorStatus.h:17
constexpr unsigned version()
Version of the COMMS library as single numeric value.
Definition version.h:64
STL namespace.
Contains definition of all the options used by the COMMS library.