forked from Alepha/Alepha
Make stream state have a default-construction option.
Start integrating it for the field delimiters.
This commit is contained in:
@ -30,10 +30,28 @@ namespace
|
|||||||
stringify( const Agg &agg, const std::string delim )
|
stringify( const Agg &agg, const std::string delim )
|
||||||
{
|
{
|
||||||
std::ostringstream oss;
|
std::ostringstream oss;
|
||||||
|
Alepha::IOStreams::setGlobalFieldDelimiter( "YOU SHOULD NOT SEE THIS" );
|
||||||
oss << Alepha::IOStreams::setFieldDelimiter( delim );
|
oss << Alepha::IOStreams::setFieldDelimiter( delim );
|
||||||
oss << agg;
|
oss << agg;
|
||||||
return std::move( oss ).str();
|
return std::move( oss ).str();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto
|
||||||
|
stringify_global( const Agg &agg, const std::string delim )
|
||||||
|
{
|
||||||
|
std::ostringstream oss;
|
||||||
|
Alepha::IOStreams::setGlobalFieldDelimiter( delim );
|
||||||
|
oss << agg;
|
||||||
|
return std::move( oss ).str();
|
||||||
|
}
|
||||||
|
|
||||||
|
auto
|
||||||
|
stringify_default( const Agg &agg )
|
||||||
|
{
|
||||||
|
std::ostringstream oss;
|
||||||
|
oss << agg;
|
||||||
|
return std::move( oss ).str();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static auto init= Alepha::Utility::enroll <=[]
|
static auto init= Alepha::Utility::enroll <=[]
|
||||||
@ -41,7 +59,13 @@ static auto init= Alepha::Utility::enroll <=[]
|
|||||||
using namespace Alepha::Testing::exports;
|
using namespace Alepha::Testing::exports;
|
||||||
using namespace Alepha::Testing::literals::test_literals;
|
using namespace Alepha::Testing::literals::test_literals;
|
||||||
|
|
||||||
"Simple OStream"_test <=TableTest< stringify >
|
"Simple OStream (default delimiter)"_test <=TableTest< stringify_default >
|
||||||
|
::Cases
|
||||||
|
{
|
||||||
|
{ "smoke test", { { 1, 2, 3 } }, { "1\t2\t3" } },
|
||||||
|
};
|
||||||
|
|
||||||
|
"Simple OStream (specific delimiter)"_test <=TableTest< stringify >
|
||||||
::Cases
|
::Cases
|
||||||
{
|
{
|
||||||
{ "smoke test", { { 1, 2, 3 }, "\t" }, { "1\t2\t3" } },
|
{ "smoke test", { { 1, 2, 3 }, "\t" }, { "1\t2\t3" } },
|
||||||
@ -49,4 +73,14 @@ static auto init= Alepha::Utility::enroll <=[]
|
|||||||
{ "smoke test", { { 1, 2, 3 }, ";;" }, { "1;;2;;3" } },
|
{ "smoke test", { { 1, 2, 3 }, ";;" }, { "1;;2;;3" } },
|
||||||
{ "smoke test", { { 1, 2, 3 }, ", " }, { "1, 2, 3" } },
|
{ "smoke test", { { 1, 2, 3 }, ", " }, { "1, 2, 3" } },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
"Simple OStream (global delimiter)"_test <=TableTest< stringify_global >
|
||||||
|
::Cases
|
||||||
|
{
|
||||||
|
{ "smoke test", { { 1, 2, 3 }, "\t" }, { "1\t2\t3" } },
|
||||||
|
{ "smoke test", { { 1, 2, 3 }, "," }, { "1,2,3" } },
|
||||||
|
{ "smoke test", { { 1, 2, 3 }, ";;" }, { "1;;2;;3" } },
|
||||||
|
{ "smoke test", { { 1, 2, 3 }, ", " }, { "1, 2, 3" } },
|
||||||
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|||||||
@ -11,11 +11,11 @@ namespace Alepha::Hydrogen::IOStreams ::detail:: stream_state
|
|||||||
{
|
{
|
||||||
inline namespace exports
|
inline namespace exports
|
||||||
{
|
{
|
||||||
template< typename Tag, typename Type >
|
template< typename Tag, typename Type, auto Default= [] { return Type{}; } >
|
||||||
class StreamState;
|
class StreamState;
|
||||||
}
|
}
|
||||||
|
|
||||||
template< typename Tag, typename Type >
|
template< typename Tag, typename Type, auto Default >
|
||||||
class exports::StreamState
|
class exports::StreamState
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
@ -70,7 +70,7 @@ namespace Alepha::Hydrogen::IOStreams ::detail:: stream_state
|
|||||||
ios.register_callback( callback, index() );
|
ios.register_callback( callback, index() );
|
||||||
}
|
}
|
||||||
auto *&ptr= get_ptr( ios );
|
auto *&ptr= get_ptr( ios );
|
||||||
if( not ptr ) ptr= new Type{};
|
if( not ptr ) ptr= new Type{ Default() };
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|||||||
@ -20,8 +20,6 @@ namespace Alepha::Hydrogen::IOStreams ::detail:: delimiters
|
|||||||
enum { RecordDelimiter };
|
enum { RecordDelimiter };
|
||||||
}
|
}
|
||||||
|
|
||||||
using FieldDelimiterState= StreamState< decltype( FieldDelimiter ), std::string >;
|
|
||||||
|
|
||||||
namespace C
|
namespace C
|
||||||
{
|
{
|
||||||
const std::string defaultFieldDelimiter= "\t";
|
const std::string defaultFieldDelimiter= "\t";
|
||||||
@ -41,6 +39,15 @@ namespace Alepha::Hydrogen::IOStreams ::detail:: delimiters
|
|||||||
return storage::globalFieldDelimiter().value();
|
return storage::globalFieldDelimiter().value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace exports
|
||||||
|
{
|
||||||
|
inline void
|
||||||
|
setGlobalFieldDelimiter( const std::string delim )
|
||||||
|
{
|
||||||
|
storage::globalFieldDelimiter()= delim;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
inline char
|
inline char
|
||||||
globalRecordDelimiter()
|
globalRecordDelimiter()
|
||||||
{
|
{
|
||||||
@ -48,6 +55,8 @@ namespace Alepha::Hydrogen::IOStreams ::detail:: delimiters
|
|||||||
return storage::globalRecordDelimiter().value();
|
return storage::globalRecordDelimiter().value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
using FieldDelimiterState= StreamState< decltype( FieldDelimiter ), std::string, globalFieldDelimiter >;
|
||||||
|
|
||||||
inline std::ostream &
|
inline std::ostream &
|
||||||
operator << ( std::ostream &os, decltype( FieldDelimiter ) )
|
operator << ( std::ostream &os, decltype( FieldDelimiter ) )
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user