1
0
forked from Alepha/Alepha

Make stream state have a default-construction option.

Start integrating it for the field delimiters.
This commit is contained in:
2023-10-25 03:55:42 -04:00
parent 5e86b58987
commit bacaa9fcee
3 changed files with 49 additions and 6 deletions

View File

@ -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" } },
};
}; };

View File

@ -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:

View File

@ -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 ) )
{ {