19namespace seqan3::detail
30enum struct strong_type_skill
42 bitwise_lshift = 1 << 9,
43 bitwise_rshift = 1 << 10,
44 logical_and = 1 << 11,
46 logical_not = 1 << 13,
51 additive = add | subtract,
52 multiplicative = multiply | divide | modulo,
53 bitwise_logic = bitwise_and | bitwise_or | bitwise_xor | bitwise_not,
54 bitwise_shift = bitwise_lshift | bitwise_rshift,
55 logic = logical_and | logical_or | logical_not
66inline constexpr bool add_enum_bitwise_operators<seqan3::detail::strong_type_skill> =
true;
70namespace seqan3::detail
74template <
typename,
typename, strong_type_skill>
100template <
typename strong_type_t>
101concept derived_from_strong_type =
102 requires (strong_type_t && obj) {
111 requires std::derived_from<std::remove_cvref_t<strong_type_t>,
112 strong_type<typename std::remove_reference_t<strong_type_t>::value_type,
172template <
typename value_t,
typename derived_t, strong_type_skill skills_ = strong_type_skill::none>
177 static constexpr strong_type_skill skills = skills_;
179 using value_type = value_t;
185 constexpr strong_type() noexcept = default;
186 constexpr strong_type(strong_type const &) noexcept = default;
187 constexpr strong_type(strong_type &&) noexcept = default;
188 constexpr strong_type & operator=(strong_type const &) noexcept = default;
189 constexpr strong_type & operator=(strong_type &&) noexcept = default;
190 ~strong_type() noexcept = default;
193 constexpr explicit strong_type(value_t _value) : value(
std::move(_value))
201 constexpr value_t &
get() &
noexcept
207 constexpr value_t
const &
get() const & noexcept
213 constexpr value_t &&
get() &&
noexcept
215 return std::move(value);
219 constexpr value_t
const &&
get() const && noexcept
221 return std::move(value);
231 constexpr derived_t operator+(strong_type
const & other)
232 requires ((skills & strong_type_skill::add) != strong_type_skill::none)
234 return derived_t{
get() + other.get()};
238 constexpr derived_t operator-(strong_type
const & other)
239 requires ((skills & strong_type_skill::subtract) != strong_type_skill::none)
241 return derived_t{
get() - other.get()};
251 constexpr derived_t operator*(strong_type
const & other)
252 requires ((skills & strong_type_skill::multiply) != strong_type_skill::none)
254 return derived_t{
get() * other.get()};
258 constexpr derived_t
operator/(strong_type
const & other)
259 requires ((skills & strong_type_skill::divide) != strong_type_skill::none)
261 return derived_t{
get() / other.get()};
265 constexpr derived_t operator%(strong_type
const & other)
266 requires ((skills & strong_type_skill::modulo) != strong_type_skill::none)
268 return derived_t{
get() % other.get()};
279 constexpr derived_t operator&(strong_type
const & other)
280 requires ((skills & strong_type_skill::bitwise_and) != strong_type_skill::none)
282 return derived_t{
get() & other.get()};
286 constexpr derived_t
operator|(strong_type
const & other)
287 requires ((skills & strong_type_skill::bitwise_or) != strong_type_skill::none)
289 return derived_t{
get() | other.get()};
293 constexpr derived_t operator^(strong_type
const & other)
294 requires ((skills & strong_type_skill::bitwise_xor) != strong_type_skill::none)
296 return derived_t{
get() ^ other.get()};
300 constexpr derived_t operator~()
301 requires ((skills & strong_type_skill::bitwise_not) != strong_type_skill::none)
303 return derived_t{~get()};
314 constexpr derived_t
operator<<(strong_type
const & other)
315 requires ((skills & strong_type_skill::bitwise_lshift) != strong_type_skill::none)
317 return derived_t{
get() << other.get()};
321 template <std::
integral
integral_t>
322 constexpr derived_t
operator<<(integral_t
const shift)
323 requires ((skills & strong_type_skill::bitwise_lshift) != strong_type_skill::none)
325 return derived_t{
get() << shift};
329 constexpr derived_t operator>>(strong_type
const & other)
330 requires ((skills & strong_type_skill::bitwise_rshift) != strong_type_skill::none)
332 return derived_t{
get() >> other.get()};
336 template <std::
integral
integral_t>
337 constexpr derived_t operator>>(integral_t
const shift)
338 requires ((skills & strong_type_skill::bitwise_rshift) != strong_type_skill::none)
340 return derived_t{
get() >> shift};
351 constexpr bool operator&&(strong_type
const & other)
352 requires ((skills & strong_type_skill::logical_and) != strong_type_skill::none)
354 return get() && other.get();
358 constexpr bool operator||(strong_type
const & other)
359 requires ((skills & strong_type_skill::logical_or) != strong_type_skill::none)
361 return get() || other.get();
365 constexpr bool operator!()
366 requires ((skills & strong_type_skill::logical_not) != strong_type_skill::none)
378 constexpr derived_t & operator++()
379 requires ((skills & strong_type_skill::increment) != strong_type_skill::none)
382 return static_cast<derived_t &
>(*this);
386 constexpr derived_t operator++(
int)
387 requires ((skills & strong_type_skill::increment) != strong_type_skill::none)
389 derived_t tmp{
get()};
395 constexpr derived_t & operator--()
396 requires ((skills & strong_type_skill::decrement) != strong_type_skill::none)
399 return static_cast<derived_t &
>(*this);
403 constexpr derived_t operator--(
int)
404 requires ((skills & strong_type_skill::decrement) != strong_type_skill::none)
406 derived_t tmp{
get()};
421 constexpr bool operator==(strong_type
const & rhs)
const
422 requires ((skills & strong_type_skill::comparable) != strong_type_skill::none)
424 return get() == rhs.get();
428 constexpr bool operator!=(strong_type
const & rhs)
const
429 requires ((skills & strong_type_skill::comparable) != strong_type_skill::none)
431 return !(*
this == rhs);
441 explicit constexpr operator value_t() const
442 requires ((skills & strong_type_skill::convert) != strong_type_skill::none)
475template <
typename char_t, derived_from_strong_type strong_type_t>
476debug_stream_type<char_t> &
operator<<(debug_stream_type<char_t> & stream, strong_type_t && value)
478 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:107
auto operator|(validator1_type &&vali1, validator2_type &&vali2)
Enables the chaining of validators.
Definition validators.hpp:1121
@ none
No flag is set.
Definition debug_stream_type.hpp:29
constexpr auto convert
A view that converts each element in the input range (implicitly or via static_cast).
Definition utility/views/convert.hpp:66
The main SeqAn3 namespace.
Definition aligned_sequence_concept.hpp:26
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:412
SeqAn specific customisations in the standard namespace.