22namespace seqan3::detail
33enum struct strong_type_skill
45 bitwise_lshift = 1 << 9,
46 bitwise_rshift = 1 << 10,
47 logical_and = 1 << 11,
49 logical_not = 1 << 13,
54 additive = add | subtract,
55 multiplicative = multiply | divide | modulo,
56 bitwise_logic = bitwise_and | bitwise_or | bitwise_xor | bitwise_not,
57 bitwise_shift = bitwise_lshift | bitwise_rshift,
58 logic = logical_and | logical_or | logical_not
69constexpr bool add_enum_bitwise_operators<seqan3::detail::strong_type_skill> =
true;
73namespace seqan3::detail
77template <
typename,
typename, strong_type_skill>
103template <
typename strong_type_t>
104concept derived_from_strong_type =
105 requires (strong_type_t && obj) {
114 requires std::derived_from<std::remove_cvref_t<strong_type_t>,
115 strong_type<typename std::remove_reference_t<strong_type_t>::value_type,
175template <
typename value_t,
typename derived_t, strong_type_skill skills_ = strong_type_skill::none>
180 static constexpr strong_type_skill skills = skills_;
182 using value_type = value_t;
188 constexpr strong_type() noexcept = default;
189 constexpr strong_type(strong_type const &) noexcept = default;
190 constexpr strong_type(strong_type &&) noexcept = default;
191 constexpr strong_type & operator=(strong_type const &) noexcept = default;
192 constexpr strong_type & operator=(strong_type &&) noexcept = default;
193 ~strong_type() noexcept = default;
196 constexpr explicit strong_type(value_t _value) : value(
std::move(_value))
204 constexpr value_t &
get() &
noexcept
210 constexpr value_t
const &
get() const & noexcept
216 constexpr value_t &&
get() &&
noexcept
218 return std::move(value);
222 constexpr value_t
const &&
get() const && noexcept
224 return std::move(value);
234 constexpr derived_t operator+(strong_type
const & other)
235 requires ((skills & strong_type_skill::add) != strong_type_skill::none)
237 return derived_t{
get() + other.get()};
241 constexpr derived_t operator-(strong_type
const & other)
242 requires ((skills & strong_type_skill::subtract) != strong_type_skill::none)
244 return derived_t{
get() - other.get()};
254 constexpr derived_t operator*(strong_type
const & other)
255 requires ((skills & strong_type_skill::multiply) != strong_type_skill::none)
257 return derived_t{
get() * other.get()};
261 constexpr derived_t
operator/(strong_type
const & other)
262 requires ((skills & strong_type_skill::divide) != strong_type_skill::none)
264 return derived_t{
get() / other.get()};
268 constexpr derived_t operator%(strong_type
const & other)
269 requires ((skills & strong_type_skill::modulo) != strong_type_skill::none)
271 return derived_t{
get() % other.get()};
282 constexpr derived_t operator&(strong_type
const & other)
283 requires ((skills & strong_type_skill::bitwise_and) != strong_type_skill::none)
285 return derived_t{
get() & other.get()};
289 constexpr derived_t
operator|(strong_type
const & other)
290 requires ((skills & strong_type_skill::bitwise_or) != strong_type_skill::none)
292 return derived_t{
get() | other.get()};
296 constexpr derived_t operator^(strong_type
const & other)
297 requires ((skills & strong_type_skill::bitwise_xor) != strong_type_skill::none)
299 return derived_t{
get() ^ other.get()};
303 constexpr derived_t operator~()
304 requires ((skills & strong_type_skill::bitwise_not) != strong_type_skill::none)
306 return derived_t{~get()};
317 constexpr derived_t
operator<<(strong_type
const & other)
318 requires ((skills & strong_type_skill::bitwise_lshift) != strong_type_skill::none)
320 return derived_t{
get() << other.get()};
324 template <std::
integral
integral_t>
325 constexpr derived_t
operator<<(integral_t
const shift)
326 requires ((skills & strong_type_skill::bitwise_lshift) != strong_type_skill::none)
328 return derived_t{
get() << shift};
332 constexpr derived_t operator>>(strong_type
const & other)
333 requires ((skills & strong_type_skill::bitwise_rshift) != strong_type_skill::none)
335 return derived_t{
get() >> other.get()};
339 template <std::
integral
integral_t>
340 constexpr derived_t operator>>(integral_t
const shift)
341 requires ((skills & strong_type_skill::bitwise_rshift) != strong_type_skill::none)
343 return derived_t{
get() >> shift};
354 constexpr bool operator&&(strong_type
const & other)
355 requires ((skills & strong_type_skill::logical_and) != strong_type_skill::none)
357 return get() && other.get();
361 constexpr bool operator||(strong_type
const & other)
362 requires ((skills & strong_type_skill::logical_or) != strong_type_skill::none)
364 return get() || other.get();
368 constexpr bool operator!()
369 requires ((skills & strong_type_skill::logical_not) != strong_type_skill::none)
381 constexpr derived_t & operator++()
382 requires ((skills & strong_type_skill::increment) != strong_type_skill::none)
385 return static_cast<derived_t &
>(*this);
389 constexpr derived_t operator++(
int)
390 requires ((skills & strong_type_skill::increment) != strong_type_skill::none)
392 derived_t tmp{
get()};
398 constexpr derived_t & operator--()
399 requires ((skills & strong_type_skill::decrement) != strong_type_skill::none)
402 return static_cast<derived_t &
>(*this);
406 constexpr derived_t operator--(
int)
407 requires ((skills & strong_type_skill::decrement) != strong_type_skill::none)
409 derived_t tmp{
get()};
424 constexpr bool operator==(strong_type
const & rhs)
const
425 requires ((skills & strong_type_skill::comparable) != strong_type_skill::none)
427 return get() == rhs.get();
431 constexpr bool operator!=(strong_type
const & rhs)
const
432 requires ((skills & strong_type_skill::comparable) != strong_type_skill::none)
434 return !(*
this == rhs);
444 explicit constexpr operator value_t() const
445 requires ((skills & strong_type_skill::convert) != strong_type_skill::
none)
478template <
typename char_t, derived_from_strong_type strong_type_t>
479debug_stream_type<char_t> &
operator<<(debug_stream_type<char_t> & stream, strong_type_t && value)
481 stream << value.get();
Provides seqan3::add_enum_bitwise_operators.
Provides various type traits on generic types.
Provides seqan3::debug_stream and related types.
debug_stream_type< char_t > & operator<<(debug_stream_type< char_t > &stream, alignment_t &&alignment)
Stream operator for alignments, which are represented as tuples of aligned sequences.
Definition: debug_stream_alignment.hpp:110
auto operator|(validator1_type &&vali1, validator2_type &&vali2)
Enables the chaining of validators.
Definition: validators.hpp:1124
@ none
No flag is set.
Definition: debug_stream_type.hpp:32
constexpr auto convert
A view that converts each element in the input range (implicitly or via static_cast).
Definition: convert.hpp:69
The main SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29
constexpr auto const & get(configuration< configs_t... > const &config) noexcept
This is an overloaded member function, provided for convenience. It differs from the above function o...
Definition: configuration.hpp:415
SeqAn specific customisations in the standard namespace.