mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-10-25 10:45:40 +02:00 
			
		
		
		
	Fix catch exception by reference
When compiling our codebase with clang we were getting the following
error:
GSL/tests/algorithm_tests.cpp:198:58: warning: catch handler catches by
value; should catch by reference instead
[misc-throw-by-value-catch-by-reference]
    CHECK_THROWS_AS(copy(src_span_dyn, dst_span_static), fail_fast);
                                                             ^
Looking at the catch source code exceptions were being caught by value.
One could have it designed so that users might say:
CHECK_THROWS_AS(copy(src_span_dyn, dst_span_static), fail_fast&);
But I don't think this is the intent and looking at the Catch tests
itself looks like this macro does not expect the reference:
    REQUIRE_THROWS_AS( thisThrows(), std::domain_error );
    CHECK_THROWS_AS( thisDoesntThrow(), std::domain_error );
This commit makes Catch catch exceptions by reference instead of by
value.
			
			
This commit is contained in:
		| @@ -136,7 +136,7 @@ | |||||||
|                 static_cast<void>(expr); \ |                 static_cast<void>(expr); \ | ||||||
|                 __catchResult.captureResult( Catch::ResultWas::DidntThrowException ); \ |                 __catchResult.captureResult( Catch::ResultWas::DidntThrowException ); \ | ||||||
|             } \ |             } \ | ||||||
|             catch( exceptionType ) { \ |             catch( exceptionType& ) { \ | ||||||
|                 __catchResult.captureResult( Catch::ResultWas::Ok ); \ |                 __catchResult.captureResult( Catch::ResultWas::Ok ); \ | ||||||
|             } \ |             } \ | ||||||
|             catch( ... ) { \ |             catch( ... ) { \ | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ bool templated_tests(T t) { | |||||||
|     REQUIRE(a == t); |     REQUIRE(a == t); | ||||||
|     CHECK(a == t); |     CHECK(a == t); | ||||||
|     REQUIRE_THROWS(throws_int(true)); |     REQUIRE_THROWS(throws_int(true)); | ||||||
|     CHECK_THROWS_AS(throws_int(true), const int&); |     CHECK_THROWS_AS(throws_int(true), const int); | ||||||
|     REQUIRE_NOTHROW(throws_int(false)); |     REQUIRE_NOTHROW(throws_int(false)); | ||||||
|     REQUIRE_THAT("aaa", Catch::EndsWith("aaa")); |     REQUIRE_THAT("aaa", Catch::EndsWith("aaa")); | ||||||
|     return true; |     return true; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Tiago Macarios
					Tiago Macarios