mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-11-04 00:51:52 +01:00 
			
		
		
		
	Compare commits
	
		
			44 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					5c198d85e6 | ||
| 
						 | 
					5a6b291878 | ||
| 
						 | 
					92b141ee53 | ||
| 
						 | 
					4f1263d6b4 | ||
| 
						 | 
					3b19458fed | ||
| 
						 | 
					e5537842d0 | ||
| 
						 | 
					0fe303b6b7 | ||
| 
						 | 
					1c47fe023a | ||
| 
						 | 
					6f3bc629be | ||
| 
						 | 
					6de7142d1f | ||
| 
						 | 
					7544644bb4 | ||
| 
						 | 
					7075b7defb | ||
| 
						 | 
					c984fc3ecd | ||
| 
						 | 
					447f53e9e3 | ||
| 
						 | 
					13a887ad24 | ||
| 
						 | 
					02af70ed0b | ||
| 
						 | 
					c362894565 | ||
| 
						 | 
					97e335437e | ||
| 
						 | 
					ae5ee2cf63 | ||
| 
						 | 
					f895e0d95f | ||
| 
						 | 
					458f37ed57 | ||
| 
						 | 
					91bfe68a75 | ||
| 
						 | 
					8ccb18daa9 | ||
| 
						 | 
					dce2154474 | ||
| 
						 | 
					e52ad48fb7 | ||
| 
						 | 
					776247af81 | ||
| 
						 | 
					3b4edd7a48 | ||
| 
						 | 
					880a2046d9 | ||
| 
						 | 
					ffad3a0a39 | ||
| 
						 | 
					3bd20bf2cd | ||
| 
						 | 
					c7243562b0 | ||
| 
						 | 
					b84e08ad6f | ||
| 
						 | 
					aca16a0f99 | ||
| 
						 | 
					f294c98472 | ||
| 
						 | 
					7424b23bfb | ||
| 
						 | 
					dbd3a84d92 | ||
| 
						 | 
					5262e61e9d | ||
| 
						 | 
					a5fba672e1 | ||
| 
						 | 
					2106d82881 | ||
| 
						 | 
					981347b6e4 | ||
| 
						 | 
					9e341231ba | ||
| 
						 | 
					2b688e1cef | ||
| 
						 | 
					84d1c080d6 | ||
| 
						 | 
					722315a1f5 | 
@@ -1,12 +1,10 @@
 | 
			
		||||

 | 
			
		||||
 | 
			
		||||
*v1.3.0*
 | 
			
		||||
*v1.5.2*
 | 
			
		||||
 | 
			
		||||
Build status (on Travis CI) [](https://travis-ci.org/philsquared/Catch)
 | 
			
		||||
 | 
			
		||||
[Please see this page if you are updating from a version before 1.0](docs/whats-changed.md)
 | 
			
		||||
 | 
			
		||||
<a href="https://raw.githubusercontent.com/philsquared/Catch/master/single_include/catch.hpp">[The latest, single header, version can be downloaded directly using this link]</a>
 | 
			
		||||
<a href="https://raw.githubusercontent.com/philsquared/Catch/master/single_include/catch.hpp">The latest, single header, version can be downloaded directly using this link</a>
 | 
			
		||||
 | 
			
		||||
## What's the Catch?
 | 
			
		||||
 | 
			
		||||
@@ -19,8 +17,6 @@ This documentation comprises these three parts:
 | 
			
		||||
* [Tutorial](docs/tutorial.md) - getting started
 | 
			
		||||
* [Reference section](docs/Readme.md) - all the details
 | 
			
		||||
 | 
			
		||||
The documentation will continue until morale improves
 | 
			
		||||
 | 
			
		||||
## More
 | 
			
		||||
* Issues and bugs can be raised on the [Issue tracker on GitHub](https://github.com/philsquared/Catch/issues)
 | 
			
		||||
* For discussion or questions please use [the dedicated Google Groups forum](https://groups.google.com/forum/?fromgroups#!forum/catch-forum)
 | 
			
		||||
 
 | 
			
		||||
@@ -16,5 +16,4 @@ Before looking at this material be sure to read the [tutorial](tutorial.md)
 | 
			
		||||
Other
 | 
			
		||||
 | 
			
		||||
* [Why Catch?](why-catch.md)
 | 
			
		||||
* [What's changed](whats-changed.md)
 | 
			
		||||
* [Contributing](contributing.md)
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,6 @@
 | 
			
		||||
# Getting Catch
 | 
			
		||||
 | 
			
		||||
The simplest way to get Catch is to download the single header version from [http://builds.catch-lib.net](http://builds.catch-lib.net). Don't be put off by the word "builds" there. The single header is generated by merging a set of individual headers but it is still just normal source code in a header file.
 | 
			
		||||
The simplest way to get Catch is to download the latest [single header version](https://raw.githubusercontent.com/philsquared/Catch/master/single_include/catch.hpp). The single header is generated by merging a set of individual headers but it is still just normal source code in a header file.
 | 
			
		||||
 | 
			
		||||
The full source for Catch, including test projects, documentation, and other things, is hosted on GitHub. [http://catch-lib.net](http://catch-lib.net) will redirect you there.
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,24 +0,0 @@
 | 
			
		||||
## What's new in Catch for 1.0
 | 
			
		||||
 | 
			
		||||
After a long "developer preview" state Catch turned 1.0 in mid-2013. Just prior to this a large number of changes, some of them breaking, where merged from the integration branch and now form part of the 1.0 code-base. If this might affect you please read this summary through so you know what to expect.
 | 
			
		||||
 | 
			
		||||
* Calling Catch from your own ```main()``` has changed - please review [the updated docs](own-main.md)
 | 
			
		||||
* The command line has changed. The biggest change is that test case names and tags should now only be supplied as primary arguments - in fact the ```-t``` option has been repurposed to mean "list tags". There are [updated docs for this too](command-line.md)
 | 
			
		||||
* There is a new reporter interface. If you have written a custom reporter you can use the ```LegacyReporterAdapter``` to minimise any differences. Ideally you should update to the new interface - especially as it has been designed to be more robust in the face of future changes (which should be minimal).
 | 
			
		||||
* The docs have moved from the wiki to the repository itself. They consist of a set of markdown files in the docs folder and are referenced directly from the README in the root. You can still read them online from GitHub.
 | 
			
		||||
* Lots of new goodness - more documentation for which is coming. The existing docs have been updated to account for some of the changes already (e.g. variadic macros). A quick rundown:
 | 
			
		||||
	* Variadic macros are used, where possible, so that, e.g. you can write a ```TEST_CASE``` with just a name - or even no name at all (making it an anonymous test case).
 | 
			
		||||
	* The hierarchical naming convention is deprecated in favour of using tags (see next)
 | 
			
		||||
	* ```TEST_CASE```s (but not ```SECTION```s) can now be tagged by placing keywords in square brackets in the second argument - e.g.: ```TEST_CASE( "A nice name", "[tag1][tag2]")```. The old style is still supported but please consider using this new style.
 | 
			
		||||
	* Tests can still be "hidden" using the ```./``` prefix as before, but the preferred way now is to give it the ```[hide]``` tag (hidden tests are skipped if you run the test process without specifying any test specs).
 | 
			
		||||
	* As well as ```TEST_CASE```s and ```SECTION```s you can now also use BDD-style ```SCENARIO``` (in place of ```TEST_CASE```) and ```GIVEN```, ```WHEN``` and ```THEN``` macros (in place of ```SECTION```s).
 | 
			
		||||
	* New command line parser. Under the hood it is a complete rewrite - now powered by a command line library that will soon be spun out as a separate project: Clara. The options themselves are largely the same but there are some notable differences (as already discussed).
 | 
			
		||||
	* Completely overhauled output from the textual reporter (now the Console reporter). This now features a much clearer, cleaner format, including good use of indentation.
 | 
			
		||||
 | 
			
		||||
More information can be found in [this blog post](http://www.levelofindirection.com/journal/2013/6/28/catch-10.html).
 | 
			
		||||
 | 
			
		||||
If you find any issues please raise issue tickets on the [issue tracker on GitHub](https://github.com/philsquared/Catch/issues) as before. For general questions, comments and suggestions, though, please use the [new forums on Google Groups](https://groups.google.com/forum/?fromgroups#!forum/catch-forum).
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 | 
			
		||||
[Home](Readme.md)
 | 
			
		||||
@@ -99,7 +99,7 @@
 | 
			
		||||
    #define CATCH_TEST_CASE( ... ) INTERNAL_CATCH_TESTCASE( __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_TEST_CASE_METHOD( className, ... ) INTERNAL_CATCH_TEST_CASE_METHOD( className, __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_METHOD_AS_TEST_CASE( method, ... ) INTERNAL_CATCH_METHOD_AS_TEST_CASE( method, __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_REGISTER_TEST_CASE( ... ) INTERNAL_CATCH_REGISTER_TESTCASE( __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_REGISTER_TEST_CASE( Function, ... ) INTERNAL_CATCH_REGISTER_TESTCASE( Function, __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_SECTION( ... ) INTERNAL_CATCH_SECTION( __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_FAIL( ... ) INTERNAL_CATCH_MSG( Catch::ResultWas::ExplicitFailure, Catch::ResultDisposition::Normal, "CATCH_FAIL", __VA_ARGS__ )
 | 
			
		||||
    #define CATCH_SUCCEED( ... ) INTERNAL_CATCH_MSG( Catch::ResultWas::Ok, Catch::ResultDisposition::ContinueOnFailure, "CATCH_SUCCEED", __VA_ARGS__ )
 | 
			
		||||
@@ -168,7 +168,7 @@
 | 
			
		||||
    #define TEST_CASE( ... ) INTERNAL_CATCH_TESTCASE( __VA_ARGS__ )
 | 
			
		||||
    #define TEST_CASE_METHOD( className, ... ) INTERNAL_CATCH_TEST_CASE_METHOD( className, __VA_ARGS__ )
 | 
			
		||||
    #define METHOD_AS_TEST_CASE( method, ... ) INTERNAL_CATCH_METHOD_AS_TEST_CASE( method, __VA_ARGS__ )
 | 
			
		||||
    #define REGISTER_TEST_CASE( ... ) INTERNAL_CATCH_REGISTER_TESTCASE( __VA_ARGS__ )
 | 
			
		||||
    #define REGISTER_TEST_CASE( Function, ... ) INTERNAL_CATCH_REGISTER_TESTCASE( Function, __VA_ARGS__ )
 | 
			
		||||
    #define SECTION( ... ) INTERNAL_CATCH_SECTION( __VA_ARGS__ )
 | 
			
		||||
    #define FAIL( ... ) INTERNAL_CATCH_MSG( Catch::ResultWas::ExplicitFailure, Catch::ResultDisposition::Normal, "FAIL", __VA_ARGS__ )
 | 
			
		||||
    #define SUCCEED( ... ) INTERNAL_CATCH_MSG( Catch::ResultWas::Ok, Catch::ResultDisposition::ContinueOnFailure, "SUCCEED", __VA_ARGS__ )
 | 
			
		||||
@@ -176,7 +176,7 @@
 | 
			
		||||
    #define TEST_CASE( name, description ) INTERNAL_CATCH_TESTCASE( name, description )
 | 
			
		||||
    #define TEST_CASE_METHOD( className, name, description ) INTERNAL_CATCH_TEST_CASE_METHOD( className, name, description )
 | 
			
		||||
    #define METHOD_AS_TEST_CASE( method, name, description ) INTERNAL_CATCH_METHOD_AS_TEST_CASE( method, name, description )
 | 
			
		||||
    #define REGISTER_TEST_CASE( ... ) INTERNAL_CATCH_REGISTER_TESTCASE( __VA_ARGS__ )
 | 
			
		||||
    #define REGISTER_TEST_CASE( method, name, description ) INTERNAL_CATCH_REGISTER_TESTCASE( method, name, description )
 | 
			
		||||
    #define SECTION( name, description ) INTERNAL_CATCH_SECTION( name, description )
 | 
			
		||||
    #define FAIL( msg ) INTERNAL_CATCH_MSG( Catch::ResultWas::ExplicitFailure, Catch::ResultDisposition::Normal, "FAIL", msg )
 | 
			
		||||
    #define SUCCEED( msg ) INTERNAL_CATCH_MSG( Catch::ResultWas::Ok, Catch::ResultDisposition::ContinueOnFailure, "SUCCEED", msg )
 | 
			
		||||
 
 | 
			
		||||
@@ -131,10 +131,10 @@ namespace Catch {
 | 
			
		||||
            Catch::cout() << "For more detail usage please see the project docs\n" << std::endl;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        int applyCommandLine( int argc, char const* const argv[], OnUnusedOptions::DoWhat unusedOptionBehaviour = OnUnusedOptions::Fail ) {
 | 
			
		||||
        int applyCommandLine( int argc, char const* const* const argv, OnUnusedOptions::DoWhat unusedOptionBehaviour = OnUnusedOptions::Fail ) {
 | 
			
		||||
            try {
 | 
			
		||||
                m_cli.setThrowOnUnrecognisedTokens( unusedOptionBehaviour == OnUnusedOptions::Fail );
 | 
			
		||||
                m_unusedTokens = m_cli.parseInto( argc, argv, m_configData );
 | 
			
		||||
                m_unusedTokens = m_cli.parseInto( Clara::argsToVector( argc, argv ), m_configData );
 | 
			
		||||
                if( m_configData.showHelp )
 | 
			
		||||
                    showHelp( m_configData.processName );
 | 
			
		||||
                m_config.reset();
 | 
			
		||||
@@ -158,7 +158,7 @@ namespace Catch {
 | 
			
		||||
            m_config.reset();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        int run( int argc, char const* const argv[] ) {
 | 
			
		||||
        int run( int argc, char const* const* const argv ) {
 | 
			
		||||
 | 
			
		||||
            int returnCode = applyCommandLine( argc, argv );
 | 
			
		||||
            if( returnCode == 0 )
 | 
			
		||||
 
 | 
			
		||||
@@ -8,8 +8,7 @@
 | 
			
		||||
#ifndef TWOBLUECUBES_CATCH_WITH_MAIN_HPP_INCLUDED
 | 
			
		||||
#define TWOBLUECUBES_CATCH_WITH_MAIN_HPP_INCLUDED
 | 
			
		||||
 | 
			
		||||
#include "catch_runner.hpp"
 | 
			
		||||
#define CATCH_CONFIG_MAIN
 | 
			
		||||
#include "catch.hpp"
 | 
			
		||||
#include "internal/catch_default_main.hpp"
 | 
			
		||||
 | 
			
		||||
#endif // TWOBLUECUBES_CATCH_WITH_MAIN_HPP_INCLUDED
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										347
									
								
								include/external/clara.h
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										347
									
								
								include/external/clara.h
									
									
									
									
										vendored
									
									
								
							@@ -6,6 +6,8 @@
 | 
			
		||||
 *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
// Version 0.0.2.4
 | 
			
		||||
 | 
			
		||||
// Only use header guard if we are not using an outer namespace
 | 
			
		||||
#if !defined(TWOBLUECUBES_CLARA_H_INCLUDED) || defined(STITCH_CLARA_OPEN_NAMESPACE)
 | 
			
		||||
 | 
			
		||||
@@ -38,6 +40,7 @@
 | 
			
		||||
#include <string>
 | 
			
		||||
#include <vector>
 | 
			
		||||
#include <sstream>
 | 
			
		||||
#include <algorithm>
 | 
			
		||||
 | 
			
		||||
// Use optional outer namespace
 | 
			
		||||
#ifdef STITCH_TBC_TEXT_FORMAT_OUTER_NAMESPACE
 | 
			
		||||
@@ -172,16 +175,179 @@ namespace Tbc {
 | 
			
		||||
#endif // TBC_TEXT_FORMAT_H_INCLUDED
 | 
			
		||||
 | 
			
		||||
// ----------- end of #include from tbc_text_format.h -----------
 | 
			
		||||
// ........... back in /Users/philnash/Dev/OSS/Clara/srcs/clara.h
 | 
			
		||||
// ........... back in clara.h
 | 
			
		||||
 | 
			
		||||
#undef STITCH_TBC_TEXT_FORMAT_OPEN_NAMESPACE
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// ----------- #included from clara_compilers.h -----------
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 *  Created by Phil on 10/02/2016.
 | 
			
		||||
 *  Copyright 2016 Two Blue Cubes Ltd. All rights reserved.
 | 
			
		||||
 *
 | 
			
		||||
 *  Distributed under the Boost Software License, Version 1.0. (See accompanying
 | 
			
		||||
 *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
 | 
			
		||||
 */
 | 
			
		||||
#ifndef TWOBLUECUBES_CLARA_COMPILERS_H_INCLUDED
 | 
			
		||||
#define TWOBLUECUBES_CLARA_COMPILERS_H_INCLUDED
 | 
			
		||||
 | 
			
		||||
// Detect a number of compiler features - mostly C++11/14 conformance - by compiler
 | 
			
		||||
// The following features are defined:
 | 
			
		||||
//
 | 
			
		||||
// CLARA_CONFIG_CPP11_NULLPTR : is nullptr supported?
 | 
			
		||||
// CLARA_CONFIG_CPP11_NOEXCEPT : is noexcept supported?
 | 
			
		||||
// CLARA_CONFIG_CPP11_GENERATED_METHODS : The delete and default keywords for compiler generated methods
 | 
			
		||||
// CLARA_CONFIG_CPP11_OVERRIDE : is override supported?
 | 
			
		||||
// CLARA_CONFIG_CPP11_UNIQUE_PTR : is unique_ptr supported (otherwise use auto_ptr)
 | 
			
		||||
 | 
			
		||||
// CLARA_CONFIG_CPP11_OR_GREATER : Is C++11 supported?
 | 
			
		||||
 | 
			
		||||
// CLARA_CONFIG_VARIADIC_MACROS : are variadic macros supported?
 | 
			
		||||
 | 
			
		||||
// In general each macro has a _NO_<feature name> form
 | 
			
		||||
// (e.g. CLARA_CONFIG_CPP11_NO_NULLPTR) which disables the feature.
 | 
			
		||||
// Many features, at point of detection, define an _INTERNAL_ macro, so they
 | 
			
		||||
// can be combined, en-mass, with the _NO_ forms later.
 | 
			
		||||
 | 
			
		||||
// All the C++11 features can be disabled with CLARA_CONFIG_NO_CPP11
 | 
			
		||||
 | 
			
		||||
#ifdef __clang__
 | 
			
		||||
 | 
			
		||||
#if __has_feature(cxx_nullptr)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if __has_feature(cxx_noexcept)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NOEXCEPT
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#endif // __clang__
 | 
			
		||||
 | 
			
		||||
////////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
// GCC
 | 
			
		||||
#ifdef __GNUC__
 | 
			
		||||
 | 
			
		||||
#if __GNUC__ == 4 && __GNUC_MINOR__ >= 6 && defined(__GXX_EXPERIMENTAL_CXX0X__)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// - otherwise more recent versions define __cplusplus >= 201103L
 | 
			
		||||
// and will get picked up below
 | 
			
		||||
 | 
			
		||||
#endif // __GNUC__
 | 
			
		||||
 | 
			
		||||
////////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
// Visual C++
 | 
			
		||||
#ifdef _MSC_VER
 | 
			
		||||
 | 
			
		||||
#if (_MSC_VER >= 1600)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_UNIQUE_PTR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if (_MSC_VER >= 1900 ) // (VC++ 13 (VS2015))
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NOEXCEPT
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_GENERATED_METHODS
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#endif // _MSC_VER
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
////////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
// C++ language feature support
 | 
			
		||||
 | 
			
		||||
// catch all support for C++11
 | 
			
		||||
#if defined(__cplusplus) && __cplusplus >= 201103L
 | 
			
		||||
 | 
			
		||||
#define CLARA_CPP11_OR_GREATER
 | 
			
		||||
 | 
			
		||||
#if !defined(CLARA_INTERNAL_CONFIG_CPP11_NULLPTR)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifndef CLARA_INTERNAL_CONFIG_CPP11_NOEXCEPT
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_NOEXCEPT
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifndef CLARA_INTERNAL_CONFIG_CPP11_GENERATED_METHODS
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_GENERATED_METHODS
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if !defined(CLARA_INTERNAL_CONFIG_CPP11_OVERRIDE)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_OVERRIDE
 | 
			
		||||
#endif
 | 
			
		||||
#if !defined(CLARA_INTERNAL_CONFIG_CPP11_UNIQUE_PTR)
 | 
			
		||||
#define CLARA_INTERNAL_CONFIG_CPP11_UNIQUE_PTR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#endif // __cplusplus >= 201103L
 | 
			
		||||
 | 
			
		||||
// Now set the actual defines based on the above + anything the user has configured
 | 
			
		||||
#if defined(CLARA_INTERNAL_CONFIG_CPP11_NULLPTR) && !defined(CLARA_CONFIG_CPP11_NO_NULLPTR) && !defined(CLARA_CONFIG_CPP11_NULLPTR) && !defined(CLARA_CONFIG_NO_CPP11)
 | 
			
		||||
#define CLARA_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(CLARA_INTERNAL_CONFIG_CPP11_NOEXCEPT) && !defined(CLARA_CONFIG_CPP11_NO_NOEXCEPT) && !defined(CLARA_CONFIG_CPP11_NOEXCEPT) && !defined(CLARA_CONFIG_NO_CPP11)
 | 
			
		||||
#define CLARA_CONFIG_CPP11_NOEXCEPT
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(CLARA_INTERNAL_CONFIG_CPP11_GENERATED_METHODS) && !defined(CLARA_CONFIG_CPP11_NO_GENERATED_METHODS) && !defined(CLARA_CONFIG_CPP11_GENERATED_METHODS) && !defined(CLARA_CONFIG_NO_CPP11)
 | 
			
		||||
#define CLARA_CONFIG_CPP11_GENERATED_METHODS
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(CLARA_INTERNAL_CONFIG_CPP11_OVERRIDE) && !defined(CLARA_CONFIG_NO_OVERRIDE) && !defined(CLARA_CONFIG_CPP11_OVERRIDE) && !defined(CLARA_CONFIG_NO_CPP11)
 | 
			
		||||
#define CLARA_CONFIG_CPP11_OVERRIDE
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(CLARA_INTERNAL_CONFIG_CPP11_UNIQUE_PTR) && !defined(CLARA_CONFIG_NO_UNIQUE_PTR) && !defined(CLARA_CONFIG_CPP11_UNIQUE_PTR) && !defined(CLARA_CONFIG_NO_CPP11)
 | 
			
		||||
#define CLARA_CONFIG_CPP11_UNIQUE_PTR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// noexcept support:
 | 
			
		||||
#if defined(CLARA_CONFIG_CPP11_NOEXCEPT) && !defined(CLARA_NOEXCEPT)
 | 
			
		||||
#define CLARA_NOEXCEPT noexcept
 | 
			
		||||
#  define CLARA_NOEXCEPT_IS(x) noexcept(x)
 | 
			
		||||
#else
 | 
			
		||||
#define CLARA_NOEXCEPT throw()
 | 
			
		||||
#  define CLARA_NOEXCEPT_IS(x)
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// nullptr support
 | 
			
		||||
#ifdef CLARA_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#define CLARA_NULL nullptr
 | 
			
		||||
#else
 | 
			
		||||
#define CLARA_NULL NULL
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// override support
 | 
			
		||||
#ifdef CLARA_CONFIG_CPP11_OVERRIDE
 | 
			
		||||
#define CLARA_OVERRIDE override
 | 
			
		||||
#else
 | 
			
		||||
#define CLARA_OVERRIDE
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// unique_ptr support
 | 
			
		||||
#ifdef CLARA_CONFIG_CPP11_UNIQUE_PTR
 | 
			
		||||
#   define CLARA_AUTO_PTR( T ) std::unique_ptr<T>
 | 
			
		||||
#else
 | 
			
		||||
#   define CLARA_AUTO_PTR( T ) std::auto_ptr<T>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#endif // TWOBLUECUBES_CLARA_COMPILERS_H_INCLUDED
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// ----------- end of #include from clara_compilers.h -----------
 | 
			
		||||
// ........... back in clara.h
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#include <map>
 | 
			
		||||
#include <algorithm>
 | 
			
		||||
#include <stdexcept>
 | 
			
		||||
#include <memory>
 | 
			
		||||
 | 
			
		||||
#if defined(WIN32) || defined(__WIN32__) || defined(_WIN32) || defined(_MSC_VER)
 | 
			
		||||
#define CLARA_PLATFORM_WINDOWS
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// Use optional outer namespace
 | 
			
		||||
#ifdef STITCH_CLARA_OPEN_NAMESPACE
 | 
			
		||||
STITCH_CLARA_OPEN_NAMESPACE
 | 
			
		||||
@@ -240,23 +406,16 @@ namespace Clara {
 | 
			
		||||
            else
 | 
			
		||||
                throw std::runtime_error( "Expected a boolean value but did not recognise:\n  '" + _source + "'" );
 | 
			
		||||
        }
 | 
			
		||||
        inline void convertInto( bool _source, bool& _dest ) {
 | 
			
		||||
            _dest = _source;
 | 
			
		||||
        }
 | 
			
		||||
        template<typename T>
 | 
			
		||||
        inline void convertInto( bool, T& ) {
 | 
			
		||||
            throw std::runtime_error( "Invalid conversion" );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        template<typename ConfigT>
 | 
			
		||||
        struct IArgFunction {
 | 
			
		||||
            virtual ~IArgFunction() {}
 | 
			
		||||
#  ifdef CATCH_CONFIG_CPP11_GENERATED_METHODS
 | 
			
		||||
#ifdef CLARA_CONFIG_CPP11_GENERATED_METHODS
 | 
			
		||||
            IArgFunction()                      = default;
 | 
			
		||||
            IArgFunction( IArgFunction const& ) = default;
 | 
			
		||||
#  endif
 | 
			
		||||
#endif
 | 
			
		||||
            virtual void set( ConfigT& config, std::string const& value ) const = 0;
 | 
			
		||||
            virtual void setFlag( ConfigT& config ) const = 0;
 | 
			
		||||
            virtual bool takesArg() const = 0;
 | 
			
		||||
            virtual IArgFunction* clone() const = 0;
 | 
			
		||||
        };
 | 
			
		||||
@@ -264,11 +423,11 @@ namespace Clara {
 | 
			
		||||
        template<typename ConfigT>
 | 
			
		||||
        class BoundArgFunction {
 | 
			
		||||
        public:
 | 
			
		||||
            BoundArgFunction() : functionObj( CATCH_NULL ) {}
 | 
			
		||||
            BoundArgFunction() : functionObj( CLARA_NULL ) {}
 | 
			
		||||
            BoundArgFunction( IArgFunction<ConfigT>* _functionObj ) : functionObj( _functionObj ) {}
 | 
			
		||||
            BoundArgFunction( BoundArgFunction const& other ) : functionObj( other.functionObj ? other.functionObj->clone() : CATCH_NULL ) {}
 | 
			
		||||
            BoundArgFunction( BoundArgFunction const& other ) : functionObj( other.functionObj ? other.functionObj->clone() : CLARA_NULL ) {}
 | 
			
		||||
            BoundArgFunction& operator = ( BoundArgFunction const& other ) {
 | 
			
		||||
                IArgFunction<ConfigT>* newFunctionObj = other.functionObj ? other.functionObj->clone() : CATCH_NULL;
 | 
			
		||||
                IArgFunction<ConfigT>* newFunctionObj = other.functionObj ? other.functionObj->clone() : CLARA_NULL;
 | 
			
		||||
                delete functionObj;
 | 
			
		||||
                functionObj = newFunctionObj;
 | 
			
		||||
                return *this;
 | 
			
		||||
@@ -278,13 +437,10 @@ namespace Clara {
 | 
			
		||||
            void set( ConfigT& config, std::string const& value ) const {
 | 
			
		||||
                functionObj->set( config, value );
 | 
			
		||||
            }
 | 
			
		||||
            void setFlag( ConfigT& config ) const {
 | 
			
		||||
                functionObj->setFlag( config );
 | 
			
		||||
            }
 | 
			
		||||
            bool takesArg() const { return functionObj->takesArg(); }
 | 
			
		||||
 | 
			
		||||
            bool isSet() const {
 | 
			
		||||
                return functionObj != CATCH_NULL;
 | 
			
		||||
                return functionObj != CLARA_NULL;
 | 
			
		||||
            }
 | 
			
		||||
        private:
 | 
			
		||||
            IArgFunction<ConfigT>* functionObj;
 | 
			
		||||
@@ -294,7 +450,6 @@ namespace Clara {
 | 
			
		||||
        template<typename C>
 | 
			
		||||
        struct NullBinder : IArgFunction<C>{
 | 
			
		||||
            virtual void set( C&, std::string const& ) const {}
 | 
			
		||||
            virtual void setFlag( C& ) const {}
 | 
			
		||||
            virtual bool takesArg() const { return true; }
 | 
			
		||||
            virtual IArgFunction<C>* clone() const { return new NullBinder( *this ); }
 | 
			
		||||
        };
 | 
			
		||||
@@ -305,9 +460,6 @@ namespace Clara {
 | 
			
		||||
            virtual void set( C& p, std::string const& stringValue ) const {
 | 
			
		||||
                convertInto( stringValue, p.*member );
 | 
			
		||||
            }
 | 
			
		||||
            virtual void setFlag( C& p ) const {
 | 
			
		||||
                convertInto( true, p.*member );
 | 
			
		||||
            }
 | 
			
		||||
            virtual bool takesArg() const { return !IsBool<M>::value; }
 | 
			
		||||
            virtual IArgFunction<C>* clone() const { return new BoundDataMember( *this ); }
 | 
			
		||||
            M C::* member;
 | 
			
		||||
@@ -320,11 +472,6 @@ namespace Clara {
 | 
			
		||||
                convertInto( stringValue, value );
 | 
			
		||||
                (p.*member)( value );
 | 
			
		||||
            }
 | 
			
		||||
            virtual void setFlag( C& p ) const {
 | 
			
		||||
                typename RemoveConstRef<M>::type value;
 | 
			
		||||
                convertInto( true, value );
 | 
			
		||||
                (p.*member)( value );
 | 
			
		||||
            }
 | 
			
		||||
            virtual bool takesArg() const { return !IsBool<M>::value; }
 | 
			
		||||
            virtual IArgFunction<C>* clone() const { return new BoundUnaryMethod( *this ); }
 | 
			
		||||
            void (C::*member)( M );
 | 
			
		||||
@@ -338,9 +485,6 @@ namespace Clara {
 | 
			
		||||
                if( value )
 | 
			
		||||
                    (p.*member)();
 | 
			
		||||
            }
 | 
			
		||||
            virtual void setFlag( C& p ) const {
 | 
			
		||||
                (p.*member)();
 | 
			
		||||
            }
 | 
			
		||||
            virtual bool takesArg() const { return false; }
 | 
			
		||||
            virtual IArgFunction<C>* clone() const { return new BoundNullaryMethod( *this ); }
 | 
			
		||||
            void (C::*member)();
 | 
			
		||||
@@ -355,9 +499,6 @@ namespace Clara {
 | 
			
		||||
                if( value )
 | 
			
		||||
                    function( obj );
 | 
			
		||||
            }
 | 
			
		||||
            virtual void setFlag( C& p ) const {
 | 
			
		||||
                function( p );
 | 
			
		||||
            }
 | 
			
		||||
            virtual bool takesArg() const { return false; }
 | 
			
		||||
            virtual IArgFunction<C>* clone() const { return new BoundUnaryFunction( *this ); }
 | 
			
		||||
            void (*function)( C& );
 | 
			
		||||
@@ -371,11 +512,6 @@ namespace Clara {
 | 
			
		||||
                convertInto( stringValue, value );
 | 
			
		||||
                function( obj, value );
 | 
			
		||||
            }
 | 
			
		||||
            virtual void setFlag( C& obj ) const {
 | 
			
		||||
                typename RemoveConstRef<T>::type value;
 | 
			
		||||
                convertInto( true, value );
 | 
			
		||||
                function( obj, value );
 | 
			
		||||
            }
 | 
			
		||||
            virtual bool takesArg() const { return !IsBool<T>::value; }
 | 
			
		||||
            virtual IArgFunction<C>* clone() const { return new BoundBinaryFunction( *this ); }
 | 
			
		||||
            void (*function)( C&, T );
 | 
			
		||||
@@ -383,8 +519,20 @@ namespace Clara {
 | 
			
		||||
 | 
			
		||||
    } // namespace Detail
 | 
			
		||||
 | 
			
		||||
    struct Parser {
 | 
			
		||||
        Parser() : separators( " \t=:" ) {}
 | 
			
		||||
    inline std::vector<std::string> argsToVector( int argc, char const* const* const argv ) {
 | 
			
		||||
        std::vector<std::string> args( static_cast<std::size_t>( argc ) );
 | 
			
		||||
        for( std::size_t i = 0; i < static_cast<std::size_t>( argc ); ++i )
 | 
			
		||||
            args[i] = argv[i];
 | 
			
		||||
 | 
			
		||||
        return args;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    class Parser {
 | 
			
		||||
        enum Mode { None, MaybeShortOpt, SlashOpt, ShortOpt, LongOpt, Positional };
 | 
			
		||||
        Mode mode;
 | 
			
		||||
        std::size_t from;
 | 
			
		||||
        bool inQuotes;
 | 
			
		||||
    public:
 | 
			
		||||
 | 
			
		||||
        struct Token {
 | 
			
		||||
            enum Type { Positional, ShortOpt, LongOpt };
 | 
			
		||||
@@ -393,38 +541,75 @@ namespace Clara {
 | 
			
		||||
            std::string data;
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        void parseIntoTokens( int argc, char const * const * argv, std::vector<Parser::Token>& tokens ) const {
 | 
			
		||||
        Parser() : mode( None ), from( 0 ), inQuotes( false ){}
 | 
			
		||||
 | 
			
		||||
        void parseIntoTokens( std::vector<std::string> const& args, std::vector<Token>& tokens ) {
 | 
			
		||||
            const std::string doubleDash = "--";
 | 
			
		||||
            for( int i = 1; i < argc && argv[i] != doubleDash; ++i )
 | 
			
		||||
                parseIntoTokens( argv[i] , tokens);
 | 
			
		||||
            for( std::size_t i = 1; i < args.size() && args[i] != doubleDash; ++i )
 | 
			
		||||
                parseIntoTokens( args[i], tokens);
 | 
			
		||||
        }
 | 
			
		||||
        void parseIntoTokens( std::string arg, std::vector<Parser::Token>& tokens ) const {
 | 
			
		||||
            while( !arg.empty() ) {
 | 
			
		||||
                Parser::Token token( Parser::Token::Positional, arg );
 | 
			
		||||
                arg = "";
 | 
			
		||||
                if( token.data[0] == '-' ) {
 | 
			
		||||
                    if( token.data.size() > 1 && token.data[1] == '-' ) {
 | 
			
		||||
                        token = Parser::Token( Parser::Token::LongOpt, token.data.substr( 2 ) );
 | 
			
		||||
                    }
 | 
			
		||||
                    else {
 | 
			
		||||
                        token = Parser::Token( Parser::Token::ShortOpt, token.data.substr( 1 ) );
 | 
			
		||||
                        if( token.data.size() > 1 && separators.find( token.data[1] ) == std::string::npos ) {
 | 
			
		||||
                            arg = "-" + token.data.substr( 1 );
 | 
			
		||||
                            token.data = token.data.substr( 0, 1 );
 | 
			
		||||
                        }
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
                if( token.type != Parser::Token::Positional ) {
 | 
			
		||||
                    std::size_t pos = token.data.find_first_of( separators );
 | 
			
		||||
                    if( pos != std::string::npos ) {
 | 
			
		||||
                        arg = token.data.substr( pos+1 );
 | 
			
		||||
                        token.data = token.data.substr( 0, pos );
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
                tokens.push_back( token );
 | 
			
		||||
 | 
			
		||||
        void parseIntoTokens( std::string const& arg, std::vector<Token>& tokens ) {
 | 
			
		||||
            for( std::size_t i = 0; i <= arg.size(); ++i ) {
 | 
			
		||||
                char c = arg[i];
 | 
			
		||||
                if( c == '"' )
 | 
			
		||||
                    inQuotes = !inQuotes;
 | 
			
		||||
                mode = handleMode( i, c, arg, tokens );
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        std::string separators;
 | 
			
		||||
        Mode handleMode( std::size_t i, char c, std::string const& arg, std::vector<Token>& tokens ) {
 | 
			
		||||
            switch( mode ) {
 | 
			
		||||
                case None: return handleNone( i, c );
 | 
			
		||||
                case MaybeShortOpt: return handleMaybeShortOpt( i, c );
 | 
			
		||||
                case ShortOpt:
 | 
			
		||||
                case LongOpt:
 | 
			
		||||
                case SlashOpt: return handleOpt( i, c, arg, tokens );
 | 
			
		||||
                case Positional: return handlePositional( i, c, arg, tokens );
 | 
			
		||||
                default: throw std::logic_error( "Unknown mode" );
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        Mode handleNone( std::size_t i, char c ) {
 | 
			
		||||
            if( inQuotes ) {
 | 
			
		||||
                from = i;
 | 
			
		||||
                return Positional;
 | 
			
		||||
            }
 | 
			
		||||
            switch( c ) {
 | 
			
		||||
                case '-': return MaybeShortOpt;
 | 
			
		||||
#ifdef CLARA_PLATFORM_WINDOWS
 | 
			
		||||
                case '/': from = i+1; return SlashOpt;
 | 
			
		||||
#endif
 | 
			
		||||
                default: from = i; return Positional;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        Mode handleMaybeShortOpt( std::size_t i, char c ) {
 | 
			
		||||
            switch( c ) {
 | 
			
		||||
                case '-': from = i+1; return LongOpt;
 | 
			
		||||
                default: from = i; return ShortOpt;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
        Mode handleOpt( std::size_t i, char c, std::string const& arg, std::vector<Token>& tokens ) {
 | 
			
		||||
            if( std::string( ":=\0", 5 ).find( c ) == std::string::npos )
 | 
			
		||||
                return mode;
 | 
			
		||||
 | 
			
		||||
            std::string optName = arg.substr( from, i-from );
 | 
			
		||||
            if( mode == ShortOpt )
 | 
			
		||||
                for( std::size_t j = 0; j < optName.size(); ++j )
 | 
			
		||||
                    tokens.push_back( Token( Token::ShortOpt, optName.substr( j, 1 ) ) );
 | 
			
		||||
            else if( mode == SlashOpt && optName.size() == 1 )
 | 
			
		||||
                tokens.push_back( Token( Token::ShortOpt, optName ) );
 | 
			
		||||
            else
 | 
			
		||||
                tokens.push_back( Token( Token::LongOpt, optName ) );
 | 
			
		||||
            return None;
 | 
			
		||||
        }
 | 
			
		||||
        Mode handlePositional( std::size_t i, char c, std::string const& arg, std::vector<Token>& tokens ) {
 | 
			
		||||
            if( inQuotes || std::string( "\0", 3 ).find( c ) == std::string::npos )
 | 
			
		||||
                return mode;
 | 
			
		||||
 | 
			
		||||
            std::string data = arg.substr( from, i-from );
 | 
			
		||||
            tokens.push_back( Token( Token::Positional, data ) );
 | 
			
		||||
            return None;
 | 
			
		||||
        }
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    template<typename ConfigT>
 | 
			
		||||
@@ -503,7 +688,7 @@ namespace Clara {
 | 
			
		||||
            }
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        typedef CATCH_AUTO_PTR( Arg ) ArgAutoPtr;
 | 
			
		||||
        typedef CLARA_AUTO_PTR( Arg ) ArgAutoPtr;
 | 
			
		||||
 | 
			
		||||
        friend void addOptName( Arg& arg, std::string const& optName )
 | 
			
		||||
        {
 | 
			
		||||
@@ -580,8 +765,8 @@ namespace Clara {
 | 
			
		||||
                m_arg->description = description;
 | 
			
		||||
                return *this;
 | 
			
		||||
            }
 | 
			
		||||
            ArgBuilder& detail( std::string const& _detail ) {
 | 
			
		||||
                m_arg->detail = _detail;
 | 
			
		||||
            ArgBuilder& detail( std::string const& detail ) {
 | 
			
		||||
                m_arg->detail = detail;
 | 
			
		||||
                return *this;
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
@@ -665,14 +850,14 @@ namespace Clara {
 | 
			
		||||
                maxWidth = (std::max)( maxWidth, it->commands().size() );
 | 
			
		||||
 | 
			
		||||
            for( it = itBegin; it != itEnd; ++it ) {
 | 
			
		||||
                Detail::Text usageText( it->commands(), Detail::TextAttributes()
 | 
			
		||||
                Detail::Text usage( it->commands(), Detail::TextAttributes()
 | 
			
		||||
                                                        .setWidth( maxWidth+indent )
 | 
			
		||||
                                                        .setIndent( indent ) );
 | 
			
		||||
                Detail::Text desc( it->description, Detail::TextAttributes()
 | 
			
		||||
                                                        .setWidth( width - maxWidth - 3 ) );
 | 
			
		||||
 | 
			
		||||
                for( std::size_t i = 0; i < (std::max)( usageText.size(), desc.size() ); ++i ) {
 | 
			
		||||
                    std::string usageCol = i < usageText.size() ? usageText[i] : "";
 | 
			
		||||
                for( std::size_t i = 0; i < (std::max)( usage.size(), desc.size() ); ++i ) {
 | 
			
		||||
                    std::string usageCol = i < usage.size() ? usage[i] : "";
 | 
			
		||||
                    os << usageCol;
 | 
			
		||||
 | 
			
		||||
                    if( i < desc.size() && !desc[i].empty() )
 | 
			
		||||
@@ -729,21 +914,21 @@ namespace Clara {
 | 
			
		||||
            return oss.str();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        ConfigT parse( int argc, char const * const * argv ) const {
 | 
			
		||||
        ConfigT parse( std::vector<std::string> const& args ) const {
 | 
			
		||||
            ConfigT config;
 | 
			
		||||
            parseInto( argc, argv, config );
 | 
			
		||||
            parseInto( args, config );
 | 
			
		||||
            return config;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        std::vector<Parser::Token> parseInto( int argc, char const * const * argv, ConfigT& config ) const {
 | 
			
		||||
            std::string processName = argv[0];
 | 
			
		||||
        std::vector<Parser::Token> parseInto( std::vector<std::string> const& args, ConfigT& config ) const {
 | 
			
		||||
            std::string processName = args[0];
 | 
			
		||||
            std::size_t lastSlash = processName.find_last_of( "/\\" );
 | 
			
		||||
            if( lastSlash != std::string::npos )
 | 
			
		||||
                processName = processName.substr( lastSlash+1 );
 | 
			
		||||
            m_boundProcessName.set( config, processName );
 | 
			
		||||
            std::vector<Parser::Token> tokens;
 | 
			
		||||
            Parser parser;
 | 
			
		||||
            parser.parseIntoTokens( argc, argv, tokens );
 | 
			
		||||
            parser.parseIntoTokens( args, tokens );
 | 
			
		||||
            return populate( tokens, config );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@@ -774,7 +959,7 @@ namespace Clara {
 | 
			
		||||
                                    arg.boundField.set( config, tokens[++i].data );
 | 
			
		||||
                            }
 | 
			
		||||
                            else {
 | 
			
		||||
                                arg.boundField.setFlag( config );
 | 
			
		||||
                                arg.boundField.set( config, "true" );
 | 
			
		||||
                            }
 | 
			
		||||
                            break;
 | 
			
		||||
                        }
 | 
			
		||||
 
 | 
			
		||||
@@ -33,13 +33,14 @@
 | 
			
		||||
    do { \
 | 
			
		||||
        Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #expr, resultDisposition ); \
 | 
			
		||||
        try { \
 | 
			
		||||
            CATCH_INTERNAL_SUPPRESS_PARENTHESES_WARNINGS \
 | 
			
		||||
            ( __catchResult <= expr ).endExpression(); \
 | 
			
		||||
        } \
 | 
			
		||||
        catch( ... ) { \
 | 
			
		||||
            __catchResult.useActiveException( Catch::ResultDisposition::Normal ); \
 | 
			
		||||
        } \
 | 
			
		||||
        INTERNAL_CATCH_REACT( __catchResult ) \
 | 
			
		||||
    } while( Catch::isTrue( false && (expr) ) ) // expr here is never evaluated at runtime but it forces the compiler to give it a look
 | 
			
		||||
    } while( Catch::isTrue( false && static_cast<bool>(expr) ) ) // expr here is never evaluated at runtime but it forces the compiler to give it a look
 | 
			
		||||
 | 
			
		||||
///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
#define INTERNAL_CATCH_IF( expr, resultDisposition, macroName ) \
 | 
			
		||||
@@ -129,7 +130,7 @@
 | 
			
		||||
///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
#define INTERNAL_CHECK_THAT( arg, matcher, resultDisposition, macroName ) \
 | 
			
		||||
    do { \
 | 
			
		||||
        Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #arg " " #matcher, resultDisposition ); \
 | 
			
		||||
        Catch::ResultBuilder __catchResult( macroName, CATCH_INTERNAL_LINEINFO, #arg ", " #matcher, resultDisposition ); \
 | 
			
		||||
        try { \
 | 
			
		||||
            std::string matcherAsString = (matcher).toString(); \
 | 
			
		||||
            __catchResult \
 | 
			
		||||
 
 | 
			
		||||
@@ -62,6 +62,21 @@ namespace Catch {
 | 
			
		||||
            ? ShowDurations::Always
 | 
			
		||||
            : ShowDurations::Never;
 | 
			
		||||
    }
 | 
			
		||||
    inline void setUseColour( ConfigData& config, std::string const& value ) {
 | 
			
		||||
        std::string mode = toLower( value );
 | 
			
		||||
        
 | 
			
		||||
        if( mode == "yes" )
 | 
			
		||||
            config.useColour = UseColour::Yes;
 | 
			
		||||
        else if( mode == "no" )
 | 
			
		||||
            config.useColour = UseColour::No;
 | 
			
		||||
        else if( mode == "auto" )
 | 
			
		||||
            config.useColour = UseColour::Auto;
 | 
			
		||||
        else
 | 
			
		||||
            throw std::runtime_error( "colour mode must be one of: auto, yes or no" );
 | 
			
		||||
    }
 | 
			
		||||
    inline void forceColour( ConfigData& config ) {
 | 
			
		||||
        config.useColour = UseColour::Yes;
 | 
			
		||||
    }
 | 
			
		||||
    inline void loadTestNamesFromFile( ConfigData& config, std::string const& _filename ) {
 | 
			
		||||
        std::ifstream f( _filename.c_str() );
 | 
			
		||||
        if( !f.is_open() )
 | 
			
		||||
@@ -148,7 +163,7 @@ namespace Catch {
 | 
			
		||||
 | 
			
		||||
        cli["-d"]["--durations"]
 | 
			
		||||
            .describe( "show test durations" )
 | 
			
		||||
            .bind( &setShowDurations, "yes/no" );
 | 
			
		||||
            .bind( &setShowDurations, "yes|no" );
 | 
			
		||||
 | 
			
		||||
        cli["-f"]["--input-file"]
 | 
			
		||||
            .describe( "load test names to run from a file" )
 | 
			
		||||
@@ -176,8 +191,12 @@ namespace Catch {
 | 
			
		||||
            .bind( &setRngSeed, "'time'|number" );
 | 
			
		||||
 | 
			
		||||
        cli["--force-colour"]
 | 
			
		||||
            .describe( "force colourised output" )
 | 
			
		||||
            .bind( &ConfigData::forceColour );
 | 
			
		||||
            .describe( "force colourised output (deprecated)" )
 | 
			
		||||
            .bind( &forceColour );
 | 
			
		||||
        
 | 
			
		||||
        cli["--use-colour"]
 | 
			
		||||
            .describe( "should output be colourised" )
 | 
			
		||||
            .bind( &setUseColour, "yes|no" );
 | 
			
		||||
 | 
			
		||||
        return cli;
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -10,7 +10,11 @@
 | 
			
		||||
 | 
			
		||||
#define INTERNAL_CATCH_UNIQUE_NAME_LINE2( name, line ) name##line
 | 
			
		||||
#define INTERNAL_CATCH_UNIQUE_NAME_LINE( name, line ) INTERNAL_CATCH_UNIQUE_NAME_LINE2( name, line )
 | 
			
		||||
#define INTERNAL_CATCH_UNIQUE_NAME( name ) INTERNAL_CATCH_UNIQUE_NAME_LINE( name, __LINE__ )
 | 
			
		||||
#ifdef CATCH_CONFIG_COUNTER
 | 
			
		||||
#  define INTERNAL_CATCH_UNIQUE_NAME( name ) INTERNAL_CATCH_UNIQUE_NAME_LINE( name, __COUNTER__ )
 | 
			
		||||
#else
 | 
			
		||||
#  define INTERNAL_CATCH_UNIQUE_NAME( name ) INTERNAL_CATCH_UNIQUE_NAME_LINE( name, __LINE__ )
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#define INTERNAL_CATCH_STRINGIFY2( expr ) #expr
 | 
			
		||||
#define INTERNAL_CATCH_STRINGIFY( expr ) INTERNAL_CATCH_STRINGIFY2( expr )
 | 
			
		||||
 
 | 
			
		||||
@@ -23,7 +23,7 @@
 | 
			
		||||
// CATCH_CONFIG_CPP11_OR_GREATER : Is C++11 supported?
 | 
			
		||||
 | 
			
		||||
// CATCH_CONFIG_VARIADIC_MACROS : are variadic macros supported?
 | 
			
		||||
 | 
			
		||||
// CATCH_CONFIG_COUNTER : is the __COUNTER__ macro supported?
 | 
			
		||||
// ****************
 | 
			
		||||
// Note to maintainers: if new toggles are added please document them
 | 
			
		||||
// in configuration.md, too
 | 
			
		||||
@@ -36,6 +36,10 @@
 | 
			
		||||
 | 
			
		||||
// All the C++11 features can be disabled with CATCH_CONFIG_NO_CPP11
 | 
			
		||||
 | 
			
		||||
#if defined(__cplusplus) && __cplusplus >= 201103L
 | 
			
		||||
#  define CATCH_CPP11_OR_GREATER
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifdef __clang__
 | 
			
		||||
 | 
			
		||||
#  if __has_feature(cxx_nullptr)
 | 
			
		||||
@@ -46,6 +50,10 @@
 | 
			
		||||
#    define CATCH_INTERNAL_CONFIG_CPP11_NOEXCEPT
 | 
			
		||||
#  endif
 | 
			
		||||
 | 
			
		||||
#   if defined(CATCH_CPP11_OR_GREATER)
 | 
			
		||||
#       define CATCH_INTERNAL_SUPPRESS_PARENTHESES_WARNINGS _Pragma( "clang diagnostic ignored \"-Wparentheses\"" )
 | 
			
		||||
#   endif
 | 
			
		||||
 | 
			
		||||
#endif // __clang__
 | 
			
		||||
 | 
			
		||||
////////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
@@ -73,9 +81,13 @@
 | 
			
		||||
// GCC
 | 
			
		||||
#ifdef __GNUC__
 | 
			
		||||
 | 
			
		||||
#if __GNUC__ == 4 && __GNUC_MINOR__ >= 6 && defined(__GXX_EXPERIMENTAL_CXX0X__)
 | 
			
		||||
#   define CATCH_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#endif
 | 
			
		||||
#   if __GNUC__ == 4 && __GNUC_MINOR__ >= 6 && defined(__GXX_EXPERIMENTAL_CXX0X__)
 | 
			
		||||
#       define CATCH_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
#   endif
 | 
			
		||||
 | 
			
		||||
#   if !defined(CATCH_INTERNAL_SUPPRESS_PARENTHESES_WARNINGS) && defined(CATCH_CPP11_OR_GREATER)
 | 
			
		||||
#       define CATCH_INTERNAL_SUPPRESS_PARENTHESES_WARNINGS _Pragma( "GCC diagnostic ignored \"-Wparentheses\"" )
 | 
			
		||||
#   endif
 | 
			
		||||
 | 
			
		||||
// - otherwise more recent versions define __cplusplus >= 201103L
 | 
			
		||||
// and will get picked up below
 | 
			
		||||
@@ -111,13 +123,20 @@
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// Use __COUNTER__ if the compiler supports it
 | 
			
		||||
#if ( defined _MSC_VER && _MSC_VER >= 1300 ) || \
 | 
			
		||||
    ( defined __GNUC__  && __GNUC__ >= 4 && __GNUC_MINOR__ >= 3 ) || \
 | 
			
		||||
    ( defined __clang__ && __clang_major__ >= 3 )
 | 
			
		||||
 | 
			
		||||
#define CATCH_INTERNAL_CONFIG_COUNTER
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
////////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
// C++ language feature support
 | 
			
		||||
 | 
			
		||||
// catch all support for C++11
 | 
			
		||||
#if defined(__cplusplus) && __cplusplus >= 201103L
 | 
			
		||||
 | 
			
		||||
#  define CATCH_CPP11_OR_GREATER
 | 
			
		||||
#if defined(CATCH_CPP11_OR_GREATER)
 | 
			
		||||
 | 
			
		||||
#  if !defined(CATCH_INTERNAL_CONFIG_CPP11_NULLPTR)
 | 
			
		||||
#    define CATCH_INTERNAL_CONFIG_CPP11_NULLPTR
 | 
			
		||||
@@ -185,7 +204,13 @@
 | 
			
		||||
#if defined(CATCH_INTERNAL_CONFIG_CPP11_UNIQUE_PTR) && !defined(CATCH_CONFIG_NO_UNIQUE_PTR) && !defined(CATCH_CONFIG_CPP11_UNIQUE_PTR) && !defined(CATCH_CONFIG_NO_CPP11)
 | 
			
		||||
#   define CATCH_CONFIG_CPP11_UNIQUE_PTR
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(CATCH_INTERNAL_CONFIG_COUNTER) && !defined(CATCH_CONFIG_NO_COUNTER) && !defined(CATCH_CONFIG_COUNTER)
 | 
			
		||||
#   define CATCH_CONFIG_COUNTER
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if !defined(CATCH_INTERNAL_SUPPRESS_PARENTHESES_WARNINGS)
 | 
			
		||||
#   define CATCH_INTERNAL_SUPPRESS_PARENTHESES_WARNINGS
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
// noexcept support:
 | 
			
		||||
#if defined(CATCH_CONFIG_CPP11_NOEXCEPT) && !defined(CATCH_NOEXCEPT)
 | 
			
		||||
 
 | 
			
		||||
@@ -37,14 +37,14 @@ namespace Catch {
 | 
			
		||||
            noThrow( false ),
 | 
			
		||||
            showHelp( false ),
 | 
			
		||||
            showInvisibles( false ),
 | 
			
		||||
            forceColour( false ),
 | 
			
		||||
            filenamesAsTags( false ),
 | 
			
		||||
            abortAfter( -1 ),
 | 
			
		||||
            rngSeed( 0 ),
 | 
			
		||||
            verbosity( Verbosity::Normal ),
 | 
			
		||||
            warnings( WarnAbout::Nothing ),
 | 
			
		||||
            showDurations( ShowDurations::DefaultForReporter ),
 | 
			
		||||
            runOrder( RunTests::InDeclarationOrder )
 | 
			
		||||
            runOrder( RunTests::InDeclarationOrder ),
 | 
			
		||||
            useColour( UseColour::Auto )
 | 
			
		||||
        {}
 | 
			
		||||
 | 
			
		||||
        bool listTests;
 | 
			
		||||
@@ -57,7 +57,6 @@ namespace Catch {
 | 
			
		||||
        bool noThrow;
 | 
			
		||||
        bool showHelp;
 | 
			
		||||
        bool showInvisibles;
 | 
			
		||||
        bool forceColour;
 | 
			
		||||
        bool filenamesAsTags;
 | 
			
		||||
 | 
			
		||||
        int abortAfter;
 | 
			
		||||
@@ -67,6 +66,7 @@ namespace Catch {
 | 
			
		||||
        WarnAbout::What warnings;
 | 
			
		||||
        ShowDurations::OrNot showDurations;
 | 
			
		||||
        RunTests::InWhatOrder runOrder;
 | 
			
		||||
        UseColour::YesOrNo useColour;
 | 
			
		||||
 | 
			
		||||
        std::string outputFilename;
 | 
			
		||||
        std::string name;
 | 
			
		||||
@@ -133,7 +133,7 @@ namespace Catch {
 | 
			
		||||
        virtual ShowDurations::OrNot showDurations() const { return m_data.showDurations; }
 | 
			
		||||
        virtual RunTests::InWhatOrder runOrder() const  { return m_data.runOrder; }
 | 
			
		||||
        virtual unsigned int rngSeed() const    { return m_data.rngSeed; }
 | 
			
		||||
        virtual bool forceColour() const { return m_data.forceColour; }
 | 
			
		||||
        virtual UseColour::YesOrNo useColour() const { return m_data.useColour; }
 | 
			
		||||
 | 
			
		||||
    private:
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -95,7 +95,18 @@ namespace {
 | 
			
		||||
 | 
			
		||||
    IColourImpl* platformColourInstance() {
 | 
			
		||||
        static Win32ColourImpl s_instance;
 | 
			
		||||
        return &s_instance;
 | 
			
		||||
 | 
			
		||||
        Ptr<IConfig const> config = getCurrentContext().getConfig();
 | 
			
		||||
        UseColour::YesOrNo colourMode = config
 | 
			
		||||
            ? config->useColour()
 | 
			
		||||
            : UseColour::Auto;
 | 
			
		||||
        if( colourMode == UseColour::Auto )
 | 
			
		||||
            colourMode = !isDebuggerActive()
 | 
			
		||||
                ? UseColour::Yes
 | 
			
		||||
                : UseColour::No;
 | 
			
		||||
        return colourMode == UseColour::Yes
 | 
			
		||||
            ? &s_instance
 | 
			
		||||
            : NoColourImpl::instance();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
} // end anon namespace
 | 
			
		||||
@@ -146,7 +157,14 @@ namespace {
 | 
			
		||||
 | 
			
		||||
    IColourImpl* platformColourInstance() {
 | 
			
		||||
        Ptr<IConfig const> config = getCurrentContext().getConfig();
 | 
			
		||||
        return (config && config->forceColour()) || isatty(STDOUT_FILENO)
 | 
			
		||||
        UseColour::YesOrNo colourMode = config
 | 
			
		||||
            ? config->useColour()
 | 
			
		||||
            : UseColour::Auto;
 | 
			
		||||
        if( colourMode == UseColour::Auto )
 | 
			
		||||
            colourMode = (!isDebuggerActive() && isatty(STDOUT_FILENO) )
 | 
			
		||||
                ? UseColour::Yes
 | 
			
		||||
                : UseColour::No;
 | 
			
		||||
        return colourMode == UseColour::Yes
 | 
			
		||||
            ? PosixColourImpl::instance()
 | 
			
		||||
            : NoColourImpl::instance();
 | 
			
		||||
    }
 | 
			
		||||
@@ -171,9 +189,7 @@ namespace Catch {
 | 
			
		||||
    Colour::~Colour(){ if( !m_moved ) use( None ); }
 | 
			
		||||
 | 
			
		||||
    void Colour::use( Code _colourCode ) {
 | 
			
		||||
        static IColourImpl* impl = isDebuggerActive()
 | 
			
		||||
            ? NoColourImpl::instance()
 | 
			
		||||
            : platformColourInstance();
 | 
			
		||||
        static IColourImpl* impl = platformColourInstance();
 | 
			
		||||
        impl->use( _colourCode );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -11,7 +11,7 @@
 | 
			
		||||
#ifndef __OBJC__
 | 
			
		||||
 | 
			
		||||
// Standard C/C++ main entry point
 | 
			
		||||
int main (int argc, char * const argv[]) {
 | 
			
		||||
int main (int argc, char * argv[]) {
 | 
			
		||||
    return Catch::Session().run( argc, argv );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -52,37 +52,37 @@ namespace Internal {
 | 
			
		||||
    template<typename T1, typename T2>
 | 
			
		||||
    struct Evaluator<T1, T2, IsEqualTo> {
 | 
			
		||||
        static bool evaluate( T1 const& lhs, T2 const& rhs) {
 | 
			
		||||
            return opCast( lhs ) ==  opCast( 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 opCast( lhs ) != opCast( 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 opCast( lhs ) < opCast( 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 opCast( lhs ) > opCast( 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 opCast( lhs ) >= opCast( 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 opCast( lhs ) <= opCast( rhs );
 | 
			
		||||
            return bool( opCast( lhs ) <= opCast( rhs ) );
 | 
			
		||||
        }
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -37,6 +37,11 @@ namespace Catch {
 | 
			
		||||
        InLexicographicalOrder,
 | 
			
		||||
        InRandomOrder
 | 
			
		||||
    }; };
 | 
			
		||||
    struct UseColour { enum YesOrNo {
 | 
			
		||||
        Auto,
 | 
			
		||||
        Yes,
 | 
			
		||||
        No
 | 
			
		||||
    }; };    
 | 
			
		||||
 | 
			
		||||
    class TestSpec;
 | 
			
		||||
 | 
			
		||||
@@ -56,7 +61,7 @@ namespace Catch {
 | 
			
		||||
        virtual TestSpec const& testSpec() const = 0;
 | 
			
		||||
        virtual RunTests::InWhatOrder runOrder() const = 0;
 | 
			
		||||
        virtual unsigned int rngSeed() const = 0;
 | 
			
		||||
        virtual bool forceColour() const = 0;
 | 
			
		||||
        virtual UseColour::YesOrNo useColour() const = 0;
 | 
			
		||||
    };
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -19,7 +19,7 @@ namespace Catch {
 | 
			
		||||
 | 
			
		||||
    struct IExceptionTranslator;
 | 
			
		||||
    typedef std::vector<const IExceptionTranslator*> ExceptionTranslators;
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
    struct IExceptionTranslator {
 | 
			
		||||
        virtual ~IExceptionTranslator();
 | 
			
		||||
        virtual std::string translate( ExceptionTranslators::const_iterator it, ExceptionTranslators::const_iterator itEnd ) const = 0;
 | 
			
		||||
@@ -66,9 +66,11 @@ namespace Catch {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION( signature ) \
 | 
			
		||||
    static std::string INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionTranslator )( signature ); \
 | 
			
		||||
    namespace{ Catch::ExceptionTranslatorRegistrar INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionRegistrar )( &INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionTranslator ) ); }\
 | 
			
		||||
    static std::string INTERNAL_CATCH_UNIQUE_NAME(  catch_internal_ExceptionTranslator )( signature )
 | 
			
		||||
#define INTERNAL_CATCH_TRANSLATE_EXCEPTION2( translatorName, signature ) \
 | 
			
		||||
    static std::string translatorName( signature ); \
 | 
			
		||||
    namespace{ Catch::ExceptionTranslatorRegistrar INTERNAL_CATCH_UNIQUE_NAME( catch_internal_ExceptionRegistrar )( &translatorName ); }\
 | 
			
		||||
    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
 | 
			
		||||
 
 | 
			
		||||
@@ -219,6 +219,7 @@ namespace Catch
 | 
			
		||||
        bool aborting;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    class MultipleReporters;
 | 
			
		||||
 | 
			
		||||
    struct IStreamingReporter : IShared {
 | 
			
		||||
        virtual ~IStreamingReporter();
 | 
			
		||||
@@ -247,6 +248,8 @@ namespace Catch
 | 
			
		||||
        virtual void testRunEnded( TestRunStats const& testRunStats ) = 0;
 | 
			
		||||
 | 
			
		||||
        virtual void skipTest( TestCaseInfo const& testInfo ) = 0;
 | 
			
		||||
        
 | 
			
		||||
        virtual MultipleReporters* tryAsMulti() { return CATCH_NULL; }
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -17,7 +17,7 @@ namespace Matchers {
 | 
			
		||||
        template<typename ExpressionT> class AnyOf;
 | 
			
		||||
        template<typename ExpressionT> class Not;
 | 
			
		||||
    }
 | 
			
		||||
        
 | 
			
		||||
 | 
			
		||||
    template<typename ExpressionT>
 | 
			
		||||
    struct Matcher : SharedImpl<IShared>
 | 
			
		||||
    {
 | 
			
		||||
@@ -27,7 +27,7 @@ namespace Matchers {
 | 
			
		||||
        virtual Ptr<Matcher> clone() const = 0;
 | 
			
		||||
        virtual bool match( ExpressionT const& expr ) const = 0;
 | 
			
		||||
        virtual std::string toString() const = 0;
 | 
			
		||||
        
 | 
			
		||||
 | 
			
		||||
        Generic::AllOf<ExpressionT> operator && ( Matcher<ExpressionT> const& other ) const;
 | 
			
		||||
        Generic::AnyOf<ExpressionT> operator || ( Matcher<ExpressionT> const& other ) const;
 | 
			
		||||
        Generic::Not<ExpressionT> operator ! () const;
 | 
			
		||||
@@ -134,13 +134,13 @@ namespace Matchers {
 | 
			
		||||
                anyOfExpr.add( other );
 | 
			
		||||
                return anyOfExpr;
 | 
			
		||||
            }
 | 
			
		||||
            
 | 
			
		||||
 | 
			
		||||
        private:
 | 
			
		||||
            std::vector<Ptr<Matcher<ExpressionT> > > m_matchers;
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
    } // namespace Generic
 | 
			
		||||
        
 | 
			
		||||
 | 
			
		||||
    template<typename ExpressionT>
 | 
			
		||||
    Generic::AllOf<ExpressionT> Matcher<ExpressionT>::operator && ( Matcher<ExpressionT> const& other ) const {
 | 
			
		||||
        Generic::AllOf<ExpressionT> allOfExpr;
 | 
			
		||||
@@ -161,7 +161,7 @@ namespace Matchers {
 | 
			
		||||
    Generic::Not<ExpressionT> Matcher<ExpressionT>::operator ! () const {
 | 
			
		||||
        return Generic::Not<ExpressionT>( *this );
 | 
			
		||||
    }
 | 
			
		||||
        
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    namespace StdString {
 | 
			
		||||
 | 
			
		||||
@@ -234,7 +234,7 @@ namespace Matchers {
 | 
			
		||||
            virtual ~StartsWith();
 | 
			
		||||
 | 
			
		||||
            virtual bool match( std::string const& expr ) const {
 | 
			
		||||
                return m_data.adjustString( expr ).find( m_data.m_str ) == 0;
 | 
			
		||||
                return startsWith( m_data.adjustString( expr ), m_data.m_str );
 | 
			
		||||
            }
 | 
			
		||||
            virtual std::string toString() const {
 | 
			
		||||
                return "starts with: \"" + m_data.m_str + "\"" + m_data.toStringSuffix();
 | 
			
		||||
@@ -251,7 +251,7 @@ namespace Matchers {
 | 
			
		||||
            virtual ~EndsWith();
 | 
			
		||||
 | 
			
		||||
            virtual bool match( std::string const& expr ) const {
 | 
			
		||||
                return m_data.adjustString( expr ).find( m_data.m_str ) == expr.size() - m_data.m_str.size();
 | 
			
		||||
                return endsWith( m_data.adjustString( expr ), m_data.m_str );
 | 
			
		||||
            }
 | 
			
		||||
            virtual std::string toString() const {
 | 
			
		||||
                return "ends with: \"" + m_data.m_str + "\"" + m_data.toStringSuffix();
 | 
			
		||||
 
 | 
			
		||||
@@ -109,6 +109,11 @@ namespace Catch {
 | 
			
		||||
            while( getCurrentContext().advanceGeneratorsForCurrentTest() && !aborting() );
 | 
			
		||||
 | 
			
		||||
            Totals deltaTotals = m_totals.delta( prevTotals );
 | 
			
		||||
            if( testInfo.expectedToFail() && deltaTotals.testCases.passed > 0 ) {
 | 
			
		||||
                deltaTotals.assertions.failed++;
 | 
			
		||||
                deltaTotals.testCases.passed--;
 | 
			
		||||
                deltaTotals.testCases.failed++;
 | 
			
		||||
            }
 | 
			
		||||
            m_totals.testCases += deltaTotals.testCases;
 | 
			
		||||
            m_reporter->testCaseEnded( TestCaseStats(   testInfo,
 | 
			
		||||
                                                        deltaTotals,
 | 
			
		||||
 
 | 
			
		||||
@@ -87,7 +87,10 @@ namespace Catch {
 | 
			
		||||
 | 
			
		||||
    class TestRegistry : public ITestCaseRegistry {
 | 
			
		||||
    public:
 | 
			
		||||
        TestRegistry() : m_unnamedCount( 0 ) {}
 | 
			
		||||
        TestRegistry()
 | 
			
		||||
        :   m_currentSortOrder( RunTests::InDeclarationOrder ),
 | 
			
		||||
            m_unnamedCount( 0 )
 | 
			
		||||
        {}
 | 
			
		||||
        virtual ~TestRegistry();
 | 
			
		||||
 | 
			
		||||
        virtual void registerTest( TestCase const& testCase ) {
 | 
			
		||||
@@ -157,7 +160,7 @@ namespace Catch {
 | 
			
		||||
            char const* classOrQualifiedMethodName,
 | 
			
		||||
            NameAndDesc const& nameAndDesc,
 | 
			
		||||
            SourceLineInfo const& lineInfo ) {
 | 
			
		||||
        
 | 
			
		||||
 | 
			
		||||
        getMutableRegistryHub().registerTest
 | 
			
		||||
            ( makeTestCase
 | 
			
		||||
                (   testCase,
 | 
			
		||||
@@ -172,7 +175,7 @@ namespace Catch {
 | 
			
		||||
            NameAndDesc const& nameAndDesc ) {
 | 
			
		||||
        registerTestCase( new FreeFunctionTestCase( function ), "", nameAndDesc, lineInfo );
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////
 | 
			
		||||
 | 
			
		||||
    AutoReg::AutoReg
 | 
			
		||||
 
 | 
			
		||||
@@ -41,6 +41,10 @@ namespace TestCaseTracking {
 | 
			
		||||
        virtual void addChild( Ptr<ITracker> const& child ) = 0;
 | 
			
		||||
        virtual ITracker* findChild( std::string const& name ) = 0;
 | 
			
		||||
        virtual void openChild() = 0;
 | 
			
		||||
        
 | 
			
		||||
        // Debug/ checking
 | 
			
		||||
        virtual bool isSectionTracker() const = 0;
 | 
			
		||||
        virtual bool isIndexTracker() const = 0;
 | 
			
		||||
    };
 | 
			
		||||
 | 
			
		||||
    class TrackerContext {
 | 
			
		||||
@@ -167,6 +171,10 @@ namespace TestCaseTracking {
 | 
			
		||||
                    m_parent->openChild();
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        virtual bool isSectionTracker() const CATCH_OVERRIDE { return false; }
 | 
			
		||||
        virtual bool isIndexTracker() const CATCH_OVERRIDE { return false; }
 | 
			
		||||
        
 | 
			
		||||
        void open() {
 | 
			
		||||
            m_runState = Executing;
 | 
			
		||||
            moveToThis();
 | 
			
		||||
@@ -230,13 +238,16 @@ namespace TestCaseTracking {
 | 
			
		||||
        {}
 | 
			
		||||
        virtual ~SectionTracker();
 | 
			
		||||
 | 
			
		||||
        virtual bool isSectionTracker() const CATCH_OVERRIDE { return true; }
 | 
			
		||||
        
 | 
			
		||||
        static SectionTracker& acquire( TrackerContext& ctx, std::string const& name ) {
 | 
			
		||||
            SectionTracker* section = CATCH_NULL;
 | 
			
		||||
 | 
			
		||||
            ITracker& currentTracker = ctx.currentTracker();
 | 
			
		||||
            if( ITracker* childTracker = currentTracker.findChild( name ) ) {
 | 
			
		||||
                section = dynamic_cast<SectionTracker*>( childTracker );
 | 
			
		||||
                assert( section );
 | 
			
		||||
                assert( childTracker );
 | 
			
		||||
                assert( childTracker->isSectionTracker() );
 | 
			
		||||
                section = static_cast<SectionTracker*>( childTracker );
 | 
			
		||||
            }
 | 
			
		||||
            else {
 | 
			
		||||
                section = new SectionTracker( name, ctx, ¤tTracker );
 | 
			
		||||
@@ -261,13 +272,16 @@ namespace TestCaseTracking {
 | 
			
		||||
        {}
 | 
			
		||||
        virtual ~IndexTracker();
 | 
			
		||||
 | 
			
		||||
        virtual bool isIndexTracker() const CATCH_OVERRIDE { return true; }
 | 
			
		||||
        
 | 
			
		||||
        static IndexTracker& acquire( TrackerContext& ctx, std::string const& name, int size ) {
 | 
			
		||||
            IndexTracker* tracker = CATCH_NULL;
 | 
			
		||||
 | 
			
		||||
            ITracker& currentTracker = ctx.currentTracker();
 | 
			
		||||
            if( ITracker* childTracker = currentTracker.findChild( name ) ) {
 | 
			
		||||
                tracker = dynamic_cast<IndexTracker*>( childTracker );
 | 
			
		||||
                assert( tracker );
 | 
			
		||||
                assert( childTracker );
 | 
			
		||||
                assert( childTracker->isIndexTracker() );
 | 
			
		||||
                tracker = static_cast<IndexTracker*>( childTracker );
 | 
			
		||||
            }
 | 
			
		||||
            else {
 | 
			
		||||
                tracker = new IndexTracker( name, ctx, ¤tTracker, size );
 | 
			
		||||
 
 | 
			
		||||
@@ -85,24 +85,28 @@ void registerTestCaseFunction
 | 
			
		||||
 | 
			
		||||
#ifdef CATCH_CONFIG_VARIADIC_MACROS
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_TESTCASE2( TestName, ... ) \
 | 
			
		||||
        static void TestName(); \
 | 
			
		||||
        namespace{ Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar )( &TestName, CATCH_INTERNAL_LINEINFO, Catch::NameAndDesc( __VA_ARGS__ ) ); }\
 | 
			
		||||
        static void TestName()
 | 
			
		||||
    #define INTERNAL_CATCH_TESTCASE( ... ) \
 | 
			
		||||
        static void INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ )(); \
 | 
			
		||||
        namespace{ Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar )( &INTERNAL_CATCH_UNIQUE_NAME(  ____C_A_T_C_H____T_E_S_T____ ), CATCH_INTERNAL_LINEINFO, Catch::NameAndDesc( __VA_ARGS__ ) ); }\
 | 
			
		||||
        static void INTERNAL_CATCH_UNIQUE_NAME(  ____C_A_T_C_H____T_E_S_T____ )()
 | 
			
		||||
        INTERNAL_CATCH_TESTCASE2( INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ ), __VA_ARGS__ )
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_METHOD_AS_TEST_CASE( QualifiedMethod, ... ) \
 | 
			
		||||
        namespace{ Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar )( &QualifiedMethod, "&" #QualifiedMethod, Catch::NameAndDesc( __VA_ARGS__ ), CATCH_INTERNAL_LINEINFO ); }
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_TEST_CASE_METHOD( ClassName, ... )\
 | 
			
		||||
    #define INTERNAL_CATCH_TEST_CASE_METHOD2( TestName, ClassName, ... )\
 | 
			
		||||
        namespace{ \
 | 
			
		||||
            struct INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ ) : ClassName{ \
 | 
			
		||||
            struct TestName : ClassName{ \
 | 
			
		||||
                void test(); \
 | 
			
		||||
            }; \
 | 
			
		||||
            Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar ) ( &INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ )::test, #ClassName, Catch::NameAndDesc( __VA_ARGS__ ), CATCH_INTERNAL_LINEINFO ); \
 | 
			
		||||
            Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar ) ( &TestName::test, #ClassName, Catch::NameAndDesc( __VA_ARGS__ ), CATCH_INTERNAL_LINEINFO ); \
 | 
			
		||||
        } \
 | 
			
		||||
        void INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ )::test()
 | 
			
		||||
        void TestName::test()
 | 
			
		||||
    #define INTERNAL_CATCH_TEST_CASE_METHOD( ClassName, ... ) \
 | 
			
		||||
        INTERNAL_CATCH_TEST_CASE_METHOD2( INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ ), ClassName, __VA_ARGS__ )
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_REGISTER_TESTCASE( Function, ... ) \
 | 
			
		||||
@@ -110,24 +114,28 @@ void registerTestCaseFunction
 | 
			
		||||
 | 
			
		||||
#else
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_TESTCASE2( TestName, Name, Desc ) \
 | 
			
		||||
        static void TestName(); \
 | 
			
		||||
        namespace{ Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar )( &TestName, CATCH_INTERNAL_LINEINFO, Catch::NameAndDesc( Name, Desc ) ); }\
 | 
			
		||||
        static void TestName()
 | 
			
		||||
    #define INTERNAL_CATCH_TESTCASE( Name, Desc ) \
 | 
			
		||||
        static void INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ )(); \
 | 
			
		||||
        namespace{ Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar )( &INTERNAL_CATCH_UNIQUE_NAME(  ____C_A_T_C_H____T_E_S_T____ ), CATCH_INTERNAL_LINEINFO, Catch::NameAndDesc( Name, Desc ) ); }\
 | 
			
		||||
        static void INTERNAL_CATCH_UNIQUE_NAME(  ____C_A_T_C_H____T_E_S_T____ )()
 | 
			
		||||
        INTERNAL_CATCH_TESTCASE2( INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ ), Name, Desc )
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_METHOD_AS_TEST_CASE( QualifiedMethod, Name, Desc ) \
 | 
			
		||||
        namespace{ Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar )( &QualifiedMethod, "&" #QualifiedMethod, Catch::NameAndDesc( Name, Desc ), CATCH_INTERNAL_LINEINFO ); }
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_TEST_CASE_METHOD( ClassName, TestName, Desc )\
 | 
			
		||||
    #define INTERNAL_CATCH_TEST_CASE_METHOD2( TestCaseName, ClassName, TestName, Desc )\
 | 
			
		||||
        namespace{ \
 | 
			
		||||
            struct INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ ) : ClassName{ \
 | 
			
		||||
            struct TestCaseName : ClassName{ \
 | 
			
		||||
                void test(); \
 | 
			
		||||
            }; \
 | 
			
		||||
            Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar ) ( &INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ )::test, #ClassName, Catch::NameAndDesc( TestName, Desc ), CATCH_INTERNAL_LINEINFO ); \
 | 
			
		||||
            Catch::AutoReg INTERNAL_CATCH_UNIQUE_NAME( autoRegistrar ) ( &TestCaseName::test, #ClassName, Catch::NameAndDesc( TestName, Desc ), CATCH_INTERNAL_LINEINFO ); \
 | 
			
		||||
        } \
 | 
			
		||||
        void INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ )::test()
 | 
			
		||||
        void TestCaseName::test()
 | 
			
		||||
    #define INTERNAL_CATCH_TEST_CASE_METHOD( ClassName, TestName, Desc )\
 | 
			
		||||
        INTERNAL_CATCH_TEST_CASE_METHOD2( INTERNAL_CATCH_UNIQUE_NAME( ____C_A_T_C_H____T_E_S_T____ ), ClassName, TestName, Desc )
 | 
			
		||||
 | 
			
		||||
    ///////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
    #define INTERNAL_CATCH_REGISTER_TESTCASE( Function, Name, Desc ) \
 | 
			
		||||
 
 | 
			
		||||
@@ -37,7 +37,7 @@ namespace Catch {
 | 
			
		||||
        return os;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    Version libraryVersion( 1, 3, 0, "", 0 );
 | 
			
		||||
    Version libraryVersion( 1, 5, 2, "", 0 );
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -166,7 +166,7 @@ namespace Catch {
 | 
			
		||||
 | 
			
		||||
        virtual void assertionStarting( AssertionInfo const& ) CATCH_OVERRIDE {}
 | 
			
		||||
 | 
			
		||||
        virtual bool assertionEnded( AssertionStats const& assertionStats ) {
 | 
			
		||||
        virtual bool assertionEnded( AssertionStats const& assertionStats ) CATCH_OVERRIDE {
 | 
			
		||||
            assert( !m_sectionStack.empty() );
 | 
			
		||||
            SectionNode& sectionNode = *m_sectionStack.back();
 | 
			
		||||
            sectionNode.assertions.push_back( assertionStats );
 | 
			
		||||
 
 | 
			
		||||
@@ -349,7 +349,7 @@ namespace Catch {
 | 
			
		||||
            if( totals.testCases.total() == 0 ) {
 | 
			
		||||
                stream << Colour( Colour::Warning ) << "No tests ran\n";
 | 
			
		||||
            }
 | 
			
		||||
            else if( totals.assertions.total() > 0 && totals.assertions.allPassed() ) {
 | 
			
		||||
            else if( totals.assertions.total() > 0 && totals.testCases.allPassed() ) {
 | 
			
		||||
                stream << Colour( Colour::ResultSuccess ) << "All tests passed";
 | 
			
		||||
                stream << " ("
 | 
			
		||||
                        << pluralise( totals.assertions.passed, "assertion" ) << " in "
 | 
			
		||||
 
 | 
			
		||||
@@ -118,13 +118,18 @@ public: // IStreamingReporter
 | 
			
		||||
                ++it )
 | 
			
		||||
            (*it)->skipTest( testInfo );
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    virtual MultipleReporters* tryAsMulti() CATCH_OVERRIDE {
 | 
			
		||||
        return this;
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
Ptr<IStreamingReporter> addReporter( Ptr<IStreamingReporter> const& existingReporter, Ptr<IStreamingReporter> const& additionalReporter ) {
 | 
			
		||||
    Ptr<IStreamingReporter> resultingReporter;
 | 
			
		||||
 | 
			
		||||
    if( existingReporter ) {
 | 
			
		||||
        MultipleReporters* multi = dynamic_cast<MultipleReporters*>( existingReporter.get() );
 | 
			
		||||
        MultipleReporters* multi = existingReporter->tryAsMulti();
 | 
			
		||||
        if( !multi ) {
 | 
			
		||||
            multi = new MultipleReporters;
 | 
			
		||||
            resultingReporter = Ptr<IStreamingReporter>( multi );
 | 
			
		||||
 
 | 
			
		||||
@@ -680,7 +680,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Contains( "not there" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Contains( "not there" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" contains: "not there"
 | 
			
		||||
 | 
			
		||||
@@ -691,7 +691,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() StartsWith( "string" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), StartsWith( "string" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" starts with: "string"
 | 
			
		||||
 | 
			
		||||
@@ -702,7 +702,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() EndsWith( "this" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), EndsWith( "this" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ends with: "this"
 | 
			
		||||
 | 
			
		||||
@@ -713,7 +713,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Equals( "something else" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Equals( "something else" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" equals: "something else"
 | 
			
		||||
 | 
			
		||||
@@ -724,7 +724,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() ( Contains( "string" ) || Contains( "different" ) ) && Contains( "random" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), ( Contains( "string" ) || Contains( "different" ) ) && Contains( "random" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( ( contains: "string" or
 | 
			
		||||
  contains: "different" ) and contains: "random" )
 | 
			
		||||
@@ -736,7 +736,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() !Contains( "substring" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), !Contains( "substring" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" not contains: "substring"
 | 
			
		||||
 | 
			
		||||
@@ -830,6 +830,6 @@ with expansion:
 | 
			
		||||
  "first" == "second"
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
test cases: 167 | 124 passed | 42 failed |  1 failed as expected
 | 
			
		||||
assertions: 914 | 818 passed | 83 failed | 13 failed as expected
 | 
			
		||||
test cases: 168 | 124 passed | 42 failed |  2 failed as expected
 | 
			
		||||
assertions: 920 | 824 passed | 78 failed | 18 failed as expected
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -3304,25 +3304,25 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE_THAT( testStringForMatching() Contains( "string" ) )
 | 
			
		||||
  REQUIRE_THAT( testStringForMatching(), Contains( "string" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" contains: "string"
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Contains( "abc" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Contains( "abc" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" contains: "abc"
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() StartsWith( "this" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), StartsWith( "this" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" starts with: "this"
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() EndsWith( "substring" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), EndsWith( "substring" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ends with: "substring"
 | 
			
		||||
 | 
			
		||||
@@ -3333,7 +3333,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Contains( "not there" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Contains( "not there" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" contains: "not there"
 | 
			
		||||
 | 
			
		||||
@@ -3344,7 +3344,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() StartsWith( "string" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), StartsWith( "string" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" starts with: "string"
 | 
			
		||||
 | 
			
		||||
@@ -3355,7 +3355,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() EndsWith( "this" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), EndsWith( "this" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ends with: "this"
 | 
			
		||||
 | 
			
		||||
@@ -3366,7 +3366,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Equals( "something else" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Equals( "something else" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" equals: "something else"
 | 
			
		||||
 | 
			
		||||
@@ -3378,7 +3378,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE_THAT( "" Equals(nullptr) )
 | 
			
		||||
  REQUIRE_THAT( "", Equals(nullptr) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "" equals: ""
 | 
			
		||||
 | 
			
		||||
@@ -3390,7 +3390,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() AllOf( Catch::Contains( "string" ), Catch::Contains( "abc" ) ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), AllOf( Catch::Contains( "string" ), Catch::Contains( "abc" ) ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( contains: "string" and
 | 
			
		||||
  contains: "abc" )
 | 
			
		||||
@@ -3403,14 +3403,14 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() AnyOf( Catch::Contains( "string" ), Catch::Contains( "not there" ) ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), AnyOf( Catch::Contains( "string" ), Catch::Contains( "not there" ) ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( contains: "string" or contains:
 | 
			
		||||
  "not there" )
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() AnyOf( Catch::Contains( "not there" ), Catch::Contains( "string" ) ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), AnyOf( Catch::Contains( "not there" ), Catch::Contains( "string" ) ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( contains: "not there" or
 | 
			
		||||
  contains: "string" )
 | 
			
		||||
@@ -3423,7 +3423,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Equals( "this string contains 'abc' as a substring" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Equals( "this string contains 'abc' as a substring" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" equals: "this string contains
 | 
			
		||||
  'abc' as a substring"
 | 
			
		||||
@@ -3436,7 +3436,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Contains( "string" ) && Contains( "abc" ) && Contains( "substring" ) && Contains( "contains" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Contains( "string" ) && Contains( "abc" ) && Contains( "substring" ) && Contains( "contains" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( contains: "string" and
 | 
			
		||||
  contains: "abc" and contains: "substring" and contains: "contains" )
 | 
			
		||||
@@ -3449,14 +3449,14 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() Contains( "string" ) || Contains( "different" ) || Contains( "random" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), Contains( "string" ) || Contains( "different" ) || Contains( "random" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( contains: "string" or contains:
 | 
			
		||||
  "different" or contains: "random" )
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching2() Contains( "string" ) || Contains( "different" ) || Contains( "random" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching2(), Contains( "string" ) || Contains( "different" ) || Contains( "random" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "some completely different text that contains one common word" ( contains:
 | 
			
		||||
  "string" or contains: "different" or contains: "random" )
 | 
			
		||||
@@ -3469,7 +3469,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() ( Contains( "string" ) || Contains( "different" ) ) && Contains( "substring" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), ( Contains( "string" ) || Contains( "different" ) ) && Contains( "substring" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( ( contains: "string" or
 | 
			
		||||
  contains: "different" ) and contains: "substring" )
 | 
			
		||||
@@ -3481,7 +3481,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() ( Contains( "string" ) || Contains( "different" ) ) && Contains( "random" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), ( Contains( "string" ) || Contains( "different" ) ) && Contains( "random" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" ( ( contains: "string" or
 | 
			
		||||
  contains: "different" ) and contains: "random" )
 | 
			
		||||
@@ -3494,7 +3494,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() !Contains( "different" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), !Contains( "different" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" not contains: "different"
 | 
			
		||||
 | 
			
		||||
@@ -3505,7 +3505,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK_THAT( testStringForMatching() !Contains( "substring" ) )
 | 
			
		||||
  CHECK_THAT( testStringForMatching(), !Contains( "substring" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "this string contains 'abc' as a substring" not contains: "substring"
 | 
			
		||||
 | 
			
		||||
@@ -3951,6 +3951,17 @@ with expansion:
 | 
			
		||||
  ==
 | 
			
		||||
  9223372036854775807 (0x<hex digits>)
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
This test 'should' fail but doesn't
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
MiscTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
MiscTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
with message:
 | 
			
		||||
  oops!
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Process can be configured on command line
 | 
			
		||||
  default - no arguments
 | 
			
		||||
@@ -4224,7 +4235,7 @@ TestMain.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE_THAT( parseIntoConfigAndReturnError( argv, config ) Contains( "greater than zero" ) )
 | 
			
		||||
  REQUIRE_THAT( parseIntoConfigAndReturnError( argv, config ), Contains( "greater than zero" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "Value after -x or --abortAfter must be greater than zero
 | 
			
		||||
  - while parsing: (-x, --abortx <no. failures>)" contains: "greater than zero"
 | 
			
		||||
@@ -4239,7 +4250,7 @@ TestMain.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE_THAT( parseIntoConfigAndReturnError( argv, config ) Contains( "-x" ) )
 | 
			
		||||
  REQUIRE_THAT( parseIntoConfigAndReturnError( argv, config ), Contains( "-x" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "Unable to convert oops to destination type
 | 
			
		||||
  - while parsing: (-x, --abortx <no. failures>)" contains: "-x"
 | 
			
		||||
@@ -4348,8 +4359,8 @@ with expansion:
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Process can be configured on command line
 | 
			
		||||
  force-colour
 | 
			
		||||
  --force-colour
 | 
			
		||||
  use-colour
 | 
			
		||||
  without option
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
TestMain.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
@@ -4360,14 +4371,14 @@ PASSED:
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( config.forceColour )
 | 
			
		||||
  REQUIRE( config.useColour == UseColour::Auto )
 | 
			
		||||
with expansion:
 | 
			
		||||
  true
 | 
			
		||||
  0 == 0
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Process can be configured on command line
 | 
			
		||||
  force-colour
 | 
			
		||||
  without --force-colour
 | 
			
		||||
  use-colour
 | 
			
		||||
  auto
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
TestMain.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
@@ -4378,9 +4389,57 @@ PASSED:
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( !config.forceColour )
 | 
			
		||||
  REQUIRE( config.useColour == UseColour::Auto )
 | 
			
		||||
with expansion:
 | 
			
		||||
  true
 | 
			
		||||
  0 == 0
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Process can be configured on command line
 | 
			
		||||
  use-colour
 | 
			
		||||
  yes
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
TestMain.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_NOTHROW( parseIntoConfig( argv, config ) )
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( config.useColour == UseColour::Yes )
 | 
			
		||||
with expansion:
 | 
			
		||||
  1 == 1
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Process can be configured on command line
 | 
			
		||||
  use-colour
 | 
			
		||||
  no
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
TestMain.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_NOTHROW( parseIntoConfig( argv, config ) )
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( config.useColour == UseColour::No )
 | 
			
		||||
with expansion:
 | 
			
		||||
  2 == 2
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Process can be configured on command line
 | 
			
		||||
  use-colour
 | 
			
		||||
  error
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
TestMain.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE_THROWS_WITH( parseIntoConfig( argv, config ), Contains( "colour mode must be one of" ) )
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Long strings can be wrapped
 | 
			
		||||
@@ -5000,7 +5059,7 @@ TestMain.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
TestMain.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( t.toString() EndsWith( "... message truncated due to excessive size" ) )
 | 
			
		||||
  CHECK_THAT( t.toString(), EndsWith( "... message truncated due to excessive size" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "***************************************************************************-
 | 
			
		||||
  ***-
 | 
			
		||||
@@ -8783,7 +8842,7 @@ TagAliasTests.cpp:<line number>
 | 
			
		||||
 | 
			
		||||
TagAliasTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( what Contains( "[@zzz]" ) )
 | 
			
		||||
  CHECK_THAT( what, Contains( "[@zzz]" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
  First seen at file:2
 | 
			
		||||
@@ -8792,7 +8851,7 @@ with expansion:
 | 
			
		||||
 | 
			
		||||
TagAliasTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( what Contains( "file" ) )
 | 
			
		||||
  CHECK_THAT( what, Contains( "file" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
  First seen at file:2
 | 
			
		||||
@@ -8801,7 +8860,7 @@ with expansion:
 | 
			
		||||
 | 
			
		||||
TagAliasTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( what Contains( "2" ) )
 | 
			
		||||
  CHECK_THAT( what, Contains( "2" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
  First seen at file:2
 | 
			
		||||
@@ -8810,7 +8869,7 @@ with expansion:
 | 
			
		||||
 | 
			
		||||
TagAliasTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  CHECK_THAT( what Contains( "10" ) )
 | 
			
		||||
  CHECK_THAT( what, Contains( "10" ) )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
  First seen at file:2
 | 
			
		||||
@@ -9045,6 +9104,6 @@ with expansion:
 | 
			
		||||
  1 > 0
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
test cases: 167 | 123 passed | 43 failed |  1 failed as expected
 | 
			
		||||
assertions: 916 | 818 passed | 85 failed | 13 failed as expected
 | 
			
		||||
test cases: 168 | 123 passed | 43 failed |  2 failed as expected
 | 
			
		||||
assertions: 922 | 824 passed | 80 failed | 18 failed as expected
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -485,7 +485,131 @@ ConditionTests.cpp:<line number>: FAILED:
 | 
			
		||||
with expansion:
 | 
			
		||||
  9.1f != Approx( 9.1000003815 )
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
test cases: 19 | 15 passed | 3 failed | 1 failed as expected
 | 
			
		||||
assertions: 62 | 56 passed | 4 failed | 2 failed as expected
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Ordering comparison checks that should succeed
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
ConditionTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven < 8 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 < 8
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven > 6 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 > 6
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven > 0 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 > 0
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven > -1 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 > -1
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven >= 7 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 >= 7
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven >= 6 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 >= 6
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven <= 7 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 <= 7
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.int_seven <= 8 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 <= 8
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.float_nine_point_one > 9 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  9.1f > 9
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.float_nine_point_one < 10 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  9.1f < 10
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.float_nine_point_one < 9.2 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  9.1f < 9.2
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.str_hello <= "hello" )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "hello" <= "hello"
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.str_hello >= "hello" )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "hello" >= "hello"
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.str_hello < "hellp" )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "hello" < "hellp"
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.str_hello < "zebra" )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "hello" < "zebra"
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.str_hello > "hellm" )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "hello" > "hellm"
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>:
 | 
			
		||||
PASSED:
 | 
			
		||||
  REQUIRE( data.str_hello > "a" )
 | 
			
		||||
with expansion:
 | 
			
		||||
  "hello" > "a"
 | 
			
		||||
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
Ordering comparison checks that should fail
 | 
			
		||||
-------------------------------------------------------------------------------
 | 
			
		||||
ConditionTests.cpp:<line number>
 | 
			
		||||
...............................................................................
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK( data.int_seven > 7 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 > 7
 | 
			
		||||
 | 
			
		||||
ConditionTests.cpp:<line number>: FAILED:
 | 
			
		||||
  CHECK( data.int_seven < 7 )
 | 
			
		||||
with expansion:
 | 
			
		||||
  7 < 7
 | 
			
		||||
 | 
			
		||||
===============================================================================
 | 
			
		||||
test cases: 21 | 16 passed | 3 failed | 2 failed as expected
 | 
			
		||||
assertions: 81 | 73 passed | 4 failed | 4 failed as expected
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
<testsuites>
 | 
			
		||||
  <testsuite name="CatchSelfTest" errors="13" failures="72" tests="916" hostname="tbd" time="{duration}" timestamp="tbd">
 | 
			
		||||
  <testsuite name="CatchSelfTest" errors="13" failures="68" tests="923" hostname="tbd" time="{duration}" timestamp="tbd">
 | 
			
		||||
    <testcase classname="global" name="toString(enum)" time="{duration}"/>
 | 
			
		||||
    <testcase classname="global" name="toString(enum w/operator<<)" time="{duration}"/>
 | 
			
		||||
    <testcase classname="global" name="toString(enum class)" time="{duration}"/>
 | 
			
		||||
@@ -499,6 +499,7 @@ MiscTests.cpp:<line number>
 | 
			
		||||
    <testcase classname="XmlEncode" name="string with control char (1)" time="{duration}"/>
 | 
			
		||||
    <testcase classname="XmlEncode" name="string with control char (x7F)" time="{duration}"/>
 | 
			
		||||
    <testcase classname="global" name="long long" time="{duration}"/>
 | 
			
		||||
    <testcase classname="global" name="This test 'should' fail but doesn't" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="default - no arguments" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="test lists/1 test" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="test lists/Specify one test case exclusion using exclude:" time="{duration}"/>
 | 
			
		||||
@@ -518,8 +519,11 @@ MiscTests.cpp:<line number>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="output filename/-o filename" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="output filename/--out" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="combinations/Single character flags can be combined" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="force-colour/--force-colour" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="force-colour/without --force-colour" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="use-colour/without option" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="use-colour/auto" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="use-colour/yes" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="use-colour/no" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Process can be configured on command line" name="use-colour/error" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Long strings can be wrapped" name="plain string/No wrapping" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Long strings can be wrapped" name="plain string/Wrapped once" time="{duration}"/>
 | 
			
		||||
    <testcase classname="Long strings can be wrapped" name="plain string/Wrapped twice" time="{duration}"/>
 | 
			
		||||
 
 | 
			
		||||
@@ -665,7 +665,7 @@
 | 
			
		||||
          5 != 5
 | 
			
		||||
        </Expanded>
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <OverallResult success="false"/>
 | 
			
		||||
      <OverallResult success="true"/>
 | 
			
		||||
    </TestCase>
 | 
			
		||||
    <TestCase name="Ordering comparison checks that should succeed">
 | 
			
		||||
      <Expression success="true" type="REQUIRE" filename="projects/SelfTest/ConditionTests.cpp" >
 | 
			
		||||
@@ -3468,7 +3468,7 @@
 | 
			
		||||
    <TestCase name="String matchers">
 | 
			
		||||
      <Expression success="true" type="REQUIRE_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Contains( "string" )
 | 
			
		||||
          testStringForMatching(), Contains( "string" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" contains: "string"
 | 
			
		||||
@@ -3476,7 +3476,7 @@
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Contains( "abc" )
 | 
			
		||||
          testStringForMatching(), Contains( "abc" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" contains: "abc"
 | 
			
		||||
@@ -3484,7 +3484,7 @@
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() StartsWith( "this" )
 | 
			
		||||
          testStringForMatching(), StartsWith( "this" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" starts with: "this"
 | 
			
		||||
@@ -3492,7 +3492,7 @@
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() EndsWith( "substring" )
 | 
			
		||||
          testStringForMatching(), EndsWith( "substring" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ends with: "substring"
 | 
			
		||||
@@ -3503,7 +3503,7 @@
 | 
			
		||||
    <TestCase name="Contains string matcher">
 | 
			
		||||
      <Expression success="false" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Contains( "not there" )
 | 
			
		||||
          testStringForMatching(), Contains( "not there" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" contains: "not there"
 | 
			
		||||
@@ -3514,7 +3514,7 @@
 | 
			
		||||
    <TestCase name="StartsWith string matcher">
 | 
			
		||||
      <Expression success="false" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() StartsWith( "string" )
 | 
			
		||||
          testStringForMatching(), StartsWith( "string" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" starts with: "string"
 | 
			
		||||
@@ -3525,7 +3525,7 @@
 | 
			
		||||
    <TestCase name="EndsWith string matcher">
 | 
			
		||||
      <Expression success="false" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() EndsWith( "this" )
 | 
			
		||||
          testStringForMatching(), EndsWith( "this" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ends with: "this"
 | 
			
		||||
@@ -3536,7 +3536,7 @@
 | 
			
		||||
    <TestCase name="Equals string matcher">
 | 
			
		||||
      <Expression success="false" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Equals( "something else" )
 | 
			
		||||
          testStringForMatching(), Equals( "something else" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" equals: "something else"
 | 
			
		||||
@@ -3547,7 +3547,7 @@
 | 
			
		||||
    <TestCase name="Equals string matcher, with NULL">
 | 
			
		||||
      <Expression success="true" type="REQUIRE_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          "" Equals(nullptr)
 | 
			
		||||
          "", Equals(nullptr)
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "" equals: ""
 | 
			
		||||
@@ -3558,7 +3558,7 @@
 | 
			
		||||
    <TestCase name="AllOf matcher">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() AllOf( Catch::Contains( "string" ), Catch::Contains( "abc" ) )
 | 
			
		||||
          testStringForMatching(), AllOf( Catch::Contains( "string" ), Catch::Contains( "abc" ) )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( contains: "string" and contains: "abc" )
 | 
			
		||||
@@ -3569,7 +3569,7 @@
 | 
			
		||||
    <TestCase name="AnyOf matcher">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() AnyOf( Catch::Contains( "string" ), Catch::Contains( "not there" ) )
 | 
			
		||||
          testStringForMatching(), AnyOf( Catch::Contains( "string" ), Catch::Contains( "not there" ) )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( contains: "string" or contains: "not there" )
 | 
			
		||||
@@ -3577,7 +3577,7 @@
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() AnyOf( Catch::Contains( "not there" ), Catch::Contains( "string" ) )
 | 
			
		||||
          testStringForMatching(), AnyOf( Catch::Contains( "not there" ), Catch::Contains( "string" ) )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( contains: "not there" or contains: "string" )
 | 
			
		||||
@@ -3588,7 +3588,7 @@
 | 
			
		||||
    <TestCase name="Equals">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Equals( "this string contains 'abc' as a substring" )
 | 
			
		||||
          testStringForMatching(), Equals( "this string contains 'abc' as a substring" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" equals: "this string contains 'abc' as a substring"
 | 
			
		||||
@@ -3599,7 +3599,7 @@
 | 
			
		||||
    <TestCase name="Matchers can be (AllOf) composed with the && operator">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Contains( "string" ) && Contains( "abc" ) && Contains( "substring" ) && Contains( "contains" )
 | 
			
		||||
          testStringForMatching(), Contains( "string" ) && Contains( "abc" ) && Contains( "substring" ) && Contains( "contains" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( contains: "string" and contains: "abc" and contains: "substring" and contains: "contains" )
 | 
			
		||||
@@ -3610,7 +3610,7 @@
 | 
			
		||||
    <TestCase name="Matchers can be (AnyOf) composed with the || operator">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() Contains( "string" ) || Contains( "different" ) || Contains( "random" )
 | 
			
		||||
          testStringForMatching(), Contains( "string" ) || Contains( "different" ) || Contains( "random" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( contains: "string" or contains: "different" or contains: "random" )
 | 
			
		||||
@@ -3618,7 +3618,7 @@
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching2() Contains( "string" ) || Contains( "different" ) || Contains( "random" )
 | 
			
		||||
          testStringForMatching2(), Contains( "string" ) || Contains( "different" ) || Contains( "random" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "some completely different text that contains one common word" ( contains: "string" or contains: "different" or contains: "random" )
 | 
			
		||||
@@ -3629,7 +3629,7 @@
 | 
			
		||||
    <TestCase name="Matchers can be composed with both && and ||">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() ( Contains( "string" ) || Contains( "different" ) ) && Contains( "substring" )
 | 
			
		||||
          testStringForMatching(), ( Contains( "string" ) || Contains( "different" ) ) && Contains( "substring" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( ( contains: "string" or contains: "different" ) and contains: "substring" )
 | 
			
		||||
@@ -3640,7 +3640,7 @@
 | 
			
		||||
    <TestCase name="Matchers can be composed with both && and || - failing">
 | 
			
		||||
      <Expression success="false" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() ( Contains( "string" ) || Contains( "different" ) ) && Contains( "random" )
 | 
			
		||||
          testStringForMatching(), ( Contains( "string" ) || Contains( "different" ) ) && Contains( "random" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" ( ( contains: "string" or contains: "different" ) and contains: "random" )
 | 
			
		||||
@@ -3651,7 +3651,7 @@
 | 
			
		||||
    <TestCase name="Matchers can be negated (Not) with the ! operator">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() !Contains( "different" )
 | 
			
		||||
          testStringForMatching(), !Contains( "different" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" not contains: "different"
 | 
			
		||||
@@ -3662,7 +3662,7 @@
 | 
			
		||||
    <TestCase name="Matchers can be negated (Not) with the ! operator - failing">
 | 
			
		||||
      <Expression success="false" type="CHECK_THAT" filename="projects/SelfTest/MiscTests.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          testStringForMatching() !Contains( "substring" )
 | 
			
		||||
          testStringForMatching(), !Contains( "substring" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "this string contains 'abc' as a substring" not contains: "substring"
 | 
			
		||||
@@ -4085,6 +4085,9 @@
 | 
			
		||||
      </Expression>
 | 
			
		||||
      <OverallResult success="true"/>
 | 
			
		||||
    </TestCase>
 | 
			
		||||
    <TestCase name="This test 'should' fail but doesn't">
 | 
			
		||||
      <OverallResult success="false"/>
 | 
			
		||||
    </TestCase>
 | 
			
		||||
    <TestCase name="Process can be configured on command line">
 | 
			
		||||
      <Section name="default - no arguments">
 | 
			
		||||
        <Expression success="true" type="CHECK_NOTHROW" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
@@ -4415,7 +4418,7 @@
 | 
			
		||||
        <Section name="-x must be greater than zero">
 | 
			
		||||
          <Expression success="true" type="REQUIRE_THAT" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfigAndReturnError( argv, config ) Contains( "greater than zero" )
 | 
			
		||||
              parseIntoConfigAndReturnError( argv, config ), Contains( "greater than zero" )
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              "Value after -x or --abortAfter must be greater than zero
 | 
			
		||||
@@ -4430,7 +4433,7 @@
 | 
			
		||||
        <Section name="-x must be numeric">
 | 
			
		||||
          <Expression success="true" type="REQUIRE_THAT" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfigAndReturnError( argv, config ) Contains( "-x" )
 | 
			
		||||
              parseIntoConfigAndReturnError( argv, config ), Contains( "-x" )
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              "Unable to convert oops to destination type
 | 
			
		||||
@@ -4567,8 +4570,8 @@
 | 
			
		||||
        </Section>
 | 
			
		||||
        <OverallResults successes="4" failures="0" expectedFailures="0"/>
 | 
			
		||||
      </Section>
 | 
			
		||||
      <Section name="force-colour">
 | 
			
		||||
        <Section name="--force-colour">
 | 
			
		||||
      <Section name="use-colour">
 | 
			
		||||
        <Section name="without option">
 | 
			
		||||
          <Expression success="true" type="CHECK_NOTHROW" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfig( argv, config )
 | 
			
		||||
@@ -4579,18 +4582,18 @@
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <Expression success="true" type="REQUIRE" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              config.forceColour
 | 
			
		||||
              config.useColour == UseColour::Auto
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              true
 | 
			
		||||
              0 == 0
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
        </Section>
 | 
			
		||||
        <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
      </Section>
 | 
			
		||||
      <Section name="force-colour">
 | 
			
		||||
        <Section name="without --force-colour">
 | 
			
		||||
      <Section name="use-colour">
 | 
			
		||||
        <Section name="auto">
 | 
			
		||||
          <Expression success="true" type="CHECK_NOTHROW" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfig( argv, config )
 | 
			
		||||
@@ -4601,16 +4604,74 @@
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <Expression success="true" type="REQUIRE" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              !config.forceColour
 | 
			
		||||
              config.useColour == UseColour::Auto
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              true
 | 
			
		||||
              0 == 0
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
        </Section>
 | 
			
		||||
        <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
      </Section>
 | 
			
		||||
      <Section name="use-colour">
 | 
			
		||||
        <Section name="yes">
 | 
			
		||||
          <Expression success="true" type="CHECK_NOTHROW" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfig( argv, config )
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              parseIntoConfig( argv, config )
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <Expression success="true" type="REQUIRE" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              config.useColour == UseColour::Yes
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              1 == 1
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
        </Section>
 | 
			
		||||
        <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
      </Section>
 | 
			
		||||
      <Section name="use-colour">
 | 
			
		||||
        <Section name="no">
 | 
			
		||||
          <Expression success="true" type="CHECK_NOTHROW" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfig( argv, config )
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              parseIntoConfig( argv, config )
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <Expression success="true" type="REQUIRE" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              config.useColour == UseColour::No
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              2 == 2
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
        </Section>
 | 
			
		||||
        <OverallResults successes="2" failures="0" expectedFailures="0"/>
 | 
			
		||||
      </Section>
 | 
			
		||||
      <Section name="use-colour">
 | 
			
		||||
        <Section name="error">
 | 
			
		||||
          <Expression success="true" type="REQUIRE_THROWS_WITH" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
            <Original>
 | 
			
		||||
              parseIntoConfig( argv, config ), Contains( "colour mode must be one of" )
 | 
			
		||||
            </Original>
 | 
			
		||||
            <Expanded>
 | 
			
		||||
              parseIntoConfig( argv, config ), Contains( "colour mode must be one of" )
 | 
			
		||||
            </Expanded>
 | 
			
		||||
          </Expression>
 | 
			
		||||
          <OverallResults successes="1" failures="0" expectedFailures="0"/>
 | 
			
		||||
        </Section>
 | 
			
		||||
        <OverallResults successes="1" failures="0" expectedFailures="0"/>
 | 
			
		||||
      </Section>
 | 
			
		||||
      <OverallResult success="true"/>
 | 
			
		||||
    </TestCase>
 | 
			
		||||
    <TestCase name="Long strings can be wrapped">
 | 
			
		||||
@@ -5276,7 +5337,7 @@ there"
 | 
			
		||||
    <TestCase name="Long text is truncted">
 | 
			
		||||
      <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/TestMain.cpp" >
 | 
			
		||||
        <Original>
 | 
			
		||||
          t.toString() EndsWith( "... message truncated due to excessive size" )
 | 
			
		||||
          t.toString(), EndsWith( "... message truncated due to excessive size" )
 | 
			
		||||
        </Original>
 | 
			
		||||
        <Expanded>
 | 
			
		||||
          "******************************************************************************-
 | 
			
		||||
@@ -9254,7 +9315,7 @@ there"
 | 
			
		||||
      <Section name="The same tag alias can only be registered once">
 | 
			
		||||
        <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/TagAliasTests.cpp" >
 | 
			
		||||
          <Original>
 | 
			
		||||
            what Contains( "[@zzz]" )
 | 
			
		||||
            what, Contains( "[@zzz]" )
 | 
			
		||||
          </Original>
 | 
			
		||||
          <Expanded>
 | 
			
		||||
            "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
@@ -9264,7 +9325,7 @@ there"
 | 
			
		||||
        </Expression>
 | 
			
		||||
        <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/TagAliasTests.cpp" >
 | 
			
		||||
          <Original>
 | 
			
		||||
            what Contains( "file" )
 | 
			
		||||
            what, Contains( "file" )
 | 
			
		||||
          </Original>
 | 
			
		||||
          <Expanded>
 | 
			
		||||
            "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
@@ -9274,7 +9335,7 @@ there"
 | 
			
		||||
        </Expression>
 | 
			
		||||
        <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/TagAliasTests.cpp" >
 | 
			
		||||
          <Original>
 | 
			
		||||
            what Contains( "2" )
 | 
			
		||||
            what, Contains( "2" )
 | 
			
		||||
          </Original>
 | 
			
		||||
          <Expanded>
 | 
			
		||||
            "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
@@ -9284,7 +9345,7 @@ there"
 | 
			
		||||
        </Expression>
 | 
			
		||||
        <Expression success="true" type="CHECK_THAT" filename="projects/SelfTest/TagAliasTests.cpp" >
 | 
			
		||||
          <Original>
 | 
			
		||||
            what Contains( "10" )
 | 
			
		||||
            what, Contains( "10" )
 | 
			
		||||
          </Original>
 | 
			
		||||
          <Expanded>
 | 
			
		||||
            "error: tag alias, "[@zzz]" already registered.
 | 
			
		||||
@@ -9505,7 +9566,7 @@ there"
 | 
			
		||||
      </Section>
 | 
			
		||||
      <OverallResult success="true"/>
 | 
			
		||||
    </TestCase>
 | 
			
		||||
    <OverallResults successes="818" failures="85" expectedFailures="13"/>
 | 
			
		||||
    <OverallResults successes="824" failures="81" expectedFailures="18"/>
 | 
			
		||||
  </Group>
 | 
			
		||||
  <OverallResults successes="818" failures="85" expectedFailures="13"/>
 | 
			
		||||
  <OverallResults successes="824" failures="80" expectedFailures="18"/>
 | 
			
		||||
</Catch>
 | 
			
		||||
 
 | 
			
		||||
@@ -101,7 +101,7 @@ TEST_CASE( "Inequality checks that should succeed", "" )
 | 
			
		||||
    REQUIRE( data.str_hello.size() != 6 );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
TEST_CASE( "Inequality checks that should fail", "[.][failing]" )
 | 
			
		||||
TEST_CASE( "Inequality checks that should fail", "[.][failing][!shouldfail]" )
 | 
			
		||||
{
 | 
			
		||||
    TestData data;
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -113,12 +113,12 @@ public:
 | 
			
		||||
    : m_msg( msg )
 | 
			
		||||
    {}
 | 
			
		||||
    ~CustomStdException() CATCH_NOEXCEPT {}
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
    std::string getMessage() const
 | 
			
		||||
    {
 | 
			
		||||
        return m_msg;
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
    std::string m_msg;
 | 
			
		||||
};
 | 
			
		||||
 
 | 
			
		||||
@@ -478,3 +478,8 @@ TEST_CASE( "long long" ) {
 | 
			
		||||
//    int x = 10/i; // This should cause the signal to fire
 | 
			
		||||
//    CHECK( x == 0 );
 | 
			
		||||
//}
 | 
			
		||||
 | 
			
		||||
TEST_CASE( "This test 'should' fail but doesn't", "[.][failing][!shouldfail]" )
 | 
			
		||||
{
 | 
			
		||||
    SUCCEED( "oops!" );
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -25,7 +25,7 @@ CATCH_REGISTER_TAG_ALIAS( "[@tricky]", "[tricky]~[.]" )
 | 
			
		||||
template<size_t size>
 | 
			
		||||
void parseIntoConfig( const char * (&argv)[size], Catch::ConfigData& config ) {
 | 
			
		||||
    Catch::Clara::CommandLine<Catch::ConfigData> parser = Catch::makeCommandLineParser();
 | 
			
		||||
    parser.parseInto( size, argv, config );
 | 
			
		||||
    parser.parseInto( Catch::Clara::argsToVector( size, argv ), config );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
template<size_t size>
 | 
			
		||||
@@ -195,19 +195,41 @@ TEST_CASE( "Process can be configured on command line", "[config][command-line]"
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    SECTION( "force-colour", "") {
 | 
			
		||||
        SECTION( "--force-colour", "" ) {
 | 
			
		||||
            const char* argv[] = { "test", "--force-colour" };
 | 
			
		||||
            CHECK_NOTHROW( parseIntoConfig( argv, config ) );
 | 
			
		||||
 | 
			
		||||
            REQUIRE( config.forceColour );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        SECTION( "without --force-colour", "" ) {
 | 
			
		||||
    SECTION( "use-colour", "") {
 | 
			
		||||
        
 | 
			
		||||
        using Catch::UseColour;
 | 
			
		||||
        
 | 
			
		||||
        SECTION( "without option", "" ) {
 | 
			
		||||
            const char* argv[] = { "test" };
 | 
			
		||||
            CHECK_NOTHROW( parseIntoConfig( argv, config ) );
 | 
			
		||||
            
 | 
			
		||||
            REQUIRE( config.useColour == UseColour::Auto );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
            REQUIRE( !config.forceColour );
 | 
			
		||||
        SECTION( "auto", "" ) {
 | 
			
		||||
            const char* argv[] = { "test", "--use-colour", "auto" };
 | 
			
		||||
            CHECK_NOTHROW( parseIntoConfig( argv, config ) );
 | 
			
		||||
 | 
			
		||||
            REQUIRE( config.useColour == UseColour::Auto );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        SECTION( "yes", "" ) {
 | 
			
		||||
            const char* argv[] = { "test", "--use-colour", "yes" };
 | 
			
		||||
            CHECK_NOTHROW( parseIntoConfig( argv, config ) );
 | 
			
		||||
            
 | 
			
		||||
            REQUIRE( config.useColour == UseColour::Yes );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        SECTION( "no", "" ) {
 | 
			
		||||
            const char* argv[] = { "test", "--use-colour", "no" };
 | 
			
		||||
            CHECK_NOTHROW( parseIntoConfig( argv, config ) );
 | 
			
		||||
            
 | 
			
		||||
            REQUIRE( config.useColour == UseColour::No );
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        SECTION( "error", "" ) {
 | 
			
		||||
            const char* argv[] = { "test", "--use-colour", "wrong" };
 | 
			
		||||
            REQUIRE_THROWS_WITH( parseIntoConfig( argv, config ), Contains( "colour mode must be one of" ) );
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -93,7 +93,7 @@
 | 
			
		||||
  <ItemGroup>
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\ApproxTests.cpp" />
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\BDDTests.cpp" />
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\SectionTrackerTests.cpp" />
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\PartTrackerTests.cpp" />
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\TestMain.cpp" />
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\ClassTests.cpp" />
 | 
			
		||||
    <ClCompile Include="..\..\..\SelfTest\ConditionTests.cpp" />
 | 
			
		||||
 
 | 
			
		||||
@@ -513,7 +513,7 @@
 | 
			
		||||
		4A6D0C17149B3D3B00DB3EAA /* Project object */ = {
 | 
			
		||||
			isa = PBXProject;
 | 
			
		||||
			attributes = {
 | 
			
		||||
				LastUpgradeCheck = 0630;
 | 
			
		||||
				LastUpgradeCheck = 0710;
 | 
			
		||||
			};
 | 
			
		||||
			buildConfigurationList = 4A6D0C1A149B3D3B00DB3EAA /* Build configuration list for PBXProject "CatchSelfTest" */;
 | 
			
		||||
			compatibilityVersion = "Xcode 3.2";
 | 
			
		||||
@@ -595,6 +595,7 @@
 | 
			
		||||
				CLANG_WARN__EXIT_TIME_DESTRUCTORS = NO;
 | 
			
		||||
				COPY_PHASE_STRIP = NO;
 | 
			
		||||
				ENABLE_STRICT_OBJC_MSGSEND = YES;
 | 
			
		||||
				ENABLE_TESTABILITY = YES;
 | 
			
		||||
				GCC_C_LANGUAGE_STANDARD = gnu99;
 | 
			
		||||
				GCC_DYNAMIC_NO_PIC = NO;
 | 
			
		||||
				GCC_ENABLE_OBJC_EXCEPTIONS = YES;
 | 
			
		||||
 
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user