Well, since no one has chimed in, here is the solution. It uses C++14 std::index_sequence
, so the recursion is hidden in it.
#include <tuple>
#include <utility>
template<class... ARGS1, class... ARGS2, std::size_t... Is>
bool tuple_compare_helper(const std::tuple<ARGS1...>& lhs, const std::tuple<ARGS2...>& rhs, std::index_sequence<Is...> ) {
return std::tie(std::get<Is>(lhs)...) < std::tie(std::get<Is>(rhs)...);
}
template<class... ARGS1, class... ARGS2>
bool tuple_compare(const std::tuple<ARGS1...>& lhs, const std::tuple<ARGS2...>& rhs) {
const auto min_size = std::min(sizeof...(ARGS1), sizeof...(ARGS2));
return tuple_compare_helper(lhs, rhs, std::make_index_sequence<min_size>());
}
// test driver
#include <iostream>
int main() {
auto t1 = std::make_tuple(1, std::string("One"), 2.0);
auto t2 = std::make_tuple(3, std::string("Two"));
std::cout << tuple_compare(t2, t1) << "\n";
}