From 0dbcf218c353e801d4fa26d14696e81f6b832cad Mon Sep 17 00:00:00 2001 From: Andy Sawyer Date: Tue, 17 Sep 2013 22:22:47 +0100 Subject: [PATCH] Add allocator support to StringMaker - also extracted out 'rangeToString', in an attempt to make it easier to add support for other containers --- include/internal/catch_tostring.hpp | 22 +++++++++++++++------- single_include/catch.hpp | 24 ++++++++++++++++-------- 2 files changed, 31 insertions(+), 15 deletions(-) diff --git a/include/internal/catch_tostring.hpp b/include/internal/catch_tostring.hpp index 78c725e..48bc683 100644 --- a/include/internal/catch_tostring.hpp +++ b/include/internal/catch_tostring.hpp @@ -99,19 +99,27 @@ struct StringMaker { } }; -template -struct StringMaker > { - static std::string convert( std::vector const& v ) { +namespace Detail { + template + std::string rangeToString( InputIterator first, InputIterator last ) { std::ostringstream oss; oss << "{ "; - for( std::size_t i = 0; i < v.size(); ++ i ) { - oss << toString( v[i] ); - if( i < v.size() - 1 ) - oss << ", "; + if( first != last ) { + oss << toString( *first ); + for( ++first ; first != last ; ++first ) { + oss << ", " << toString( *first ); + } } oss << " }"; return oss.str(); } +} + +template +struct StringMaker > { + static std::string convert( std::vector const& v ) { + return Detail::rangeToString( v.begin(), v.end() ); + } }; namespace Detail { diff --git a/single_include/catch.hpp b/single_include/catch.hpp index 523fa08..00dd9fc 100644 --- a/single_include/catch.hpp +++ b/single_include/catch.hpp @@ -1,6 +1,6 @@ /* * CATCH v1.0 build 10 (master branch) - * Generated: 2013-09-14 19:56:34.776409 + * Generated: 2013-09-17 22:21:47.780755 * ---------------------------------------------------------- * This file has been merged from multiple headers. Please don't edit it directly * Copyright (c) 2012 Two Blue Cubes Ltd. All rights reserved. @@ -722,19 +722,27 @@ struct StringMaker { } }; -template -struct StringMaker > { - static std::string convert( std::vector const& v ) { +namespace Detail { + template + std::string rangeToString( InputIterator first, InputIterator last ) { std::ostringstream oss; oss << "{ "; - for( std::size_t i = 0; i < v.size(); ++ i ) { - oss << toString( v[i] ); - if( i < v.size() - 1 ) - oss << ", "; + if( first != last ) { + oss << toString( *first ); + for( ++first ; first != last ; ++first ) { + oss << ", " << toString( *first ); + } } oss << " }"; return oss.str(); } +} + +template +struct StringMaker > { + static std::string convert( std::vector const& v ) { + return Detail::rangeToString( v.begin(), v.end() ); + } }; namespace Detail {