forked from Alepha/Alepha
Make it possible to use arbitrary code in making delimited lists.
This commit is contained in:
@ -28,23 +28,23 @@ namespace Alepha::Hydrogen ::detail:: delimited_list_m
|
||||
: virtual public IOStreams::StackableStreambuf, virtual public std::streambuf
|
||||
{
|
||||
private:
|
||||
std::string delim;
|
||||
DelimiterWriter writer;
|
||||
bool first= true;
|
||||
|
||||
public:
|
||||
explicit
|
||||
DelimitedListStreambuf( std::ios &is, const std::string delim )
|
||||
: StackableStreambuf( is ), delim( delim )
|
||||
DelimitedListStreambuf( std::ios &is, const DelimiterWriter writer )
|
||||
: StackableStreambuf( is ), writer( writer )
|
||||
{
|
||||
tracker.get( is )= this;
|
||||
if( C::debug ) error() << "Streambuf adapted." << std::endl;
|
||||
}
|
||||
|
||||
void
|
||||
doNext()
|
||||
doNext( std::ostream &out )
|
||||
{
|
||||
if( C::debug ) error() << "Do Next called" << std::endl;
|
||||
if( not first ) out() << delim;
|
||||
if( not first ) writer( out );
|
||||
first= false;
|
||||
}
|
||||
|
||||
@ -66,7 +66,7 @@ namespace Alepha::Hydrogen ::detail:: delimited_list_m
|
||||
{
|
||||
if( C::debug ) error() << "Marker called" << std::endl;
|
||||
auto thisTracker= tracker.get( os );
|
||||
if( thisTracker != nullptr ) thisTracker->doNext();
|
||||
if( thisTracker != nullptr ) thisTracker->doNext( os );
|
||||
|
||||
return os;
|
||||
}
|
||||
@ -74,6 +74,6 @@ namespace Alepha::Hydrogen ::detail:: delimited_list_m
|
||||
void
|
||||
impl::build_streambuf( std::ostream &os, StartDelimitedList &¶ms )
|
||||
{
|
||||
new impl_cc::DelimitedListStreambuf( os, params.delimiter );
|
||||
new impl_cc::DelimitedListStreambuf( os, params.writer );
|
||||
}
|
||||
}
|
||||
|
@ -12,11 +12,20 @@ namespace Alepha::Hydrogen ::detail:: delimited_list_m
|
||||
{
|
||||
inline namespace exports {}
|
||||
|
||||
using DelimiterWriter= std::function< void ( std::ostream & ) >;
|
||||
struct DelimitedList_params
|
||||
{
|
||||
const std::string delimiter;
|
||||
DelimiterWriter writer;
|
||||
|
||||
explicit DelimitedList_params( const std::string delimiter ) : delimiter( delimiter ) {}
|
||||
explicit
|
||||
DelimitedList_params( const std::string delimiter )
|
||||
: writer( [delimiter] ( std::ostream &os ) { os << delimiter; } )
|
||||
{}
|
||||
|
||||
explicit
|
||||
DelimitedList_params( DelimiterWriter writer )
|
||||
: writer( writer )
|
||||
{}
|
||||
};
|
||||
|
||||
struct MarkItem_t {};
|
||||
|
@ -7,6 +7,8 @@ static_assert( __cplusplus > 2020'99 );
|
||||
|
||||
#include <Alepha/Utility/evaluation_helpers.h>
|
||||
|
||||
#include <Alepha/IOStreams/delimiters.h>
|
||||
|
||||
static auto init= Alepha::Utility::enroll <=[]
|
||||
{
|
||||
using namespace Alepha::Testing::literals;
|
||||
@ -32,4 +34,32 @@ static auto init= Alepha::Utility::enroll <=[]
|
||||
{
|
||||
{ "Simple", { { "Alpha", "Bravo", "Charlie", "Delta", "Echo" } }, "Alpha, Bravo, Charlie, Delta, Echo" },
|
||||
};
|
||||
|
||||
"Simple Comma Testing using delim function"_test <=TableTest
|
||||
<
|
||||
[]( std::vector< std::string > names )
|
||||
{
|
||||
std::ostringstream oss;
|
||||
oss << setDelimiter( Alepha::IOStreams::fieldDelimiter, ", " );
|
||||
|
||||
oss << Alepha::StartDelimitedList
|
||||
{
|
||||
[]( std::ostream &os )
|
||||
{
|
||||
os << Alepha::IOStreams::fieldDelimiter;
|
||||
}
|
||||
};
|
||||
|
||||
for( const auto &name: names )
|
||||
{
|
||||
oss << Alepha::NextItem << name;
|
||||
}
|
||||
|
||||
return oss.str();
|
||||
}
|
||||
>
|
||||
::Cases
|
||||
{
|
||||
{ "Simple", { { "Alpha", "Bravo", "Charlie", "Delta", "Echo" } }, "Alpha, Bravo, Charlie, Delta, Echo" },
|
||||
};
|
||||
};
|
||||
|
Reference in New Issue
Block a user