forked from Alepha/Alepha
Tuplize args testing.
The code bit-rotted a bit. Some internals of Alepha changed, this impl of tuplize args being imported from a near-dead laptop.
This commit is contained in:
@ -30,6 +30,7 @@ add_subdirectory( comparisons.test )
|
|||||||
add_subdirectory( Exception.test )
|
add_subdirectory( Exception.test )
|
||||||
add_subdirectory( word_wrap.test )
|
add_subdirectory( word_wrap.test )
|
||||||
add_subdirectory( string_algorithms.test )
|
add_subdirectory( string_algorithms.test )
|
||||||
|
add_subdirectory( tuplize_args.test )
|
||||||
|
|
||||||
# Sample applications
|
# Sample applications
|
||||||
add_executable( example example.cc )
|
add_executable( example example.cc )
|
||||||
|
@ -33,7 +33,7 @@ namespace Alepha::Hydrogen ::detail:: tuplize_args
|
|||||||
*
|
*
|
||||||
* Iterates thru the runtime arguments and attempts to parse them to the compiletime specified types.
|
* Iterates thru the runtime arguments and attempts to parse them to the compiletime specified types.
|
||||||
*/
|
*/
|
||||||
template< typename Tuple T >
|
template< Tuple T >
|
||||||
auto
|
auto
|
||||||
tuplizeArgs( const std::vector< std::string > &args );
|
tuplizeArgs( const std::vector< std::string > &args );
|
||||||
|
|
||||||
@ -50,10 +50,10 @@ namespace Alepha::Hydrogen ::detail:: tuplize_args
|
|||||||
explicit
|
explicit
|
||||||
ArityMismatchError( const std::size_t remaining, const std::size_t processed, const std::string &clarification= "" )
|
ArityMismatchError( const std::size_t remaining, const std::size_t processed, const std::string &clarification= "" )
|
||||||
: remaining_( remaining ), processed_( processed ), clarification( clarification ),
|
: remaining_( remaining ), processed_( processed ), clarification( clarification ),
|
||||||
message( IOStream::Stream{} << ( clarification.empty() ? "" : ( clarification + ": " ) )
|
message( IOStreams::Stream{} << ( clarification.empty() ? "" : ( clarification + ": " ) )
|
||||||
<< "Argument count mismatch. "
|
<< "Argument count mismatch. "
|
||||||
<< remaining << " remaining "
|
<< remaining << " remaining "
|
||||||
<< processed j< " processed" ) {}
|
<< processed << " processed" ) {}
|
||||||
|
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
@ -74,7 +74,7 @@ namespace Alepha::Hydrogen ::detail:: tuplize_args
|
|||||||
|
|
||||||
// TODO: Expand this to handle compiletime-bound defaulted values.
|
// TODO: Expand this to handle compiletime-bound defaulted values.
|
||||||
template< typename Type >
|
template< typename Type >
|
||||||
concept Omittable= Optional< Type >;
|
concept Omittable= is_optional_v< Type >;
|
||||||
|
|
||||||
template< TypeListType list >
|
template< TypeListType list >
|
||||||
tuple_from_list_t< list >
|
tuple_from_list_t< list >
|
||||||
@ -101,18 +101,19 @@ namespace Alepha::Hydrogen ::detail:: tuplize_args
|
|||||||
else return tuplizeArgsBackend( cons_t< typename first::value_type, tail >{}, args, offset );
|
else return tuplizeArgsBackend( cons_t< typename first::value_type, tail >{}, args, offset );
|
||||||
}
|
}
|
||||||
else if( offset >= args.size() ) throw ArityMismatchError{ args.size() - offset, offset, "no more arguments left" };
|
else if( offset >= args.size() ) throw ArityMismatchError{ args.size() - offset, offset, "no more arguments left" };
|
||||||
else if constexpr( is_vector_v< first > )
|
else if constexpr( Vector< first > )
|
||||||
{
|
{
|
||||||
static_assert( std::is_same_v< cdr_t< list >, Nil >, "A vector is only permissible as the final argument." );
|
static_assert( std::is_same_v< cdr_t< list >, Nil >, "A vector is only permissible as the final argument." );
|
||||||
if( args.size() <= offset )
|
if( args.size() <= offset )
|
||||||
{
|
{
|
||||||
throw ArityMismatchError{ args.size() - offset, offset, "a vector/list requires at least one runtime argument." }
|
throw ArityMismatchError{ args.size() - offset, offset, "a vector/list requires at least one runtime argument." };
|
||||||
}
|
}
|
||||||
|
using first_type= typename first::value_type;
|
||||||
|
|
||||||
const std::vector< std::string > rv;
|
std::vector< first_type > rv;
|
||||||
std::transform( begin( args ) + offset, end( args ), back_inserter( rv ),
|
std::transform( begin( args ) + offset, end( args ), back_inserter( rv ),
|
||||||
IOStreams::stringify< type > );
|
boost::lexical_cast< first_type, std::string > );
|
||||||
return std::tuple_cat( std::tuple{ arv }, tuplizeArgsBackend( tail{}, args, offset + rv.size() ) );
|
return std::tuple_cat( std::tuple{ rv }, tuplizeArgsBackend( tail{}, args, offset + rv.size() ) );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -131,7 +132,7 @@ namespace Alepha::Hydrogen ::detail:: tuplize_args
|
|||||||
auto
|
auto
|
||||||
exports::tuplizeArgs( const std::vector< std::string > &args )
|
exports::tuplizeArgs( const std::vector< std::string > &args )
|
||||||
{
|
{
|
||||||
return tuplizeArgsBackend( list_from_tuple_t< T > args );
|
return tuplizeArgsBackend( list_from_tuple_t< T >{}, args );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
44
tuplize_args.test/0.cc
Normal file
44
tuplize_args.test/0.cc
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
#include "../tuplize_args.h"
|
||||||
|
|
||||||
|
#include <Alepha/Testing/test.h>
|
||||||
|
#include <Alepha/Testing/TableTest.h>
|
||||||
|
|
||||||
|
#include <Alepha/Utility/evaluation_helpers.h>
|
||||||
|
|
||||||
|
static auto init= Alepha::Utility::enroll <=[]
|
||||||
|
{
|
||||||
|
using namespace Alepha::Testing::exports;
|
||||||
|
using namespace Alepha::Utility::exports::evaluation_helpers;
|
||||||
|
|
||||||
|
"A basic tuplization example"_test <=TableTest
|
||||||
|
<
|
||||||
|
Alepha::tuplizeArgs< std::tuple< int, std::string, int, char > >
|
||||||
|
>
|
||||||
|
::Cases
|
||||||
|
{
|
||||||
|
{ "Smoke example", { { "1", "Hello", "42", "x" } }, { 1, "Hello", 42, 'x' } },
|
||||||
|
};
|
||||||
|
|
||||||
|
"Do trailing vectors permit variadics?"_test <=TableTest
|
||||||
|
<
|
||||||
|
Alepha::tuplizeArgs< std::tuple< int, std::string, std::vector< int > > >
|
||||||
|
>
|
||||||
|
::Cases
|
||||||
|
{
|
||||||
|
{ "One extra argument", { { "1", "Hello", "2" } }, { 1, "Hello", { 2 } } },
|
||||||
|
{ "Two extra arguments", { { "1", "Hello", "2", "3" } }, { 1, "Hello", { 2, 3 } } },
|
||||||
|
{ "Three extra arguments", { { "1", "Hello", "2", "3", "4" } }, { 1, "Hello", { 2, 3, 4 } } },
|
||||||
|
};
|
||||||
|
|
||||||
|
"Does trailing optional stacked permit variadics??"_test <=TableTest
|
||||||
|
<
|
||||||
|
Alepha::tuplizeArgs< std::tuple< std::optional< int >, std::optional< std::string >, std::optional< int > > >
|
||||||
|
>
|
||||||
|
::Cases
|
||||||
|
{
|
||||||
|
{ "No arguments", { {} }, { std::nullopt, std::nullopt, std::nullopt } },
|
||||||
|
{ "One argument", { { "1" } }, { 1, std::nullopt, std::nullopt } },
|
||||||
|
{ "Two arguments", { { "1", "Hello" } }, { 1, "Hello", std::nullopt } },
|
||||||
|
{ "Three arguments", { { "1", "Hello", "2" } }, { 1, "Hello", 2 } },
|
||||||
|
};
|
||||||
|
};
|
1
tuplize_args.test/CMakeLists.txt
Normal file
1
tuplize_args.test/CMakeLists.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
unit_test( 0 )
|
Reference in New Issue
Block a user