mirror of
				https://github.com/catchorg/Catch2.git
				synced 2025-10-31 20:27:11 +01:00 
			
		
		
		
	Use Clara v0.0.1.1
This commit is contained in:
		| @@ -131,7 +131,7 @@ namespace Catch { | |||||||
|             Catch::cout() << "For more detail usage please see the project docs\n" << std::endl; |             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* argv[], OnUnusedOptions::DoWhat unusedOptionBehaviour = OnUnusedOptions::Fail ) { | ||||||
|             try { |             try { | ||||||
|                 m_cli.setThrowOnUnrecognisedTokens( unusedOptionBehaviour == OnUnusedOptions::Fail ); |                 m_cli.setThrowOnUnrecognisedTokens( unusedOptionBehaviour == OnUnusedOptions::Fail ); | ||||||
|                 m_unusedTokens = m_cli.parseInto( argc, argv, m_configData ); |                 m_unusedTokens = m_cli.parseInto( argc, argv, m_configData ); | ||||||
| @@ -158,13 +158,16 @@ namespace Catch { | |||||||
|             m_config.reset(); |             m_config.reset(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         int run( int argc, char const* const argv[] ) { |         int run( int argc, char const* argv[] ) { | ||||||
|  |  | ||||||
|             int returnCode = applyCommandLine( argc, argv ); |             int returnCode = applyCommandLine( argc, argv ); | ||||||
|             if( returnCode == 0 ) |             if( returnCode == 0 ) | ||||||
|                 returnCode = run(); |                 returnCode = run(); | ||||||
|             return returnCode; |             return returnCode; | ||||||
|         } |         } | ||||||
|  |         int run( int argc, char* argv[] ) { | ||||||
|  |             return run( argc, const_cast<char const**>( argv ) ); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         int run() { |         int run() { | ||||||
|             if( m_configData.showHelp ) |             if( m_configData.showHelp ) | ||||||
|   | |||||||
							
								
								
									
										201
									
								
								include/external/clara.h
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										201
									
								
								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) |  *  file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | // Version 0.0.1.1 | ||||||
|  |  | ||||||
| // Only use header guard if we are not using an outer namespace | // Only use header guard if we are not using an outer namespace | ||||||
| #if !defined(TWOBLUECUBES_CLARA_H_INCLUDED) || defined(STITCH_CLARA_OPEN_NAMESPACE) | #if !defined(TWOBLUECUBES_CLARA_H_INCLUDED) || defined(STITCH_CLARA_OPEN_NAMESPACE) | ||||||
|  |  | ||||||
| @@ -38,6 +40,7 @@ | |||||||
| #include <string> | #include <string> | ||||||
| #include <vector> | #include <vector> | ||||||
| #include <sstream> | #include <sstream> | ||||||
|  | #include <algorithm> | ||||||
|  |  | ||||||
| // Use optional outer namespace | // Use optional outer namespace | ||||||
| #ifdef STITCH_TBC_TEXT_FORMAT_OUTER_NAMESPACE | #ifdef STITCH_TBC_TEXT_FORMAT_OUTER_NAMESPACE | ||||||
| @@ -172,13 +175,171 @@ namespace Tbc { | |||||||
| #endif // TBC_TEXT_FORMAT_H_INCLUDED | #endif // TBC_TEXT_FORMAT_H_INCLUDED | ||||||
|  |  | ||||||
| // ----------- end of #include from tbc_text_format.h ----------- | // ----------- 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 | #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 <map> | ||||||
| #include <algorithm> |  | ||||||
| #include <stdexcept> | #include <stdexcept> | ||||||
| #include <memory> | #include <memory> | ||||||
|  |  | ||||||
| @@ -205,6 +366,9 @@ namespace Clara { | |||||||
|     const unsigned int consoleWidth = 80; |     const unsigned int consoleWidth = 80; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |         // Use this to try and stop compiler from warning about unreachable code | ||||||
|  |         inline bool isTrue( bool value ) { return value; } | ||||||
|  |  | ||||||
|         using namespace Tbc; |         using namespace Tbc; | ||||||
|  |  | ||||||
|         inline bool startsWith( std::string const& str, std::string const& prefix ) { |         inline bool startsWith( std::string const& str, std::string const& prefix ) { | ||||||
| @@ -245,16 +409,17 @@ namespace Clara { | |||||||
|         } |         } | ||||||
|         template<typename T> |         template<typename T> | ||||||
|         inline void convertInto( bool, T& ) { |         inline void convertInto( bool, T& ) { | ||||||
|             throw std::runtime_error( "Invalid conversion" ); |             if( isTrue( true ) ) | ||||||
|  |                 throw std::runtime_error( "Invalid conversion" ); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         template<typename ConfigT> |         template<typename ConfigT> | ||||||
|         struct IArgFunction { |         struct IArgFunction { | ||||||
|             virtual ~IArgFunction() {} |             virtual ~IArgFunction() {} | ||||||
| #  ifdef CATCH_CONFIG_CPP11_GENERATED_METHODS | #ifdef CLARA_CONFIG_CPP11_GENERATED_METHODS | ||||||
|             IArgFunction()                      = default; |             IArgFunction()                      = default; | ||||||
|             IArgFunction( IArgFunction const& ) = default; |             IArgFunction( IArgFunction const& ) = default; | ||||||
| #  endif | #endif | ||||||
|             virtual void set( ConfigT& config, std::string const& value ) const = 0; |             virtual void set( ConfigT& config, std::string const& value ) const = 0; | ||||||
|             virtual void setFlag( ConfigT& config ) const = 0; |             virtual void setFlag( ConfigT& config ) const = 0; | ||||||
|             virtual bool takesArg() const = 0; |             virtual bool takesArg() const = 0; | ||||||
| @@ -264,11 +429,11 @@ namespace Clara { | |||||||
|         template<typename ConfigT> |         template<typename ConfigT> | ||||||
|         class BoundArgFunction { |         class BoundArgFunction { | ||||||
|         public: |         public: | ||||||
|             BoundArgFunction() : functionObj( CATCH_NULL ) {} |             BoundArgFunction() : functionObj( CLARA_NULL ) {} | ||||||
|             BoundArgFunction( IArgFunction<ConfigT>* _functionObj ) : functionObj( _functionObj ) {} |             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 ) { |             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; |                 delete functionObj; | ||||||
|                 functionObj = newFunctionObj; |                 functionObj = newFunctionObj; | ||||||
|                 return *this; |                 return *this; | ||||||
| @@ -284,7 +449,7 @@ namespace Clara { | |||||||
|             bool takesArg() const { return functionObj->takesArg(); } |             bool takesArg() const { return functionObj->takesArg(); } | ||||||
|  |  | ||||||
|             bool isSet() const { |             bool isSet() const { | ||||||
|                 return functionObj != CATCH_NULL; |                 return functionObj != CLARA_NULL; | ||||||
|             } |             } | ||||||
|         private: |         private: | ||||||
|             IArgFunction<ConfigT>* functionObj; |             IArgFunction<ConfigT>* functionObj; | ||||||
| @@ -393,7 +558,7 @@ namespace Clara { | |||||||
|             std::string data; |             std::string data; | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         void parseIntoTokens( int argc, char const * const * argv, std::vector<Parser::Token>& tokens ) const { |         void parseIntoTokens( int argc, char const* const argv[], std::vector<Parser::Token>& tokens ) const { | ||||||
|             const std::string doubleDash = "--"; |             const std::string doubleDash = "--"; | ||||||
|             for( int i = 1; i < argc && argv[i] != doubleDash; ++i ) |             for( int i = 1; i < argc && argv[i] != doubleDash; ++i ) | ||||||
|                 parseIntoTokens( argv[i] , tokens); |                 parseIntoTokens( argv[i] , tokens); | ||||||
| @@ -503,7 +668,7 @@ namespace Clara { | |||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         typedef CATCH_AUTO_PTR( Arg ) ArgAutoPtr; |         typedef CLARA_AUTO_PTR( Arg ) ArgAutoPtr; | ||||||
|  |  | ||||||
|         friend void addOptName( Arg& arg, std::string const& optName ) |         friend void addOptName( Arg& arg, std::string const& optName ) | ||||||
|         { |         { | ||||||
| @@ -580,8 +745,8 @@ namespace Clara { | |||||||
|                 m_arg->description = description; |                 m_arg->description = description; | ||||||
|                 return *this; |                 return *this; | ||||||
|             } |             } | ||||||
|             ArgBuilder& detail( std::string const& _detail ) { |             ArgBuilder& detail( std::string const& detail ) { | ||||||
|                 m_arg->detail = _detail; |                 m_arg->detail = detail; | ||||||
|                 return *this; |                 return *this; | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @@ -665,14 +830,14 @@ namespace Clara { | |||||||
|                 maxWidth = (std::max)( maxWidth, it->commands().size() ); |                 maxWidth = (std::max)( maxWidth, it->commands().size() ); | ||||||
|  |  | ||||||
|             for( it = itBegin; it != itEnd; ++it ) { |             for( it = itBegin; it != itEnd; ++it ) { | ||||||
|                 Detail::Text usageText( it->commands(), Detail::TextAttributes() |                 Detail::Text usage( it->commands(), Detail::TextAttributes() | ||||||
|                                                         .setWidth( maxWidth+indent ) |                                                         .setWidth( maxWidth+indent ) | ||||||
|                                                         .setIndent( indent ) ); |                                                         .setIndent( indent ) ); | ||||||
|                 Detail::Text desc( it->description, Detail::TextAttributes() |                 Detail::Text desc( it->description, Detail::TextAttributes() | ||||||
|                                                         .setWidth( width - maxWidth - 3 ) ); |                                                         .setWidth( width - maxWidth - 3 ) ); | ||||||
|  |  | ||||||
|                 for( std::size_t i = 0; i < (std::max)( usageText.size(), desc.size() ); ++i ) { |                 for( std::size_t i = 0; i < (std::max)( usage.size(), desc.size() ); ++i ) { | ||||||
|                     std::string usageCol = i < usageText.size() ? usageText[i] : ""; |                     std::string usageCol = i < usage.size() ? usage[i] : ""; | ||||||
|                     os << usageCol; |                     os << usageCol; | ||||||
|  |  | ||||||
|                     if( i < desc.size() && !desc[i].empty() ) |                     if( i < desc.size() && !desc[i].empty() ) | ||||||
| @@ -729,13 +894,13 @@ namespace Clara { | |||||||
|             return oss.str(); |             return oss.str(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ConfigT parse( int argc, char const * const * argv ) const { |         ConfigT parse( int argc, char const* const argv[] ) const { | ||||||
|             ConfigT config; |             ConfigT config; | ||||||
|             parseInto( argc, argv, config ); |             parseInto( argc, argv, config ); | ||||||
|             return config; |             return config; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         std::vector<Parser::Token> parseInto( int argc, char const * const * argv, ConfigT& config ) const { |         std::vector<Parser::Token> parseInto( int argc, char const* argv[], ConfigT& config ) const { | ||||||
|             std::string processName = argv[0]; |             std::string processName = argv[0]; | ||||||
|             std::size_t lastSlash = processName.find_last_of( "/\\" ); |             std::size_t lastSlash = processName.find_last_of( "/\\" ); | ||||||
|             if( lastSlash != std::string::npos ) |             if( lastSlash != std::string::npos ) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Phil Nash
					Phil Nash