mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-25 23:06:10 +01:00
Split CATCH_TRANSLATE_EXCEPTION into its own header
As far as I know, only a few users actually use it, but these changes allow us to avoid including a surprising amount of code in the main compilation path.
This commit is contained in:
parent
0c6fda6e7d
commit
4b2f1da02a
@ -123,6 +123,7 @@ set(INTERNAL_HEADERS
|
|||||||
${SOURCES_DIR}/internal/catch_to_string.hpp
|
${SOURCES_DIR}/internal/catch_to_string.hpp
|
||||||
${SOURCES_DIR}/catch_tostring.hpp
|
${SOURCES_DIR}/catch_tostring.hpp
|
||||||
${SOURCES_DIR}/catch_totals.hpp
|
${SOURCES_DIR}/catch_totals.hpp
|
||||||
|
${SOURCES_DIR}/catch_translate_exception.hpp
|
||||||
${SOURCES_DIR}/internal/catch_uncaught_exceptions.hpp
|
${SOURCES_DIR}/internal/catch_uncaught_exceptions.hpp
|
||||||
${SOURCES_DIR}/catch_version.hpp
|
${SOURCES_DIR}/catch_version.hpp
|
||||||
${SOURCES_DIR}/catch_version_macros.hpp
|
${SOURCES_DIR}/catch_version_macros.hpp
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include <catch2/catch_timer.hpp>
|
#include <catch2/catch_timer.hpp>
|
||||||
#include <catch2/catch_tostring.hpp>
|
#include <catch2/catch_tostring.hpp>
|
||||||
#include <catch2/catch_totals.hpp>
|
#include <catch2/catch_totals.hpp>
|
||||||
|
#include <catch2/catch_translate_exception.hpp>
|
||||||
#include <catch2/catch_version.hpp>
|
#include <catch2/catch_version.hpp>
|
||||||
#include <catch2/catch_version_macros.hpp>
|
#include <catch2/catch_version_macros.hpp>
|
||||||
#include <catch2/generators/catch_generators_all.hpp>
|
#include <catch2/generators/catch_generators_all.hpp>
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
|
|
||||||
#include <catch2/internal/catch_test_macro_impl.hpp>
|
#include <catch2/internal/catch_test_macro_impl.hpp>
|
||||||
#include <catch2/catch_message.hpp>
|
#include <catch2/catch_message.hpp>
|
||||||
#include <catch2/interfaces/catch_interfaces_exception.hpp>
|
|
||||||
#include <catch2/internal/catch_preprocessor.hpp>
|
#include <catch2/internal/catch_preprocessor.hpp>
|
||||||
#include <catch2/internal/catch_section.hpp>
|
#include <catch2/internal/catch_section.hpp>
|
||||||
#include <catch2/internal/catch_test_registry.hpp>
|
#include <catch2/internal/catch_test_registry.hpp>
|
||||||
@ -202,13 +201,6 @@
|
|||||||
|
|
||||||
#endif // ^^ unprefixed, disabled
|
#endif // ^^ unprefixed, disabled
|
||||||
|
|
||||||
// This macro is always prefixed
|
|
||||||
#if !defined(CATCH_CONFIG_DISABLE)
|
|
||||||
#define CATCH_TRANSLATE_EXCEPTION( signature ) INTERNAL_CATCH_TRANSLATE_EXCEPTION( signature )
|
|
||||||
#else
|
|
||||||
#define CATCH_TRANSLATE_EXCEPTION( signature ) INTERNAL_CATCH_TRANSLATE_EXCEPTION_NO_REG( INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionTranslator ), signature )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// end of user facing macros
|
// end of user facing macros
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_TEST_MACROS_HPP_INCLUDED
|
#endif // TWOBLUECUBES_CATCH_TEST_MACROS_HPP_INCLUDED
|
||||||
|
74
src/catch2/catch_translate_exception.hpp
Normal file
74
src/catch2/catch_translate_exception.hpp
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#ifndef CATCH_TRANSLATE_EXCEPTION_HPP_INCLUDED
|
||||||
|
#define CATCH_TRANSLATE_EXCEPTION_HPP_INCLUDED
|
||||||
|
|
||||||
|
#include <catch2/interfaces/catch_interfaces_exception.hpp>
|
||||||
|
|
||||||
|
#include <exception>
|
||||||
|
|
||||||
|
namespace Catch {
|
||||||
|
|
||||||
|
class ExceptionTranslatorRegistrar {
|
||||||
|
template<typename T>
|
||||||
|
class ExceptionTranslator : public IExceptionTranslator {
|
||||||
|
public:
|
||||||
|
|
||||||
|
ExceptionTranslator( std::string(*translateFunction)( T& ) )
|
||||||
|
: m_translateFunction( translateFunction )
|
||||||
|
{}
|
||||||
|
|
||||||
|
std::string translate( ExceptionTranslators::const_iterator it, ExceptionTranslators::const_iterator itEnd ) const override {
|
||||||
|
#if !defined(CATCH_CONFIG_DISABLE_EXCEPTIONS)
|
||||||
|
try {
|
||||||
|
if( it == itEnd )
|
||||||
|
std::rethrow_exception(std::current_exception());
|
||||||
|
else
|
||||||
|
return (*it)->translate( it+1, itEnd );
|
||||||
|
}
|
||||||
|
catch( T& ex ) {
|
||||||
|
return m_translateFunction( ex );
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
return "You should never get here!";
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
std::string(*m_translateFunction)( T& );
|
||||||
|
};
|
||||||
|
|
||||||
|
public:
|
||||||
|
template<typename T>
|
||||||
|
ExceptionTranslatorRegistrar( std::string(*translateFunction)( T& ) ) {
|
||||||
|
getMutableRegistryHub().registerTranslator
|
||||||
|
( new ExceptionTranslator<T>( translateFunction ) );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace Catch
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION2( translatorName, signature ) \
|
||||||
|
static std::string translatorName( signature ); \
|
||||||
|
CATCH_INTERNAL_START_WARNINGS_SUPPRESSION \
|
||||||
|
CATCH_INTERNAL_SUPPRESS_GLOBALS_WARNINGS \
|
||||||
|
namespace{ Catch::ExceptionTranslatorRegistrar INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionRegistrar )( &translatorName ); } \
|
||||||
|
CATCH_INTERNAL_STOP_WARNINGS_SUPPRESSION \
|
||||||
|
static std::string translatorName( signature )
|
||||||
|
|
||||||
|
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION( signature ) INTERNAL_CATCH_TRANSLATE_EXCEPTION2( INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionTranslator ), signature )
|
||||||
|
|
||||||
|
#if defined(CATCH_CONFIG_DISABLE)
|
||||||
|
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION_NO_REG( translatorName, signature) \
|
||||||
|
static std::string translatorName( signature )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
// This macro is always prefixed
|
||||||
|
#if !defined(CATCH_CONFIG_DISABLE)
|
||||||
|
#define CATCH_TRANSLATE_EXCEPTION( signature ) INTERNAL_CATCH_TRANSLATE_EXCEPTION( signature )
|
||||||
|
#else
|
||||||
|
#define CATCH_TRANSLATE_EXCEPTION( signature ) INTERNAL_CATCH_TRANSLATE_EXCEPTION_NO_REG( INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionTranslator ), signature )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif // CATCH_TRANSLATE_EXCEPTION_HPP_INCLUDED
|
@ -11,12 +11,6 @@
|
|||||||
#include <catch2/interfaces/catch_interfaces_registry_hub.hpp>
|
#include <catch2/interfaces/catch_interfaces_registry_hub.hpp>
|
||||||
#include <catch2/internal/catch_compiler_capabilities.hpp>
|
#include <catch2/internal/catch_compiler_capabilities.hpp>
|
||||||
|
|
||||||
#if defined(CATCH_CONFIG_DISABLE)
|
|
||||||
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION_NO_REG( translatorName, signature) \
|
|
||||||
static std::string translatorName( signature )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <exception>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
@ -37,53 +31,6 @@ namespace Catch {
|
|||||||
virtual std::string translateActiveException() const = 0;
|
virtual std::string translateActiveException() const = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class ExceptionTranslatorRegistrar {
|
} // namespace Catch
|
||||||
template<typename T>
|
|
||||||
class ExceptionTranslator : public IExceptionTranslator {
|
|
||||||
public:
|
|
||||||
|
|
||||||
ExceptionTranslator( std::string(*translateFunction)( T& ) )
|
|
||||||
: m_translateFunction( translateFunction )
|
|
||||||
{}
|
|
||||||
|
|
||||||
std::string translate( ExceptionTranslators::const_iterator it, ExceptionTranslators::const_iterator itEnd ) const override {
|
|
||||||
#if !defined(CATCH_CONFIG_DISABLE_EXCEPTIONS)
|
|
||||||
try {
|
|
||||||
if( it == itEnd )
|
|
||||||
std::rethrow_exception(std::current_exception());
|
|
||||||
else
|
|
||||||
return (*it)->translate( it+1, itEnd );
|
|
||||||
}
|
|
||||||
catch( T& ex ) {
|
|
||||||
return m_translateFunction( ex );
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
return "You should never get here!";
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
std::string(*m_translateFunction)( T& );
|
|
||||||
};
|
|
||||||
|
|
||||||
public:
|
|
||||||
template<typename T>
|
|
||||||
ExceptionTranslatorRegistrar( std::string(*translateFunction)( T& ) ) {
|
|
||||||
getMutableRegistryHub().registerTranslator
|
|
||||||
( new ExceptionTranslator<T>( translateFunction ) );
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
|
||||||
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION2( translatorName, signature ) \
|
|
||||||
static std::string translatorName( signature ); \
|
|
||||||
CATCH_INTERNAL_START_WARNINGS_SUPPRESSION \
|
|
||||||
CATCH_INTERNAL_SUPPRESS_GLOBALS_WARNINGS \
|
|
||||||
namespace{ Catch::ExceptionTranslatorRegistrar INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionRegistrar )( &translatorName ); } \
|
|
||||||
CATCH_INTERNAL_STOP_WARNINGS_SUPPRESSION \
|
|
||||||
static std::string translatorName( signature )
|
|
||||||
|
|
||||||
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION( signature ) INTERNAL_CATCH_TRANSLATE_EXCEPTION2( INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionTranslator ), signature )
|
|
||||||
|
|
||||||
#endif // TWOBLUECUBES_CATCH_INTERFACES_EXCEPTION_H_INCLUDED
|
#endif // TWOBLUECUBES_CATCH_INTERFACES_EXCEPTION_H_INCLUDED
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <catch2/catch_test_macros.hpp>
|
#include <catch2/catch_test_macros.hpp>
|
||||||
|
#include <catch2/catch_translate_exception.hpp>
|
||||||
#include <catch2/matchers/catch_matchers_string.hpp>
|
#include <catch2/matchers/catch_matchers_string.hpp>
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
Loading…
Reference in New Issue
Block a user