|
|
@@ -1,6 +1,6 @@ |
|
|
|
/* |
|
|
|
* Catch v2.4.0 |
|
|
|
* Generated: 2018-09-04 11:55:01.682061 |
|
|
|
* Catch v2.4.1 |
|
|
|
* Generated: 2018-09-28 15:50:15.645795 |
|
|
|
* ---------------------------------------------------------- |
|
|
|
* This file has been merged from multiple headers. Please don't edit it directly |
|
|
|
* Copyright (c) 2018 Two Blue Cubes Ltd. All rights reserved. |
|
|
@@ -15,7 +15,7 @@ |
|
|
|
|
|
|
|
#define CATCH_VERSION_MAJOR 2 |
|
|
|
#define CATCH_VERSION_MINOR 4 |
|
|
|
#define CATCH_VERSION_PATCH 0 |
|
|
|
#define CATCH_VERSION_PATCH 1 |
|
|
|
|
|
|
|
#ifdef __clang__ |
|
|
|
# pragma clang system_header |
|
|
@@ -121,11 +121,11 @@ namespace Catch { |
|
|
|
|
|
|
|
#ifdef __cplusplus |
|
|
|
|
|
|
|
# if __cplusplus >= 201402L |
|
|
|
# if (__cplusplus >= 201402L) || (defined(_MSVC_LANG) && _MSVC_LANG >= 201402L) |
|
|
|
# define CATCH_CPP14_OR_GREATER |
|
|
|
# endif |
|
|
|
|
|
|
|
# if __cplusplus >= 201703L |
|
|
|
# if (__cplusplus >= 201703L) || (defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) |
|
|
|
# define CATCH_CPP17_OR_GREATER |
|
|
|
# endif |
|
|
|
|
|
|
@@ -200,7 +200,14 @@ namespace Catch { |
|
|
|
// Required for some versions of Cygwin to declare gettimeofday |
|
|
|
// see: http://stackoverflow.com/questions/36901803/gettimeofday-not-declared-in-this-scope-cygwin |
|
|
|
# define _BSD_SOURCE |
|
|
|
// some versions of cygwin (most) do not support std::to_string. Use the libstd check. |
|
|
|
// https://gcc.gnu.org/onlinedocs/gcc-4.8.2/libstdc++/api/a01053_source.html line 2812-2813 |
|
|
|
# if !((__cplusplus >= 201103L) && defined(_GLIBCXX_USE_C99) \ |
|
|
|
&& !defined(_GLIBCXX_HAVE_BROKEN_VSWPRINTF)) |
|
|
|
|
|
|
|
# define CATCH_INTERNAL_CONFIG_NO_CPP11_TO_STRING |
|
|
|
|
|
|
|
# endif |
|
|
|
#endif // __CYGWIN__ |
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////// |
|
|
@@ -244,6 +251,32 @@ namespace Catch { |
|
|
|
#define CATCH_INTERNAL_CONFIG_COUNTER |
|
|
|
#endif |
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////// |
|
|
|
// Check if string_view is available and usable |
|
|
|
// The check is split apart to work around v140 (VS2015) preprocessor issue... |
|
|
|
#if defined(__has_include) |
|
|
|
#if __has_include(<string_view>) && defined(CATCH_CPP17_OR_GREATER) |
|
|
|
# define CATCH_INTERNAL_CONFIG_CPP17_STRING_VIEW |
|
|
|
#endif |
|
|
|
#endif |
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////// |
|
|
|
// Check if variant is available and usable |
|
|
|
#if defined(__has_include) |
|
|
|
# if __has_include(<variant>) && defined(CATCH_CPP17_OR_GREATER) |
|
|
|
# if defined(__clang__) && (__clang_major__ < 8) |
|
|
|
// work around clang bug with libstdc++ https://bugs.llvm.org/show_bug.cgi?id=31852 |
|
|
|
// fix should be in clang 8, workaround in libstdc++ 8.2 |
|
|
|
# include <ciso646> |
|
|
|
# if defined(__GLIBCXX__) && defined(_GLIBCXX_RELEASE) && (_GLIBCXX_RELEASE < 9) |
|
|
|
# define CATCH_CONFIG_NO_CPP17_VARIANT |
|
|
|
# else |
|
|
|
# define CATCH_INTERNAL_CONFIG_CPP17_VARIANT |
|
|
|
# endif // defined(__GLIBCXX__) && defined(_GLIBCXX_RELEASE) && (_GLIBCXX_RELEASE < 9) |
|
|
|
# endif // defined(__clang__) && (__clang_major__ < 8) |
|
|
|
# endif // __has_include(<variant>) && defined(CATCH_CPP17_OR_GREATER) |
|
|
|
#endif // __has_include |
|
|
|
|
|
|
|
#if defined(CATCH_INTERNAL_CONFIG_COUNTER) && !defined(CATCH_CONFIG_NO_COUNTER) && !defined(CATCH_CONFIG_COUNTER) |
|
|
|
# define CATCH_CONFIG_COUNTER |
|
|
|
#endif |
|
|
@@ -267,6 +300,14 @@ namespace Catch { |
|
|
|
# define CATCH_CONFIG_CPP17_UNCAUGHT_EXCEPTIONS |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(CATCH_INTERNAL_CONFIG_CPP17_STRING_VIEW) && !defined(CATCH_CONFIG_NO_CPP17_STRING_VIEW) && !defined(CATCH_CONFIG_CPP17_STRING_VIEW) |
|
|
|
# define CATCH_CONFIG_CPP17_STRING_VIEW |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(CATCH_INTERNAL_CONFIG_CPP17_VARIANT) && !defined(CATCH_CONFIG_NO_CPP17_VARIANT) && !defined(CATCH_CONFIG_CPP17_VARIANT) |
|
|
|
# define CATCH_CONFIG_CPP17_VARIANT |
|
|
|
#endif |
|
|
|
|
|
|
|
#if defined(CATCH_CONFIG_EXPERIMENTAL_REDIRECT) |
|
|
|
# define CATCH_INTERNAL_CONFIG_NEW_CAPTURE |
|
|
|
#endif |
|
|
@@ -754,6 +795,10 @@ namespace Catch { |
|
|
|
|
|
|
|
// end catch_stream.h |
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_CPP17_STRING_VIEW |
|
|
|
#include <string_view> |
|
|
|
#endif |
|
|
|
|
|
|
|
#ifdef __OBJC__ |
|
|
|
// start catch_objc_arc.hpp |
|
|
|
|
|
|
@@ -929,10 +974,11 @@ namespace Catch { |
|
|
|
struct StringMaker<std::string> { |
|
|
|
static std::string convert(const std::string& str); |
|
|
|
}; |
|
|
|
#ifdef CATCH_CONFIG_WCHAR |
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_CPP17_STRING_VIEW |
|
|
|
template<> |
|
|
|
struct StringMaker<std::wstring> { |
|
|
|
static std::string convert(const std::wstring& wstr); |
|
|
|
struct StringMaker<std::string_view> { |
|
|
|
static std::string convert(std::string_view str); |
|
|
|
}; |
|
|
|
#endif |
|
|
|
|
|
|
@@ -946,6 +992,18 @@ namespace Catch { |
|
|
|
}; |
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_WCHAR |
|
|
|
template<> |
|
|
|
struct StringMaker<std::wstring> { |
|
|
|
static std::string convert(const std::wstring& wstr); |
|
|
|
}; |
|
|
|
|
|
|
|
# ifdef CATCH_CONFIG_CPP17_STRING_VIEW |
|
|
|
template<> |
|
|
|
struct StringMaker<std::wstring_view> { |
|
|
|
static std::string convert(std::wstring_view str); |
|
|
|
}; |
|
|
|
# endif |
|
|
|
|
|
|
|
template<> |
|
|
|
struct StringMaker<wchar_t const *> { |
|
|
|
static std::string convert(wchar_t const * str); |
|
|
@@ -1114,6 +1172,7 @@ namespace Catch { |
|
|
|
#if defined(CATCH_CONFIG_ENABLE_ALL_STRINGMAKERS) |
|
|
|
# define CATCH_CONFIG_ENABLE_PAIR_STRINGMAKER |
|
|
|
# define CATCH_CONFIG_ENABLE_TUPLE_STRINGMAKER |
|
|
|
# define CATCH_CONFIG_ENABLE_VARIANT_STRINGMAKER |
|
|
|
# define CATCH_CONFIG_ENABLE_CHRONO_STRINGMAKER |
|
|
|
#endif |
|
|
|
|
|
|
@@ -1177,6 +1236,34 @@ namespace Catch { |
|
|
|
} |
|
|
|
#endif // CATCH_CONFIG_ENABLE_TUPLE_STRINGMAKER |
|
|
|
|
|
|
|
#if defined(CATCH_CONFIG_ENABLE_VARIANT_STRINGMAKER) && defined(CATCH_CONFIG_CPP17_VARIANT) |
|
|
|
#include <variant> |
|
|
|
namespace Catch { |
|
|
|
template<> |
|
|
|
struct StringMaker<std::monostate> { |
|
|
|
static std::string convert(const std::monostate&) { |
|
|
|
return "{ }"; |
|
|
|
} |
|
|
|
}; |
|
|
|
|
|
|
|
template<typename... Elements> |
|
|
|
struct StringMaker<std::variant<Elements...>> { |
|
|
|
static std::string convert(const std::variant<Elements...>& variant) { |
|
|
|
if (variant.valueless_by_exception()) { |
|
|
|
return "{valueless variant}"; |
|
|
|
} else { |
|
|
|
return std::visit( |
|
|
|
[](const auto& value) { |
|
|
|
return ::Catch::Detail::stringify(value); |
|
|
|
}, |
|
|
|
variant |
|
|
|
); |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
} |
|
|
|
#endif // CATCH_CONFIG_ENABLE_VARIANT_STRINGMAKER |
|
|
|
|
|
|
|
namespace Catch { |
|
|
|
struct not_this_one {}; // Tag type for detecting which begin/ end are being selected |
|
|
|
|
|
|
@@ -2761,7 +2848,7 @@ namespace Matchers { |
|
|
|
auto lfirst = m_target.begin(), llast = m_target.end(); |
|
|
|
auto rfirst = vec.begin(), rlast = vec.end(); |
|
|
|
// Cut common prefix to optimize checking of permuted parts |
|
|
|
while (lfirst != llast && *lfirst != *rfirst) { |
|
|
|
while (lfirst != llast && *lfirst == *rfirst) { |
|
|
|
++lfirst; ++rfirst; |
|
|
|
} |
|
|
|
if (lfirst == llast) { |
|
|
@@ -9597,7 +9684,7 @@ namespace Catch { |
|
|
|
} |
|
|
|
|
|
|
|
bool RunContext::aborting() const { |
|
|
|
return m_totals.assertions.failed == static_cast<std::size_t>(m_config->abortAfter()); |
|
|
|
return m_totals.assertions.failed >= static_cast<std::size_t>(m_config->abortAfter()); |
|
|
|
} |
|
|
|
|
|
|
|
void RunContext::runCurrentTest(std::string & redirectedCout, std::string & redirectedCerr) { |
|
|
@@ -11512,14 +11599,9 @@ std::string StringMaker<std::string>::convert(const std::string& str) { |
|
|
|
return s; |
|
|
|
} |
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_WCHAR |
|
|
|
std::string StringMaker<std::wstring>::convert(const std::wstring& wstr) { |
|
|
|
std::string s; |
|
|
|
s.reserve(wstr.size()); |
|
|
|
for (auto c : wstr) { |
|
|
|
s += (c <= 0xff) ? static_cast<char>(c) : '?'; |
|
|
|
} |
|
|
|
return ::Catch::Detail::stringify(s); |
|
|
|
#ifdef CATCH_CONFIG_CPP17_STRING_VIEW |
|
|
|
std::string StringMaker<std::string_view>::convert(std::string_view str) { |
|
|
|
return ::Catch::Detail::stringify(std::string{ str }); |
|
|
|
} |
|
|
|
#endif |
|
|
|
|
|
|
@@ -11537,7 +11619,23 @@ std::string StringMaker<char*>::convert(char* str) { |
|
|
|
return{ "{null string}" }; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
#ifdef CATCH_CONFIG_WCHAR |
|
|
|
std::string StringMaker<std::wstring>::convert(const std::wstring& wstr) { |
|
|
|
std::string s; |
|
|
|
s.reserve(wstr.size()); |
|
|
|
for (auto c : wstr) { |
|
|
|
s += (c <= 0xff) ? static_cast<char>(c) : '?'; |
|
|
|
} |
|
|
|
return ::Catch::Detail::stringify(s); |
|
|
|
} |
|
|
|
|
|
|
|
# ifdef CATCH_CONFIG_CPP17_STRING_VIEW |
|
|
|
std::string StringMaker<std::wstring_view>::convert(std::wstring_view str) { |
|
|
|
return StringMaker<std::wstring>::convert(std::wstring(str)); |
|
|
|
} |
|
|
|
# endif |
|
|
|
|
|
|
|
std::string StringMaker<wchar_t const*>::convert(wchar_t const * str) { |
|
|
|
if (str) { |
|
|
|
return ::Catch::Detail::stringify(std::wstring{ str }); |
|
|
@@ -11738,7 +11836,7 @@ namespace Catch { |
|
|
|
} |
|
|
|
|
|
|
|
Version const& libraryVersion() { |
|
|
|
static Version version( 2, 4, 0, "", 0 ); |
|
|
|
static Version version( 2, 4, 1, "", 0 ); |
|
|
|
return version; |
|
|
|
} |
|
|
|
|