|
|
|
@ -1,6 +1,6 @@
|
|
|
|
|
/*
|
|
|
|
|
* Catch v1.11.0
|
|
|
|
|
* Generated: 2017-10-31 13:42:42.914833
|
|
|
|
|
* Catch v1.12.0
|
|
|
|
|
* Generated: 2018-01-11 21:56:34.893972
|
|
|
|
|
* ----------------------------------------------------------
|
|
|
|
|
* This file has been merged from multiple headers. Please don't edit it directly
|
|
|
|
|
* Copyright (c) 2012 Two Blue Cubes Ltd. All rights reserved.
|
|
|
|
@ -1320,10 +1320,12 @@ namespace Internal {
|
|
|
|
|
template<> struct OperatorTraits<IsGreaterThanOrEqualTo>{ static const char* getName(){ return ">="; } };
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
T& removeConst(T const &t) { return const_cast<T&>(t); }
|
|
|
|
|
T& opCast(T const& t) { return const_cast<T&>(t); }
|
|
|
|
|
|
|
|
|
|
// nullptr_t support based on pull request #154 from Konstantin Baumann
|
|
|
|
|
#ifdef CATCH_CONFIG_CPP11_NULLPTR
|
|
|
|
|
inline std::nullptr_t removeConst(std::nullptr_t) { return nullptr; }
|
|
|
|
|
#endif
|
|
|
|
|
inline std::nullptr_t opCast(std::nullptr_t) { return nullptr; }
|
|
|
|
|
#endif // CATCH_CONFIG_CPP11_NULLPTR
|
|
|
|
|
|
|
|
|
|
// So the compare overloads can be operator agnostic we convey the operator as a template
|
|
|
|
|
// enum, which is used to specialise an Evaluator for doing the comparison.
|
|
|
|
@ -1333,90 +1335,161 @@ namespace Internal {
|
|
|
|
|
template<typename T1, typename T2>
|
|
|
|
|
struct Evaluator<T1, T2, IsEqualTo> {
|
|
|
|
|
static bool evaluate( T1 const& lhs, T2 const& rhs) {
|
|
|
|
|
return bool(removeConst(lhs) == removeConst(rhs) );
|
|
|
|
|
return bool( opCast( lhs ) == opCast( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T1, typename T2>
|
|
|
|
|
struct Evaluator<T1, T2, IsNotEqualTo> {
|
|
|
|
|
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return bool(removeConst(lhs) != removeConst(rhs) );
|
|
|
|
|
return bool( opCast( lhs ) != opCast( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T1, typename T2>
|
|
|
|
|
struct Evaluator<T1, T2, IsLessThan> {
|
|
|
|
|
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return bool(removeConst(lhs) < removeConst(rhs) );
|
|
|
|
|
return bool( opCast( lhs ) < opCast( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T1, typename T2>
|
|
|
|
|
struct Evaluator<T1, T2, IsGreaterThan> {
|
|
|
|
|
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return bool(removeConst(lhs) > removeConst(rhs) );
|
|
|
|
|
return bool( opCast( lhs ) > opCast( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T1, typename T2>
|
|
|
|
|
struct Evaluator<T1, T2, IsGreaterThanOrEqualTo> {
|
|
|
|
|
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return bool(removeConst(lhs) >= removeConst(rhs) );
|
|
|
|
|
return bool( opCast( lhs ) >= opCast( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T1, typename T2>
|
|
|
|
|
struct Evaluator<T1, T2, IsLessThanOrEqualTo> {
|
|
|
|
|
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return bool(removeConst(lhs) <= removeConst(rhs) );
|
|
|
|
|
return bool( opCast( lhs ) <= opCast( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Special case for comparing a pointer to an int (deduced for p==0)
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<int const&, T* const&, IsEqualTo> {
|
|
|
|
|
static bool evaluate( int lhs, T* rhs) {
|
|
|
|
|
return reinterpret_cast<void const*>( lhs ) == rhs;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<T* const&, int const&, IsEqualTo> {
|
|
|
|
|
static bool evaluate( T* lhs, int rhs) {
|
|
|
|
|
return lhs == reinterpret_cast<void const*>( rhs );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<int const&, T* const&, IsNotEqualTo> {
|
|
|
|
|
static bool evaluate( int lhs, T* rhs) {
|
|
|
|
|
return reinterpret_cast<void const*>( lhs ) != rhs;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<T* const&, int const&, IsNotEqualTo> {
|
|
|
|
|
static bool evaluate( T* lhs, int rhs) {
|
|
|
|
|
return lhs != reinterpret_cast<void const*>( rhs );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<Operator Op, typename T1, typename T2>
|
|
|
|
|
bool applyEvaluator( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return Evaluator<T1, T2, Op>::evaluate( lhs, rhs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<long const&, T* const&, IsEqualTo> {
|
|
|
|
|
static bool evaluate( long lhs, T* rhs) {
|
|
|
|
|
return reinterpret_cast<void const*>( lhs ) == rhs;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<T* const&, long const&, IsEqualTo> {
|
|
|
|
|
static bool evaluate( T* lhs, long rhs) {
|
|
|
|
|
return lhs == reinterpret_cast<void const*>( rhs );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<long const&, T* const&, IsNotEqualTo> {
|
|
|
|
|
static bool evaluate( long lhs, T* rhs) {
|
|
|
|
|
return reinterpret_cast<void const*>( lhs ) != rhs;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct Evaluator<T* const&, long const&, IsNotEqualTo> {
|
|
|
|
|
static bool evaluate( T* lhs, long rhs) {
|
|
|
|
|
return lhs != reinterpret_cast<void const*>( rhs );
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
// This level of indirection allows us to specialise for integer types
|
|
|
|
|
// to avoid signed/ unsigned warnings
|
|
|
|
|
|
|
|
|
|
// "base" overload
|
|
|
|
|
template<Operator Op, typename T1, typename T2>
|
|
|
|
|
bool compare( T1 const& lhs, T2 const& rhs ) {
|
|
|
|
|
return Evaluator<T1, T2, Op>::evaluate( lhs, rhs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// unsigned X to int
|
|
|
|
|
template<Operator Op> bool compare( unsigned int lhs, int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( lhs, static_cast<unsigned int>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned long lhs, int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( lhs, static_cast<unsigned int>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned char lhs, int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( lhs, static_cast<unsigned int>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// unsigned X to long
|
|
|
|
|
template<Operator Op> bool compare( unsigned int lhs, long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( lhs, static_cast<unsigned long>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned long lhs, long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( lhs, static_cast<unsigned long>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned char lhs, long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( lhs, static_cast<unsigned long>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// int to unsigned X
|
|
|
|
|
template<Operator Op> bool compare( int lhs, unsigned int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned int>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( int lhs, unsigned long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned int>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( int lhs, unsigned char rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned int>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// long to unsigned X
|
|
|
|
|
template<Operator Op> bool compare( long lhs, unsigned int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( long lhs, unsigned long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( long lhs, unsigned char rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// pointer to long (when comparing against NULL)
|
|
|
|
|
template<Operator Op, typename T> bool compare( long lhs, T* rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( reinterpret_cast<T*>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op, typename T> bool compare( T* lhs, long rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( lhs, reinterpret_cast<T*>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// pointer to int (when comparing against NULL)
|
|
|
|
|
template<Operator Op, typename T> bool compare( int lhs, T* rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( reinterpret_cast<T*>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op, typename T> bool compare( T* lhs, int rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( lhs, reinterpret_cast<T*>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_CPP11_LONG_LONG
|
|
|
|
|
// long long to unsigned X
|
|
|
|
|
template<Operator Op> bool compare( long long lhs, unsigned int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( long long lhs, unsigned long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( long long lhs, unsigned long long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( long long lhs, unsigned char rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<unsigned long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// unsigned long long to X
|
|
|
|
|
template<Operator Op> bool compare( unsigned long long lhs, int rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned long long lhs, long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned long long lhs, long long rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op> bool compare( unsigned long long lhs, char rhs ) {
|
|
|
|
|
return applyEvaluator<Op>( static_cast<long>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// pointer to long long (when comparing against NULL)
|
|
|
|
|
template<Operator Op, typename T> bool compare( long long lhs, T* rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( reinterpret_cast<T*>( lhs ), rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op, typename T> bool compare( T* lhs, long long rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( lhs, reinterpret_cast<T*>( rhs ) );
|
|
|
|
|
}
|
|
|
|
|
#endif // CATCH_CONFIG_CPP11_LONG_LONG
|
|
|
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_CPP11_NULLPTR
|
|
|
|
|
// pointer to nullptr_t (when comparing against nullptr)
|
|
|
|
|
template<Operator Op, typename T> bool compare( std::nullptr_t, T* rhs ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( nullptr, rhs );
|
|
|
|
|
}
|
|
|
|
|
template<Operator Op, typename T> bool compare( T* lhs, std::nullptr_t ) {
|
|
|
|
|
return Evaluator<T*, T*, Op>::evaluate( lhs, nullptr );
|
|
|
|
|
}
|
|
|
|
|
#endif // CATCH_CONFIG_CPP11_NULLPTR
|
|
|
|
|
|
|
|
|
|
} // end of namespace Internal
|
|
|
|
|
} // end of namespace Catch
|
|
|
|
@ -1837,7 +1910,7 @@ public:
|
|
|
|
|
|
|
|
|
|
void endExpression() const {
|
|
|
|
|
m_rb
|
|
|
|
|
.setResultType( Internal::Evaluator<LhsT, RhsT, Op>::evaluate( m_lhs, m_rhs ) )
|
|
|
|
|
.setResultType( Internal::compare<Op>( m_lhs, m_rhs ) )
|
|
|
|
|
.endExpression( *this );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -8393,7 +8466,7 @@ namespace Catch {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
inline Version libraryVersion() {
|
|
|
|
|
static Version version( 1, 11, 0, "", 0 );
|
|
|
|
|
static Version version( 1, 12, 0, "", 0 );
|
|
|
|
|
return version;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -10207,12 +10280,12 @@ namespace Catch {
|
|
|
|
|
|
|
|
|
|
bool includeResults = m_config->includeSuccessfulResults() || !result.isOk();
|
|
|
|
|
|
|
|
|
|
if( includeResults ) {
|
|
|
|
|
if( includeResults || result.getResultType() == ResultWas::Warning ) {
|
|
|
|
|
// Print any info messages in <Info> tags.
|
|
|
|
|
for( std::vector<MessageInfo>::const_iterator it = assertionStats.infoMessages.begin(), itEnd = assertionStats.infoMessages.end();
|
|
|
|
|
it != itEnd;
|
|
|
|
|
++it ) {
|
|
|
|
|
if( it->type == ResultWas::Info ) {
|
|
|
|
|
if( it->type == ResultWas::Info && includeResults ) {
|
|
|
|
|
m_xml.scopedElement( "Info" )
|
|
|
|
|
.writeText( it->message );
|
|
|
|
|
} else if ( it->type == ResultWas::Warning ) {
|
|
|
|
|