diff --git a/README.md b/README.md
index b1eaf22c..b866f8fd 100644
--- a/README.md
+++ b/README.md
@@ -3,9 +3,9 @@
[![Github Releases](https://img.shields.io/github/release/philsquared/catch.svg)](https://github.com/philsquared/catch/releases)
[![Build Status](https://travis-ci.org/philsquared/Catch.svg?branch=master)](https://travis-ci.org/philsquared/Catch)
[![Build status](https://ci.appveyor.com/api/projects/status/hrtk60hv6tw6fght/branch/master?svg=true)](https://ci.appveyor.com/project/philsquared/catch/branch/master)
-[![Try online](https://img.shields.io/badge/try-online-blue.svg)](https://wandbox.org/permlink/EyEbEIfp8CnnjguW)
+[![Try online](https://img.shields.io/badge/try-online-blue.svg)](https://wandbox.org/permlink/hgiYhcvH835lHvaA)
-The latest, single header, version can be downloaded directly using this link
+The latest, single header, version can be downloaded directly using this link
## What's the Catch?
diff --git a/conanfile.py b/conanfile.py
index 02699974..025aec84 100644
--- a/conanfile.py
+++ b/conanfile.py
@@ -4,7 +4,7 @@ from conans import ConanFile
class CatchConan(ConanFile):
name = "Catch"
- version = "1.11.0"
+ version = "1.12.0"
description = "A modern, C++-native, header-only, framework for unit-tests, TDD and BDD"
author = "philsquared"
generators = "cmake"
diff --git a/docs/release-notes.md b/docs/release-notes.md
index 3661c6f6..e7e32441 100644
--- a/docs/release-notes.md
+++ b/docs/release-notes.md
@@ -1,3 +1,11 @@
+# 1.12.0
+
+### Fixes
+* Fixed compilation for strict C++98 mode (ie not gnu++98) and older compilers (#1103)
+* `INFO` messages are included in the `xml` reporter output even without `-s` specified.
+
+
+
# 1.11.0
### Fixes
diff --git a/include/internal/catch_version.hpp b/include/internal/catch_version.hpp
index 8049e3fb..e3e0cb20 100644
--- a/include/internal/catch_version.hpp
+++ b/include/internal/catch_version.hpp
@@ -38,7 +38,7 @@ namespace Catch {
}
inline Version libraryVersion() {
- static Version version( 1, 11, 0, "", 0 );
+ static Version version( 1, 12, 0, "", 0 );
return version;
}
diff --git a/single_include/catch.hpp b/single_include/catch.hpp
index 849c53c1..6b5129d6 100644
--- a/single_include/catch.hpp
+++ b/single_include/catch.hpp
@@ -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{ static const char* getName(){ return ">="; } };
template
- T& removeConst(T const &t) { return const_cast(t); }
+ T& opCast(T const& t) { return const_cast(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
struct Evaluator {
static bool evaluate( T1 const& lhs, T2 const& rhs) {
- return bool(removeConst(lhs) == removeConst(rhs) );
+ return bool( opCast( lhs ) == opCast( rhs ) );
}
};
template
struct Evaluator {
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
- return bool(removeConst(lhs) != removeConst(rhs) );
+ return bool( opCast( lhs ) != opCast( rhs ) );
}
};
template
struct Evaluator {
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
- return bool(removeConst(lhs) < removeConst(rhs) );
+ return bool( opCast( lhs ) < opCast( rhs ) );
}
};
template
struct Evaluator {
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
- return bool(removeConst(lhs) > removeConst(rhs) );
+ return bool( opCast( lhs ) > opCast( rhs ) );
}
};
template
struct Evaluator {
static bool evaluate( T1 const& lhs, T2 const& rhs ) {
- return bool(removeConst(lhs) >= removeConst(rhs) );
+ return bool( opCast( lhs ) >= opCast( rhs ) );
}
};
template
struct Evaluator {
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
- struct Evaluator {
- static bool evaluate( int lhs, T* rhs) {
- return reinterpret_cast( lhs ) == rhs;
- }
- };
- template
- struct Evaluator {
- static bool evaluate( T* lhs, int rhs) {
- return lhs == reinterpret_cast( rhs );
- }
- };
- template
- struct Evaluator {
- static bool evaluate( int lhs, T* rhs) {
- return reinterpret_cast( lhs ) != rhs;
- }
- };
- template
- struct Evaluator {
- static bool evaluate( T* lhs, int rhs) {
- return lhs != reinterpret_cast( rhs );
- }
- };
+ template
+ bool applyEvaluator( T1 const& lhs, T2 const& rhs ) {
+ return Evaluator::evaluate( lhs, rhs );
+ }
- template
- struct Evaluator {
- static bool evaluate( long lhs, T* rhs) {
- return reinterpret_cast( lhs ) == rhs;
- }
- };
- template
- struct Evaluator {
- static bool evaluate( T* lhs, long rhs) {
- return lhs == reinterpret_cast( rhs );
- }
- };
- template
- struct Evaluator {
- static bool evaluate( long lhs, T* rhs) {
- return reinterpret_cast( lhs ) != rhs;
- }
- };
- template
- struct Evaluator {
- static bool evaluate( T* lhs, long rhs) {
- return lhs != reinterpret_cast( rhs );
- }
- };
+ // This level of indirection allows us to specialise for integer types
+ // to avoid signed/ unsigned warnings
+
+ // "base" overload
+ template
+ bool compare( T1 const& lhs, T2 const& rhs ) {
+ return Evaluator::evaluate( lhs, rhs );
+ }
+
+ // unsigned X to int
+ template bool compare( unsigned int lhs, int rhs ) {
+ return applyEvaluator( lhs, static_cast( rhs ) );
+ }
+ template bool compare( unsigned long lhs, int rhs ) {
+ return applyEvaluator( lhs, static_cast( rhs ) );
+ }
+ template bool compare( unsigned char lhs, int rhs ) {
+ return applyEvaluator( lhs, static_cast( rhs ) );
+ }
+
+ // unsigned X to long
+ template bool compare( unsigned int lhs, long rhs ) {
+ return applyEvaluator( lhs, static_cast( rhs ) );
+ }
+ template bool compare( unsigned long lhs, long rhs ) {
+ return applyEvaluator( lhs, static_cast( rhs ) );
+ }
+ template bool compare( unsigned char lhs, long rhs ) {
+ return applyEvaluator( lhs, static_cast( rhs ) );
+ }
+
+ // int to unsigned X
+ template bool compare( int lhs, unsigned int rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( int lhs, unsigned long rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( int lhs, unsigned char rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+
+ // long to unsigned X
+ template bool compare( long lhs, unsigned int rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( long lhs, unsigned long rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( long lhs, unsigned char rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+
+ // pointer to long (when comparing against NULL)
+ template bool compare( long lhs, T* rhs ) {
+ return Evaluator::evaluate( reinterpret_cast( lhs ), rhs );
+ }
+ template bool compare( T* lhs, long rhs ) {
+ return Evaluator::evaluate( lhs, reinterpret_cast( rhs ) );
+ }
+
+ // pointer to int (when comparing against NULL)
+ template bool compare( int lhs, T* rhs ) {
+ return Evaluator::evaluate( reinterpret_cast( lhs ), rhs );
+ }
+ template bool compare( T* lhs, int rhs ) {
+ return Evaluator::evaluate( lhs, reinterpret_cast( rhs ) );
+ }
+
+#ifdef CATCH_CONFIG_CPP11_LONG_LONG
+ // long long to unsigned X
+ template bool compare( long long lhs, unsigned int rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( long long lhs, unsigned long rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( long long lhs, unsigned long long rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( long long lhs, unsigned char rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+
+ // unsigned long long to X
+ template bool compare( unsigned long long lhs, int rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( unsigned long long lhs, long rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( unsigned long long lhs, long long rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+ template bool compare( unsigned long long lhs, char rhs ) {
+ return applyEvaluator( static_cast( lhs ), rhs );
+ }
+
+ // pointer to long long (when comparing against NULL)
+ template bool compare( long long lhs, T* rhs ) {
+ return Evaluator::evaluate( reinterpret_cast( lhs ), rhs );
+ }
+ template bool compare( T* lhs, long long rhs ) {
+ return Evaluator::evaluate( lhs, reinterpret_cast( rhs ) );
+ }
+#endif // CATCH_CONFIG_CPP11_LONG_LONG
+
+#ifdef CATCH_CONFIG_CPP11_NULLPTR
+ // pointer to nullptr_t (when comparing against nullptr)
+ template bool compare( std::nullptr_t, T* rhs ) {
+ return Evaluator::evaluate( nullptr, rhs );
+ }
+ template bool compare( T* lhs, std::nullptr_t ) {
+ return Evaluator::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::evaluate( m_lhs, m_rhs ) )
+ .setResultType( Internal::compare( 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 tags.
for( std::vector::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 ) {
diff --git a/test_package/conanfile.py b/test_package/conanfile.py
index a864b9da..c3d0b43e 100644
--- a/test_package/conanfile.py
+++ b/test_package/conanfile.py
@@ -10,7 +10,7 @@ class CatchConanTest(ConanFile):
settings = "os", "compiler", "arch", "build_type"
username = getenv("CONAN_USERNAME", "philsquared")
channel = getenv("CONAN_CHANNEL", "testing")
- requires = "Catch/1.11.0@%s/%s" % (username, channel)
+ requires = "Catch/1.12.0@%s/%s" % (username, channel)
def build(self):
cmake = CMake(self)