micro-test-plus 4.1.0
µTest++ Testing Framework
Loading...
Searching...
No Matches
micro_os_plus::micro_test_plus::detail::eq_< Lhs_T, Rhs_T > Struct Template Reference

Equality comparator struct template. More...

#include <micro-os-plus/micro-test-plus.h>

Inheritance diagram for micro_os_plus::micro_test_plus::detail::eq_< Lhs_T, Rhs_T >:

Public Member Functions

constexpr eq_ (const Lhs_T &lhs={}, const Rhs_T &rhs={})
 Constructs an equality comparator for the given operands.
constexpr auto lhs (void) const
 Retrieves the left-hand operand.
constexpr operator bool () const
 Conversion operator to boolean.
constexpr auto rhs (void) const
 Retrieves the right-hand operand.

Private Attributes

const Lhs_T lhs_ {}
 Stores the left-hand operand.
const Rhs_T rhs_ {}
 Stores the right-hand operand.
const bool value_ {}
 Stores the result of the comparison.

Detailed Description

template<class Lhs_T, class Rhs_T>
struct micro_os_plus::micro_test_plus::detail::eq_< Lhs_T, Rhs_T >

Derived from binary_op_, this struct checks whether the left-hand operand is equal to the right-hand operand. It is used within test expressions to provide human-readable equality assertions with enhanced reporting of the actual and expected values upon failure.

Template Parameters
Lhs_TThe type of the left-hand operand.
Rhs_TThe type of the right-hand operand.

Definition at line 305 of file detail.h.

Constructor & Destructor Documentation

◆ eq_()

template<class Lhs_T, class Rhs_T>
micro_os_plus::micro_test_plus::detail::eq_< Lhs_T, Rhs_T >::eq_ ( const Lhs_T & lhs = {},
const Rhs_T & rhs = {} )
constexpr
Parameters
lhsThe left-hand operand.
rhsThe right-hand operand.

Evaluates the equality of lhs and rhs inside an immediately invoked lambda and passes the boolean result to the binary_op_ base class constructor. Supports types with static value members, types with an epsilon precision member, and generic types.

Definition at line 189 of file detail-inlines.h.

191 {
192 // This lambda is called in the constructor to evaluate the
193 // comparison. Its result is implicitly converted to bool via
194 // the operator bool() of whatever type the branch returns.
195 // This is intentional: all result types (integral_constant,
196 // comparator objects, plain bool) define operator bool().
197 using std::operator==;
198 using std::operator<;
199
200#if defined(__GNUC__)
201#pragma GCC diagnostic push
202#pragma GCC diagnostic ignored "-Wfloat-equal"
203#pragma GCC diagnostic ignored "-Wconversion"
204#pragma GCC diagnostic ignored "-Wdouble-promotion"
205#pragma GCC diagnostic ignored "-Wsign-compare"
206#if defined(__clang__)
207#pragma clang diagnostic ignored "-Wimplicit-int-float-conversion"
208#pragma clang diagnostic ignored "-Wpedantic"
209#endif
210#endif
213 {
214 // If both types have values (like numeric constants),
215 // compare them directly.
216 return Lhs_T::value == Rhs_T::value;
217 }
218 else if constexpr (type_traits::has_epsilon<Lhs_T>
220 {
221 // If both values have precision, compare them using
222 // the smallest precision.
223 return math::abs (get (lhs) - get (rhs))
224 < math::min_value (lhs.epsilon, rhs.epsilon);
225 }
226 else if constexpr (type_traits::has_epsilon<Lhs_T>)
227 {
228 // If only the left operand has precision, use it.
229 return math::abs (get (lhs) - get (rhs)) < lhs.epsilon;
230 }
231 else if constexpr (type_traits::has_epsilon<Rhs_T>)
232 {
233 // If only the right operand has precision, use it.
234 return math::abs (get (lhs) - get (rhs)) < rhs.epsilon;
235 }
236 else
237 {
238 // Call the generic getters, which might
239 // either call the type get() or return the value.
240 return get (lhs) == get (rhs);
241 }
242#if defined(__GNUC__)
243#pragma GCC diagnostic pop
244#endif
245 }() }
246 {
247 }
constexpr auto get(const T &t)
Generic getter function template for value retrieval.
constexpr auto min_value(const T &lhs, const T &rhs) noexcept -> const T &
Computes the minimum of two comparable values.
constexpr auto abs(const T t) noexcept -> T
Computes the absolute value of a given comparable value.
constexpr auto lhs(void) const
Retrieves the left-hand operand.
constexpr binary_op_(const Lhs_T &lhs, const Rhs_T &rhs, bool value)
Constructs a binary comparator with the given operands and pre-computed result.
constexpr auto rhs(void) const
Retrieves the right-hand operand.
Equality comparator struct template.
Definition detail.h:306

References micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::binary_op_(), micro_os_plus::micro_test_plus::math::abs(), micro_os_plus::micro_test_plus::detail::get(), micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::lhs(), micro_os_plus::micro_test_plus::math::min_value(), and micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::rhs().

Member Function Documentation

◆ lhs()

template<class Lhs_T, class Rhs_T>
auto micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::lhs ( void ) const
nodiscardconstexprinherited
Parameters
None.
Returns
The extracted left-hand operand.

Returns the value of the left-hand operand, applying the generic getter to ensure correct extraction for both custom and standard types.

Definition at line 161 of file detail-inlines.h.

162 {
163 return get (lhs_);
164 }
const Lhs_T lhs_
Stores the left-hand operand.
Definition detail.h:272

References micro_os_plus::micro_test_plus::detail::get(), and lhs_.

Referenced by micro_os_plus::micro_test_plus::detail::and_< Lhs_T, Rhs_T >::and_(), binary_op_(), micro_os_plus::micro_test_plus::detail::eq_< Lhs_T, Rhs_T >::eq_(), micro_os_plus::micro_test_plus::detail::ge_< Lhs_T, Rhs_T >::ge_(), micro_os_plus::micro_test_plus::detail::gt_< Lhs_T, Rhs_T >::gt_(), micro_os_plus::micro_test_plus::detail::le_< Lhs_T, Rhs_T >::le_(), micro_os_plus::micro_test_plus::detail::lt_< Lhs_T, Rhs_T >::lt_(), micro_os_plus::micro_test_plus::detail::ne_< Lhs_T, Rhs_T >::ne_(), micro_os_plus::micro_test_plus::detail::or_< Lhs_T, Rhs_T >::or_(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), and micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<().

◆ operator bool()

template<class Lhs_T, class Rhs_T>
micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::operator bool ( ) const
nodiscardconstexprinherited
Parameters
None.
Returns
The result of the comparison.

Returns the pre-computed boolean result stored by the derived comparator's constructor.

Definition at line 147 of file detail-inlines.h.

149 {
150 return value_;
151 }
const bool value_
Stores the result of the comparison.
Definition detail.h:285

References binary_op_(), and value_.

◆ rhs()

template<class Lhs_T, class Rhs_T>
auto micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::rhs ( void ) const
nodiscardconstexprinherited
Parameters
None.
Returns
The extracted right-hand operand.

Returns the value of the right-hand operand, applying the generic getter to ensure correct extraction for both custom and standard types.

Definition at line 174 of file detail-inlines.h.

175 {
176 return get (rhs_);
177 }
const Rhs_T rhs_
Stores the right-hand operand.
Definition detail.h:280

References micro_os_plus::micro_test_plus::detail::get(), and rhs_.

Referenced by micro_os_plus::micro_test_plus::detail::and_< Lhs_T, Rhs_T >::and_(), binary_op_(), micro_os_plus::micro_test_plus::detail::eq_< Lhs_T, Rhs_T >::eq_(), micro_os_plus::micro_test_plus::detail::ge_< Lhs_T, Rhs_T >::ge_(), micro_os_plus::micro_test_plus::detail::gt_< Lhs_T, Rhs_T >::gt_(), micro_os_plus::micro_test_plus::detail::le_< Lhs_T, Rhs_T >::le_(), micro_os_plus::micro_test_plus::detail::lt_< Lhs_T, Rhs_T >::lt_(), micro_os_plus::micro_test_plus::detail::ne_< Lhs_T, Rhs_T >::ne_(), micro_os_plus::micro_test_plus::detail::or_< Lhs_T, Rhs_T >::or_(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<(), and micro_os_plus::micro_test_plus::detail::expression_formatter::operator<<().

Member Data Documentation

◆ lhs_

template<class Lhs_T, class Rhs_T>
const Lhs_T micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::lhs_ {}
privateinherited
Note
Operands are stored by value; passing a large container will copy it into this member.

Definition at line 272 of file detail.h.

272{};

Referenced by binary_op_(), and lhs().

◆ rhs_

template<class Lhs_T, class Rhs_T>
const Rhs_T micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::rhs_ {}
privateinherited
Note
Operands are stored by value; passing a large container will copy it into this member.

Definition at line 280 of file detail.h.

280{};

Referenced by binary_op_(), and rhs().

◆ value_

template<class Lhs_T, class Rhs_T>
const bool micro_os_plus::micro_test_plus::detail::binary_op_< Lhs_T, Rhs_T >::value_ {}
privateinherited

Definition at line 285 of file detail.h.

285{};

Referenced by binary_op_(), and operator bool().


The documentation for this struct was generated from the following files: